????JFIF??x?x????'
| Server IP : 104.21.30.238 / Your IP : 216.73.216.87 Web Server : LiteSpeed System : Linux premium151.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 User : tempvsty ( 647) PHP Version : 8.0.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /././././proc/self/root/opt/hc_python/lib/python3.12/site-packages/pyone/ |
Upload File : |
# Copyright 2018 www.privaz.io Valletech AB
# Copyright 2002-2024, OpenNebula Project, OpenNebula Systems
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from . import OneException
from . import MARKETPLACEAPP_STATES, MARKETPLACEAPP_TYPES
from base64 import b64decode
class OneHelperException(OneException):
pass
# Helpers implementation
# This methods are non primitive XMLRPC methods, they can be implemented as a
# series of calls to primitive XMLRPC methods, however they are called in the
# exact same way as XMLRPC method
# They are implemented as standalone functions that take the XMLRPC server as first parameter
# they need to be registered in the XMLRPC server constructor
def marketapp_export(one, appid, dsid=None, name=None, vmtemplate_name=None):
'''
Exports a market app to a suitable OpenNebula object
:param one: the XMLRPC server
:param appid: id of the marketplace app
:param dsid: id of the datastore to save images, if not provided the datastore named "default" will be used.
:param name: name of the new object, if not provided the same name as the App will be used
:param vmtemplate_name: name for the VM Template, if the app has one.
:return: a dictionary with the ID of the new Image as image and the ID of the new associated template as vmtemplate. If no template has been defined, it will return -1.
'''
ret= {
"image": -1,
"vmtemplate": -1
}
# find out the datastore
if not dsid:
datastores = one.datastorepool.info()
for ds in datastores.DATASTORE:
if ds.NAME == "default":
dsid = ds.ID
break
if not dsid:
raise OneHelperException("Datastore was not provided and could not find the defaultone")
# get the application
app = one.marketapp.info(appid)
if app.STATE != MARKETPLACEAPP_STATES.READY:
raise OneHelperException("Application is not in READY state")
if app.TYPE == MARKETPLACEAPP_TYPES.IMAGE:
if app.APPTEMPLATE64:
templ=b64decode(app.APPTEMPLATE64).decode()
else:
templ=""
if not name:
name = app.NAME
templ+='''\nNAME="%s"\nFROM_APP="%d"''' % (name,app.ID)
ret['image'] = one.image.allocate(templ,dsid)
if 'VMTEMPLATE64' in app.TEMPLATE:
vmtempl = b64decode(app.TEMPLATE['VMTEMPLATE64']).decode()
if not vmtemplate_name:
vmtemplate_name = app.NAME
vmtempl += '''\nNAME="%s"\nDISK=[ IMAGE_ID = %d ]''' % (vmtemplate_name, ret['image'])
ret['vmtemplate'] = one.template.allocate(vmtempl)
else:
raise OneHelperException('App type %s not supported' % MARKETPLACEAPP_TYPES(app.TYPE).name)
return ret