[Kimchi-devel] [PATCH V3 3/4] improve controller: Root loads collections/resouces automatically
Aline Manera
alinefm at linux.vnet.ibm.com
Thu Jan 23 20:04:03 UTC 2014
Reviewed-by: Aline Manera <alinefm at linux.vnet.ibm.com>
On 01/22/2014 02:51 PM, shaohef at linux.vnet.ibm.com wrote:
> From: ShaoHe Feng <shaohef at linux.vnet.ibm.com>
>
> Remove hard code from root.py.
> We do not need to touch root.py any more when we add a new sub
> collection/resouce.
>
> Signed-off-by: ShaoHe Feng <shaohef at linux.vnet.ibm.com>
> ---
> src/kimchi/root.py | 26 +++++---------------------
> 1 file changed, 5 insertions(+), 21 deletions(-)
>
> diff --git a/src/kimchi/root.py b/src/kimchi/root.py
> index 3cc6321..83a777c 100644
> --- a/src/kimchi/root.py
> +++ b/src/kimchi/root.py
> @@ -28,23 +28,15 @@ import json
> from kimchi import auth
> from kimchi import template
> from kimchi.config import get_api_schema_file
> +from kimchi.control import sub_nodes
> from kimchi.control.base import Resource
> -from kimchi.control.config import Config
> -from kimchi.control.debugreports import DebugReports
> -from kimchi.control.host import Host
> -from kimchi.control.interfaces import Interfaces
> -from kimchi.control.networks import Networks
> -from kimchi.control.plugins import Plugins
> -from kimchi.control.storagepools import StoragePools
> -from kimchi.control.tasks import Tasks
> -from kimchi.control.templates import Templates
> from kimchi.control.utils import parse_request
> -from kimchi.control.vms import VMs
> from kimchi.exception import OperationFailed
>
>
> class Root(Resource):
> def __init__(self, model, dev_env):
> + super(Root, self).__init__(model)
> self._handled_error = ['error_page.400', 'error_page.404',
> 'error_page.405', 'error_page.406',
> 'error_page.415', 'error_page.500']
> @@ -56,17 +48,9 @@ class Root(Resource):
> self._cp_config = dict([(key, self.error_development_handler)
> for key in self._handled_error])
>
> - Resource.__init__(self, model)
> - self.vms = VMs(model)
> - self.templates = Templates(model)
> - self.storagepools = StoragePools(model)
> - self.interfaces = Interfaces(model)
> - self.networks = Networks(model)
> - self.tasks = Tasks(model)
> - self.config = Config(model)
> - self.host = Host(model)
> - self.debugreports = DebugReports(model)
> - self.plugins = Plugins(model)
> + for ident, node in sub_nodes.items():
> + setattr(self, ident, node(model))
> +
> self.api_schema = json.load(open(get_api_schema_file()))
>
> def error_production_handler(self, status, message, traceback, version):
More information about the Kimchi-devel
mailing list