[Kimchi-devel] [PATCHv3 1/3] Dedicated ISO pool: create an out of box ISO pool

Aline Manera alinefm at linux.vnet.ibm.com
Tue Jun 17 20:14:03 UTC 2014


On 06/16/2014 05:29 AM, lvroyce at linux.vnet.ibm.com wrote:
> From: Royce Lv <lvroyce at linux.vnet.ibm.com>
>
> An out of box ISO pool is created to make sure user
> will find a well known place to put his ISO.
>
> Signed-off-by: Royce Lv <lvroyce at linux.vnet.ibm.com>
> ---
>   src/kimchi/model/model.py | 26 +++++++++++++++-----------
>   1 file changed, 15 insertions(+), 11 deletions(-)
>
> diff --git a/src/kimchi/model/model.py b/src/kimchi/model/model.py
> index a766ca5..3c6dc8c 100644
> --- a/src/kimchi/model/model.py
> +++ b/src/kimchi/model/model.py
> @@ -24,6 +24,8 @@ import sys
>
>   import cherrypy
>   import libvirt
> +import lxml.etree as ET
> +from lxml.builder import E
>
>   from kimchi.basemodel import BaseModel
>   from kimchi.model.libvirtconnection import LibvirtConnection
> @@ -31,6 +33,10 @@ from kimchi.objectstore import ObjectStore
>   from kimchi.utils import import_module, listPathModules
>
>
> +DEFAULT_POOLS = {'default': {'path': '/var/lib/libvirt/images'},
> +                 'ISO': {'path': '/var/lib/libvirt/isos'}}

/var/lib/kimchi would be better as kimchi will create it

> +
> +
>   class Model(BaseModel):
>       def __init__(self, libvirt_uri='qemu:///system', objstore_loc=None):
>           self.objstore = ObjectStore(objstore_loc)
> @@ -38,7 +44,8 @@ class Model(BaseModel):
>           kargs = {'objstore': self.objstore, 'conn': self.conn}
>
>           if 'qemu:///' in libvirt_uri:
> -            self._default_pool_check()
> +            for pool_name, pool_arg in DEFAULT_POOLS.iteritems():
> +                self._default_pool_check(pool_name, pool_arg)
>
>           this = os.path.basename(__file__)
>           this_mod = os.path.splitext(this)[0]
> @@ -57,21 +64,18 @@ class Model(BaseModel):
>
>           return super(Model, self).__init__(models)
>
> -    def _default_pool_check(self):
> +    def _default_pool_check(self, pool_name, pool_arg):
>           conn = self.conn.get()
> -        xml = """
> -            <pool type='dir'>
> -              <name>default</name>
> -              <target>
> -                <path>/var/lib/libvirt/images</path>
> -              </target>
> -            </pool>
> -        """
> +        pool = E.pool(E.name(pool_name), type='dir')
> +        pool.append(E.target(E.path(pool_arg['path'])))
> +        xml = ET.tostring(pool)
>           try:
> -            pool = conn.storagePoolLookupByName("default")
> +            pool = conn.storagePoolLookupByName(pool_name)
>           except libvirt.libvirtError:
>               try:
>                   pool = conn.storagePoolDefineXML(xml, 0)
> +                # Add build step to make sure target directory created
> +                pool.build(libvirt.VIR_STORAGE_POOL_BUILD_NEW)
>                   pool.setAutostart(1)
>               except libvirt.libvirtError, e:
>                   cherrypy.log.error("Fatal: Cannot create default pool because "




More information about the Kimchi-devel mailing list