feat: added user_assigned_to uda and fixed merge into tw method
This commit is contained in:
parent
94ffe82636
commit
ae132c2484
@ -7,7 +7,7 @@ services:
|
|||||||
- name: grocy
|
- name: grocy
|
||||||
api: 'https://aerex.me/grocy/api'
|
api: 'https://aerex.me/grocy/api'
|
||||||
token: 'McaeCf5FrT9Sqr96tPcZg9l4uUCexR1fGVGIfDR6qNQxsWECpv'
|
token: 'McaeCf5FrT9Sqr96tPcZg9l4uUCexR1fGVGIfDR6qNQxsWECpv'
|
||||||
resolution: tw
|
resolution: grocy
|
||||||
tags:
|
category: grocy
|
||||||
- grocy
|
assigned_to: grocy
|
||||||
|
|
||||||
|
@ -21,13 +21,17 @@ class RestService(object):
|
|||||||
self.headers = {}
|
self.headers = {}
|
||||||
self.json = json
|
self.json = json
|
||||||
|
|
||||||
def get(self, path):
|
def get(self, path, id=None):
|
||||||
|
|
||||||
|
# TODO: change this to a single pattern assume a pattern then stick with it
|
||||||
if self.api_url.endswith('/'):
|
if self.api_url.endswith('/'):
|
||||||
url = '{0}{1}'.format(self.api_url, path[1:])
|
url = '{0}{1}'.format(self.api_url, path[1:])
|
||||||
else:
|
else:
|
||||||
url = '{0}{1}'.format(self.api_url, path)
|
url = '{0}{1}'.format(self.api_url, path)
|
||||||
|
|
||||||
|
if id:
|
||||||
|
url = '{0}/{1}'.format(url, id)
|
||||||
|
|
||||||
r = requests.get(url, headers=self.headers)
|
r = requests.get(url, headers=self.headers)
|
||||||
|
|
||||||
if r.raise_for_status():
|
if r.raise_for_status():
|
||||||
|
@ -12,15 +12,28 @@ class Grocy(TaskService):
|
|||||||
|
|
||||||
# Endpoints
|
# Endpoints
|
||||||
FIND_ALL_TASKS_ENDPOINT = '/get-objects/tasks'
|
FIND_ALL_TASKS_ENDPOINT = '/get-objects/tasks'
|
||||||
|
FIND_ALL_CATEGORIES_ENDPOINT = '/get-objects/task_categories'
|
||||||
DELETE_TASK_ENDPOINT = '/delete-object/tasks/{0}'
|
DELETE_TASK_ENDPOINT = '/delete-object/tasks/{0}'
|
||||||
|
ADD_CATEGORY_ENDPOINT = '/add-object/task_categories'
|
||||||
ADD_TASK_ENDPOINT = '/add-object/tasks'
|
ADD_TASK_ENDPOINT = '/add-object/tasks'
|
||||||
MODIFY_TASK_ENDPOINT = '/edit-object/tasks'
|
MODIFY_TASK_ENDPOINT = '/edit-object/tasks'
|
||||||
# UDA
|
# UDA
|
||||||
GROCY_ID = 'grocy_id'
|
GROCY_ID = 'grocy_id'
|
||||||
|
GROCY_ASSIGNED_TO_USER_ID = 'grocy_assigned_to'
|
||||||
|
GROCY_CATEGORY_ID = 'grocy_category_id'
|
||||||
|
GROCY_CATEGORY_NAME = 'grocy_category_name'
|
||||||
UDAS = {
|
UDAS = {
|
||||||
GROCY_ID: {
|
GROCY_ID: {
|
||||||
'type': 'string',
|
'type': 'string',
|
||||||
'label': 'Grocy Task ID'
|
'label': 'Grocy Task ID'
|
||||||
|
},
|
||||||
|
GROCY_ASSIGNED_TO_USER_ID: {
|
||||||
|
'type': 'string',
|
||||||
|
'label': 'Grocy Assigned User ID'
|
||||||
|
},
|
||||||
|
GROCY_CATEGORY_ID: {
|
||||||
|
'type': 'string',
|
||||||
|
'label': 'Grocy Category ID'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -50,17 +63,62 @@ class Grocy(TaskService):
|
|||||||
|
|
||||||
return tasks
|
return tasks
|
||||||
|
|
||||||
|
def get_category(self):
|
||||||
|
if not self.rest_service:
|
||||||
|
raise Exception('rest service for grocy is not defined')
|
||||||
|
# Find specified category from all categories
|
||||||
|
try:
|
||||||
|
responses = self.rest_service.get(Grocy.FIND_ALL_CATEGORIES_ENDPOINT)
|
||||||
|
except BaseException as e:
|
||||||
|
logger.error(e)
|
||||||
|
raise e
|
||||||
|
|
||||||
|
if responses:
|
||||||
|
for category in responses:
|
||||||
|
if category['name'] == self.category:
|
||||||
|
print('not sure')
|
||||||
|
print(category)
|
||||||
|
return category
|
||||||
|
logger.warn('Could not find category {} in list'.format(self.category))
|
||||||
|
|
||||||
|
return None
|
||||||
|
|
||||||
|
def create_category(self):
|
||||||
|
if not self.rest_service:
|
||||||
|
raise Exception('rest service for grocy is not defined')
|
||||||
|
# Add new category to list
|
||||||
|
try:
|
||||||
|
responses = self.rest_service.get(Grocy.ADD_CATEGORY_ENDPOINT, self.category)
|
||||||
|
except BaseException as e:
|
||||||
|
logger.error(e)
|
||||||
|
raise e
|
||||||
|
|
||||||
|
return responses
|
||||||
|
|
||||||
def to_grocy(self, task):
|
def to_grocy(self, task):
|
||||||
print('before the dawn')
|
|
||||||
print(task)
|
|
||||||
grocy_task = {}
|
grocy_task = {}
|
||||||
|
|
||||||
if Grocy.GROCY_ID in task:
|
if Grocy.GROCY_ID in task:
|
||||||
grocy_task['id'] = task[Grocy.GROCY_ID]
|
grocy_task['id'] = task[Grocy.GROCY_ID]
|
||||||
|
|
||||||
|
if 'uuid' in task:
|
||||||
|
grocy_task['_uuid'] = task['uuid']
|
||||||
|
|
||||||
|
if Grocy.GROCY_ASSIGNED_TO_USER_ID in task:
|
||||||
|
grocy_task['assigned_to_user_id'] = task[Grocy.GROCY_ASSIGNED_TO_USER_ID]
|
||||||
|
|
||||||
if 'description' in task:
|
if 'description' in task:
|
||||||
grocy_task['name'] = task['description']
|
grocy_task['name'] = task['description']
|
||||||
|
|
||||||
|
if 'tags' in task and self.category in task['tags']:
|
||||||
|
category_id = self.get_category()
|
||||||
|
category_does_not_exist = not category_id
|
||||||
|
|
||||||
|
if category_does_not_exist:
|
||||||
|
category_id = self.create_category()
|
||||||
|
|
||||||
|
grocy_task['category'] = category_id
|
||||||
|
|
||||||
if 'annotations' in task:
|
if 'annotations' in task:
|
||||||
grocy_task['description'] = ''
|
grocy_task['description'] = ''
|
||||||
for note in task['annotations']:
|
for note in task['annotations']:
|
||||||
@ -82,16 +140,24 @@ class Grocy(TaskService):
|
|||||||
|
|
||||||
if 'id' in grocy_task:
|
if 'id' in grocy_task:
|
||||||
taskwarrior_task[Grocy.GROCY_ID] = grocy_task['id']
|
taskwarrior_task[Grocy.GROCY_ID] = grocy_task['id']
|
||||||
|
if '_uuid' in grocy_task:
|
||||||
|
taskwarrior_task['uuid'] = grocy_task['_uuid']
|
||||||
|
|
||||||
|
if 'assigned_to_user_id' in grocy_task:
|
||||||
|
taskwarrior_task[Grocy.GROCY_ASSIGNED_TO_USER_ID] = grocy_task['assigned_to_user_id']
|
||||||
|
|
||||||
if 'name' in grocy_task:
|
if 'name' in grocy_task:
|
||||||
taskwarrior_task['description'] = grocy_task['name']
|
taskwarrior_task['description'] = grocy_task['name']
|
||||||
|
|
||||||
if 'description' in grocy_task:
|
if 'description' in grocy_task:
|
||||||
|
if '\r' in grocy_task['description']:
|
||||||
|
grocy_task['description'] = grocy_task['description'].replace('\r', '')
|
||||||
taskwarrior_task['annotations'] = grocy_task['description'].split('\n')
|
taskwarrior_task['annotations'] = grocy_task['description'].split('\n')
|
||||||
last_element_is_empty_string = taskwarrior_task['annotations'][-1] == ''
|
last_element_is_empty_string = taskwarrior_task['annotations'][-1] == ''
|
||||||
if last_element_is_empty_string:
|
if last_element_is_empty_string:
|
||||||
taskwarrior_task['annotations'] = taskwarrior_task['annotations'][0:-1] # Remove empty string in array
|
taskwarrior_task['annotations'] = taskwarrior_task['annotations'][0:-1] # Remove empty string in array
|
||||||
|
|
||||||
|
|
||||||
if 'row_created_timestamp' in grocy_task:
|
if 'row_created_timestamp' in grocy_task:
|
||||||
taskwarrior_task['entry'] = grocy_task['row_created_timestamp']
|
taskwarrior_task['entry'] = grocy_task['row_created_timestamp']
|
||||||
|
|
||||||
@ -101,9 +167,13 @@ class Grocy(TaskService):
|
|||||||
if 'done' in grocy_task and grocy_task['done'] == '1':
|
if 'done' in grocy_task and grocy_task['done'] == '1':
|
||||||
taskwarrior_task['status'] = 'completed'
|
taskwarrior_task['status'] = 'completed'
|
||||||
|
|
||||||
return taskwarrior_task
|
if 'category_id' in grocy_task:
|
||||||
|
category = self.get_category()
|
||||||
|
taskwarrior_task[Grocy.GRO
|
||||||
|
|
||||||
|
|
||||||
|
return taskwarrior_task
|
||||||
|
|
||||||
def __initRestService(self):
|
def __initRestService(self):
|
||||||
if self.api.startswith == '/':
|
if self.api.startswith == '/':
|
||||||
self.api = self.api[1:]
|
self.api = self.api[1:]
|
||||||
@ -219,7 +289,7 @@ class Grocy(TaskService):
|
|||||||
# Delete taskwarrior task
|
# Delete taskwarrior task
|
||||||
if self._should_merge(converted_tw_to_grocy_task, grocy_task):
|
if self._should_merge(converted_tw_to_grocy_task, grocy_task):
|
||||||
modified_grocy_tasks.append(converted_tw_to_grocy_task)
|
modified_grocy_tasks.append(converted_tw_to_grocy_task)
|
||||||
logger.debug('Merged taskwarrior task %s to grocy task %s', converted_tw_to_grocy_task['uuid'], grocy_task['id'])
|
logger.debug('Merged taskwarrior task %s to grocy task %s', converted_tw_to_grocy_task['id'], grocy_task['id'])
|
||||||
del remaining_grocy_tasks_to_process[index]
|
del remaining_grocy_tasks_to_process[index]
|
||||||
# Add taskwarrior task into taskwarrior
|
# Add taskwarrior task into taskwarrior
|
||||||
else:
|
else:
|
||||||
@ -230,19 +300,33 @@ class Grocy(TaskService):
|
|||||||
# Send requests to Grocy service
|
# Send requests to Grocy service
|
||||||
if len(modified_grocy_tasks) > 0:
|
if len(modified_grocy_tasks) > 0:
|
||||||
modify_responses = self.modify(modified_grocy_tasks)
|
modify_responses = self.modify(modified_grocy_tasks)
|
||||||
logger.debug(added_responses)
|
logger.debug(modify_responses)
|
||||||
if len(tasks_to_add_to_grocy) > 0:
|
if len(tasks_to_add_to_grocy) > 0:
|
||||||
added_responses = self.add(tasks_to_add_to_grocy)
|
added_responses = self.add(tasks_to_add_to_grocy)
|
||||||
logger.debug(added_responses)
|
logger.debug(added_responses)
|
||||||
|
|
||||||
def merge_into_tw(self, taskwarrior_tasks, grocy_tasks):
|
def merge_into_tw(self, taskwarrior_tasks, grocy_tasks):
|
||||||
|
print(taskwarrior_tasks)
|
||||||
|
print(grocy_tasks)
|
||||||
# Convert to taskwarrior tasks into grocy tasks
|
# Convert to taskwarrior tasks into grocy tasks
|
||||||
converted_tw_to_grocy_tasks = []
|
converted_tw_to_grocy_tasks = []
|
||||||
converted_tw_to_grocy_tasks = [self.to_grocy(task) for task in taskwarrior_tasks]
|
converted_tw_to_grocy_tasks = [self.to_grocy(task) for task in taskwarrior_tasks]
|
||||||
|
|
||||||
# Sort grocy tasks by id and converted taskwarrior tasks by GROCY_ID
|
# Sort grocy tasks by id and converted taskwarrior tasks by GROCY_ID
|
||||||
grocy_tasks.sort(key=lambda x: x['id'])
|
grocy_tasks.sort(key=lambda x: x['id'])
|
||||||
converted_tw_to_grocy_tasks.sort(key=lambda x: x[Grocy.GROCY_ID])
|
converted_tw_to_grocy_tasks.sort(key=lambda x: x['id'])
|
||||||
|
|
||||||
|
# If no taskwarrior tasks add grocy tasks to taskwarrior
|
||||||
|
if len(converted_tw_to_grocy_tasks) == 0:
|
||||||
|
convert_grocy_tasks_to_tw = [self.to_taskwarrior(grocy_task) for grocy_task in grocy_tasks]
|
||||||
|
for task in convert_grocy_tasks_to_tw:
|
||||||
|
try:
|
||||||
|
added_task = self.tw.task_add(**task)
|
||||||
|
logger.debug('Added grocy task %s to taskwarrior', task)
|
||||||
|
except TaskwarriorError as e:
|
||||||
|
logger.exception('Unable to add task from grocy: %s', e.stderr)
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
if len(grocy_tasks) == 0:
|
if len(grocy_tasks) == 0:
|
||||||
self.add(converted_tw_to_grocy_tasks)
|
self.add(converted_tw_to_grocy_tasks)
|
||||||
@ -263,21 +347,17 @@ class Grocy(TaskService):
|
|||||||
continue
|
continue
|
||||||
# Merge from grocy into taskwarrior if match found
|
# Merge from grocy into taskwarrior if match found
|
||||||
# Delete taskwarrior task
|
# Delete taskwarrior task
|
||||||
if self.should_merge(converted_tw_to_grocy_task, grocy_task):
|
if self._should_merge(converted_tw_to_grocy_task, grocy_task):
|
||||||
try:
|
try:
|
||||||
converted_grocy_task_to_tw = self.to_taskwarrior(grocy_task)
|
converted_grocy_task_to_tw = self.to_taskwarrior(grocy_task)
|
||||||
self.tw.update(converted_grocy_task_to_tw)
|
converted_grocy_task_to_tw['uuid'] = converted_tw_to_grocy_task['_uuid']
|
||||||
|
print('convert fool')
|
||||||
|
print(converted_grocy_task_to_tw)
|
||||||
|
self.tw.task_update(converted_grocy_task_to_tw)
|
||||||
logger.debug('Merged grocy task %s to taskwarrior task %s', grocy_task['id'], converted_grocy_task_to_tw['uuid'])
|
logger.debug('Merged grocy task %s to taskwarrior task %s', grocy_task['id'], converted_grocy_task_to_tw['uuid'])
|
||||||
del converted_tw_to_grocy_tasks[index]
|
del converted_tw_to_grocy_tasks[index]
|
||||||
except TaskwarriorError as e:
|
except TaskwarriorError as e:
|
||||||
logger.exception('Could not update task: %s', e.stderr)
|
logger.exception('Could not update task: %s', e.stderr)
|
||||||
# Add grocy task into taskwarrior
|
|
||||||
else:
|
|
||||||
try:
|
|
||||||
self.tw.task_add(converted_grocy_task_to_tw)
|
|
||||||
logger.debug('Added grocy task %s to taskwarrior task', grocy_task['id'])
|
|
||||||
except TaskwarriorError as e:
|
|
||||||
logger.exception('Could not add task: %s', e.stderr)
|
|
||||||
|
|
||||||
|
|
||||||
def sync(self):
|
def sync(self):
|
||||||
@ -295,7 +375,9 @@ class Grocy(TaskService):
|
|||||||
try:
|
try:
|
||||||
if self.resolution == 'tw':
|
if self.resolution == 'tw':
|
||||||
self.merge_from_tw(taskwarrior_tasks, grocy_tasks)
|
self.merge_from_tw(taskwarrior_tasks, grocy_tasks)
|
||||||
else:
|
elif self.resolution == 'grocy':
|
||||||
self.merge_into_tw(taskwarrior_tasks, grocy_tasks)
|
self.merge_into_tw(taskwarrior_tasks, grocy_tasks)
|
||||||
|
else:
|
||||||
|
raise Exception('Could not determine resolution for grocy')
|
||||||
except TaskwarriorError as e:
|
except TaskwarriorError as e:
|
||||||
logger.exception('Could not sync tasks %s', e.stderr)
|
logger.exception('Could not sync tasks %s', e.stderr)
|
||||||
|
Loading…
Reference in New Issue
Block a user