Deduplicate logic between ActivityType's and WorkflowType's
This commit is contained in:
parent
c4e903706c
commit
6e6b325225
@ -26,46 +26,31 @@ class Domain(object):
|
||||
def __repr__(self):
|
||||
return "Domain(name: %(name)s, status: %(status)s)" % self.__dict__
|
||||
|
||||
def get_activity_type(self, name, version, ignore_empty=False):
|
||||
def get_type(self, kind, name, version, ignore_empty=False):
|
||||
try:
|
||||
return self.activity_types[name][version]
|
||||
_types = getattr(self, "{}_types".format(kind))
|
||||
return _types[name][version]
|
||||
except KeyError:
|
||||
if not ignore_empty:
|
||||
raise SWFUnknownResourceFault(
|
||||
"type",
|
||||
"ActivityType=[name={}, version={}]".format(name, version)
|
||||
"{}Type=[name={}, version={}]".format(
|
||||
kind.capitalize(), name, version
|
||||
)
|
||||
)
|
||||
|
||||
def add_activity_type(self, _type):
|
||||
self.activity_types[_type.name][_type.version] = _type
|
||||
def add_type(self, _type):
|
||||
if isinstance(_type, ActivityType):
|
||||
self.activity_types[_type.name][_type.version] = _type
|
||||
elif isinstance(_type, WorkflowType):
|
||||
self.workflow_types[_type.name][_type.version] = _type
|
||||
else:
|
||||
raise ValueError("Unknown SWF type: {}".format(_type))
|
||||
|
||||
def find_activity_types(self, status):
|
||||
def find_types(self, kind, status):
|
||||
_all = []
|
||||
for _, family in self.activity_types.iteritems():
|
||||
for _, _type in family.iteritems():
|
||||
if _type.status == status:
|
||||
_all.append(_type)
|
||||
return _all
|
||||
|
||||
# TODO: refactor it with get_activity_type()
|
||||
def get_workflow_type(self, name, version, ignore_empty=False):
|
||||
try:
|
||||
return self.workflow_types[name][version]
|
||||
except KeyError:
|
||||
if not ignore_empty:
|
||||
raise SWFUnknownResourceFault(
|
||||
"type",
|
||||
"WorkflowType=[name={}, version={}]".format(name, version)
|
||||
)
|
||||
|
||||
# TODO: refactor it with add_activity_type()
|
||||
def add_workflow_type(self, _type):
|
||||
self.workflow_types[_type.name][_type.version] = _type
|
||||
|
||||
# TODO: refactor it with find_activity_types()
|
||||
def find_workflow_types(self, status):
|
||||
_all = []
|
||||
for _, family in self.workflow_types.iteritems():
|
||||
_types = getattr(self, "{}_types".format(kind))
|
||||
for _, family in _types.iteritems():
|
||||
for _, _type in family.iteritems():
|
||||
if _type.status == status:
|
||||
_all.append(_type)
|
||||
@ -151,17 +136,17 @@ class SWFBackend(BaseBackend):
|
||||
self._check_string(name)
|
||||
return self._get_domain(name)
|
||||
|
||||
def list_activity_types(self, domain_name, status, reverse_order=None):
|
||||
def list_types(self, kind, domain_name, status, reverse_order=None):
|
||||
self._check_string(domain_name)
|
||||
self._check_string(status)
|
||||
domain = self._get_domain(domain_name)
|
||||
_types = domain.find_activity_types(status)
|
||||
_types = domain.find_types(kind, status)
|
||||
_types = sorted(_types, key=lambda domain: domain.name)
|
||||
if reverse_order:
|
||||
_types = reversed(_types)
|
||||
return _types
|
||||
|
||||
def register_activity_type(self, domain_name, name, version, **kwargs):
|
||||
def register_type(self, kind, domain_name, name, version, **kwargs):
|
||||
self._check_string(domain_name)
|
||||
self._check_string(name)
|
||||
self._check_string(version)
|
||||
@ -171,71 +156,30 @@ class SWFBackend(BaseBackend):
|
||||
if value is not None:
|
||||
self._check_string(value)
|
||||
domain = self._get_domain(domain_name)
|
||||
_type = domain.get_activity_type(name, version, ignore_empty=True)
|
||||
_type = domain.get_type(kind, name, version, ignore_empty=True)
|
||||
if _type:
|
||||
raise SWFTypeAlreadyExistsFault(_type)
|
||||
activity_type = ActivityType(name, version, **kwargs)
|
||||
domain.add_activity_type(activity_type)
|
||||
_class = globals()["{}Type".format(kind.capitalize())]
|
||||
_type = _class(name, version, **kwargs)
|
||||
domain.add_type(_type)
|
||||
|
||||
def deprecate_activity_type(self, domain_name, name, version):
|
||||
def deprecate_type(self, kind, domain_name, name, version):
|
||||
self._check_string(domain_name)
|
||||
self._check_string(name)
|
||||
self._check_string(version)
|
||||
domain = self._get_domain(domain_name)
|
||||
_type = domain.get_activity_type(name, version)
|
||||
_type = domain.get_type(kind, name, version)
|
||||
if _type.status == "DEPRECATED":
|
||||
raise SWFTypeDeprecatedFault(_type)
|
||||
_type.status = "DEPRECATED"
|
||||
|
||||
def describe_activity_type(self, domain_name, name, version):
|
||||
def describe_type(self, kind, domain_name, name, version):
|
||||
self._check_string(domain_name)
|
||||
self._check_string(name)
|
||||
self._check_string(version)
|
||||
domain = self._get_domain(domain_name)
|
||||
return domain.get_activity_type(name, version)
|
||||
return domain.get_type(kind, name, version)
|
||||
|
||||
def list_workflow_types(self, domain_name, status, reverse_order=None):
|
||||
self._check_string(domain_name)
|
||||
self._check_string(status)
|
||||
domain = self._get_domain(domain_name)
|
||||
_types = domain.find_workflow_types(status)
|
||||
_types = sorted(_types, key=lambda domain: domain.name)
|
||||
if reverse_order:
|
||||
_types = reversed(_types)
|
||||
return _types
|
||||
|
||||
def register_workflow_type(self, domain_name, name, version, **kwargs):
|
||||
self._check_string(domain_name)
|
||||
self._check_string(name)
|
||||
self._check_string(version)
|
||||
for _, value in kwargs.iteritems():
|
||||
if value == (None,):
|
||||
print _
|
||||
if value is not None:
|
||||
self._check_string(value)
|
||||
domain = self._get_domain(domain_name)
|
||||
_type = domain.get_workflow_type(name, version, ignore_empty=True)
|
||||
if _type:
|
||||
raise SWFTypeAlreadyExistsFault(_type)
|
||||
workflow_type = WorkflowType(name, version, **kwargs)
|
||||
domain.add_workflow_type(workflow_type)
|
||||
|
||||
def deprecate_workflow_type(self, domain_name, name, version):
|
||||
self._check_string(domain_name)
|
||||
self._check_string(name)
|
||||
self._check_string(version)
|
||||
domain = self._get_domain(domain_name)
|
||||
_type = domain.get_workflow_type(name, version)
|
||||
if _type.status == "DEPRECATED":
|
||||
raise SWFTypeDeprecatedFault(_type)
|
||||
_type.status = "DEPRECATED"
|
||||
|
||||
def describe_workflow_type(self, domain_name, name, version):
|
||||
self._check_string(domain_name)
|
||||
self._check_string(name)
|
||||
self._check_string(version)
|
||||
domain = self._get_domain(domain_name)
|
||||
return domain.get_workflow_type(name, version)
|
||||
|
||||
swf_backends = {}
|
||||
for region in boto.swf.regions():
|
||||
|
@ -51,6 +51,33 @@ class SWFResponse(BaseResponse):
|
||||
def _params(self):
|
||||
return json.loads(self.body)
|
||||
|
||||
def _list_types(self, kind, template_str):
|
||||
domain_name = self._params.get("domain")
|
||||
status = self._params.get("registrationStatus")
|
||||
reverse_order = self._params.get("reverseOrder", None)
|
||||
types = self.swf_backend.list_types(kind, domain_name, status, reverse_order=reverse_order)
|
||||
template = self.response_template(template_str)
|
||||
return template.render(types=types)
|
||||
|
||||
def _describe_type(self, kind, template_str):
|
||||
domain = self._params.get("domain")
|
||||
_type = self._params.get("{}Type".format(kind))
|
||||
|
||||
name = _type["name"]
|
||||
version = _type["version"]
|
||||
_type = self.swf_backend.describe_type(kind, domain, name, version)
|
||||
template = self.response_template(template_str)
|
||||
return template.render(_type=_type)
|
||||
|
||||
def _deprecate_type(self, kind):
|
||||
domain = self._params.get("domain")
|
||||
_type = self._params.get("{}Type".format(kind))
|
||||
name = _type["name"]
|
||||
version = _type["version"]
|
||||
self.swf_backend.deprecate_type(kind, domain, name, version)
|
||||
template = self.response_template("")
|
||||
return template.render()
|
||||
|
||||
# TODO: implement pagination
|
||||
def list_domains(self):
|
||||
status = self._params.get("registrationStatus")
|
||||
@ -82,12 +109,7 @@ class SWFResponse(BaseResponse):
|
||||
|
||||
# TODO: implement pagination
|
||||
def list_activity_types(self):
|
||||
domain_name = self._params.get("domain")
|
||||
status = self._params.get("registrationStatus")
|
||||
reverse_order = self._params.get("reverseOrder", None)
|
||||
types = self.swf_backend.list_activity_types(domain_name, status, reverse_order=reverse_order)
|
||||
template = self.response_template(LIST_ACTIVITY_TYPES_TEMPLATE)
|
||||
return template.render(types=types)
|
||||
return self._list_types("activity", LIST_ACTIVITY_TYPES_TEMPLATE)
|
||||
|
||||
def register_activity_type(self):
|
||||
domain = self._params.get("domain")
|
||||
@ -104,8 +126,8 @@ class SWFResponse(BaseResponse):
|
||||
default_task_start_to_close_timeout = self._params.get("defaultTaskStartToCloseTimeout")
|
||||
description = self._params.get("description")
|
||||
# TODO: add defaultTaskPriority when boto gets to support it
|
||||
activity_type = self.swf_backend.register_activity_type(
|
||||
domain, name, version, task_list=task_list,
|
||||
activity_type = self.swf_backend.register_type(
|
||||
"activity", domain, name, version, task_list=task_list,
|
||||
default_task_heartbeat_timeout=default_task_heartbeat_timeout,
|
||||
default_task_schedule_to_close_timeout=default_task_schedule_to_close_timeout,
|
||||
default_task_schedule_to_start_timeout=default_task_schedule_to_start_timeout,
|
||||
@ -116,33 +138,14 @@ class SWFResponse(BaseResponse):
|
||||
return template.render()
|
||||
|
||||
def deprecate_activity_type(self):
|
||||
domain = self._params.get("domain")
|
||||
_type = self._params.get("activityType")
|
||||
name = _type["name"]
|
||||
version = _type["version"]
|
||||
domain = self.swf_backend.deprecate_activity_type(domain, name, version)
|
||||
template = self.response_template("")
|
||||
return template.render()
|
||||
return self._deprecate_type("activity")
|
||||
|
||||
def describe_activity_type(self):
|
||||
domain = self._params.get("domain")
|
||||
_type = self._params.get("activityType")
|
||||
return self._describe_type("activity", DESCRIBE_ACTIVITY_TYPE_TEMPLATE)
|
||||
|
||||
name = _type["name"]
|
||||
version = _type["version"]
|
||||
_type = self.swf_backend.describe_activity_type(domain, name, version)
|
||||
template = self.response_template(DESCRIBE_ACTIVITY_TYPE_TEMPLATE)
|
||||
return template.render(_type=_type)
|
||||
|
||||
# TODO: implement pagination
|
||||
# TODO: refactor with list_activity_types()
|
||||
def list_workflow_types(self):
|
||||
domain_name = self._params.get("domain")
|
||||
status = self._params.get("registrationStatus")
|
||||
reverse_order = self._params.get("reverseOrder", None)
|
||||
types = self.swf_backend.list_workflow_types(domain_name, status, reverse_order=reverse_order)
|
||||
template = self.response_template(LIST_WORKFLOW_TYPES_TEMPLATE)
|
||||
return template.render(types=types)
|
||||
return self._list_types("workflow", LIST_WORKFLOW_TYPES_TEMPLATE)
|
||||
|
||||
def register_workflow_type(self):
|
||||
domain = self._params.get("domain")
|
||||
@ -159,8 +162,8 @@ class SWFResponse(BaseResponse):
|
||||
description = self._params.get("description")
|
||||
# TODO: add defaultTaskPriority when boto gets to support it
|
||||
# TODO: add defaultLambdaRole when boto gets to support it
|
||||
workflow_type = self.swf_backend.register_workflow_type(
|
||||
domain, name, version, task_list=task_list,
|
||||
workflow_type = self.swf_backend.register_type(
|
||||
"workflow", domain, name, version, task_list=task_list,
|
||||
default_child_policy=default_child_policy,
|
||||
default_task_start_to_close_timeout=default_task_start_to_close_timeout,
|
||||
default_execution_start_to_close_timeout=default_execution_start_to_close_timeout,
|
||||
@ -169,26 +172,11 @@ class SWFResponse(BaseResponse):
|
||||
template = self.response_template("")
|
||||
return template.render()
|
||||
|
||||
# TODO: refactor with deprecate_activity_type()
|
||||
def deprecate_workflow_type(self):
|
||||
domain = self._params.get("domain")
|
||||
_type = self._params.get("workflowType")
|
||||
name = _type["name"]
|
||||
version = _type["version"]
|
||||
domain = self.swf_backend.deprecate_workflow_type(domain, name, version)
|
||||
template = self.response_template("")
|
||||
return template.render()
|
||||
return self._deprecate_type("workflow")
|
||||
|
||||
# TODO: refactor with describe_activity_type()
|
||||
def describe_workflow_type(self):
|
||||
domain = self._params.get("domain")
|
||||
_type = self._params.get("workflowType")
|
||||
|
||||
name = _type["name"]
|
||||
version = _type["version"]
|
||||
_type = self.swf_backend.describe_workflow_type(domain, name, version)
|
||||
template = self.response_template(DESCRIBE_WORKFLOW_TYPE_TEMPLATE)
|
||||
return template.render(_type=_type)
|
||||
return self._describe_type("workflow", DESCRIBE_WORKFLOW_TYPE_TEMPLATE)
|
||||
|
||||
|
||||
LIST_DOMAINS_TEMPLATE = """{
|
||||
|
Loading…
Reference in New Issue
Block a user