Chris Spencer 743898d75a Adding support for creating a region.
Adding ability to create region in both python and CLI clients.
Adding doctests and unit tests for region creation.

Change-Id: I59bcf4e727d3fd7ed6d55a58560fcf48eed8cb3d
Implements: blueprint craton-client-access-inventory (partial)
Closes-Bug: #1611418
2016-09-16 12:49:42 -07:00

64 lines
1.8 KiB
Python

# -*- coding: utf-8 -*-
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
"""Regions manager code."""
from cratonclient import crud
class Region(crud.Resource):
"""Representation of a Region."""
pass
class RegionManager(crud.CRUDClient):
"""A manager for regions."""
key = 'region'
base_path = '/regions'
resource_class = Region
project_id = 0
def __init__(self, session, url):
"""Initialize our RegionManager with project, session, and url."""
super(RegionManager, self).__init__(session, url)
self.project_id = session.project_id
def create(self, **kwargs):
"""Create a region.
.. code-block:: python
>>> from cratonclient.v1 import client
>>> from cratonclient import session
>>> session = session.Session(
... username='demo',
... token='password',
... project_id=1
... )
>>> client = client.Client(session, 'http://example.com')
>>> client.regions.create(name='region')
"""
kwargs['project_id'] = self.project_id
return super(RegionManager, self).create(**kwargs)
REGION_FIELDS = {
'id': 'ID',
'project_id': 'Project ID',
'name': 'Name',
'note': 'Note',
'created_at': 'Created At',
'update_at': 'Updated At'
}