Source code for openlmi.storage.LMI_AttachedFileSystem

# Copyright (C) 2013 Red Hat, Inc.  All rights reserved.
#
# 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
#
# Authors: Jan Synacek <jsynacek@redhat.com>
# -*- coding: utf-8 -*-
"""
Python Provider for LMI_AttachedFileSystem

LMI_AttachedFileSystem
----------------------

.. autoclass:: LMI_AttachedFileSystem
    :members:

"""

import pywbem
import blivet
from openlmi.storage.BaseProvider import BaseProvider
import openlmi.common.cmpi_logging as cmpi_logging

[docs]class LMI_AttachedFileSystem(BaseProvider): """Instrument the CIM class LMI_AttachedFileSystem CIM_Dependency is a generic association used to establish dependency relationships between ManagedElements. """ @cmpi_logging.trace_method
[docs] def __init__ (self, *args, **kwargs): super(LMI_AttachedFileSystem, self).__init__(*args, **kwargs) self.classname = 'LMI_AttachedFileSystem'
@cmpi_logging.trace_method
[docs] def get_instance(self, env, model): """ Provider implementation of GetInstance intrinsic method. """ fs = model['Antecedent'] if (fs['CSCreationClassName'] != self.config.system_class_name or fs['CSName'] != self.config.system_name): raise pywbem.CIMError(pywbem.CIM_ERR_NOT_FOUND, "Wrong Antecedent keys.") spec = model['Dependent']['FileSystemSpec'] path = model['Dependent']['MountPointPath'] provider = self.provider_manager.get_provider_for_format_name(fs) if provider is None: raise pywbem.CIMError(pywbem.CIM_ERR_FAILED, "Could not get provider for %s" % fs['Name']) # XXX somewhat hackish, the method should return tuples consistently (device, fmt) = provider.get_format_for_name(fs) or (None, None) if device is None: raise pywbem.CIMError(pywbem.CIM_ERR_FAILED, "No such device: " + fs['Name']) paths = blivet.util.get_mount_paths(device.path) if not paths: raise pywbem.CIMError(pywbem.CIM_ERR_FAILED, "No such mounted device: " + spec) if path not in paths or device.path != spec: raise pywbem.CIMError(pywbem.CIM_ERR_FAILED, "%s is not mounted here: %s" % (spec, path)) return model
@cmpi_logging.trace_method
[docs] def enum_instances(self, env, model, keys_only): """Enumerate instances. """ model.path.update({'Dependent': None, 'Antecedent': None}) for device in self.storage.devices: for path in blivet.util.get_mount_paths(device.path): provider = self.provider_manager.get_provider_for_format(device, device.format) if provider is None: raise pywbem.CIMError(pywbem.CIM_ERR_FAILED, "Could not get provider for %s" % path) model['Antecedent'] = provider.get_name_for_format(device, device.format) model['Dependent'] = pywbem.CIMInstanceName( classname='LMI_MountedFileSystem', namespace=self.config.namespace, keybindings={ 'FileSystemSpec' : device.path, 'MountPointPath' : path }) yield model
def references(self, env, object_name, model, result_class_name, role, result_role, keys_only): return self.simple_references(env, object_name, model, result_class_name, role, result_role, keys_only, "LMI_MountedFileSystem", "CIM_FileSystem")