[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