diff options
author | Jing Lu <lvjing5@huawei.com> | 2017-07-19 08:18:22 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@opnfv.org> | 2017-07-19 08:18:22 +0000 |
commit | df77b6585cb54d2e4691b946ea1bc9cca637c108 (patch) | |
tree | 17185e36cbe6f7b6586a202dd1864497ecbe07b8 /api/resources | |
parent | dec0be619a3968b0a30de710d83636c372f75574 (diff) | |
parent | cf0f0e355fe3b242ba33638958ce431180010e41 (diff) |
Merge "Add API(v2) to delete container"
Diffstat (limited to 'api/resources')
-rw-r--r-- | api/resources/v2/containers.py | 40 |
1 files changed, 38 insertions, 2 deletions
diff --git a/api/resources/v2/containers.py b/api/resources/v2/containers.py index 556477df7..ce7130376 100644 --- a/api/resources/v2/containers.py +++ b/api/resources/v2/containers.py @@ -326,12 +326,12 @@ class V2Container(ApiResource): try: uuid.UUID(container_id) except ValueError: - result_handler(consts.API_ERROR, 'invalid container id') + return result_handler(consts.API_ERROR, 'invalid container id') try: container = container_handler.get_by_uuid(container_id) except ValueError: - result_handler(consts.API_ERROR, 'no such container id') + return result_handler(consts.API_ERROR, 'no such container id') name = container.name client = Client(base_url=consts.DOCKER_URL) @@ -345,3 +345,39 @@ class V2Container(ApiResource): } return result_handler(consts.API_SUCCESS, {'container': data}) + + def delete(self, container_id): + try: + uuid.UUID(container_id) + except ValueError: + return result_handler(consts.API_ERROR, 'invalid container id') + + try: + container = container_handler.get_by_uuid(container_id) + except ValueError: + return result_handler(consts.API_ERROR, 'no such container id') + + environment_id = container.environment_id + + client = Client(base_url=consts.DOCKER_URL) + LOG.info('delete container: %s', container.name) + try: + client.remove_container(container.name, force=True) + except Exception: + LOG.exception('delete container failed') + return result_handler(consts.API_ERROR, 'delete container failed') + + LOG.info('delete container in database') + container_handler.delete_by_uuid(container_id) + + LOG.info('update container in environment') + environment = environment_handler.get_by_uuid(environment_id) + container_info = jsonutils.loads(environment.container_id) + key = next((k for k, v in container_info.items() if v == container_id)) + container_info.pop(key) + environment_delete_data = { + 'container_id': jsonutils.dumps(container_info) + } + environment_handler.update_attr(environment_id, environment_delete_data) + + return result_handler(consts.API_SUCCESS, {'container': container_id}) |