1646-clone
dgtlmoon 2 years ago
parent 8cbf8e8f57
commit f81a7b3438

@ -205,10 +205,9 @@ class ChangeDetectionStore:
# Clone a watch by UUID # Clone a watch by UUID
def clone(self, uuid): def clone(self, uuid):
url = self.data['watching'][uuid]['url'] url = self.data['watching'][uuid].get('url')
tag = self.data['watching'][uuid].get('tags',[])
extras = self.data['watching'][uuid] extras = self.data['watching'][uuid]
new_uuid = self.add_watch(url=url, tag_uuids=tag, extras=extras) new_uuid = self.add_watch(url=url, extras=extras)
return new_uuid return new_uuid
def url_exists(self, url): def url_exists(self, url):
@ -248,10 +247,6 @@ class ChangeDetectionStore:
if extras is None: if extras is None:
extras = {} extras = {}
# should always be str
if tag is None or not tag:
tag = ''
# Incase these are copied across, assume it's a reference and deepcopy() # Incase these are copied across, assume it's a reference and deepcopy()
apply_extras = deepcopy(extras) apply_extras = deepcopy(extras)
@ -303,15 +298,17 @@ class ChangeDetectionStore:
flash('Watch protocol is not permitted by SAFE_PROTOCOL_REGEX', 'error') flash('Watch protocol is not permitted by SAFE_PROTOCOL_REGEX', 'error')
return None return None
if extras.get('tags') and type(extras.get('tags')) == str:
extras['tags'] = list(extras.get('tags'))
# #Re 569 if tag:
# Could be in 'tags', var or extras, smash them together and strip if tag and type(tag) == str:
apply_extras['tags'] = [] tag = [str]
if tag or extras.get('tags'): for t in tag:
tags = list(filter(None, list(set().union(tag.split(','), extras.get('tags', '').split(',')))))
for t in list(map(str.strip, tags)):
# for each stripped tag, add tag as UUID # for each stripped tag, add tag as UUID
apply_extras['tags'].append(self.add_tag(t)) for a_t in t.split(','):
apply_extras['tags'].append(self.add_tag(a_t))
# Or if UUIDs given directly # Or if UUIDs given directly
if tag_uuids: if tag_uuids:

Loading…
Cancel
Save