Source code for LMIBaseClient

# Copyright (C) 2012-2013 Peter Hatina <phatina@redhat.com>
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program 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 General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, see <http://www.gnu.org/licenses/>.

import sys
import pywbem

from LMIObjectFactory import LMIObjectFactory
from LMIReturnValue import LMIReturnValue
from LMIUtil import lmi_raise_or_dump_exception

from LMIExceptions import LMIFilterError

[docs]class LMIBaseClient(object): """ Base client class for CIMOM communication. It abstracts the :py:mod:`pywbem` dependent calls to :py:class:`LMIBaseClient` API. :param string uri: URI of the CIMOM :param string username: account, under which, the CIM calls will be performed :param string password: user's password :param conn_type: type of connection; can be of 2 values: * :py:attr:`LMIBaseClient.CONN_TYPE_WBEM` -- WBEM connection * :py:attr:`LMIBaseClient.CONN_TYPE_PEGASUS_UDS` -- applicable only for Tog-Pegasus CIMOM, it uses Unix socket for the connection; default value is :py:attr:`LMIbaseClient.CONN_TYPE_WBEM` :param string key_file: path to x509 key file; default value is None :param string cert_file: path to x509 cert file; default value is None :param bool verify_server_cert: indicates, whether a server side certificate needs to be verified, if SSL used; default value is True """ QUERY_LANG_CQL = "DMTF:CQL" QUERY_LANG_WQL = "WQL" CONN_TYPE_WBEM, \ CONN_TYPE_PEGASUS_UDS = range(2) def __init__(self, uri, username="", password="", **kwargs): def verify_callback(conn, cert, errno, errdepth, rcode): """ Callback function used to verify the server certificate. It is passed to OpenSSL.SSL.set_verify, and is called during the SSL handshake. This function returns True, if verification passes and False otherwise. :param conn: Connection object :param cert: x509 object :param int errno: potential error number :param int errdepth: error depth :param int rcode: return code :returns: True, if certificate was successfully verified; False otherwise **NOTE:** see :py:class:`pywbem.cim_operations.WBEMConnection` """ return bool(rcode) # Set remaining arguments conn_type = kwargs.pop("conn_type", LMIBaseClient.CONN_TYPE_WBEM) verify_server_cert = kwargs.pop("verify_server_cert", True) key_file = kwargs.pop("key_file", None) cert_file = kwargs.pop("cert_file", None) if kwargs: raise TypeError("__init__() got an unexpected keyword arguments: %s" % ", ".join(kwargs.keys())) self._uri = uri self._username = username if not self._uri.startswith("http://") and not self._uri.startswith("https://"): self._uri= "https://" + self._uri if conn_type == LMIBaseClient.CONN_TYPE_PEGASUS_UDS: self._cliconn = pywbem.PegasusUDSConnection() else: self._cliconn = pywbem.WBEMConnection(self._uri, (self._username, password), x509={"key_file" : key_file, "cert_file" : cert_file}, verify_callback=verify_callback if verify_server_cert else None ) # NOTE: usage with Key=something, Value=something is deprecated # NOTE: inst_filter is either None or dict def _get_instance_names(self, class_name, namespace=None, inst_filter=None, **kwargs): """ Returns a list of :py:class:`CIMInstanceName` objects. :param string class_name: class name :param string namespace: namespace name, where the instance names live :param dictionary inst_filter: dictionary containing filter values. The key corresponds to the primary key of the :py:class:`CIMInstanceName`; value contains the filtering value. :param dictionary kwargs: supported keyword arguments (these are **deprecated**) * **Key** or **key** (*string*) -- filtering key, see above * **Value** or **value** (*string*) -- filtering value, see above :returns: :py:class:`LMIReturnValue` object with ``rval`` contains a list of :py:class:`CIMInstanceName` objects, if no error occurs; otherwise ``rval`` is set to None and ``errorstr`` contains appropriate error string :raises: :py:exc:`.LMIFilterError`, :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ filter_value = "" filter_key = "Name" if inst_filter is None: inst_filter = {} if "key" in kwargs: filter_key = kwargs["key"] kwargs.pop("key") elif "Key" in kwargs: filter_key = kwargs["Key"] kwargs.pop("Key") if "value" in kwargs: filter_value = kwargs["value"] kwargs.pop("value") if "Value" in kwargs: filter_value = kwargs["Value"] kwargs.pop("Value") if filter_value: inst_filter[filter_key] = filter_value try: inst_name_list = self._cliconn.EnumerateInstanceNames(class_name, namespace, **kwargs) if inst_filter: inst_name_list_filtered = [] for inst_name in inst_name_list: append = True for (filter_key, filter_value) in inst_filter.iteritems(): if inst_name[filter_key] != filter_value: append = False break if append: inst_name_list_filtered.append(inst_name) inst_name_list = inst_name_list_filtered except KeyError, e: errorstr = "Can not filter by '%s'" % filter_key lmi_raise_or_dump_exception(LMIFilterError(errorstr)) return LMIReturnValue(rval=None, errorstr=errorstr) except pywbem.cim_operations.CIMError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[1]) except pywbem.cim_http.AuthError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[0]) return LMIReturnValue(rval=inst_name_list) def _get_instance(self, path, **kwargs): """ Returns a :py:class:`CIMInstance` object. :param CIMInstanceName path: path of the object, which is about to be retrieved :param bool LocalOnly: indicates if to include the only elements (properties, methods, references) overridden or defined in the class :param bool IncludeQualifiers: indicates, if all Qualifiers for the class and its elements shall be included in the response :param bool IncludeClassOrigin: indicates, if the ``CLASSORIGIN`` attribute shall be present on all appropriate elements in the returned class :param list PropertyList: if present and not None, the members of the list define one or more property names. The returned class shall not include elements for properties missing from this list. Note that if LocalOnly is specified as True, it acts as an additional filter on the set of properties returned. For example, if property A is included in the PropertyList but LocalOnly is set to True and A is not local to the requested class, it is not included in the response. If the PropertyList input parameter is an empty list, no properties are included in the response. If the PropertyList input parameter is None, no additional filtering is defined. :returns: :py:class:`LMIReturnValue` object, where ``rval`` is set to :pyclass:`CIMInstance` object, if no error occurs; otherwise ``errorstr`` is set to corresponding error string :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ if isinstance(path, LMIObjectFactory().LMIInstanceName): path = path.wrapped_object try: inst = self._cliconn.GetInstance(path, **kwargs) except pywbem.cim_operations.CIMError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[1]) except pywbem.cim_http.AuthError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[0]) return LMIReturnValue(rval=inst) # NOTE: usage with Key=something, Value=something is deprecated # NOTE: inst_filter is either None or dict def _get_instances(self, class_name, namespace=None, inst_filter=None, **kwargs): """ Returns a list of :py:class:`CIMInstance` objects. :param string class_name: class name :param string namespace: namespace, where the instances live :param dictionary inst_filter: dictionary containing filter values. The key corresponds to the primary key of the :py:class:`CIMInstanceName`; value contains the filtering value. :param dictionary kwargs: supported keyword arguments (these are **deprecated**) * **Key** or **key** (*string*) -- filtering key, see above * **Value** or **value** (*string*) -- filtering value, see above :returns: :py:class:`LMIReturnValue` object with ``rval`` set to a list of :py:class:`CIMIntance` objects, if no error occurs; otherwise ``rval`` is set to None and ``errorstr`` is set to corresponding error string. :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ filter_value = "" filter_key = "Name" if inst_filter is None: inst_filter = {} if "key" in kwargs: filter_key = kwargs["key"] kwargs.pop("key") elif "Key" in kwargs: filter_key = kwargs["Key"] kwargs.pop("Key") if "value" in kwargs: filter_value = kwargs["value"] kwargs.pop("value") if "Value" in kwargs: filter_value = kwargs["Value"] kwargs.pop("Value") if filter_value: inst_filter[filter_key] = filter_value query = "select * from %s" % class_name if inst_filter: more = False query += " where" for (filter_key, filter_value) in inst_filter.iteritems(): if more: query += " and" quotes = isinstance(filter_value, basestring) query += " %s =" % filter_key query += " \"%s\"" % filter_value if quotes else " %s" % filter_value more = True (inst_list, _, errorstr) = self._exec_query(LMIBaseClient.QUERY_LANG_WQL, query, namespace) if not inst_list: return LMIReturnValue(rval=None, errorstr=errorstr) return LMIReturnValue(rval=inst_list) def _get_class_names(self, namespace=None, **kwargs): """ Returns a list of class names. :param string namespace: namespace, from which the class names list should be retrieved; if None, default namespace will be used (**NOTE:** see :py:mod:`pywbem`) :param string ClassName: defines the class that is the basis for the enumeration. If the ClassName input parameter is absent, this implies that the names of all classes. Default value is None. :param bool DeepInheritance: if not present, of False, only the names of immediate child subclasses are returned, otherwise the names of all subclasses of the specified class should be returned. Default value is False. :returns: :py:class:`LMIReturnValue` object with ``rval`` set to a list of strings containing class names, if no error occurs; otherwise ``rval`` is set to None and ``errorstr`` contains an appropriate error string :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ try: class_name_list = self._cliconn.EnumerateClassNames(namespace, **kwargs) except pywbem.cim_operations.CIMError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[1]) except pywbem.cim_http.AuthError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[0]) return LMIReturnValue(rval=class_name_list) def _get_classes(self, namespace=None, **kwargs): """ Returns a :py:class:`CIMClass` object. :param string namespace: namespace, from which the class names list should be retrieved; if None, default namespace will be used (**NOTE:** see :py:mod:`pywbem`) :param string ClassName: defines the class that is the basis for the enumeration. If the ClassName input parameter is absent, this implies that the names of all classes. Default value is None. :param bool DeepInheritance: if not present, of False, only the names of immediate child subclasses are returned, otherwise the names of all subclasses of the specified class should be returned. Default value is False. :param bool LocalOnly: indicates, if any CIM elements (properties, methods, and qualifiers) except those added or overridden in the class as specified in the classname input parameter shall not be included in the returned class. :param bool IncludeQualifiers: indicates, if all qualifiers for each class (including qualifiers on the class and on any returned properties, methods, or method parameters) shall be included as ``<QUALIFIER>`` elements in the response. :param bool IncludeClassOrigin: indicates, if the ``CLASSORIGIN`` attribute shall be present on all appropriate elements in each returned class. :returns: :py:class:`LMIReturnValue` object with ``rval`` set to a list of :py:class:`CIMClass` objects, if no error occurs; otherwise ``rval`` is set to None and ``errorstr`` to appropriate error string :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ try: class_list = self._cliconn.EnumerateClasses(namespace, **kwargs) except pywbem.cim_operations.CIMError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[1]) except pywbem.cim_http.AuthError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[0]) return LMIReturnValue(rval=class_list) def _get_class(self, class_name, namespace=None, **kwargs): """ Returns a :py:class:`CIMClass` object. :param string class_name: class name :param string namespace: -- namespace name, from which the :py:class:`CIMClass` should be retrieved; if None, default namespace will be used (**NOTE:** see :py:mod:`pywbem`) :param bool LocalOnly: indicates, if only local members should be present in the returned :py:class:`CIMClass`; any CIM elements (properties, methods, and qualifiers), except those added or overridden in the class as specified in the classname input parameter, shall not be included in the returned class. Default value is True. :param bool IncludeQualifiers: indicates, if qualifiers for the class (including qualifiers on the class and on any returned properties, methods, or method parameters) shall be included in the response. Default value is True. :param bool IncludeClassOrigin: indicates, if the ``CLASSORIGIN`` attribute shall be present on all appropriate elements in the returned class. Default value is False. :param list PropertyList: if present and not None, the members of the list define one or more property names. The returned class shall not include elements for properties missing from this list. Note that if LocalOnly is specified as True, it acts as an additional filter on the set of properties returned. For example, if property A is included in the PropertyList but LocalOnly is set to True and A is not local to the requested class, it is not included in the response. If the PropertyList input parameter is an empty list, no properties are included in the response. If the PropertyList input parameter is None, no additional filtering is defined. Default value is None. :returns: :py:class:`LMIReturnValue` object with rval set to :py:class:`CIMClass`, if no error occurs; otherwise rval is set to none and errorstr to appropriate error string :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ try: klass = self._cliconn.GetClass(class_name, namespace, **kwargs) except pywbem.cim_operations.CIMError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[1]) except pywbem.cim_http.AuthError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[0]) return LMIReturnValue(rval=klass) def _get_superclass(self, class_name, namespace=None): """ Returns a superclass to given class. :param string class_name: class name :param string namespace: namespace name :returns: superclass to given class, if such superclass exists, None otherwise :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ (minimal_class, _, _) = LMIBaseClient._get_class(self, class_name, namespace, LocalOnly=True, IncludeQualifiers=False, PropertyList=[]) if not minimal_class: return None return minimal_class.superclass def _call_method_raw(self, instance, method, **params): """ Executes a method within a given :py:class:`CIMInstance`. :param CIMInstance instance: object, on which the method will be issued :param string method: string containing a method name :param dictionary params: parameters passed to the method call :returns: :py:class:`LMIReturnValue` object with rval set to return value of the method call, rparams set to returned parameters from the method call, if no error occurs; otherwise rval is set to -1 and errorstr to appropriate error string :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ if isinstance(instance, LMIObjectFactory().LMIInstance): instance = instance.wrapped_object try: (rval, rparams) = self._cliconn.InvokeMethod(method, instance.path, **params) except pywbem.cim_operations.CIMError, e: lmi_raise_or_dump_exception(e) errorstr = e.args[1] + ": '" + method + "'" return LMIReturnValue(rval=-1, errorstr=errorstr) except pywbem.cim_http.AuthError, e: lmi_raise_or_dump_exception(e) errorstr = e.args[0] + ": '" + method + "'" return LMIReturnValue(rval=-1, errorstr=errorstr) return LMIReturnValue(rval=rval, rparams=rparams) def _call_method(self, instance, method, **params): """ Executes a method within a given :py:class:`CIMInstance`. :param CIMInstance instance: object, on which the method will be issued :param string method: a method name :param dictionary params: parameters passed to the method call :returns: :py:class:`LMIReturnValue` object with ``rval`` set to True, rparams set to returned parameters from the method call, if no error occurs; otherwise ``rval`` is set to False and ``errorstr`` to appropriate error string :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ (rval, rparams, errorstr) = self._call_method_raw(instance, method, **params) return LMIReturnValue(rval=(rval == 0), rparams=rparams, errorstr=errorstr) def _get_associator_names(self, instance, **kwargs): """ Returns a list of associated :py:class:`CIMInstanceName` objects with an input instance. :param CIMInstance instance: for this object the list of associated :py:class:`CIMInstanceName` will be returned :param string AssocClass: valid CIM association class name. It acts as a filter on the returned set of names by mandating that each returned name identify an object that shall be associated to the source object through an instance of this class or one of its subclasses. :param string ResultClass: valid CIM class name. It acts as a filter on x the returned set of names by mandating that each returned name identify an object that shall be either an instance of this class (or one of its subclasses) or be this class (or one of its subclasses). :param string Role: valid property name. It acts as a filter on the returned set of names by mandating that each returned name identify an object that shall be associated to the source object through an association in which the source object plays the specified role. That is, the name of the property in the association class that refers to the source object shall match the value of this parameter. :param string ResultRole: valid property name. It acts as a filter on the returned set of names by mandating that each returned name identify an object that shall be associated to the source object through an association in which the named returned object plays the specified role. That is, the name of the property in the association class that refers to the returned object shall match the value of this parameter. :returns: list of associated :py:class:`CIMInstanceName` objects with an input instance, if no error occurs; otherwise en empty list is returned :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ if isinstance(instance, LMIObjectFactory().LMIInstance): instance = instance.wrapped_object try: return self._cliconn.AssociatorNames(instance.path, **kwargs) except (pywbem.cim_operations.CIMError, pywbem.cim_http.AuthError), e: lmi_raise_or_dump_exception(e) return [] def _get_associators(self, instance, **kwargs): """ Returns a list of associated :py:class:`CIMInstance` objects with an input instance. :param CIMInstance instance: for this object the list of associated :py:class:`CIMInstance` objects will be returned :param string AssocClass: valid CIM association class name. It acts as a filter on the returned set of objects by mandating that each returned object shall be associated to the source object through an instance of this class or one of its subclasses. Default value is None. :param string ResultClass: valid CIM class name. It acts as a filter on the returned set of objects by mandating that each returned object shall be either an instance of this class (or one of its subclasses) or be this class (or one of its subclasses). Default value is None. :param string Role: valid property name. It acts as a filter on the returned set of objects by mandating that each returned object shall be associated with the source object through an association in which the source object plays the specified role. That is, the name of the property in the association class that refers to the source object shall match the value of this parameter. Default value is None. :param string ResultRole: valid property name. It acts as a filter on the returned set of objects by mandating that each returned object shall be associated to the source object through an association in which the returned object plays the specified role. That is, the name of the property in the association class that refers to the returned object shall match the value of this parameter. Default value is None. :param bool IncludeQualifiers: indicates, if all qualifiers for each object (including qualifiers on the object and on any returned properties) shall be included as ``<QUALIFIER>`` elements in the response. Default value is False. :param bool IncludeClassOrigin: indicates, if the ``CLASSORIGIN`` attribute shall be present on all appropriate elements in each returned object. Default value is False. :param list PropertyList: if not None, the members of the array define one or more property names. Each returned object shall not include elements for any properties missing from this list. If PropertyList is an empty list, no properties are included in each returned object. If it is None, no additional filtering is defined. Default value is None. :returns: list of associated :py:class:`CIMInstance` objects with an input instance, if no error occurs; otherwise an empty list is returned :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ if isinstance(instance, LMIObjectFactory().LMIInstance): instance = instance.wrapped_object try: return self._cliconn.Associators(instance.path, **kwargs) except (pywbem.cim_operations.CIMError, pywbem.cim_http.AuthError), e: lmi_raise_or_dump_exception(e) return [] def _get_reference_names(self, instance, **kwargs): """ Returns a list of association :py:class:`CIMInstanceName` objects. :param CIMInstance instance: for this object the association :py:class:`CIMInstanceName` objects will be returned :param string ResultClass: valid CIM class name. It acts as a filter on the returned set of object names by mandating that each returned Object Name identify an instance of this class (or one of its subclasses) or this class (or one of its subclasses). :param string Role: valid property name. It acts as a filter on the returned set of object names by mandating that each returned object name shall identify an object that refers to the target instance through a property with a name that matches the value of this parameter. :returns: list of association :py:class:`CIMInstanceName` objects with an input instance, if no error occurs; otherwise an empty list is returned :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ if isinstance(instance, LMIObjectFactory().LMIInstance): instance = instance.wrapped_object try: return self._cliconn.ReferenceNames(instance.path, **kwargs) except (pywbem.cim_operations.CIMError, pywbem.cim_http.AuthError), e: lmi_raise_or_dump_exception(e) return [] def _get_references(self, instance, **kwargs): """ Returns a list of association :py:class:`CIMInstance` objects. :param CIMInstance instance: for this object the list of association :py:class:`CIMInstance` objects will be returned :param string ResultClass: valid CIM class name. It acts as a filter on the returned set of objects by mandating that each returned object shall be an instance of this class (or one of its subclasses) or this class (or one of its subclasses). Default value is None. :param string Role: valid property name. It acts as a filter on the returned set of objects by mandating that each returned object shall refer to the target object through a property with a name that matches the value of this parameter. Default value is None. :param bool IncludeQualifiers: bool flag indicating, if all qualifiers for each object (including qualifiers on the object and on any returned properties) shall be included as ``<QUALIFIER>`` elements in the response. Default value is False. :param bool IncludeClassOrigin: bool flag indicating, if the ``CLASSORIGIN`` attribute shall be present on all appropriate elements in each returned object. Default value is False. :param list PropertyList: if not None, the members of the list define one or more property names. Each returned object shall not include elements for any properties missing from this list. If PropertyList is an empty list, no properties are included in each returned object. If PropertyList is None, no additional filtering is defined. Default value is None. :returns: list of association :py:class:`CIMInstance` objects with an input instance, if no error occurs; otherwise an empty list is returned :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ if isinstance(instance, LMIObjectFactory().LMIInstance): instance = instance.wrapped_object try: return self._cliconn.References(instance.path, **kwargs) except (pywbem.cim_operations.CIMError, pywbem.cim_http.AuthError), e: lmi_raise_or_dump_exception(e) return [] def _create_instance(self, classname, namespace, properties=None, qualifiers=None, property_list=None): """ Creates a new :py:class:`CIMInstance` object. :param string classname: class name of a new instance :param string namespace: namespace, of the new instance :param dictionary properties: property names and values :param dictionary qualifiers: qualifier names and values :param list property_list: list for property filtering; see :py:class:`CIMInstance` :returns: new :class:`CIMInstance`, if no error occurs; otherwise None is returned :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ # Create a new dictionaries from the input ones, we do not want to modify user's # input variables. properties = dict(properties) if not properties is None else {} qualifiers = dict(qualifiers) if not qualifiers is None else {} cim_instance = pywbem.CIMInstance(classname, properties, qualifiers, pywbem.CIMInstanceName(classname, namespace=namespace), property_list) try: cim_path = self._cliconn.CreateInstance(NewInstance=cim_instance) except pywbem.CIMError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[1]) except pywbem.cim_http.AuthError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=None, errorstr=e.args[0]) return self._get_instance(cim_path, LocalOnly=False) def _modify_instance(self, instance, **kwargs): """ Modifies a :py:class:`CIMInstance` object at CIMOM side. :param CIMInstance instance: object to be modified :param bool IncludeQualifiers: indicates, if the qualifiers are modified as specified in `ModifiedInstance`. Default value is True. :param list PropertyList: if not None, the members of the list define one or more property names. Only properties specified in the PropertyList are modified. Properties of the *ModifiedInstance* that are missing from the PropertyList are ignored. If the PropertyList is an empty list, no properties are modified. If the PropertyList is None, the set of properties to be modified consists of those of *ModifiedInstance* with values different from the current values in the instance to be modified. Default value is None. :returns: :py:class:`LMIReturnValue` object with ``rval`` set to 0, if no error occurs; otherwise ``rval`` is set to -1 and ``errorstr`` is set to corresponding error string. :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ try: self._cliconn.ModifyInstance(instance, **kwargs) except pywbem.cim_operations.CIMError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=e.args[0], errorstr=e.args[1]) except pywbem.cim_http.AuthError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=-1, errorstr=e.args[0]) return LMIReturnValue(rval=0) def _delete_instance(self, instance): """ Deletes a :py:class:`CIMInstance` from the CIMOM side. :param CIMInstance instance: object to be deleted :returns: :py:class:`LMIReturnValue` object with ``rval`` set to 0, if no error occurs; otherwise ``rval`` is set to -1 and ``errorstr`` is set to corresponding error string :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ try: self._cliconn.DeleteInstance(instance) except pywbem.cim_operations.CIMError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=e.args[0], errorstr=e.args[1]) except pywbem.cim_http.AuthError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=-1, errorstr=e.args[0]) return LMIReturnValue(rval=0) def _exec_query(self, query_lang, query, namespace=None): """ Executes a query and returns a list of :py:class:`CIMInstance` objects. :param string query_lang: query language :param string query: query to execute :param string namespace: target namespace for the query :returns: :py:class:`LMIReturnValue` object with ``rval`` set to list of :py:class:`CIMInstance` objects, if no error occurs; otherwise ``rval`` is set to empty list and ``errorstr`` is set to corresponding error string :raises: :py:exc:`pywbem.CIMError`, :py:exc:`pywbem.AuthError` """ try: inst_list = self._cliconn.ExecQuery(query_lang, query, namespace) except pywbem.cim_operations.CIMError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=[], errorstr=e.args[1]) except pywbem.cim_http.AuthError, e: lmi_raise_or_dump_exception(e) return LMIReturnValue(rval=[], errorstr=e.args[0]) return LMIReturnValue(rval=inst_list) @property
[docs] def username(self): """ :returns: user name as a part of provided credentials :rtype: string """ return self._username
@property
[docs] def uri(self): """ :returns: URI of the CIMOM :rtype: string """ return self._uri