diff options
| author | Jenkins <jenkins@review.openstack.org> | 2014-11-18 03:18:10 +0000 |
|---|---|---|
| committer | Gerrit Code Review <review@openstack.org> | 2014-11-18 03:18:10 +0000 |
| commit | d827bdaaeda2e8b6ddfaec6959dadfb93bf3e171 (patch) | |
| tree | ea3220605a3932c0326f3eb946db1597fa24c2b6 /openstackclient/identity/v2_0/project.py | |
| parent | a9670b4cf0d2f8e98e62c25e6379311ef66ea01b (diff) | |
| parent | 7242113a8f8bcb8c227b259376e34e28ef6c2b52 (diff) | |
| download | python-openstackclient-d827bdaaeda2e8b6ddfaec6959dadfb93bf3e171.tar.gz | |
Merge "Add additional support for --or-show"
Diffstat (limited to 'openstackclient/identity/v2_0/project.py')
| -rw-r--r-- | openstackclient/identity/v2_0/project.py | 27 |
1 files changed, 21 insertions, 6 deletions
diff --git a/openstackclient/identity/v2_0/project.py b/openstackclient/identity/v2_0/project.py index 7ead0890..2d66b400 100644 --- a/openstackclient/identity/v2_0/project.py +++ b/openstackclient/identity/v2_0/project.py @@ -63,6 +63,11 @@ class CreateProject(show.ShowOne): help=_('Property to add for this project ' '(repeat option to set multiple properties)'), ) + parser.add_argument( + '--or-show', + action='store_true', + help=_('Return existing project'), + ) return parser def take_action(self, parsed_args): @@ -76,12 +81,22 @@ class CreateProject(show.ShowOne): if parsed_args.property: kwargs = parsed_args.property.copy() - project = identity_client.tenants.create( - parsed_args.name, - description=parsed_args.description, - enabled=enabled, - **kwargs - ) + try: + project = identity_client.tenants.create( + parsed_args.name, + description=parsed_args.description, + enabled=enabled, + **kwargs + ) + except ksc_exc.Conflict as e: + if parsed_args.or_show: + project = utils.find_resource( + identity_client.tenants, + parsed_args.name, + ) + self.log.info('Returning existing project %s', project.name) + else: + raise e info = {} info.update(project._info) |
