summaryrefslogtreecommitdiffstats
path: root/keystone-moon/keystone/resource/routers.py
diff options
context:
space:
mode:
authorWuKong <rebirthmonkey@gmail.com>2015-06-30 18:47:29 +0200
committerWuKong <rebirthmonkey@gmail.com>2015-06-30 18:47:29 +0200
commitb8c756ecdd7cced1db4300935484e8c83701c82e (patch)
tree87e51107d82b217ede145de9d9d59e2100725bd7 /keystone-moon/keystone/resource/routers.py
parentc304c773bae68fb854ed9eab8fb35c4ef17cf136 (diff)
migrate moon code from github to opnfv
Change-Id: Ice53e368fd1114d56a75271aa9f2e598e3eba604 Signed-off-by: WuKong <rebirthmonkey@gmail.com>
Diffstat (limited to 'keystone-moon/keystone/resource/routers.py')
-rw-r--r--keystone-moon/keystone/resource/routers.py94
1 files changed, 94 insertions, 0 deletions
diff --git a/keystone-moon/keystone/resource/routers.py b/keystone-moon/keystone/resource/routers.py
new file mode 100644
index 00000000..8ccd10aa
--- /dev/null
+++ b/keystone-moon/keystone/resource/routers.py
@@ -0,0 +1,94 @@
+# Copyright 2013 Metacloud, Inc.
+# Copyright 2012 OpenStack Foundation
+#
+# 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.
+
+"""WSGI Routers for the Resource service."""
+
+from keystone.common import json_home
+from keystone.common import router
+from keystone.common import wsgi
+from keystone.resource import controllers
+
+
+class Admin(wsgi.ComposableRouter):
+ def add_routes(self, mapper):
+ # Tenant Operations
+ tenant_controller = controllers.Tenant()
+ mapper.connect('/tenants',
+ controller=tenant_controller,
+ action='get_all_projects',
+ conditions=dict(method=['GET']))
+ mapper.connect('/tenants/{tenant_id}',
+ controller=tenant_controller,
+ action='get_project',
+ conditions=dict(method=['GET']))
+
+
+class Routers(wsgi.RoutersBase):
+
+ def append_v3_routers(self, mapper, routers):
+ routers.append(
+ router.Router(controllers.DomainV3(),
+ 'domains', 'domain',
+ resource_descriptions=self.v3_resources))
+
+ config_controller = controllers.DomainConfigV3()
+
+ self._add_resource(
+ mapper, config_controller,
+ path='/domains/{domain_id}/config',
+ get_head_action='get_domain_config',
+ put_action='create_domain_config',
+ patch_action='update_domain_config_only',
+ delete_action='delete_domain_config',
+ rel=json_home.build_v3_resource_relation('domain_config'),
+ status=json_home.Status.EXPERIMENTAL,
+ path_vars={
+ 'domain_id': json_home.Parameters.DOMAIN_ID
+ })
+
+ config_group_param = (
+ json_home.build_v3_parameter_relation('config_group'))
+ self._add_resource(
+ mapper, config_controller,
+ path='/domains/{domain_id}/config/{group}',
+ get_head_action='get_domain_config',
+ patch_action='update_domain_config_group',
+ delete_action='delete_domain_config',
+ rel=json_home.build_v3_resource_relation('domain_config_group'),
+ status=json_home.Status.EXPERIMENTAL,
+ path_vars={
+ 'domain_id': json_home.Parameters.DOMAIN_ID,
+ 'group': config_group_param
+ })
+
+ self._add_resource(
+ mapper, config_controller,
+ path='/domains/{domain_id}/config/{group}/{option}',
+ get_head_action='get_domain_config',
+ patch_action='update_domain_config',
+ delete_action='delete_domain_config',
+ rel=json_home.build_v3_resource_relation('domain_config_option'),
+ status=json_home.Status.EXPERIMENTAL,
+ path_vars={
+ 'domain_id': json_home.Parameters.DOMAIN_ID,
+ 'group': config_group_param,
+ 'option': json_home.build_v3_parameter_relation(
+ 'config_option')
+ })
+
+ routers.append(
+ router.Router(controllers.ProjectV3(),
+ 'projects', 'project',
+ resource_descriptions=self.v3_resources))