[Kimchi-devel] [PATCH] [Kimchi 4/9] Virt-Viewer launcher: virtviewerfile module
Daniel Henrique Barboza
dhbarboza82 at gmail.com
Thu Jul 7 17:41:08 UTC 2016
On 07/07/2016 11:32 AM, Lucio Correia wrote:
> On 07-07-2016 09:57, dhbarboza82 at gmail.com wrote:
>> From: Daniel Henrique Barboza <danielhb at linux.vnet.ibm.com>
>>
>> This new module contains functions to create virt
>> viewer files and a new model called VMVirtViewerFileModel
>> that will return a link to the new generated script
>> file in the lookup() method.
>>
>> Signed-off-by: Daniel Henrique Barboza <danielhb at linux.vnet.ibm.com>
>> ---
>> model/virtviewerfile.py | 100
>> ++++++++++++++++++++++++++++++++++++++++++++++++
>> 1 file changed, 100 insertions(+)
>> create mode 100644 model/virtviewerfile.py
>>
>> diff --git a/model/virtviewerfile.py b/model/virtviewerfile.py
>> new file mode 100644
>> index 0000000..baccc8a
>> --- /dev/null
>> +++ b/model/virtviewerfile.py
>> @@ -0,0 +1,100 @@
>> +#
>> +# Project Kimchi
>> +#
>> +# Copyright IBM Corp, 2016
>> +#
>> +# 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 cherrypy
>> +import libvirt
>> +import os
>> +
>> +from wok.config import config as wok_config
>> +from wok.exception import NotFoundError, OperationFailed
>> +from wok.plugins.kimchi import config as kimchi_config
>> +from wok.plugins.kimchi.model.vms import VMModel
>> +
>> +
>> +def write_virt_viewer_file(params):
>> + file_template = """\
>> +[virt-viewer]
>> +type=%(type)s
>> +host=%(host)s
>> +port=%(graphics_port)s
>> +"""
>> + file_contents = file_template % params
>> +
>> + if params.get('graphics_passwd'):
>> + file_contents += 'password=%s\n' % params['graphics_passwd']
>> +
>> + try:
>> + with open(params.get('path'), 'w') as vv_file:
>> + vv_file.write(file_contents)
>> + except Exception:
>> + raise
>> +
>> +
>> +def _get_request_host():
>> + host = cherrypy.request.headers.get('Host')
>> + if not host:
>> + host = wok_config.get("server", "host")
>> + host = host.split(':')[0]
>> + return host
>> +
>> +
>> +def create_virt_viewer_file(vm_name, graphics_info):
>> + graphics_type = graphics_info[0]
>> + graphics_port = graphics_info[2]
>> + graphics_passwd = graphics_info[3]
>> +
>> + try:
>> + host = _get_request_host()
>> +
>> + default_dir = kimchi_config.get_virtviewerfiles_path()
>> + file_path = os.path.join(default_dir, '%s-access.vv' % vm_name)
>> +
>> + file_params = {
>> + 'type': graphics_type,
>> + 'graphics_port': graphics_port,
>> + 'graphics_passwd': graphics_passwd,
>> + 'host': host,
>> + 'path': file_path
>> + }
>> + write_virt_viewer_file(file_params)
>> + return file_path
>> +
>> + except Exception as e:
>> + raise OperationFailed("KCHVM0084E",
>> + {'name': vm_name}, {'err': e.message})
> Why 2 dicts here? Shouldn't it be only one dict?
Why 2? Because I messed up! hehehe
Will fix in v2
>
>
>> +
>> +
>> +class VMVirtViewerFileModel(object):
>> + def __init__(self, **kargs):
>> + self.conn = kargs['conn']
>> +
>> + def _check_if_vm_running(self, name):
>> + dom = VMModel.get_vm(name, self.conn)
>> + d_info = dom.info()
>> + if d_info[0] != libvirt.VIR_DOMAIN_RUNNING:
>> + raise NotFoundError("KCHVM0083E", {'name': name})
>> +
>> + def lookup(self, name):
>> + self._check_if_vm_running(name)
>> + graphics_info = VMModel.get_graphics(name, self.conn)
>> + file_path = create_virt_viewer_file(name, graphics_info)
>> +
>> + return 'plugins/kimchi/data/virtviewerfiles/%s' %\
>> + os.path.basename(file_path)
>>
>
>
More information about the Kimchi-devel
mailing list