[Kimchi-devel] [PATCH 09/15] Move all resources related to storage volume to control/storagevolumes.py
Aline Manera
alinefm at linux.vnet.ibm.com
Thu Dec 26 21:48:57 UTC 2013
From: Aline Manera <alinefm at br.ibm.com>
StorageVolumes(Collection), StorageVolume(Resource) and IsoVolumes(Collection)
were moved to a new - control/storagevolumes.py
That way we can easily know where storage volume resource is implemented.
Signed-off-by: Aline Manera <alinefm at br.ibm.com>
---
src/kimchi/control/storagevolumes.py | 81 ++++++++++++++++++++++++++++++++++
src/kimchi/controller.py | 50 ---------------------
2 files changed, 81 insertions(+), 50 deletions(-)
create mode 100644 src/kimchi/control/storagevolumes.py
diff --git a/src/kimchi/control/storagevolumes.py b/src/kimchi/control/storagevolumes.py
new file mode 100644
index 0000000..d541807
--- /dev/null
+++ b/src/kimchi/control/storagevolumes.py
@@ -0,0 +1,81 @@
+#
+# Project Kimchi
+#
+# Copyright IBM, Corp. 2013
+#
+# Authors:
+# Adam Litke <agl at linux.vnet.ibm.com>
+# Aline Manera <alinefm at linux.vnet.ibm.com>
+# Bing Bu Cao <mars at linux.vnet.ibm.com>
+# Royce Lv <lvroyce at linux.vnet.ibm.com>
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+
+import kimchi.template
+from kimchi.control.base import Collection, Resource
+from kimchi.control.utils import get_class_name, model_fn
+
+
+class StorageVolumes(Collection):
+ def __init__(self, model, pool):
+ super(StorageVolumes, self).__init__(model)
+ self.resource = StorageVolume
+ self.pool = pool
+ self.resource_args = [self.pool, ]
+ self.model_args = [self.pool, ]
+
+
+class StorageVolume(Resource):
+ def __init__(self, model, pool, ident):
+ super(StorageVolume, self).__init__(model, ident)
+ self.pool = pool
+ self.ident = ident
+ self.info = {}
+ self.model_args = [self.pool, self.ident]
+ self.uri_fmt = '/storagepools/%s/storagevolumes/%s'
+ self.resize = self.generate_action_handler('resize', ['size'])
+ self.wipe = self.generate_action_handler('wipe')
+
+ @property
+ def data(self):
+ res = {'name': self.ident,
+ 'type': self.info['type'],
+ 'capacity': self.info['capacity'],
+ 'allocation': self.info['allocation'],
+ 'path': self.info['path'],
+ 'format': self.info['format']}
+
+ for key in ('os_version', 'os_distro', 'bootable'):
+ val = self.info.get(key)
+ if val:
+ res[key] = val
+
+ return res
+
+
+class IsoVolumes(Collection):
+ def __init__(self, model, pool):
+ super(IsoVolumes, self).__init__(model)
+ self.pool = pool
+
+ def get(self):
+ res_list = []
+ try:
+ get_list = getattr(self.model, model_fn(self, 'get_list'))
+ res_list = get_list(*self.model_args)
+ except AttributeError:
+ pass
+
+ return kimchi.template.render(get_class_name(self), res_list)
diff --git a/src/kimchi/controller.py b/src/kimchi/controller.py
index 535f816..b691842 100644
--- a/src/kimchi/controller.py
+++ b/src/kimchi/controller.py
@@ -79,56 +79,6 @@ class Network(Resource):
'state': self.info['state']}
-class StorageVolume(Resource):
- def __init__(self, model, pool, ident):
- super(StorageVolume, self).__init__(model, ident)
- self.pool = pool
- self.ident = ident
- self.info = {}
- self.model_args = [self.pool, self.ident]
- self.uri_fmt = '/storagepools/%s/storagevolumes/%s'
- self.resize = self.generate_action_handler('resize', ['size'])
- self.wipe = self.generate_action_handler('wipe')
-
- @property
- def data(self):
- res = {'name': self.ident,
- 'type': self.info['type'],
- 'capacity': self.info['capacity'],
- 'allocation': self.info['allocation'],
- 'path': self.info['path'],
- 'format': self.info['format']}
- for key in ('os_version', 'os_distro', 'bootable'):
- val = self.info.get(key)
- if val:
- res[key] = val
- return res
-
-
-class IsoVolumes(Collection):
- def __init__(self, model, pool):
- super(IsoVolumes, self).__init__(model)
- self.pool = pool
-
- def get(self):
- res_list = []
- try:
- get_list = getattr(self.model, model_fn(self, 'get_list'))
- res_list = get_list(*self.model_args)
- except AttributeError:
- pass
- return kimchi.template.render(get_class_name(self), res_list)
-
-
-class StorageVolumes(Collection):
- def __init__(self, model, pool):
- super(StorageVolumes, self).__init__(model)
- self.resource = StorageVolume
- self.pool = pool
- self.resource_args = [self.pool, ]
- self.model_args = [self.pool, ]
-
-
class Task(Resource):
def __init__(self, model, id):
super(Task, self).__init__(model, id)
--
1.7.10.4
More information about the Kimchi-devel
mailing list