configurationengine/source/cone/public/api.py
author m2lahtel
Wed, 08 Sep 2010 12:20:56 +0300
changeset 4 0951727b8815
parent 3 e7e0ae78773e
child 5 d2c80f5cab53
permissions -rw-r--r--
Updated to 1.2.13 release
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
     1
from __future__ import with_statement
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     2
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     3
# Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     4
# All rights reserved.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     5
# This component and the accompanying materials are made available
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     6
# under the terms of "Eclipse Public License v1.0"
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     7
# which accompanies this distribution, and is available
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     8
# at the URL "http://www.eclipse.org/legal/epl-v10.html".
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     9
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    10
# Initial Contributors:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    11
# Nokia Corporation - initial contribution.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    12
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    13
# Contributors:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    14
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    15
# Description: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    16
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    17
"""
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    18
Cone public API.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    19
The core interface to the ConE functionality.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    20
"""
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    21
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    22
import re
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    23
import sys
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    24
import logging
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    25
import mimetypes
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    26
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    27
from cone.public import exceptions, utils, container, mapping
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    28
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    29
def get_file_logger():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    30
    return logger
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    31
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    32
class Base(container.ObjectContainer):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    33
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    34
    The Base class is intended for capturing same kind of naming scheme.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    35
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    36
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    37
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    38
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    39
        if len(utils.dottedref.split_ref(ref)) > 1:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    40
            raise exceptions.InvalidRef("Invalid reference for Base object %s!" % ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    41
        self.ref = ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    42
        container.ObjectContainer.__init__(self, ref)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    43
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    44
            for arg in kwargs.keys():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    45
                if kwargs.get(arg) != None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    46
                    setattr(self, arg, kwargs.get(arg))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    47
        except AttributeError,e:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    48
            raise e
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    49
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    50
    def __repr__(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    51
        dict = self._dict()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    52
        return "%s(%s)" % (self.__class__.__name__, dict)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    53
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    54
#    def __reduce_ex__(self, protocol_version):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    55
#        tpl = super(Base, self).__reduce_ex__(protocol_version)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    56
#        return tpl
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    57
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    58
#    def __getstate__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    59
#        state = self._dict(internals=True, ignore_empty=True)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    60
#        # pop out the _name so that it wont appear as redundant data (ref is the same)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    61
#        state.pop('_name', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    62
#        state.pop('_parent', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    63
#        return state
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    64
#
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    65
#    def __setstate__(self, state):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    66
#        super(Base, self).__setstate__(state)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    67
#        self.ref = state.get('ref','')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    68
#        for arg in state.keys():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    69
#            self.__dict__.setdefault(arg, state.get(arg))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    70
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    71
    def _get_mapper(self,modelname):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    72
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    73
        Return a instance of appropriate mapper for given model.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    74
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    75
        return mapping.BaseMapper()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    76
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    77
    def _compare(self, other, dict_keys=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    78
        """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    79
        Compare the attributes of elements 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    80
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    81
        if isinstance(other, Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    82
            keys = dict_keys or self._dict().keys() 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    83
            for key in keys:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    84
                self_attr = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    85
                other_attr = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    86
                try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    87
                    self_attr = getattr(self, key)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    88
                    other_attr = getattr(other, key)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    89
                except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    90
                    # If the attribute is not found from either elements
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    91
                    # ignore it entirely
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    92
                    if self_attr == None and other_attr == None: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    93
                        continue
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    94
                if  self_attr != other_attr:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    95
                    return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    96
            # If all given keys match report this as as similar element
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    97
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    98
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    99
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   100
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   101
    def _clone(self, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   102
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   103
        A generic implementation for cloning the object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   104
        Copies all (public) members in dictionary.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   105
        To clone objects recursively set the recursion level with recursion param.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   106
        @param recursion: Boolean to define recursion on or off
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   107
        @param recursion_depth: positive integer to define recursion depth. default is -1 which will 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   108
        perform recursion to all objects.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   109
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   110
        dict = self._dict()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   111
        if kwargs.get('class_instance'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   112
            class_instance = kwargs.get('class_instance')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   113
            del kwargs['class_instance']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   114
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   115
            class_instance = self.__class__
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   116
        obj = class_instance(**dict)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   117
        # Remove all children created at the construction phase 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   118
        # This is needed when the recursion adds children to the object so that there are not duplicates
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   119
        obj._order = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   120
        obj._children = {}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   121
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   122
        # handle the recursion argument
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   123
        recursion = kwargs.get('recursion', False)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   124
        if recursion:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   125
            recursion_depth = kwargs.get('recursion_depth', -1)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   126
            if recursion_depth < 0 or recursion_depth > 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   127
                # decrease the recursion
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   128
                kwargs['recursion_depth'] = recursion_depth - 1 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   129
                for child in self._objects():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   130
                    obj._add(child._clone(**kwargs), container.APPEND)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   131
        return obj
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   132
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   133
    def _dict(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   134
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   135
        Return the public variables in a dictionary
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   136
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   137
        dict = {}
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   138
        # loop through the items in this object internal __dict__
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   139
        # and add all except internal variables and function overrides  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   140
        for (key,value) in self.__dict__.items():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   141
            if not kwargs.get('internals', False) and key.startswith('_'):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   142
                continue
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   143
            elif not kwargs.get('callables', False) and callable(value):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   144
                continue
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   145
            elif kwargs.get('ignore_empty') and not value:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   146
                # ignore empty values
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   147
                pass
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   148
            else:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   149
                dict[key] = value
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   150
        return dict
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   151
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   152
    def _default_object(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   153
        return Base(name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   154
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   155
    @property
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   156
    def fqr(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   157
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   158
        Return a Fully Qualified Ref, which is the full name of the reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   159
        Joins the namespace and ref to one string.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   160
        @return: A string 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   161
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   162
        return utils.dottedref.join_refs([self.namespace, self.get_ref()])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   163
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   164
    @property
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   165
    def namespace(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   166
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   167
        @return: The namespace of the object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   168
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   169
        containerpath = ""
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   170
        path = ""
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   171
        parentcontainer = self.find_parent(container=True)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   172
        parent = self.find_parent(type=Base)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   173
        paths = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   174
        while parent and parent != parentcontainer:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   175
            """ Skip the element if it is supposed to be hidden. Begins with _. """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   176
            if not parent.get_ref().startswith('_'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   177
                paths.append(parent.get_ref())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   178
            parent = parent._get_parent()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   179
        if parentcontainer:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   180
            paths.append(parentcontainer.namespace)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   181
        paths.reverse()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   182
        return utils.dottedref.join_refs(paths)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   183
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   184
    def path(self, toparent=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   185
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   186
        Get the path to this Base object..
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   187
        @param toparent: the _parent object up to which the path is relative. Default value is None.,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   188
        which gives the fully qualified path in the topology.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   189
        @return: The path to this Base object from toparent
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   190
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   191
        return self._path(toparent)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   192
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   193
    def parent_path(self, toparent=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   194
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   195
        Get the path to the parent of this Base object..
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   196
        @param toparent: the _parent object up to which the path is relative. Default value is None.,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   197
        which gives the fully qualified path in the topology.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   198
        @return: The path to this Base object from toparent
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   199
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   200
        if self._parent != None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   201
            return self._parent.path(toparent)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   202
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   203
            return ''
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   204
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   205
    def get_fullref(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   206
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   207
        Return a full reference, reference including a 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   208
        possible index of the object in list. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   209
        e.g. ref can be bar[1] or just the normal bar. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   210
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   211
        @return: The full reference of the object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   212
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   213
        if self.parent and utils.is_list(self.parent._get(self.ref)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   214
            return "%s[%s]" % (self.ref, self.get_index())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   215
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   216
            return self.ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   217
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   218
    def get_fullfqr(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   219
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   220
        Return a full reference, reference including a 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   221
        possible index of the object in list. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   222
        ref and adds index.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   223
        @return: A string 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   224
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   225
        return utils.dottedref.join_refs([self.get_fullnamespace(), self.get_fullref()])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   226
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   227
    def get_fullnamespace(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   228
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   229
        @return: The full namespace of the object with possible indexes of the parent objects
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   230
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   231
        containerpath = ""
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   232
        path = ""
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   233
        parentcontainer = self.find_parent(container=True)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   234
        parent = self.find_parent(type=Base)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   235
        paths = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   236
        while parent and parent != parentcontainer:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   237
            paths.append(parent.get_fullref())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   238
            parent = parent.parent
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   239
        if parentcontainer:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   240
            paths.append(parentcontainer.namespace)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   241
        paths.reverse()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   242
        return utils.dottedref.join_refs(paths)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   243
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   244
    def get_storage(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   245
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   246
        Get the root storage from the root object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   247
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   248
        if self._find_parent():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   249
            return self._find_parent().get_storage()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   250
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   251
            raise exceptions.StorageException("Storage is not found from root!")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   252
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   253
    def get_project(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   254
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   255
        Get the root project from the root object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   256
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   257
        if isinstance(self, Project):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   258
                return self
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   259
        elif self._find_parent():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   260
            return self._find_parent().get_project()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   261
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   262
            raise exceptions.NotFound("Project not found!!")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   263
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   264
    def get_default_view(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   265
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   266
        Get the default view from the root object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   267
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   268
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   269
            return self._find_parent().get_default_view()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   270
        except exceptions.NotFound:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   271
            raise exceptions.NotFound("Default View is not found! No root configuration?")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   272
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   273
    def get_root(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   274
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   275
        Get the root object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   276
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   277
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   278
            return self._find_parent().get_root()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   279
        except exceptions.NotFound:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   280
            return self
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   281
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   282
    def get_root_configuration(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   283
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   284
        Get the root object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   285
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   286
        if self.find_parent(type=Configuration):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   287
            return self.find_parent(type=Configuration).get_root_configuration()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   288
        elif isinstance(self, Configuration):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   289
            return self
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   290
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   291
            return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   292
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   293
    def get_configuration(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   294
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   295
        Return the containing configuration of this object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   296
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   297
        parent = self._find_parent_or_default(type=Configuration)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   298
        return parent
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   299
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   300
    def get_configuration_path(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   301
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   302
        Return the path of containing configuration of this object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   303
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   304
        parent = self._find_parent_or_default(type=Configuration)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   305
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   306
            return parent.get_full_path()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   307
        except AttributeError:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   308
            return None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   309
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   310
    def get_index(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   311
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   312
        @return : the index of the data element for sequential data defined inside the same configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   313
        0 for normal data.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   314
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   315
        # Get the list of items from parent which contains this element and ask my own index
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   316
        # Make sure that the returned element is a list with get_list
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   317
        selflist = utils.get_list(self._get_parent()._get(self.get_ref()))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   318
        return selflist.index(self)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   319
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   320
    def find_parent(self, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   321
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   322
        find the closest parent object of given type.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   323
        e.g. find_parent(type=Configuration) returns the closest parent 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   324
        Configuration parent instance
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   325
        @param type: class definitiob
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   326
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   327
        type = kwargs.get('type', None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   328
        container = kwargs.get('container', False)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   329
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   330
            parent = self._find_parent()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   331
            if type and isinstance(parent, type):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   332
                    return parent
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   333
            elif container and hasattr(parent, 'container'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   334
                    return parent
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   335
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   336
                return parent.find_parent(**kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   337
        except exceptions.NotFound:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   338
            return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   339
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   340
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   341
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   342
        A generic add function to add child objects. The function is intended to act as
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   343
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   344
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   345
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   346
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   347
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   348
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   349
        raise exceptions.NotSupportedException("Cannot add %s object to %s" % (child, self))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   350
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   351
    def get_elem(self, fqr):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   352
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   353
        A generic get function to get child objects and members. The function uses getattr
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   354
        to traverse downwards the the object tree. The returned object is the final object or attribute 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   355
        if it is found. Raises AttributeError if the child is not found.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   356
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   357
        Example: obj.get('test.bar'), returns child obj.test.bar
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   358
        @param fqr: the fully qualified ref to the object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   359
        @raise AttributeError: if the given ref is not found.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   360
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   361
        return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   362
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   363
    def get_store_interface(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   364
        # if the project cannot be retrieved return None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   365
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   366
            return self.get_project()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   367
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   368
            return None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   369
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   370
    def get_id(self): 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   371
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   372
            return self._id
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   373
        except AttributeError:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   374
            return None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   375
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   376
    def set_id(self,value): 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   377
        self._id = value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   378
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   379
    def del_id(self): 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   380
        delattr(self,'_id')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   381
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   382
    """ The id as a property """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   383
    id = property(get_id,set_id, del_id)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   384
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   385
class Project(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   386
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   387
    A project is a container that can hold several Configuration objects.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   388
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   389
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   390
    def __init__(self, storage, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   391
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   392
        Project constructor
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   393
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   394
        Base.__init__(self, "")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   395
        """ Try to set the model and tet the actual configuration class """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   396
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   397
            self._model = storage.persistentmodule.MODEL
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   398
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   399
            self._model = None
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   400
        self.loaded = {}
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   401
        self.set_storage(storage)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   402
        self.update()
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   403
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   404
    def __getstate__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   405
        state = {}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   406
        state['storage'] = self.storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   407
        return state
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   408
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   409
    def __setstate__(self, state):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   410
        self.__init__(state['storage'])
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   411
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   412
    def __add_loaded__(self, ref, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   413
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   414
        Add the object to loaded 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   415
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   416
        self.loaded[ref] = {'counter': 0, 'obj': obj}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   417
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   418
    def __get_loaded__(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   419
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   420
        Get a loaded object if it is existing and increase the reference counter
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   421
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   422
        @return: The loaded object if it exists. None if it does not. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   423
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   424
        if self.loaded.has_key(ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   425
            return self.loaded[ref]['obj']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   426
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   427
            return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   428
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   429
    def __loaded__(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   430
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   431
        Get a loaded object if it is existing and increase the reference counter
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   432
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   433
        @return: The loaded object if it exists. None if it does not. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   434
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   435
        if self.loaded.has_key(ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   436
            self.loaded[ref]['counter'] += 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   437
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   438
            raise exceptions.NotFound("ref %s is not found from loaded!" % ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   439
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   440
    def __unloaded__(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   441
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   442
        returns True when the reference count is zero and object can be released.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   443
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   444
        if self.loaded.has_key(ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   445
            self.loaded[ref]['counter'] -= 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   446
            if self.loaded[ref]['counter'] == 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   447
                del self.loaded[ref]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   448
                return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   449
            else: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   450
                return False
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   451
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   452
            # Return False in case the object is loaded at all in this project 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   453
            # increases performance as unloading is not done on unchanged objects
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   454
            return False
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   455
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   456
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   457
        if isinstance(obj, Configuration) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   458
        or isinstance(obj, ConfigurationProxy): 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   459
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   460
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   461
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   462
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   463
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   464
    def update(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   465
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   466
        update the root confml files as configurations
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   467
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   468
        root_confmls = self.get_storage().list_resources(".")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   469
        root_confmls = utils.resourceref.filter_resources(root_confmls, "\.confml")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   470
        for rootml in root_confmls:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   471
            self._add(ConfigurationProxy(rootml))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   472
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   473
    def get_storage(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   474
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   475
        Get the Storage instance of this Project.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   476
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   477
        return self.storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   478
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   479
    def set_storage(self, storage):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   480
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   481
        Set the Storage instance of this Project.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   482
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   483
        if storage != None and not isinstance(storage, Storage):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   484
            raise exceptions.StorageException("The given storage is not a instance of Storage!")
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   485
        self.storage = storage
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   486
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   487
    def list_configurations(self, filter_or_filters=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   488
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   489
        List the direct child objects of the project (Root configurations)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   490
        @param filter_or_filters: A regular expression or list of regular expressions
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   491
            used for filtering the configuration paths. If None, all configurations are
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   492
            returned.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   493
        @return: a list for configuration file paths
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   494
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   495
        filters = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   496
        if isinstance(filter_or_filters, basestring):   filters = [filter_or_filters]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   497
        elif filter_or_filters is not None:             filters = filter_or_filters
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   498
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   499
        configs = [obj.get_path() for obj in self._objects()]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   500
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   501
        if filters is not None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   502
            result = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   503
            for config in configs:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   504
                for filter in filters:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   505
                    if re.match(filter, config) is not None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   506
                        result.append(config)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   507
                        break
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   508
            return result
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   509
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   510
            return configs
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   511
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   512
    def list_all_configurations(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   513
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   514
        List all configuration objects of the project (all configurations)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   515
        @return: a list for configuration file paths
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   516
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   517
        # TODO
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   518
        # huge performance problem 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   519
        return [obj.get_full_path() for obj in self._traverse(type=(Configuration, ConfigurationProxy))]
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   520
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   521
    def get_configuration(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   522
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   523
        Get a configuration object from the given path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   524
        @param path: path to configuration 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   525
        @return: a instance of Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   526
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   527
        # Load the configuration object if it is not already loaded
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   528
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   529
            return self._get(utils.resourceref.to_objref(utils.resourceref.norm(path)))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   530
        except exceptions.NotFound, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   531
            if self.storage.is_resource(utils.resourceref.norm(path)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   532
                proxy = ConfigurationProxy(utils.resourceref.norm(path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   533
                proxy._set_parent(self)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   534
                return proxy
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   535
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   536
                raise e
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   537
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   538
    def is_configuration(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   539
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   540
        Return true if the given path is a configuration object in this Project.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   541
        @param path: path to configuration 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   542
        @return: Boolean return value.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   543
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   544
        # Changed from list_all_configurations to list_configurations
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   545
        # (list_all_configurations causes a insane performance problem with _traverse)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   546
        #
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   547
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   548
            return self.storage.is_resource(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   549
        except exceptions.NotSupportedException:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   550
            return path in self.list_configurations()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   551
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   552
    def add_configuration(self, config, overwrite_existing=False):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   553
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   554
        Add a Configuration object to this project
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   555
        @param config: The configuration object to add
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   556
        @param overwrite_existing: When this is set true any existing configuration is 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   557
        overwritten. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   558
        """ 
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   559
        if isinstance(config, Configuration):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   560
            if not overwrite_existing and self.is_configuration(config.get_path()):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   561
                raise exceptions.AlreadyExists("%s" % config.get_path())
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   562
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   563
            proxy = ConfigurationProxy(config.path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   564
            proxy._set_obj(config)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   565
            self._add(proxy)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   566
            #self._add(config)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   567
            self.__add_loaded__(config.get_path(), config)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   568
            self.__loaded__(config.get_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   569
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   570
            raise exceptions.IncorrectClassError("Only Configuration instance can be added to Project!")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   571
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   572
    def create_configuration(self, path, overwrite_existing=False, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   573
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   574
        Create a Configuration object to this project
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   575
        @param path: The path of the new configuration file
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   576
        @param overwrite_existing: When this is set true any existing configuration is 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   577
        overwritten. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   578
        @param **kwargs: normal keyword arguments that are passed on to the newly 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   579
        created Configuration object. See Configuration object constructor description on what
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   580
        you can pass on here.  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   581
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   582
        config = self.get_configuration_class()(utils.resourceref.norm(path), **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   583
        self.add_configuration(config, overwrite_existing)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   584
        return config
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   585
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   586
    def remove_configuration(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   587
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   588
        Remove a Configuration by its reference
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   589
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   590
        # remove configuration as an object and try to remove it from the storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   591
        self._remove(utils.resourceref.to_objref(path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   592
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   593
            self.storage.delete_resource(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   594
        except exceptions.NotSupportedException:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   595
            pass
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   596
        return
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   597
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   598
    def import_configuration(self, configuration):  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   599
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   600
        Import a configuration object from another storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   601
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   602
        self.storage.import_resources(configuration.list_resources(), configuration.get_storage())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   603
        return
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   604
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   605
    def export_configuration(self, configuration, export_storage, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   606
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   607
        Export a configuration object to another storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   608
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   609
        # First clone the configuration and then import the rest of the configuration resources
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   610
        if isinstance(configuration, ConfigurationProxy):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   611
            configuration = configuration._get_obj()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   612
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   613
        export_storage.unload(configuration.get_full_path(),configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   614
        for child in configuration._traverse(type=Configuration):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   615
            export_storage.unload(child.get_full_path(),child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   616
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   617
        #If the configuration is not in the root of the project adding the path 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   618
        #to final exporting source path.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   619
        #l = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   620
        cpath = utils.resourceref.get_path(configuration.get_path()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   621
        resr = [utils.resourceref.join_refs([cpath,related]) \
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   622
                for related in configuration.get_layer().list_all_related(**kwargs)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   623
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   624
        self.storage.export_resources(resr ,export_storage, kwargs.get("empty_folders", False))
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   625
        return
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   626
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   627
    def get_configuration_class(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   628
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   629
        return the default configuration class that is used with the model. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   630
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   631
        return utils.get_class(self._model, Configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   632
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   633
    def save(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   634
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   635
        Save the object to the permanent Storage object. Calls the save operation for 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   636
        all the children and also for the Storage.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   637
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   638
        for child in self._objects():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   639
            if isinstance(child, (Configuration, ConfigurationProxy)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   640
                child.save()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   641
        self.storage.save()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   642
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   643
    def close(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   644
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   645
        Close the Project.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   646
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   647
        for child in self._objects():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   648
            if isinstance(child, (Configuration, ConfigurationProxy)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   649
                child.close()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   650
        self.storage.close()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   651
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   652
    def load(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   653
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   654
        Load an object from a reference. The given reference is loaded once from storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   655
        and stored as a loaded object to the Project. Sequential loads to the same ref will
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   656
        return the same object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   657
        @param path: The reference where to load the object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   658
        @raise StorageException: if the given object cannot be loaded as an 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   659
        object from this storage 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   660
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   661
        if not self.__get_loaded__(path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   662
            configuration = self.get_storage().load(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   663
            if configuration.get_ref() == 'unknown':
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   664
                configuration.set_ref(utils.resourceref.to_dref(path))
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   665
            self.__add_loaded__(path, configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   666
        """ increase the ref counter """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   667
        self.__loaded__(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   668
        return self.__get_loaded__(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   669
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   670
    def unload(self, path, object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   671
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   672
        Release the given ref, which decreases the reference counter of the given ref.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   673
        @param path: The reference where to store the object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   674
        @param object: The object instance to dump 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   675
        @raise StorageException: if the given object cannot be dumped to this storage 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   676
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   677
        if self.__unloaded__(path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   678
            self.get_storage().unload(path, object)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   679
            # remove the configuration from this this project, 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   680
            # with proxy set the _obj reference to None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   681
            try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   682
                conf =  self.get_configuration(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   683
                if isinstance(conf, ConfigurationProxy):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   684
                    conf._set_obj(None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   685
            except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   686
                # if the configuration is not found at all then ignore the resetting
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   687
                pass
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   688
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   689
    def get_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   690
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   691
        Return the path of the project, which is always root
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   692
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   693
        return ""
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   694
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   695
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   696
class CompositeConfiguration(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   697
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   698
    A base class for composite Configuration objects.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   699
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   700
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   701
#        self.meta       = {}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   702
#        self.desc       = ""
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   703
        super(CompositeConfiguration, self).__init__(ref, **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   704
        self.container = True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   705
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   706
    def _configuration_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   707
        return Configuration
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   708
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   709
    def add_configuration(self, config):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   710
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   711
        Add an existing Configuration to this configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   712
        @param config: A Configuration instance:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   713
        @return: None 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   714
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   715
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   716
        Merge the default view features from added config to this configs _default_view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   717
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   718
        # if the Configuration has a separate resource path, add it automatically behind proxy 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   719
        if utils.resourceref.is_path(config.path) and isinstance(config, Configuration):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   720
            proxy = ConfigurationProxy(config.path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   721
            proxy._set_obj(config)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   722
            self._add(proxy)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   723
            # Add the new configuration to the list of "modified/loaded" configurations
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   724
            try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   725
                prj = self.get_project()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   726
                prj.__add_loaded__(config.get_full_path(), config)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   727
                prj.__loaded__(config.get_full_path())
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   728
            except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   729
                # if the parent is not found this configuration is not (yet) a part of project and cant be stored 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   730
                pass
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   731
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   732
            self._add(config)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   733
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   734
    def include_configuration(self, configref, policy=0):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   735
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   736
        Add an existing Configuration to this configuration by its resource reference
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   737
        @param config: A Configuration instance:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   738
        @return: None 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   739
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   740
        # add the configuration load proxy to this configuration instead 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   741
        # adding the configuration directly
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   742
        self._add(ConfigurationProxy(configref), policy)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   743
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   744
    def create_configuration(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   745
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   746
        Create a new configuration by its name to the Configuration. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   747
        1. Create new Configuration object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   748
        2. Create new ConfigurationProxy 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   749
        3. Add proxy to this object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   750
        4. Set proxy to point to the created Configuration object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   751
        @param path: The reference of the configuration to create
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   752
        @return: The new configuration object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   753
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   754
        # normalise the path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   755
        normpath = utils.resourceref.norm(path)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   756
        cklass = self._configuration_class()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   757
        conf = cklass(normpath, namespace=self.namespace)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   758
        self.add_configuration(conf)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   759
        return conf
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   760
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   761
    def remove_configuration(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   762
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   763
        Remove a Layer object from the Configuration by its reference.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   764
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   765
        self._remove(utils.resourceref.to_objref(path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   766
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   767
    def list_configurations(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   768
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   769
        List all Layer objects in the Configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   770
        @return: a copy array of layer references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   771
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   772
        return [config.get_path() for config in self._objects(type=(Configuration, ConfigurationProxy))] 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   773
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   774
    def list_all_configurations(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   775
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   776
        List all Layer objects in the Configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   777
        @return: a copy array of layer references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   778
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   779
        return [config.get_path_for_parent(self) for config in self._traverse(type=(Configuration, ConfigurationProxy))] 
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   780
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   781
    def get_configuration(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   782
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   783
        Get a Layer object by if path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   784
        @return: a Layer object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   785
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   786
        return self._get(utils.resourceref.to_objref(path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   787
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   788
    def get_configuration_by_index(self, index):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   789
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   790
        Get a Layer object by if indexing number
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   791
        @return: a Layer object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   792
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   793
        configs = self._objects(type=(Configuration, ConfigurationProxy))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   794
        return configs[index]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   795
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   796
    def get_last_configuration(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   797
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   798
        Get the last Layer object from this configuration hierarchy.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   799
        @return: a Layer object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   800
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   801
        last_config = self
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   802
        try: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   803
            last_config = last_config.get_configuration_by_index(-1)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   804
            return last_config.get_last_configuration()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   805
        except IndexError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   806
            return self 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   807
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   808
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   809
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   810
        A generic add function to add child objects. The function is intended to act as
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   811
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   812
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   813
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   814
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   815
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   816
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   817
        if isinstance(child, Configuration):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   818
            self.add_configuration(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   819
        elif isinstance(child, ConfigurationProxy):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   820
            self._add(child)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   821
        elif isinstance(child, Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   822
            self._add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   823
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   824
            raise exceptions.IncorrectClassError("Cannot add %s to %s" % (child, self))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   825
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   826
    def layered_resources(self, layers=None, empty_folders=False, folder=None, resource_type=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   827
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   828
        Fetch resource paths by layers so that if a resource with the same name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   829
        exists on multiple layers, the one on the latest layer is the active one.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   830
        @param layers: List of layer indices to specify the layer to use, None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   831
            for all layers.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   832
        @param empty_folders: If True, empty folders are returned also.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   833
        @param folder: Name of a specific folder from which to get resources, or None.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   834
            If None, resource_type must be specified.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   835
        @param resource_type: Type of the resources to find. Must be one of
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   836
            ('confml', 'implml', 'content', 'doc') or None.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   837
            If None, folder must be specified.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   838
        @return: A container.DataContainer instance containing the resource paths.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   839
            For example: {'foo.txt': ['layer1/content/foo.txt',
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   840
                                      'layer2/content/foo.txt'],
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   841
                          'bar.txt': ['layer1/content/bar.txt']}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   842
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   843
        MAPPING = {'confml':    lambda layer: layer.confml_folder(),
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   844
                   'implml':    lambda layer: layer.implml_folder(),
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   845
                   'content':   lambda layer: layer.content_folder(),
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   846
                   'doc':       lambda layer: layer.doc_folder()}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   847
        if resource_type is not None and resource_type not in MAPPING:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   848
            raise ValueError("Invalid resource type %r, should be one of %r" % (resource_type, MAPPING.keys()))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   849
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   850
        if folder and resource_type:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   851
            raise ValueError('Only one of folder and resource_type must be specified!')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   852
        if not folder and not resource_type:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   853
            raise ValueError('Either folder or resource_type must be specified!')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   854
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   855
        configuration_array = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   856
        if layers == None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   857
            configuration_array = self.list_configurations()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   858
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   859
            all = self.list_configurations()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   860
            for i in layers:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   861
                configuration_array.append(all[i])
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   862
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   863
        # Add the current configuration as the last one in the list, in case
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   864
        # the current configuration happens to be a layer root itself
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   865
        configuration_array.append('')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   866
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   867
        # Set up the get_folder function based on the parameters
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   868
        if resource_type:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   869
            get_folder = MAPPING[resource_type]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   870
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   871
            def get_folder(layer):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   872
                cpath = layer.get_current_path()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   873
                return Folder(layer.storage, utils.resourceref.join_refs([cpath, folder]))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   874
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   875
        result = container.DataContainer()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   876
        for configuration_path in configuration_array:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   877
            folder_obj = get_folder(self.get_configuration(configuration_path).get_layer())
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   878
            folder_path = folder_obj.get_current_path()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   879
            for res_path in folder_obj.list_resources("", recurse=True, empty_folders=empty_folders):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   880
                if res_path == '': continue # ZipStorage sometimes returns empty paths
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   881
                res_fullpath = utils.resourceref.join_refs([folder_path, res_path])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   882
                result.add_value(res_path, res_fullpath)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   883
        return result
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   884
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   885
    def layered_confml(self, layers=None, empty_folders=False):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   886
        return self.layered_resources(layers, empty_folders, resource_type='confml')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   887
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   888
    def layered_implml(self, layers=None, empty_folders=False):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   889
        return self.layered_resources(layers, empty_folders, resource_type='implml')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   890
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   891
    def layered_content(self, layers=None, empty_folders=False):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   892
        return self.layered_resources(layers, empty_folders, resource_type='content')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   893
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   894
    def layered_doc(self, layers=None, empty_folders=False):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   895
        return self.layered_resources(layers, empty_folders, resource_type='doc')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   896
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   897
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   898
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   899
class Configuration(CompositeConfiguration):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   900
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   901
    A Configuration is a container that can hold several Layer objects.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   902
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   903
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   904
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   905
        self.path = kwargs.get('path') or ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   906
        self.namespace = kwargs.get('namespace', '')
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   907
        self.name = kwargs.get('name',utils.resourceref.to_objref(self.path))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   908
        self.version = kwargs.get('version')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   909
        super(Configuration, self).__init__(utils.resourceref.to_objref(self.path), **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   910
        self.container = True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   911
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   912
    def _default_object(self, name):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   913
        return self._default_class()(name)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   914
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   915
    def _default_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   916
        return self._feature_class()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   917
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   918
    def _feature_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   919
        return Feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   920
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   921
    def _view_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   922
        return View
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   923
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   924
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   925
        if isinstance(obj, Configuration) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   926
        or isinstance(obj, Feature) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   927
        or isinstance(obj, Data) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   928
        or isinstance(obj, ConfigurationProxy) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   929
        or isinstance(obj, View) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   930
        or isinstance(obj, Base): 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   931
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   932
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   933
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   934
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   935
    def _dict(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   936
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   937
        Return the public variables in a dictionary
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   938
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   939
        dict = super(Configuration, self)._dict(**kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   940
        dict['namespace'] = self.namespace
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   941
        return dict
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   942
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   943
    def get_name(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   944
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   945
        Return the name of the configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   946
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   947
        return self.name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   948
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   949
    def set_name(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   950
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   951
        Set the name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   952
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   953
        self.name = name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   954
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   955
    def get_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   956
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   957
        Return the path of the configuration resource
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   958
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   959
        return self.path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   960
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   961
    def set_path(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   962
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   963
        Set the path of the configuration resource, and update the name and ref to correspond
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   964
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   965
        self.path = path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   966
        self.set_ref(utils.resourceref.to_objref(self.path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   967
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   968
    def get_full_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   969
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   970
        Return the path of the configuration resource
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   971
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   972
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   973
            parentconfig = self._find_parent(type=Configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   974
            parent_path = utils.resourceref.get_path(parentconfig.get_path()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   975
        except exceptions.NotFound:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   976
            parent_path = ""
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   977
        return utils.resourceref.join_refs([parent_path, self.path])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   978
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   979
    def get_path_for_parent(self, parent):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   980
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   981
        Return the path to this configuration for a defined parent Configuration object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   982
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   983
        parent_path = ""
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   984
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   985
            parentconfig = self._find_parent(type=Configuration)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   986
            if parent != parentconfig:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   987
                parent_path = utils.resourceref.get_path(parentconfig.get_path_for_parent(parent)) 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   988
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   989
            pass
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   990
        return utils.resourceref.join_refs([parent_path, self.path])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   991
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   992
    def get_layer(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   993
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   994
        Get the layer object where this Configuration is located. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   995
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   996
        if not hasattr(self, "layer"):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   997
            layerpath = utils.resourceref.get_path(self.get_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   998
            # hardcoded removal of confml folder from the layer path it is there
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   999
            layerpath = utils.resourceref.remove_end(layerpath, '/confml')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1000
            self.layer = Layer(self.get_storage(), layerpath)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1001
            """ Add the sublayers to this layer if they are different from this configuration """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1002
            for configpath in self.list_configurations():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1003
                sublayer_path = utils.resourceref.get_path(self.get_configuration(configpath).get_full_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1004
                sublayer_path = utils.resourceref.remove_end(sublayer_path, '/confml')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1005
                if sublayer_path != utils.resourceref.get_path(self.get_path()):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1006
                    self.layer.add_layer(self.get_configuration(configpath).get_layer())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1007
        return self.layer
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1008
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1009
    def set_namespace(self, namespace):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1010
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1011
        @param namespace: The new namespace of the object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1012
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1013
        self._namespace =  namespace
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1014
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1015
    def get_namespace(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1016
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1017
        @return: The reference of the object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1018
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1019
        return self._namespace
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1020
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1021
    def del_namespace(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1022
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1023
        @return: The reference of the object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1024
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1025
        self._namespace = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1026
    namespace = property(get_namespace, set_namespace, del_namespace)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1027
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1028
    def list_resources(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1029
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1030
        List all resources used in this configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1031
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1032
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1033
        1. First ensure that all configuration resource files are added 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1034
        2. Then add all layer resources 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1035
        3. Make the list distinct
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1036
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1037
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1038
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1039
        resources = [self.get_full_path()]
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1040
        for config in self._traverse(type=(Configuration,ConfigurationProxy)):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1041
            resources.append(config.get_full_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1042
        layer = self.get_layer()
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1043
        for resref in layer.list_all_resources():
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1044
            resources.append(utils.resourceref.join_refs([layer.get_current_path(), resref]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1045
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1046
        return utils.distinct_array(resources)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1047
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1048
    def get_resource(self, ref, mode="r"):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1049
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1050
        Get the given resource as a Resource object. The resource is searched relative to the 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1051
        Configuration path, e.g. Configuration('test/foo/root.confml') => searches from 'test/foo'.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1052
        @param ref: the reference path to the requested resource
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1053
        @return: a instance of Resource. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1054
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1055
        mypath = utils.resourceref.get_path(self.path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1056
        myref = utils.resourceref.join_refs([mypath, ref])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1057
        return self.get_storage().open_resource(myref, mode)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1058
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1059
    def get_all_resources(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1060
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1061
        Get all resources in resource list of Resource objects
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1062
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1063
        resources = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1064
        res_list = self.list_resources()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1065
        for res in res_list:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1066
            resources.append(self.get_storage().open_resource(res))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1067
        return resources
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1068
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1069
    def get_root_resource(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1070
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1071
        Get the configuration reference resource.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1072
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1073
        return self.get_storage().open_resource(self.get_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1074
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1075
    def get_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1076
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1077
        Get a feature object by its reference.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1078
        @param ref: The reference to the feature object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1079
        @return: A Feature object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1080
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1081
        return self._get(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1082
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1083
    def create_feature(self, ref, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1084
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1085
        Create a feature object to the configuration.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1086
        @param ref: The ref for the Feature object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1087
        @param **kwargs: keyword arguments  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1088
        e.g. to add fea2 under fea1 add_feature(fea2, 'fea1')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1089
        @return: the new feature object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1090
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1091
        fea = self._feature_class()(ref, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1092
        self._add(fea)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1093
        return fea
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1094
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1095
    def add_feature(self, feature, namespace=""):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1096
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1097
        Add a feature object to the configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1098
        @param feature: The Feature object to add.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1099
        @param namespace: The sub namespace for the feature. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1100
        e.g. to add fea2 under fea1 add_feature(fea2, 'fea1')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1101
        @return: None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1102
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1103
        if namespace and self._has(namespace):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1104
            # Add the feature directly with an existing feature's add_feature functionality
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1105
            self.get_feature(namespace).add_feature(feature)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1106
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1107
            self._add_to_path(namespace, feature)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1108
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1109
    def remove_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1110
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1111
        remove feature by its reference
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1112
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1113
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1114
        self._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1115
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1116
    def list_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1117
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1118
        List immediate features found under the this configuration (the top nodes). 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1119
        The features are also available via the _default_view of the configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1120
        @return: a list of feature references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1121
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1122
        return [fea.get_ref() for fea in self._objects(type=Feature)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1123
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1124
    def list_all_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1125
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1126
        List all features found under the this configuration. The features are also 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1127
        available via the _default_view of the configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1128
        @return: a list of feature references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1129
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1130
        return [fea.fqr for fea in self._traverse(type=Feature)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1131
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1132
    def add_data(self, data, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1133
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1134
        Add a data object to this configuration object.
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1135
        @param data: The Data object or list of Data objects to add.
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1136
        @return: None
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1137
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1138
        data_objs = utils.get_list(data)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1139
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1140
        if policy == container.PREPEND:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1141
            data_objs = reversed(data_objs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1142
            policy_first = container.PREPEND
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1143
            policy_rest = container.PREPEND
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1144
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1145
            policy_first = policy
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1146
            policy_rest = container.APPEND
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1147
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1148
        for i, data_obj in enumerate(data_objs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1149
            if not self._has(data_obj.attr):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1150
                self._add(DataContainer(data_obj.attr, container=True))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1151
            (namespace, name) = utils.dottedref.psplit_ref(data_obj.get_fearef())
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1152
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1153
            if i == 0:  p = policy_first
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1154
            else:       p = policy_rest
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1155
            self._get(data_obj.attr)._add_to_path(namespace, data_obj, p)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1156
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1157
    def get_data(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1158
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1159
        Get a data object by its reference.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1160
        @param ref: The reference to the data object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1161
        @return: A Data object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1162
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1163
        return self.data._get(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1164
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1165
    def remove_data(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1166
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1167
        remove feature by its reference
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1168
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1169
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1170
        self.data._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1171
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1172
    def list_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1173
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1174
        List all datas found under the this configuration. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1175
        @return: a list of Data references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1176
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1177
        if self._has('data'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1178
            return [dataelem.fqr for dataelem in self.data._objects(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1179
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1180
            return []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1181
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1182
    def get_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1183
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1184
        List immediate datas found under the this configuration (the top nodes). 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1185
        @return: a list of Data references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1186
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1187
        if self._has('data'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1188
            return [dataelem for dataelem in self.data._objects(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1189
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1190
            return []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1191
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1192
    def list_all_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1193
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1194
        List all Data elements found under the this configuration (or subconfigurations). 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1195
        @return: a list of Data references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1196
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1197
        return [dataelem.fqr for dataelem in self._traverse(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1198
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1199
    def get_all_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1200
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1201
        List all Data elements found under the this configuration (or subconfigurations). 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1202
        @return: a list of Data references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1203
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1204
        return [dataelem for dataelem in self._traverse(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1205
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1206
    def list_leaf_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1207
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1208
        List all leaf Data elements (i.e. actually modified settings) found under this configuration (or subconfigurations). 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1209
        @return: A list of Data references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1210
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1211
        return [dataelem.fqr for dataelem in self._find_leaves(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1212
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1213
    def get_leaf_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1214
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1215
        Get all leaf Data elements (i.e. actually modified settings) found under this configuration (or subconfigurations). 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1216
        @return: A list of Data objects. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1217
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1218
        return [dataelem for dataelem in self._find_leaves(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1219
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1220
    def get_view(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1221
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1222
        Get a view object by its reference.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1223
        @param ref: The reference to the view object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1224
        @return: A View object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1225
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1226
        # Populate the view object before returning it
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1227
        view = self._get(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1228
        view.populate()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1229
        return view
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1230
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1231
    def create_view(self, viewname):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1232
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1233
        Create a view object to the configuration.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1234
        @param viewname: The name of the view to add. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1235
        @return: view object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1236
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1237
        viewobj = self._view_class()(viewname)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1238
        self.add_view(viewobj)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1239
        return viewobj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1240
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1241
    def add_view(self, viewobj):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1242
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1243
        Add a view object to the configuration.
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1244
        @param viewobj: The existing view object to add. 
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1245
        @return: None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1246
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1247
        assert(isinstance(viewobj, View))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1248
        return self._add(viewobj)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1249
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1250
    def remove_view(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1251
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1252
        Remove a view object from the configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1253
        @param ref: The reference to the View. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1254
        @return: None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1255
        @raise NotFound: when view is not found.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1256
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1257
        return self._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1258
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1259
    def list_views(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1260
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1261
        List all views found under the this configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1262
        @return: a list of view references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1263
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1264
        return [view._path(self) for view in self._traverse(type=View)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1265
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1266
    def save(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1267
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1268
        Save the object to the permanent Storage object. Calls the save operation of 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1269
        all the children.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1270
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1271
        # Change the recursion order so that the current object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1272
        # is saved first and then its childen.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1273
        # This increases performance in cases where this object requires information about its childen (no unload -> load cases)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1274
        self.get_project().unload(self.get_full_path(), self)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1275
        for child in self._objects():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1276
            if isinstance(child, (Configuration,ConfigurationProxy)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1277
                child.save()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1278
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1279
    def close(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1280
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1281
        Close the configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1282
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1283
        for child in self._objects():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1284
            if isinstance(child, (Configuration, ConfigurationProxy)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1285
                child.close()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1286
#        if self.get_full_path() != "":
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1287
#            self.get_project().unload(self.get_full_path(), self)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1288
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1289
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1290
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1291
        A generic add function to add child objects. The function is intended to act as
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1292
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1293
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1294
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1295
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1296
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1297
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1298
        if isinstance(child, Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1299
            self.add_feature(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1300
        elif isinstance(child, View):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1301
            self._add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1302
        elif isinstance(child, (Data)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1303
            self.add_data(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1304
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1305
            super(Configuration, self).add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1306
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1307
    def get_default_view(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1308
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1309
        Get the default view from this configuration hierarchy.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1310
        This returns always the view from the Root configuration point of view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1311
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1312
        try:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1313
            parent = self._find_parent_or_default()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1314
            if parent and isinstance(parent, Configuration):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1315
                return parent.get_default_view()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1316
            else:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1317
                if not self._has('?default_view'):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1318
                    self._create_default_view()
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1319
                return self._get('?default_view')
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1320
        except exceptions.NotFound, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1321
            raise e
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1322
        # raise exceptions.NotFound("Default View is not found! No root configuration?")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1323
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1324
    def recreate_default_view(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1325
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1326
            parent = self._find_parent_or_default() 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1327
            if parent and isinstance(parent, Configuration):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1328
                parent.recreate_default_view()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1329
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1330
                self._create_default_view()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1331
        except exceptions.NotFound, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1332
            raise e
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1333
        # raise exceptions.NotFound("Default View is not found! No root configuration?")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1334
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1335
    def _create_default_view(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1336
        # Rebuild the default view for this Configuration
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1337
        default_view = View("?default_view", data=True)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1338
        #self._default_view._parent= self
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1339
        self._add(default_view)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1340
        # First add all features of the configuration to the view. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1341
        # Then add all data elements under the features
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1342
        for child in self._traverse(type=Feature):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1343
            # TODO print "Adding : %s -> %s" % (child.namespace, child)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1344
            default_view.add_feature(child, child.namespace)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1345
        for child in self._traverse(type=Data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1346
            #parent_config = child._find_parent_or_default(type=Configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1347
            #print "Adding data %s: fqr: %s from file %s." % (child.get_value(), child.fqr, parent_config.get_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1348
            try:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1349
                fea = default_view.get_feature(child.fqr)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1350
                fea.add_data(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1351
            except exceptions.NotFound, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1352
                data_parent_config = child._find_parent_or_default(type=Configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1353
                logging.getLogger('cone').info("Warning: Feature '%s' for data in %s not found." % (child.fqr, data_parent_config.get_path()))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1354
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1355
class ConfigurationProxy(container.LoadProxy):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1356
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1357
    Configuration loading proxy. Loads the configuration from the given reference, when needed.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1358
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1359
    def __init__(self, path, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1360
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1361
        The ConfigurationProxy that represents a configuration that is included in another configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1362
        @param ref: the reference to the storage resource 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1363
        The ConfigurationProxy trust to get the store_interface from the parent object with get_storage() function.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1364
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1365
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1366
        super(ConfigurationProxy,self).__init__(path, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1367
        self.set('_name', utils.resourceref.to_objref(path))
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1368
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1369
    def _clone(self, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1370
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1371
        A ConfigurationProxy specific implementation for cloning.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1372
        Copies all (public) members in dictionary.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1373
        To clone call the actual object that is proxied as well if the reqursion is on.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1374
        @param recursion: Boolean to define recursion on or off
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1375
        @param recursion_depth: positive integer to define recursion depth. default is -1 which will 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1376
        perform recursion to all objects.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1377
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1378
        dict = self._dict()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1379
        obj = self.__class__(**dict)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1380
        # handle the recursion argument
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1381
        recursion = kwargs.get('recursion', False)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1382
        if recursion:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1383
            recursion_depth = kwargs.get('recursion_depth', -1)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1384
            if recursion_depth < 0 or recursion_depth > 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1385
                # decrease the recursion
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1386
                kwargs['recursion_depth'] = recursion_depth - 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1387
                newobj = self._get_obj()._clone(**kwargs) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1388
                obj._set_obj(newobj)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1389
        return obj
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1390
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1391
    def _dict(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1392
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1393
        Return the public variables in a dictionary
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1394
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1395
        dict = {}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1396
        for key in self.__dict__.keys():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1397
            if key.startswith('_'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1398
                continue
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1399
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1400
                dict[key] = self.__dict__[key]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1401
        return dict
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1402
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1403
    def _get_mapper(self,modelname):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1404
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1405
        Return a instance of appropriate mapper for given model.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1406
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1407
        return mapping.BaseMapper()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1408
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1409
class Group(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1410
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1411
    A Group class. Group is used in View to group up other Group/Feature objects.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1412
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1413
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1414
        super(Group, self).__init__(ref, **kwargs)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1415
        self.name = kwargs.get('name', ref)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1416
        self.support_data = kwargs.get("data", False)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1417
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1418
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1419
        if isinstance(obj, (Group, \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1420
                           Base, \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1421
                           _FeatureProxy, \
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1422
                           FeatureLink, \
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1423
                           ConfigurationProxy)): 
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1424
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1425
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1426
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1427
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1428
    def _default_object(self, name):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1429
        return self._group_class()(name)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1430
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1431
    def _group_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1432
        return Group
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1433
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1434
    def _featurelink_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1435
        return FeatureLink
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1436
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1437
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1438
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1439
        A generic add function to add child objects. The function is intended to act as
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1440
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1441
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1442
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1443
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1444
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1445
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1446
        if self._supported_type(child):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1447
            self._add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1448
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1449
            raise exceptions.IncorrectClassError("Cannot add %s to %s" % (child, self))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1450
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1451
    def get_name(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1452
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1453
        Return the name of the configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1454
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1455
        return self.name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1456
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1457
    def set_name(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1458
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1459
        Set the name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1460
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1461
        self.name = name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1462
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1463
    def create_featurelink(self, feature_ref, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1464
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1465
        create a feature link object to this element, with the given ref
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1466
        @param feature_ref: the reference for the featurelink which should
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1467
        point to a exising feature in the configuration.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1468
        @param **kwargs: keyword arguments are passed to the featurelink object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1469
        directly.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1470
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1471
        fealink = self._featurelink_class()(feature_ref, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1472
        self.add(fealink)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1473
        return fealink
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1474
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1475
    def get_featurelink(self, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1476
        return self._get(FeatureLink.get_featurelink_ref(ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1477
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1478
    def add_feature(self, feature, path=""):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1479
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1480
        Add feature to this Group.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1481
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1482
        if not isinstance(feature, Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1483
            raise exceptions.IncorrectClassError("add_feature requires instance of Feature!! Given %s" % feature)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1484
        if not self.support_data:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1485
            self._add_to_path(path, _FeatureProxy(feature._name, feature))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1486
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1487
            self._add_to_path(path, _FeatureDataProxy(feature._name, feature))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1488
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1489
    def remove_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1490
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1491
        remove a given feature from this view by reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1492
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1493
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1494
        self._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1495
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1496
    def get_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1497
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1498
        @param path: The path (ref) to the given feature 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1499
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1500
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1501
            return self._get(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1502
        except exceptions.NotFound:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1503
            raise exceptions.NotFound("Feature '%s' not found." % ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1504
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1505
    def get_features(self, refs, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1506
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1507
        Get a list of features that match the ref. 
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1508
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1509
        @param refs: The paths (refs) to the given feature or xpath like expression. The refs
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1510
        argument can be a single reference or a list of references to features. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1511
        @return: A list of features.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1512
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1513
        NOTE! the invalid references will not raise an exception.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1514
         
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1515
        Example1: get_features('foo.bar') would be the same as get_feature('foo.bar'), but this returns 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1516
        always a list [<Feature>].
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1517
        Example2: get_features('foo.*') would try to retrieve a list of all foo children.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1518
        Example3: get_features('foo.*', type='') would try to retrieve a list of all foo children, 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1519
        that have a defined type.
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1520
        Example4: get_features(['foo','bar.set1']) would try to retrieve a foo and then bar.set1.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1521
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1522
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1523
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1524
        if utils.is_list(refs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1525
            features = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1526
            for ref in refs:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1527
                features += self.get_matching_features(ref, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1528
            return features
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1529
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1530
            return self.get_matching_features(refs, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1531
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1532
    def get_matching_features(self, ref, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1533
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1534
        Get a list of features that match the ref. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1535
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1536
        @param refs: The paths (refs) to the given feature or xpath like expression. The refs
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1537
        argument can be a single reference or a list of references to features. 
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1538
        @return: A list of features.
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1539
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1540
        NOTE! the invalid references will not raise an exception but return an empty list.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1541
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1542
        Example1: get_features('foo.bar') would be the same as get_feature('foo.bar'), but this returns 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1543
        always a list [<Feature>].
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1544
        Example2: get_features('foo.*') would try to retrieve a list of all foo children.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1545
        Example3: get_features('foo.*', type='') would try to retrieve a list of all foo children, 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1546
        that have a defined type.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1547
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1548
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1549
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1550
            (startref, last) = utils.dottedref.psplit_ref(ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1551
            startelem = self._get(startref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1552
            kwargs['type'] = _FeatureProxy
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1553
            if last == '**':
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1554
                return [fea for fea in startelem._traverse(**kwargs)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1555
            elif last == '*':
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1556
                return [fea for fea in startelem._objects(**kwargs)] 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1557
            elif ref != "":
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1558
                return [self._get(ref)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1559
            else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1560
                return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1561
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1562
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1563
         
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1564
    def list_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1565
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1566
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1567
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1568
        return [fea.get_ref() for fea in self._objects(type=(_FeatureProxy))]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1569
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1570
    def list_all_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1571
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1572
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1573
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1574
        return [fea.fqr for fea in self._traverse(type=(_FeatureProxy))]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1575
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1576
    def create_group(self, groupname, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1577
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1578
        create a group object to this element with given group name.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1579
        @param groupname: the name for the new group
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1580
        @param **kwargs: keyword arguments are passed on to the new group object.  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1581
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1582
        grp = self._group_class()(groupname, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1583
        self.add_group(grp)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1584
        return grp
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1585
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1586
    def add_group(self, grp):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1587
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1588
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1589
        self._add(grp)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1590
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1591
    def remove_group(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1592
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1593
        remove a given feature from this view by reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1594
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1595
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1596
        self._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1597
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1598
    def get_group(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1599
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1600
        @param path: The path (ref) to the given feature 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1601
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1602
        return self._get(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1603
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1604
    def list_groups(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1605
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1606
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1607
        return [group.ref for group in self._objects(type=Group)]
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1608
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1609
    def populate(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1610
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1611
        Populate or fetch the link to the actual feature for this featureproxy.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1612
        This method fetches the feature to the _obj member variable and populates also 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1613
        subfeatures. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1614
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1615
        for child in self._traverse(type=FeatureLink):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1616
            child.populate()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1617
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1618
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1619
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1620
class View(Group):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1621
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1622
    A View class. View is intended to create new or different hierarchies of existing features. A View can contain Group and/or Feature objects.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1623
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1624
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1625
        super(View, self).__init__(self.to_ref(ref), **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1626
        self.container = True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1627
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1628
    @classmethod
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1629
    def to_ref(cls, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1630
        """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1631
        return a view reference converted from name 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1632
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1633
        return ref.replace('.', '').replace('/', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1634
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1635
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1636
class Feature(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1637
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1638
    A Feature class. Feature is the base for all Configurable items in a Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1639
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1640
    PROPERTIES = ['value']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1641
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1642
        super(Feature, self).__init__(ref, **kwargs)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1643
        self.name = kwargs.get('name', None)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1644
        self.type = kwargs.get('type', None)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1645
        self.relevant = kwargs.get('relevant', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1646
        self.constraint = kwargs.get('constraint', None)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1647
        self._dataproxy = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1648
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1649
    def __copy__(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1650
        dict = {}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1651
        for key in self.__dict__.keys():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1652
            if key.startswith('_') or key == 'ref':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1653
                continue
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1654
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1655
                dict[key] = self.__dict__[key]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1656
        fea = self.__class__(self.ref, **dict)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1657
        return fea
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1658
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1659
    def __getstate__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1660
        state = super(Feature, self).__getstate__()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1661
        # remove the dataproxy value so that it is not stored in serializings
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1662
        state.pop('_dataproxy', None)
4
0951727b8815 Updated to 1.2.13 release
m2lahtel
parents: 3
diff changeset
  1663
        # remove instancemethods so that those are not stored in serializings
0951727b8815 Updated to 1.2.13 release
m2lahtel
parents: 3
diff changeset
  1664
        state.pop('get_original_value', None)
0951727b8815 Updated to 1.2.13 release
m2lahtel
parents: 3
diff changeset
  1665
        state.pop('get_value', None)
0951727b8815 Updated to 1.2.13 release
m2lahtel
parents: 3
diff changeset
  1666
        state.pop('set_value', None)
0951727b8815 Updated to 1.2.13 release
m2lahtel
parents: 3
diff changeset
  1667
        state.pop('add_feature', None)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1668
        return state
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1669
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1670
    def __setstate__(self, state):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1671
        super(Feature, self).__setstate__(state)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1672
        self._dataproxy = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1673
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1674
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1675
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1676
        # For now support added for desc element via support for Base
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1677
        if isinstance(obj, (Feature, Option, Base)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1678
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1679
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1680
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1681
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1682
    def _feature_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1683
        return Feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1684
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1685
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1686
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1687
        A generic add function to add child objects. The function is intended to act as
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1688
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1689
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1690
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1691
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1692
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1693
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1694
        if isinstance(child, Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1695
            self.add_feature(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1696
        elif isinstance(child, Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1697
            self._add(child, policy)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1698
        elif isinstance(child, Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1699
            self._add(child, policy)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1700
        elif isinstance(child, Property):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1701
            self._add(child, policy)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1702
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1703
            raise exceptions.IncorrectClassError("Cannot add %s to %s" % (child, self))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1704
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1705
    def get_name(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1706
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1707
        Return the name of the configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1708
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1709
        return self.name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1710
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1711
    def set_name(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1712
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1713
        Set the name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1714
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1715
        self.name = name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1716
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1717
    def get_relevant(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1718
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1719
        Return the relevant attribute of the feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1720
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1721
        return self.relevant
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1722
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1723
    def set_relevant(self, relevant):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1724
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1725
        Set the relevant attribute
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1726
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1727
        self.relevant = relevant
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1728
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1729
    def get_constraint(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1730
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1731
        Return the constraint attribute of the feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1732
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1733
        return self.constraint
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1734
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1735
    def set_constraint(self, constraint):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1736
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1737
        Set the constraint attribute
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1738
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1739
        self.constraint = constraint
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1740
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1741
    def get_type(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1742
        return self.type
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1743
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1744
    def set_type(self, type):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1745
        self.type = type
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1746
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1747
    def create_feature(self, ref, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1748
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1749
        Create a feature object to the configuration.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1750
        @param ref: The ref for the Feature object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1751
        @param **kwargs: keyword arguments  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1752
        e.g. to add fea2 under fea1 add_feature(fea2, 'fea1')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1753
        @return: the new feature object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1754
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1755
        fea = self._feature_class()(ref, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1756
        self.add_feature(fea)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1757
        return fea
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1758
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1759
    def add_feature(self, feature, path=""):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1760
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1761
        @param feature: The Feature object to add 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1762
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1763
        self._add_to_path(path, feature)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1764
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1765
    def get_feature(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1766
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1767
        @param path: The path (ref) to the given feature 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1768
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1769
        return self._get(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1770
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1771
    def remove_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1772
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1773
        remove a given feature from this view by reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1774
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1775
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1776
        self._remove(ref)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1777
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1778
    def list_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1779
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1780
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1781
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1782
        return [fea.get_ref() for fea in self._objects(type=Feature)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1783
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1784
    def list_all_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1785
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1786
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1787
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1788
        return [fea._path(self) for fea in self._traverse(type=Feature)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1789
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1790
    def add_option(self, option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1791
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1792
        @param option: option object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1793
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1794
        if not isinstance(option, Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1795
            raise TypeError("%r is not an instance of Option!" % option)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1796
        self._add(option)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1797
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1798
    def create_option(self, name, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1799
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1800
        @param name: option name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1801
        @param value: option value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1802
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1803
        self._add(Option(name, value))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1804
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1805
    def get_option(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1806
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1807
        @param name: The option reference of the option (as returned by list_options()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1808
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1809
        real_ref = 'opt_' + ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1810
        obj = self._get(real_ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1811
        if not isinstance(obj, Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1812
            raise TypeError('Object %r is not an instance of Option (%r instead)' % (real_ref, type(obj)))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1813
        return obj
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1814
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1815
    def remove_option(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1816
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1817
        remove a given option from this feature by option reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1818
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1819
        real_ref = 'opt_' + ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1820
        obj = self._get(real_ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1821
        if not isinstance(obj, Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1822
            raise TypeError('Trying to remove option with ref %r, but object with ref %r is not an instance of Option (%s instead)' % (ref, real_ref, type(obj)))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1823
        self._remove(real_ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1824
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1825
    def list_options(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1826
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1827
        Return a array of all Option children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1828
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1829
        # Return option refs without the leading 'opt_'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1830
        return [opt.ref[4:] for opt in self._objects(type=Option)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1831
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1832
    def add_property(self, property):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1833
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1834
        @param property: property object to add
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1835
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1836
        if not isinstance(property, Property):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1837
            raise TypeError("%r is not an instance of Property!" % property)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1838
        self._add(property)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1839
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1840
    def create_property(self, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1841
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1842
        @param name=str: property name 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1843
        @param value=str: property value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1844
        @param unit=str: property unit, e.g. kB
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1845
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1846
        self._add(Property(**kwargs))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1847
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1848
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1849
    def get_property(self, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1850
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1851
        @param ref: The ref of the property
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1852
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1853
        obj = self._get(Property.to_propertyref(ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1854
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1855
        if not isinstance(obj, Property):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1856
            raise TypeError('Object %r is not an instance of Property (%r instead)' % (Property.to_propertyref(ref), type(obj)))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1857
        return obj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1858
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1859
    def remove_property(self, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1860
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1861
        remove a given property from this feature by ref. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1862
        @param ref: 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1863
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1864
        obj = self._get(Property.to_propertyref(ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1865
        if not isinstance(obj, Property):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1866
            raise TypeError('Trying to remove property with ref %r, but object with ref %r is not an instance of Property (%s instead)' % (ref, Property.to_propertyref(ref), type(obj)))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1867
        self._remove(Property.to_propertyref(ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1868
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1869
    def list_properties(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1870
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1871
        Return a array of all Feature properties under this object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1872
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1873
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1874
        return [Property.to_normref(property.ref) for property in self._objects(type=Property)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1875
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1876
    def get_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1877
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1878
        Get the current value of the feature. 
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1879
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1880
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1881
        return self.convert_data_to_value(self.dataproxy._get_datas(attr=attr), cast=True, attr=attr)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1882
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1883
    def set_value(self, value, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1884
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1885
        Set the current value for this feature. Set the value on the topmost layer.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1886
        @param value: the value to set
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1887
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1888
        data_objs = self.convert_value_to_data(value, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1889
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1890
        # Set the created data objects to the dataproxy and the
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1891
        # last configuration, overriding any existing elements
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1892
        self.dataproxy._set_datas(data_objs, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1893
        last_config = self.get_root_configuration().get_last_configuration()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1894
        last_config.add_data(data_objs, container.REPLACE)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1895
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1896
    def convert_data_to_value(self, data_objects, cast=True, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1897
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1898
        Convert the given list of Data objects into a suitable value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1899
        for this setting.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1900
        @param data_objects: The Data object list.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1901
        @param cast: If True, the value should be cast to its correct Python type
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1902
            (e.g. int), if False, the value should remain in the string form
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1903
            it was in the data objects.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1904
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs'
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1905
        @return: The converted value.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1906
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1907
        if not data_objects:    return None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1908
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1909
        data_obj = data_objects[-1]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1910
        if data_obj.map:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1911
            value = self._resolve_name_id_mapped_value(data_obj.map, cast_value=cast)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1912
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1913
            value = data_obj.value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1914
            if cast: value = self.get_value_cast(value, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1915
        return value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1916
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1917
    def convert_value_to_data(self, value, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1918
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1919
        Convert the given value to a list of Data objects that can be placed
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1920
        in the configuration's last layer's data section (DataContainer object).
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1921
        @param value: The value to convert.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1922
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs'
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1923
        @return: The converted Data objects.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1924
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1925
        value = self.set_value_cast(value, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1926
        return [Data(fqr=self.fqr, value=value, attr=attr)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1927
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1928
    def del_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1929
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1930
        Delete the topmost value for this feature.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1931
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1932
        self.dataproxy._del_value(attr)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1933
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1934
    def get_value_cast(self, value, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1935
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1936
        A function to perform the value type casting in get operation  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1937
        @param value: the value to cast 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1938
        @param attr: the attribute which is fetched from model (normally in confml either None='data' or 'rfs')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1939
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1940
        return value 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1941
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1942
    def set_value_cast(self, value, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1943
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1944
        A function to perform the value type casting in the set operation  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1945
        @param value: the value to cast 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1946
        @param attr: the attribute which is fetched from model (normally in confml either None='data' or 'rfs')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1947
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1948
        return value 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1949
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1950
    def get_original_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1951
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1952
        Get the current value of the feature
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1953
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1954
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1955
        return self.convert_data_to_value(self.dataproxy._get_datas(attr=attr), cast=False, attr=attr)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1956
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1957
    def add_data(self, data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1958
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1959
        Add a data value.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1960
        @param data: A Data object  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1961
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1962
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1963
            return self.dataproxy._add_data(data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1964
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1965
            self.dataproxy = self.get_default_view().get_feature(self.get_fullfqr()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1966
            return self.dataproxy._add_data(data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1967
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1968
    def get_data(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1969
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1970
        Helper function to get the topmost data value from the default view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1971
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1972
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1973
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1974
            return self.dataproxy._get_data(attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1975
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1976
            self.dataproxy = self.get_default_view().get_feature(self.get_fullfqr()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1977
            return self.dataproxy._get_data(attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1978
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1979
    def get_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1980
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1981
        Helper function to get the data values from the default view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1982
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1983
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1984
            return self.dataproxy._get_datas()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1985
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1986
            self.dataproxy = self.get_default_view().get_feature(self.get_fullfqr()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1987
            return self.dataproxy._get_datas()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1988
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1989
    def get_valueset(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1990
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1991
        Get the ValueSet object for this feature, that has the list of available values.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1992
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1993
        if self.get_type() == 'boolean':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1994
            return ValueSet([True, False])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1995
        elif self.get_type() == 'int':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1996
            return ValueRange(0, sys.maxint)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1997
        elif self.get_type() == 'string':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1998
            return ValueRe('.*')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1999
        elif self.get_type() in ('selection', 'multiSelection'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2000
            values = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2001
            for opt in self._objects(type=Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2002
                v = opt.get_value()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2003
                if v is not None: values.append(v)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2004
            return ValueSet(values)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2005
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2006
    def is_sequence(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2007
        """ Return true if the feature is a sequence or part of a sequence """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2008
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2009
            return self._parent.is_sequence()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2010
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2011
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2012
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2013
    def is_sequence_root(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2014
        """ Return true if this feature is a sequence object it self """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2015
        return False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2016
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2017
    def get_sequence_parent(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2018
        """ Try to get a FeatureSequence object for this Feature if it is found """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2019
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2020
            return self._parent.get_sequence_parent()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2021
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2022
            return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2023
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2024
    def getdataproxy(self): 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2025
        if self._dataproxy == None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2026
            self.dataproxy = self.get_default_view().get_feature(self.get_fullfqr())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2027
        return self._dataproxy
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2028
    def setdataproxy(self, value): self._dataproxy = value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2029
    def deldataproxy(self): self._dataproxy = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2030
    dataproxy = property(getdataproxy, setdataproxy, deldataproxy)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2031
    """ Use custom OProperty to enable overriding value methods in subclasses """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2032
    value = utils.OProperty(get_value, set_value, del_value)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2033
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2034
    def get_column_value(self, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2035
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2036
        Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2037
        @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2038
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2039
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2040
        """ get the feature specific data from sequence => a column of data table """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2041
        seq_parent = self.get_sequence_parent()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2042
        if seq_parent._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2043
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2044
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2045
        coldata =  []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2046
        colref = self.path(seq_parent)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2047
        for row in seq_parent.data:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2048
            feadata = row.get_feature(colref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2049
            coldata.append(feadata.get_value(attr))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2050
        return coldata
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2051
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2052
    def get_column_original_value(self, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2053
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2054
        Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2055
        @param feasequence: the feature sequence object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2056
        @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2057
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2058
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2059
        """ get the feature specific data from sequence => a column of data table """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2060
        seq_parent = self.get_sequence_parent()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2061
        if seq_parent._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2062
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2063
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2064
        coldata =  []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2065
        colref = self.path(seq_parent)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2066
        for row in seq_parent.data:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2067
            feadata = row.get_feature(colref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2068
            coldata.append(feadata.get_original_value(attr))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2069
        return coldata
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2070
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2071
    def set_column_value(self, value, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2072
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2073
        Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2074
        @param feasequence: the feature sequence object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2075
        @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2076
        @param value: the value to set. This must be a list instance. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2077
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2078
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2079
        seq_parent = self.get_sequence_parent()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2080
        colref = self.path(seq_parent)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2081
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2082
        if not isinstance(value,list): 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2083
            raise exceptions.ConeException("The value for feature sequence '%s' column '%s' must be a list instance. Got %r" % (self.get_sequence_parent().fqr, colref, value))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2084
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2085
        # Handle the special case where the sequence is marked as empty
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2086
        # with the empty sequence marker (single empty data element)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2087
        if seq_parent._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2088
            seqrows = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2089
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2090
            seqrows = seq_parent.data
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2091
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2092
        if len(seqrows) < len(value):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2093
            raise exceptions.ConeException("Too many values for feature sequence '%s' column '%s'. Sequence holds only %d rows. Got %d data values in %r" % (self.get_sequence_parent().fqr, colref, len(seqrows), len(value), value))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2094
        for i in range(0, len(value)):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2095
            feadata = seqrows[i].get_feature(colref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2096
            feadata.set_value(value[i])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2097
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2098
    def add_sequence_feature(self, feature, path=""):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2099
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2100
        Override of the add_feature function in sequence to set the sequence childs to act 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2101
        as columns of the feature sequence
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2102
        @param feature: The Feature object to add 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2103
        @param path: path to feature if it not added directly under parent_fea 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2104
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2105
        # modify all possible children of feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2106
        for fea in feature._traverse(type=Feature):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2107
            to_sequence_feature(fea)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2108
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2109
        # Finally modify and add this feature to parent_feat
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2110
        to_sequence_feature(feature)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2111
        self._add_to_path(path, feature)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2112
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2113
    def _resolve_name_id_mapped_value(self, mapping_string, cast_value=True):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2114
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2115
        Resolve the name-ID mapped value based on the given mapping string.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2116
        @param mapping_string: The name-ID mapping string in the data element, e.g.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2117
            "FooFeature/FooSequence[@key='123']"
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2118
        @param cast_value: If True, the resolved value will be cast to the corresponding
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2119
            Python type, otherwise the raw string representation of the value in the
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2120
            data element will be returned.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2121
        @return: The resolved value.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2122
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2123
        def fail(msg): raise exceptions.NameIdMappingError(msg)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2124
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2125
        pattern = r"^([\w/]+)\[@key='(.*)'\]$"
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2126
        m = re.match(pattern, mapping_string)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2127
        if m is None: fail("Malformed mapping expression: %s" % mapping_string)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2128
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2129
        source_seq_ref = m.group(1).replace('/', '.')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2130
        mapping_key = m.group(2)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2131
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2132
        dview = self.get_root_configuration().get_default_view()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2133
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2134
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2135
            source_seq = dview.get_feature(source_seq_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2136
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2137
            fail("Mapping source sequence '%s' does not exist" % source_seq_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2138
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2139
        if source_seq.type != 'sequence':
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2140
            fail("Mapping source setting '%s' is not a sequence setting" % source_seq_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2141
        if not source_seq.mapKey or not source_seq.mapValue:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2142
            fail("Source sequence '%s' must have both mapKey and mapValue specified" % source_seq_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2143
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2144
        def get_subsetting(ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2145
            """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2146
            Return the sub-setting by the given mapKey or mapValue ref from the
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2147
            source sequence.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2148
            @param ref: The reference in the format it is in the ConfML file.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2149
                E.g. 'SubSetting', 'FileSubSetting/localPath', 'FileSubSetting/targetPath'
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2150
            """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2151
            subsetting = source_seq.get_feature(ref.replace('/', '.'))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2152
            # Use localPath for file and folder settings by default
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2153
            if subsetting.type in ('file', 'folder'):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2154
                subsetting = subsetting.get_feature('localPath')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2155
            return subsetting
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2156
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2157
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2158
            key_subsetting = get_subsetting(source_seq.mapKey)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2159
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2160
            fail("Invalid mapKey in source sequence '%s': no sub-setting with ref '%s'" % (source_seq_ref, source_seq.mapKey))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2161
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2162
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2163
        # Get possible override for mapValue from options
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2164
        value_subsetting_ref = source_seq.mapValue
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2165
        value_subsetting_ref_overridden = False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2166
        for opt in self._objects(type=Option):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2167
            if not opt.map or not opt.map_value: continue
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2168
            if opt.map.replace('/', '.') == source_seq_ref:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2169
                value_subsetting_ref = opt.map_value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2170
                value_subsetting_ref_overridden = True
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2171
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2172
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2173
            value_subsetting = get_subsetting(value_subsetting_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2174
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2175
            if value_subsetting_ref_overridden:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2176
                fail("Invalid mapValue override in option: sub-setting '%s' does not exist under source sequence '%s'" % (value_subsetting_ref, source_seq_ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2177
            else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2178
                fail("Invalid mapValue in source sequence '%s': no sub-setting with ref '%s'" % (source_seq_ref, value_subsetting_ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2179
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2180
        key_list = key_subsetting.get_original_value()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2181
        if mapping_key not in key_list:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2182
            fail("No item-setting in source sequence '%s' matches key '%s'" % (source_seq_ref, mapping_key))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2183
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2184
        if cast_value:  value_list = value_subsetting.get_value()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2185
        else:           value_list = value_subsetting.get_original_value()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2186
        return value_list[key_list.index(mapping_key)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2187
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2188
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2189
class FeatureSequence(Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2190
    POLICY_REPLACE = 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2191
    POLICY_APPEND = 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2192
    POLICY_PREPEND = 2
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2193
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2194
    A Feature class. Feature is the base for all Configurable items in a Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2195
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2196
    dataelem_name = '?datarows'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2197
    template_name = '?template'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2198
    def __init__(self, ref="", **kwargs):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2199
        super(FeatureSequence, self).__init__(ref, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2200
        self.name = kwargs.get('name', ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2201
        self.type = 'sequence'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2202
        self._templatedata = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2203
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2204
    def _get_policy(self, data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2205
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2206
        parse the policy from a policy string and return a constant
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2207
        @return: POLICY_* constant
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2208
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2209
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2210
            containerdata = utils.get_list(data._get_parent()._get(data.get_ref()))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2211
            firstdata = containerdata[0]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2212
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2213
            firstdata = data
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2214
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2215
        if firstdata.policy == 'append':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2216
            return self.POLICY_APPEND
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2217
        elif firstdata.policy == 'prefix':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2218
            return self.POLICY_PREPEND
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2219
        elif firstdata == data:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2220
            # otherwise the policy is either replace or undefined
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2221
            # (firstdata.policy == 'replace' or firstdata.policy == ''):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2222
            return self.POLICY_REPLACE
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2223
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2224
            return self.POLICY_APPEND
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2225
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2226
    def _set_template_data(self, data=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2227
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2228
        Set the template of the feature sequence  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2229
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2230
        if data != None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2231
            self._templatedata = data
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2232
            for feaname in self.list_features():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2233
                if self._templatedata._has(feaname):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2234
                    self.get_feature(feaname)._templatedata = self._templatedata._get(feaname)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2235
                else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2236
                    subdata = Data(ref=feaname)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2237
                    self.get_feature(feaname)._templatedata = subdata
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2238
                    self._templatedata._add(subdata) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2239
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2240
    def _add_datarow(self, dataobj=None, policy=POLICY_APPEND):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2241
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2242
        Add a feature data row for a new data in this sequence 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2243
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2244
        create_sub_data_objs = True
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2245
        if dataobj == None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2246
            dataobj = Data(fqr=self.fqr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2247
        elif dataobj.attr != 'data':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2248
            # Add data rows only for data objects (not e.g. RFS)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2249
            return
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2250
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2251
            # If the data object is given, but it doesn't contain any child
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2252
            # elements, don't add them automatically. This is to account for the
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2253
            # case where there is only one empty data element that specifies
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2254
            # that the sequence is set to be empty
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2255
            if len(dataobj._order) == 0:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2256
                create_sub_data_objs = False
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2257
        fea = FeatureSequenceSub(self.dataelem_name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2258
        rowproxy = _FeatureDataProxy(fea._name, fea)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2259
        """ the imaginary features share the parent relation of the proxy objects """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2260
        self.dataproxy._add(rowproxy, policy)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2261
        fea._parent = rowproxy._parent
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2262
        rowproxy._add_data(dataobj)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2263
        """ update the FeatureSequenceSub index from the index number of dataproxy """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2264
        fea._index = utils.get_list(self.dataproxy._get(self.dataelem_name)).index(rowproxy)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2265
        # Create a the subfeatures / columns for the parent feature and 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2266
        # add a data element under each feature.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2267
        for feaname in self.list_all_features():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2268
            (pathto_fea, fearef) = utils.dottedref.psplit_ref(feaname)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2269
            subfea = self.get_feature(feaname)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2270
            cellfea = FeatureSequenceSub(fearef)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2271
            cellfea.set_value_cast = subfea.set_value_cast
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2272
            cellfea.get_value_cast = subfea.get_value_cast
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2273
            cellfea.convert_data_to_value = subfea.convert_data_to_value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2274
            cellfea.convert_value_to_data = subfea.convert_value_to_data
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2275
            rowproxy.add_feature(cellfea, pathto_fea)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2276
            subproxy = rowproxy.get_feature(feaname)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2277
            subproxy._obj._parent = subproxy._parent
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2278
            if create_sub_data_objs and not dataobj._has(feaname):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2279
                dataobj._add_to_path(pathto_fea, Data(ref=fearef))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2280
            subproxy._add_data(dataobj._get(feaname))
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2281
        return dataobj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2282
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2283
    def _has_empty_sequence_marker(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2284
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2285
        Return True if the sequence setting has the empty sequence marker (a single
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2286
        empty data element), which denotes that the sequence is set to empty.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2287
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2288
        datatable = self.get_data()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2289
        if len(datatable) == 1:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2290
            data_elem = datatable[0].get_datas()[0]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2291
            if len(data_elem._order) == 0:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2292
                return True
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2293
        return False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2294
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2295
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2296
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2297
        A generic add function to add child objects. The function is intended to act as
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2298
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2299
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2300
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2301
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2302
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2303
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2304
        if isinstance(child, Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2305
            self.add_feature(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2306
        elif isinstance(child, Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2307
            self._add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2308
        elif isinstance(child, Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2309
            self._add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2310
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2311
            raise exceptions.IncorrectClassError("Cannot add %s to %s" % (child, self))
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2312
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2313
    def add_feature(self, feature, path=""):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2314
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2315
        Override of the add_feature function in sequence to set the sequence childs to act 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2316
        as columns of the feature sequence
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2317
        @param feature: The Feature object to add 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2318
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2319
        add_sequence_feature(self, feature, path)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2320
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2321
    def add_sequence(self, data=None, policy=POLICY_APPEND):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2322
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2323
        Add a feature data row for a new data in this sequence 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2324
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2325
        if self._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2326
            # We currently have the empty sequence marker (single empty data
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2327
            # element), so this one that we are adding should replace it
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2328
            policy = self.POLICY_REPLACE
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2329
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2330
        datarow = self._add_datarow(None, policy)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2331
        # add the new data sequence/row to the last configuration layer
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2332
        last_config = self.get_root_configuration().get_last_configuration()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2333
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2334
        container_policy = {self.POLICY_REPLACE: container.REPLACE,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2335
                            self.POLICY_APPEND:  container.APPEND,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2336
                            self.POLICY_PREPEND: container.PREPEND}[policy]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2337
        last_config.add_data(datarow, container_policy)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2338
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2339
        # set the initial data if it is given
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2340
        rowproxy = utils.get_list(self.dataproxy._get(self.dataelem_name))[-1]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2341
        if data != None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2342
            for index in range(len(data)):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2343
                if data[index] != None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2344
                    rowproxy[index].set_value(data[index])
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2345
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2346
    def set_template(self, data=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2347
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2348
        Set the template of the feature sequence  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2349
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2350
        if data is None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2351
            self._templatedata = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2352
            return
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2353
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2354
        if not isinstance(data, list):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2355
            raise TypeError('data must be a list (got %r)' % data)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2356
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2357
        # Create the new template data object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2358
        templatedata = Data(fqr=self.fqr, template=True)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2359
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2360
        # Add all sub-objects to the data object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2361
        def add_data_objects(feature, data_obj, value_list):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2362
            refs = feature.list_features()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2363
            if len(refs) != len(value_list):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2364
                raise ValueError("Data value list is invalid")
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2365
            for i, ref in enumerate(refs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2366
                value = value_list[i]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2367
                subfea = feature.get_feature(ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2368
                if isinstance(value, list):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2369
                    subdata = Data(ref=ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2370
                    data_obj.add(subdata)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2371
                    add_data_objects(feature.get_feature(ref), subdata, value)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2372
                else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2373
                    if value is not None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2374
                        subdata = Data(ref=ref, value=subfea.set_value_cast(value))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2375
                        data_obj.add(subdata)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2376
        add_data_objects(self, templatedata, data)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2377
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2378
        self._set_template_data(templatedata)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2379
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2380
        # Remove any existing template data
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2381
        pconfig = self.find_parent(type=Configuration)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2382
        dataobjs = pconfig._traverse(type=Data, filters=[lambda x: x.template and x.fqr == self.fqr])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2383
        if dataobjs:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2384
            for dataobj in dataobjs:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2385
                dataobj._parent._remove(dataobj.get_fullref())
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2386
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2387
        # Add the template data to the parent config (beginning of the data section)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2388
        pconfig.add_data(self._templatedata, policy=container.PREPEND)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2389
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2390
    def get_template(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2391
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2392
        Add a feature data row for a new data in this sequence 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2393
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2394
        #self._set_template(None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2395
        # set the initial data if it is given
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2396
        if self._templatedata:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2397
            def get_data_items(feature, data_obj):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2398
                refs = feature.list_features()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2399
                if refs:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2400
                    result = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2401
                    for ref in refs:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2402
                        if data_obj._has(ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2403
                            result.append(get_data_items(feature.get_feature(ref), data_obj._get(ref)))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2404
                        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2405
                            result.append(None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2406
                    return result
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2407
                else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2408
                    return data_obj.value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2409
            return get_data_items(self, self._templatedata)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2410
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2411
            return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2412
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2413
    def get_data(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2414
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2415
        Helper function to get the topmost data value from the default view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2416
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2417
        if self.dataproxy._has(self.dataelem_name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2418
            return utils.get_list(self.dataproxy._get(self.dataelem_name))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2419
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2420
            return []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2421
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2422
    def add_data(self, data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2423
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2424
        Add a data value.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2425
        @param data: A Data object  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2426
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2427
        # Skip template data adding
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2428
        if data.template:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2429
            self._set_template_data(data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2430
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2431
            # Get the data index
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2432
            self._add_datarow(data, self._get_policy(data))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2433
        return
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2434
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2435
    def get_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2436
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2437
        Helper function to get the topmost data value from the default view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2438
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2439
        if self._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2440
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2441
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2442
        datatable =  self.get_data()
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2443
        rettable = []
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2444
        for row in datatable:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2445
            rowvalues = row.value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2446
            rettable.append(rowvalues)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2447
        return rettable
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2448
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2449
    def get_original_value(self, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2450
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2451
        Get the current value of the feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2452
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2453
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2454
        if self._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2455
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2456
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2457
        datatable =  self.get_data()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2458
        rettable = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2459
        for row in datatable:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2460
            rowvalues = row.get_original_value()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2461
            rettable.append(rowvalues)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2462
        return rettable
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2463
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2464
    def set_value(self, value, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2465
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2466
        Set the current value for this feature. Set the value on the topmost layer.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2467
        @param value: the value to set. The value must be a two dimensional array (e.g. matrix)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2468
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2469
        if value:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2470
            # Add the first item with replace policy
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2471
            self.add_sequence(value[0], self.POLICY_REPLACE)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2472
            for row in value[1:]:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2473
                self.add_sequence(row)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2474
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2475
            # Setting the sequence to empty, so add one empty item-setting
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2476
            # to signify that
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2477
            self.add_sequence(None, self.POLICY_REPLACE)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2478
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2479
            # Strip all sub-elements from the data element just created,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2480
            # since the ConfML spec says that an empty sequence is denoted
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2481
            # by a single empty data element
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2482
            data_elem = self.get_data()[0].get_datas()[0]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2483
            for r in list(data_elem._order):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2484
                data_elem._remove(r)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2485
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2486
    def is_sequence(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2487
        """ Return always true from a sequence object """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2488
        return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2489
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2490
    def is_sequence_root(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2491
        """ Return true if this feature is a sequence object it self """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2492
        return True
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2493
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2494
    def get_column_features(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2495
        """ Return a list of sequence subfeature, which are the columns of the sequence """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2496
        columns = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2497
        for subref in self.list_features():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2498
            columns.append(self.get_feature(subref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2499
        return columns
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2500
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2501
    def get_sequence_parent(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2502
        """ Return this object as a sequence parent """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2503
        return self
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2504
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2505
    value = property(get_value, set_value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2506
    data = property(get_data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2507
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2508
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2509
def add_sequence_feature(parent_feature, feature, path=""):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2510
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2511
    Override of the add_feature function in sequence to set the sequence childs to act 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2512
    as columns of the feature sequence
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2513
    @param parent_feature: The parent feature where the feature object is added 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2514
    @param feature: The Feature object to add 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2515
    @param path: path to feature if it not added directly under parent_fea 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2516
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2517
    # modify all possible children of feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2518
    for fea in feature._traverse(type=Feature):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2519
        to_sequence_feature(fea)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2520
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2521
    # Finally modify and add this feature to parent_feat
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2522
    to_sequence_feature(feature)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2523
    parent_feature._add_to_path(path, feature)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2524
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2525
def to_sequence_feature(feature):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2526
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2527
    modify a Feature object to sequence feature that will return column like data from a sequence.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2528
    @param feature: The Feature object for which is modified.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2529
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2530
    feature.get_value = feature.get_column_value 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2531
    feature.get_original_value = feature.get_column_original_value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2532
    feature.set_value = feature.set_column_value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2533
    feature.add_feature = feature.add_sequence_feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2534
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2535
def get_column_value(feasequence, ref, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2536
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2537
    Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2538
    @param feasequence: the feature sequence object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2539
    @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2540
    @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2541
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2542
    """ get the feature specific data from sequence => a column of data table """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2543
    coldata =  []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2544
    for row in feasequence.data:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2545
        feadata = row.get_feature(ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2546
        coldata.append(feadata.get_value(attr))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2547
    return coldata
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2548
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2549
def get_column_original_value(feasequence, ref, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2550
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2551
    Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2552
    @param feasequence: the feature sequence object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2553
    @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2554
    @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2555
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2556
    """ get the feature specific data from sequence => a column of data table """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2557
    coldata =  []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2558
    for row in feasequence.data:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2559
        feadata = row.get_feature(ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2560
        coldata.append(feadata.get_original_value(attr))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2561
    return coldata
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2562
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2563
def set_column_value(feasequence, ref, value, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2564
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2565
    Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2566
    @param feasequence: the feature sequence object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2567
    @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2568
    @param value: the value to set. This must be a list instance. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2569
    @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2570
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2571
    if not isinstance(value,list): 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2572
        raise exceptions.ConeException("The value for feature sequence '%s' column '%s' must be a list instance. Got %r" % (feasequence.fqr, ref, value))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2573
    seqrows = feasequence.data
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2574
    if len(seqrows) < len(value): 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2575
        raise exceptions.ConeException("Too many values for feature sequence '%s' column '%s'. Sequence holds only %d rows. Got %d data values in %r" % (feasequence.fqr, ref, len(seqrows), len(value), value))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2576
    for i in range(0, len(value)):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2577
        feadata = seqrows[i].get_feature(ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2578
        feadata.set_value(value[i])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2579
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2580
class FeatureSequenceCell(Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2581
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2582
    A Feature class. Feature is the base for all Configurable items in a Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2583
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2584
    def __init__(self, ref="", **kwargs):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2585
        super(FeatureSequenceCell, self).__init__(ref)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2586
        self.name = kwargs.get('name', ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2587
        self.type = 'seqcell'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2588
 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2589
    def get_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2590
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2591
        Get the current value of the feature
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2592
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2593
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2594
        return self.dataproxy._get_value(attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2595
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2596
    def set_value(self, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2597
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2598
        Set the current value for this feature. Set the value on the topmost layer.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2599
        @param value: the value to set
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2600
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2601
        # The sequence cell only updates the latest value in the proxy  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2602
        self.dataproxy.get_data().set_value(value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2603
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2604
    value = property(get_value, set_value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2605
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2606
class FeatureSequenceSub(Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2607
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2608
    A Feature class. Feature is the base for all Configurable items in a Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2609
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2610
    def __init__(self, ref="", **kwargs):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2611
        super(FeatureSequenceSub, self).__init__(ref)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2612
        self.name = kwargs.get('name', ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2613
        self.type = 'subseq'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2614
        self._index = 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2615
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2616
    def get_index(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2617
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2618
        @return : the index of the data element for sequential data defined inside the same configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2619
        0 for normal data.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2620
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2621
        return self._index
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2622
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2623
    def set_value(self, value, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2624
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2625
        Set the current value for this sequence row.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2626
        @param value: the value row to set
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2627
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2628
        if utils.is_list(value):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2629
            for subindex in range(0, len(value)):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2630
                self.dataproxy[subindex].get_data().set_value(value[subindex])
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2631
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2632
            data_objs = self.convert_value_to_data(value)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2633
            data_object_where_to_add = self._parent._get_data()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2634
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2635
            self.dataproxy._set_datas(data_objs, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2636
            data_object_where_to_add._add(data_objs, container.REPLACE)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2637
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2638
    def get_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2639
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2640
        Set the current value for this feature. Set the value on the topmost layer.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2641
        @param value: the value to set
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2642
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2643
        # Handle empty sequences
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2644
        if self.get_sequence_parent()._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2645
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2646
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2647
        # The sequence cell only updates the latest value in the proxy
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2648
        childdatas = self.dataproxy._objects()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2649
        if len(childdatas) > 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2650
            return [subdata.value for subdata in childdatas]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2651
        else: 
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2652
            return super(FeatureSequenceSub,self).get_value(attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2653
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2654
    def get_original_value(self, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2655
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2656
        Get the current value of the feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2657
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2658
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2659
        # Handle empty sequences
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2660
        if self.get_sequence_parent()._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2661
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2662
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2663
        childdatas = self.dataproxy._objects()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2664
        if len(childdatas) > 0:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2665
            return [subdata.get_original_value() for subdata in childdatas]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2666
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2667
            return self.dataproxy._get_value(attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2668
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2669
    value = property(get_value, set_value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2670
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2671
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2672
class FeatureLink(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2673
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2674
    A _FeatureProxy class. _FeatureProxy is the object that is added to View as a 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2675
    link to the actual Feature object. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2676
    """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2677
    """ class variable for defining the override attributes"""
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2678
    override_attributes = ['name']
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2679
    ref_prefix = 'link_'
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2680
    PROXYREF_PREFIX = 'proxy_'
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2681
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2682
    def __init__(self, ref="", **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2683
        # Store the fully qualified reference to this object
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2684
        self.link = kwargs.get('link', ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2685
        self.name = kwargs.get('name', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2686
        ref = self.get_featurelink_ref(self.link)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2687
        # the reference of this particular object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2688
        super(FeatureLink, self).__init__(ref, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2689
        self._obj = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2690
        self._populated = False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2691
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2692
    def add(self, child, policy=container.REPLACE):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2693
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2694
        Add an override to enable adding any override attribute to a featurelink object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2695
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2696
        A generic add function to add child objects. The function is intended to act as
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2697
        proxy function that call the correct add function based on the child objects class.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2698
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2699
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2700
        @param child: the child object to add
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2701
        @raise IncorrectClassError: if the given class cannot be added to this object.  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2702
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2703
        if isinstance(child, Base):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2704
            self._add(child, policy)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2705
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2706
            raise exceptions.IncorrectClassError("Cannot add %s to %s" % (child, self))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2707
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2708
    def get_name(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2709
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2710
        Return the name of the featurelink
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2711
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2712
        return self.name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2713
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2714
    def set_name(self, name):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2715
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2716
        Set the name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2717
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2718
        self.name = name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2719
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2720
    @property
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2721
    def fqr(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2722
        return self.link
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2723
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2724
    def populate(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2725
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2726
        Populate or fetch the link to the actual feature for this featureproxy.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2727
        This method fetches the feature to the _obj member variable and populates also 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2728
        subfeatures. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2729
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2730
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2731
            if not self._populated:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2732
                feas = self.get_default_view().get_features(self.link)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2733
                # get the non wildcard part of ref
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2734
                static_ref = utils.dottedref.get_static_ref(self.link)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2735
                # add the found features to the parent
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2736
                for fea in feas:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2737
                    override_attrs = {}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2738
                    # override the FeatureProxy object with exactly same reference 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2739
                    # (in feat/* case dont override the children features)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2740
                    if fea.fqr == static_ref:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2741
                        override_attrs = self.get_attributes()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2742
                    feature = fea._obj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2743
                    proxy_ref = self.get_featureproxy_ref(feature.fqr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2744
                    proxy = _FeatureProxy(proxy_ref, feature, **override_attrs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2745
                    self._get_parent()._add(proxy)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2746
                    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2747
        except exceptions.NotFound, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2748
                parent_view = self._find_parent_or_default(type=View)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2749
                view_name = parent_view.get_name()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2750
                logging.getLogger('cone').info("Warning: Feature '%s' in view '%s' not found." % (self.link, view_name))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2751
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2752
    def get_attributes(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2753
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2754
        Returns a list of FeatureLink attributes that override settings of the original feature.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2755
        @return: a dictionary of attribute key : value pairs.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2756
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2757
        attrs = {}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2758
        for attr in self.override_attributes:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2759
            # try to get the attribute from this object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2760
            # and set it to the attribute list if it not None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2761
            try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2762
                value = getattr(self, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2763
                if value != None: attrs[attr] = value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2764
            except AttributeError:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2765
                pass
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2766
        return attrs
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2767
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2768
    @classmethod
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2769
    def get_featurelink_ref(cls, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2770
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2771
        return a featurelink ref from a feature ref. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2772
        This is needed to make the featurelink object refs unique in a container
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2773
        that has Features. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2774
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2775
        return cls.ref_prefix + ref.replace('.', '_').replace('/','_')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2776
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2777
    @classmethod
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2778
    def get_featureproxy_ref(cls, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2779
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2780
        Return a ref for a given setting fqr to be used under a group.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2781
        This is needed to make the featureproxy object refs unique in a container
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2782
        that has Features. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2783
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2784
        return cls.PROXYREF_PREFIX + ref.replace('.', '_').replace('/','_')
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2785
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2786
class _FeatureProxy(container.ObjectProxyContainer, Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2787
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2788
    A _FeatureProxy class. _FeatureProxy is the object that is added to View as a 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2789
    link to the actual Feature object. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2790
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2791
    def __init__(self, ref="", obj=None, **kwargs):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2792
        container.ObjectProxyContainer.__init__(self, obj, ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2793
        Base.__init__(self, ref, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2794
        self.support_data = False
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2795
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2796
    def __getattr__(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2797
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2798
        First check if the requested attr is a children then 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2799
        direct all not found attribute calls to the sub object getattr
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2800
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2801
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2802
            return self.__dict__['_children'][name] 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2803
        except KeyError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2804
            return getattr(self._obj, name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2805
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2806
    def __getitem__(self, index):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2807
        return self._objects()[index]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2808
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2809
    def __setitem__(self, index, value):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2810
        raise exceptions.NotSupportedException()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2811
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2812
    def __delitem__(self, index):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2813
        item = self.__getitem__(index)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2814
        return self._remove(item.get_ref())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2815
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2816
    def __len__(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2817
        return len(self._order)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2818
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2819
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2820
        if isinstance(obj, _FeatureProxy):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2821
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2822
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2823
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2824
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2825
    def _default_object(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2826
        return Group(name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2827
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2828
    def _set_parent(self, newparent):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2829
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2830
        @param newparent:  The new parent object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2831
        @return: None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2832
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2833
        self._parent = newparent
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2834
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2835
    def get_proxied_obj(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2836
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2837
        @return: Returns proxied object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2838
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2839
        return self._obj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2840
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2841
    def add_feature(self, feature, path=""):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2842
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2843
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2844
        if not isinstance(feature, Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2845
            raise exceptions.IncorrectClassError("add_feature requires instance of Feature!! Given %s" % feature)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2846
        if not self.support_data:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2847
            self._add_to_path(path, _FeatureProxy(feature._name, feature))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2848
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2849
            self._add_to_path(path, _FeatureDataProxy(feature._name, feature))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2850
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2851
    def remove_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2852
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2853
        remove a given feature from this view by reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2854
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2855
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2856
        self._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2857
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2858
    def get_feature(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2859
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2860
        @param path: The path (ref) to the given feature 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2861
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2862
        return self._get(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2863
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2864
    def list_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2865
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2866
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2867
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2868
        return self._list()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2869
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2870
    def list_all_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2871
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2872
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2873
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2874
        return [fea._path(self) for fea in self._traverse(type=_FeatureProxy)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2875
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2876
    def populate(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2877
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2878
        Dummy implementation of populate
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2879
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2880
        pass
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2881
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2882
    def has_attribute(self, name):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2883
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2884
        Perform a check whether an attribute with given name is stored inside the 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2885
        _FeatureProxy. The check does not extend to the proxied (_obj) insanses or 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2886
        children of this proxy.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2887
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2888
        @return: True when an attribute is a real attribute in this _FeatureProxy object. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2889
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2890
        return self.__dict__.has_key(name)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2891
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2892
    def get_option(self, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2893
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2894
        @param name: The option reference of the option (as returned by list_options()) 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2895
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2896
        real_ref = 'opt_' + ref
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2897
        for op in self.options.values():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2898
            if op.ref == real_ref:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2899
                return op
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2900
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2901
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2902
            obj = self.get_proxied_obj()._get(real_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2903
            if not isinstance(obj, Option):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2904
                raise TypeError('Object %r is not an instance of Option (%r instead)' % (real_ref, type(obj)))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2905
            return obj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2906
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2907
    def list_options(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2908
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2909
        Return a array of all Option children references under this object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2910
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2911
        opts = self.get_proxied_obj().list_options()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2912
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2913
        for opt in self.options:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2914
            opts.append(self.options[opt].ref[4:])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2915
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2916
        return opts
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2917
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2918
    def get_property(self, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2919
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2920
        @param name: The property reference of the property (as returned by list_properties()) 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2921
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2922
        for prop in self.properties.values():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2923
            if prop.ref == Property.to_propertyref(ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2924
                return prop
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2925
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2926
            obj = self.get_proxied_obj()._get(Property.to_propertyref(ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2927
            return obj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2928
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2929
    def list_properties(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2930
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2931
        Return a array of all Property children references under this object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2932
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2933
        props = self.get_proxied_obj().list_properties()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2934
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2935
        for pr in self.properties:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2936
            props.append(Property.to_normref(self.properties[pr].ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2937
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2938
        return props
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2939
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2940
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2941
class _FeatureDataProxy(_FeatureProxy):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2942
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2943
    A Feature class. Feature is the base for all Configurable items in a Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2944
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2945
    DEFAULT_KEY = 'data'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2946
    def __init__(self, ref="", obj=None, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2947
        # Initialize _obj to None, because __getattr__(), __setattr__()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2948
        # and __delattr__() access it.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2949
        # Note that we cannot use self._obj = None here, since that would
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2950
        # invoke __setattr__(), causing a kind of a chicken-and-egg problem
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2951
        object.__setattr__(self, '_obj', None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2952
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2953
        super(_FeatureDataProxy, self).__init__(ref, obj)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2954
        self.support_data = True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2955
        """ Create the data container of all types of data. Add the key for the default key. """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2956
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2957
        self.defaultkey = _FeatureDataProxy.DEFAULT_KEY
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2958
        self.datas = {self.defaultkey : []}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2959
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2960
    def __getattr__(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2961
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2962
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2963
        if object.__getattribute__(self, '_obj') is not None:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2964
            self.get_proxied_obj().dataproxy = self
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2965
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2966
        if name in Feature.PROPERTIES:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2967
            return getattr(self.get_proxied_obj(), name)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2968
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2969
            return super(_FeatureDataProxy, self).__getattr__(name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2970
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2971
    def __setattr__(self, name, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2972
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2973
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2974
        if object.__getattribute__(self, '_obj') is not None:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2975
            self.get_proxied_obj().dataproxy = self
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2976
            
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2977
        if name in Feature.PROPERTIES:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2978
            return setattr(self.get_proxied_obj(), name, value)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2979
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2980
            super(_FeatureDataProxy, self).__setattr__(name, value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2981
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2982
    def __delattr__(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2983
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2984
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2985
        if name in Feature.PROPERTIES:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2986
            return delattr(self.get_proxied_obj(), name)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2987
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2988
            return super(_FeatureDataProxy, self).__delattr__(name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2989
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2990
    def _add_data(self, data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2991
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2992
        Add a data value or a list of data values.
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2993
        @param data: A Data object  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2994
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2995
        if isinstance(data, list):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2996
            for d in data: self._add_data(d)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2997
            return
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2998
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2999
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3000
            self.datas[data.attr].append(data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3001
        except KeyError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3002
            """ Create a list object for missing attribute """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3003
            self.datas[data.attr] = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3004
            self.datas[data.attr].append(data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3005
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3006
    def _get_data(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3007
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3008
        Get the data value. in sequence setting cases returns an array of data.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3009
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3010
        dataattr = attr or self.defaultkey
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3011
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3012
            if len(self.datas[dataattr]) > 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3013
                return self.datas[dataattr][-1]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3014
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3015
                return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3016
        except KeyError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3017
            """ return None for missing attribute """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3018
            return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3019
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3020
    def _get_datas(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3021
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3022
        Get the entire data array.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3023
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3024
        dataattr = attr or self.defaultkey
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3025
        return self.datas.get(dataattr, [])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3026
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3027
    def _set_datas(self, datas, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3028
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3029
        Set the entire data array.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3030
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3031
        dataattr = attr or self.defaultkey
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3032
        self.datas[dataattr] = list(datas)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3033
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3034
    def _get_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3035
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3036
        Get the topmost data value.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3037
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3038
        if self._get_data(attr):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3039
            return self._get_data(attr).get_value()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3040
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3041
            return None
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3042
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3043
    def _set_value(self, datavalue, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3044
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3045
        Set the value for the feature the last configuration in the current hierarchy
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3046
        @param value: The value for the feature.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3047
        @return: The created Data object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3048
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3049
        # Make sure that data value exists only once the the last configuration layer
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3050
        # So if last_data exists on last layer, update the value of that data element.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3051
        # otherwise create a new data elem to the topmost layer
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3052
        dataobj = self._get_data(attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3053
        last_config = self.get_root_configuration().get_last_configuration()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3054
        if dataobj and dataobj.find_parent(type=Configuration) == last_config:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3055
            dataobj.set_value(datavalue)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3056
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3057
            dataobj = Data(fqr=self.fqr, value=datavalue, attr=attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3058
            last_config.add_data(dataobj)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3059
            self._add_data(dataobj)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3060
        return dataobj
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3061
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3062
    def _del_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3063
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3064
        Remove the 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3065
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3066
        data = self._get_data(attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3067
        if data:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3068
            dataattr = attr or self.defaultkey
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3069
            parentconfig = data.find_parent(type=Configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3070
            if parentconfig:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3071
                parentconfig.remove_data(data.get_fullfqr())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3072
            del self.datas[dataattr][-1]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3073
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3074
    def _get_values(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3075
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3076
        Get the topmost data value.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3077
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3078
        dataattr = attr or self.defaultkey
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3079
        return [dataelem.get_value() for dataelem in self.datas[dataattr]]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3080
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3081
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3082
class DataBase(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3083
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3084
        super(DataBase, self).__init__(ref, **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3085
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3086
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3087
        if isinstance(obj, (DataContainer, DataBase)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3088
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3089
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3090
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3091
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3092
    def _default_object(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3093
        return Data(ref=name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3094
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3095
    def count(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3096
        return len(self._objects())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3097
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3098
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3099
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3100
        A generic add function to add child objects. The function is intended to act as
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3101
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3102
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3103
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3104
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3105
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3106
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3107
        if isinstance(child, (Data)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3108
                self._add(child, container.APPEND)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3109
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3110
            raise exceptions.IncorrectClassError("Cannot add %s object to %s" % (child, self))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3111
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3112
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3113
class DataContainer(DataBase):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3114
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3115
        super(DataContainer, self).__init__(ref, **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3116
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3117
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3118
class Data(DataBase):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3119
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3120
    The data element can contain any data setting for a feature. The data element can be 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3121
    a value definition for any type of data. It basically just links some data to a feature. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3122
    The default Data attribute is 'data', but it can be any string. For example current use case 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3123
    is 'rfs'.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3124
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3125
    def __init__(self, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3126
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3127
        @param ref: the reference to the feature. E.g. foo
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3128
        @param fqr: the full reference to the feature. E.g. 'foo.bar' 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3129
        @param value: the value of the data
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3130
        @param attr: the attribute which the Data object defines. e.g. default is 'data'. But could be 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3131
        for example 'rfs'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3132
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3133
        name = kwargs.get('ref', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3134
        self.fearef = kwargs.get('fqr', None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3135
        if self.fearef:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3136
            (namespace, name) = utils.dottedref.psplit_ref(self.fearef)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3137
        super(Data, self).__init__(name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3138
        self.value  = kwargs.get('value', None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3139
        self.attr   = kwargs.get('attr') or 'data'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3140
        self.policy = kwargs.get('policy', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3141
        self.template = kwargs.get('template', False)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3142
        self.map    = kwargs.get('map')
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3143
        self.empty  = kwargs.get('empty', False)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3144
        self.lineno = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3145
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3146
    def __setstate__(self, state):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3147
        super(Data, self).__setstate__(state)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3148
        self.value = state.get('value', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3149
        self.attr = state.get('attr', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3150
        self.policy = state.get('policy', '')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3151
        self.map = state.get('map', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3152
        self.template = state.get('template', False)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3153
        self.lineno = state.get('lineno', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3154
        self.fearef = state.get('fearef', None)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3155
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3156
    def get_fearef(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3157
        if self.fearef:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3158
            return self.fearef
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3159
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3160
            return self.fqr
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3161
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3162
    def get_value(self):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3163
        return self.value
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3164
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3165
    def get_map(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3166
        return self.map
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3167
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3168
    def set_map(self, map):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3169
        self.map = map
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3170
        if self.value:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3171
            #Either value or mapping can be defined. Not both.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3172
            self.value = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3173
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3174
    def set_value(self, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3175
        self.value = value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3176
        if self.map:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3177
            #Either value or mapping can be defined. Not both.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3178
            self.map = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3179
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3180
    def get_policy(self): return self._policy
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3181
    def set_policy(self, value): self._policy = value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3182
    def del_policy(self):  self._policy = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3183
    policy = property(get_policy, set_policy, del_policy)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3184
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3185
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3186
class ValueSet(set):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3187
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3188
    A value set object to indicate a set of possible values for a feature. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3189
    e.g. A boolean feature ValueSet([True, False])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3190
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3191
    def __init__(self, initial_set=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3192
        super(ValueSet, self).__init__(initial_set or [])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3193
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3194
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3195
class ValueRange(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3196
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3197
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3198
    def __init__(self, fromvalue, tovalue, step=1):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3199
        self.fromvalue = fromvalue
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3200
        self.tovalue = tovalue
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3201
        self.step = step
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3202
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3203
    def __contains__(self, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3204
        return self.fromvalue <= value and value <= self.tovalue and (value-self.fromvalue) % self.step == 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3205
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3206
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3207
class ValueRe(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3208
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3209
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3210
    def __init__(self, regexp):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3211
        self.regexp = re.compile(regexp)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3212
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3213
    def __contains__(self, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3214
        if isinstance(value, str):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3215
            return self.regexp.match(value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3216
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3217
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3218
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3219
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3220
class Property(Base):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3221
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3222
    Confml property class
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3223
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3224
    def __init__(self, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3225
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3226
        @param name=str: name string (mandatory)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3227
        @param value=str: value for the property, string 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3228
        @param unit=str: unit of the property
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3229
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3230
        if kwargs.get('name',None) == None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3231
            raise ValueError("Property name cannot be None!")
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3232
        super(Property,self).__init__(Property.to_propertyref(kwargs.get('name',None)))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3233
        self.name = kwargs.get('name',None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3234
        self.value = kwargs.get('value',None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3235
        self.unit = kwargs.get('unit',None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3236
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3237
    @classmethod
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3238
    def to_propertyref(cls, name):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3239
        """ 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3240
        @param name: name of the property 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3241
        @return: A property reference.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3242
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3243
        if name is not None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3244
            return "property_%s" % name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3245
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3246
            raise ValueError("Property name cannot be None!")
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3247
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3248
    @classmethod
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3249
    def to_normref(cls, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3250
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3251
        @param ref: a property reference 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3252
        @return: normalized property reference
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3253
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3254
        return ref[9:]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3255
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3256
    def get_name(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3257
        return self.name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3258
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3259
    def get_value(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3260
        return self.value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3261
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3262
    def get_unit(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3263
        return self.unit
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3264
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3265
class Option(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3266
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3267
    Confml option class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3268
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3269
    def __init__(self, name, value, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3270
        super(Option, self).__init__(Option.to_optref(value, kwargs.get('map', None)))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3271
        self.name = name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3272
        self.value = value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3273
        self.map = kwargs.get('map', None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3274
        self.relevant = kwargs.get('relevant', None)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3275
        self.map_value = kwargs.get('map_value', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3276
        self.display_name = kwargs.get('display_name', None)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3277
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3278
    @classmethod
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3279
    def to_optref(cls, value, map):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3280
        """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3281
        @return: An option reference converted from value or map, depending
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3282
            on which one is not None.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3283
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3284
        if value is not None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3285
            return "opt_value_%s" % value.replace('.', '').replace('/', '').replace(' ', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3286
        elif map is not None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3287
            return "opt_map_%s" % map.replace('.', '').replace('/', '').replace(' ', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3288
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3289
            raise ValueError("Both value and map are None!")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3290
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3291
    def get_name(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3292
        return self.name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3293
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3294
    def get_value(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3295
        return self.value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3296
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3297
    def __cmp__(self, other):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3298
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3299
            ref = getattr(other, 'ref')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3300
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3301
            ref = other
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3302
        if self.ref < ref:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3303
            return -1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3304
        elif self.ref == ref:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3305
            return 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3306
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3307
            return 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3308
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3309
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3310
class Storage(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3311
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3312
    A general base class for all storage type classes
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3313
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3314
    """ File open modes """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3315
    MODE_UNKNOWN= -1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3316
    MODE_READ   = 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3317
    MODE_WRITE  = 2
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3318
    MODE_APPEND = 3
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3319
    MODE_DELETE = 4
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3320
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3321
    def __init__(self, path, mode=''):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3322
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3323
        @param path: the reference to the root of the storage.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3324
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3325
        self.rootpath = path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3326
        self.curpath = ""
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3327
        self.container = True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3328
        self.__opened_res__ = {}
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3329
        self.mode = mode
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3330
        self.cpath_stack = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3331
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3332
    def __opened__(self, res):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3333
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3334
        Internal function to add a newly opened Resource object to the list of open resources.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3335
        @param res: The resource object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3336
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3337
        if self.__opened_res__.has_key(res.path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3338
            self.__opened_res__[res.path].append(res)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3339
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3340
            self.__opened_res__[res.path] = [res]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3341
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3342
    def __closed__(self, res):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3343
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3344
        Internal function to remove a Resource object from the list of open resources.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3345
        @param res: The resource object to remove
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3346
        @raise StorageException if the given resource object is not found: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3347
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3348
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3349
            self.__opened_res__[res.path].remove(res)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3350
            if len(self.__opened_res__[res.path]) == 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3351
                del self.__opened_res__[res.path]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3352
        except KeyError, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3353
            raise exceptions.StorageException("No such %s open resource! %s" % (res, e))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3354
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3355
    def __has_open__(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3356
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3357
        Internal function to find out if any Resource objects are open from given ref.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3358
        @param ref: The resource ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3359
        @return: True if resources found. Otherwise False.   
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3360
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3361
        return self.__opened_res__.has_key(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3362
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3363
    def __get_open__(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3364
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3365
        Internal function to get all resource opened on a certain ref .
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3366
        @param ref: The resource ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3367
        @return: A list of open resources. Empty list if nothing is found   
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3368
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3369
        if self.__has_open__(path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3370
            # return a copy of currently open resources
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3371
            return self.__opened_res__[path][:]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3372
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3373
            return []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3374
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3375
    def __has_resource__(self, res):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3376
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3377
        Internal function to find out if the given Resource objects is open in this storage.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3378
        @param ref: The resource object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3379
        @return: True if resources found. Otherwise False.   
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3380
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3381
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3382
            res = self.__opened_res__[res.path].index(res)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3383
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3384
        except KeyError, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3385
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3386
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3387
    @classmethod
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3388
    def open(cls,path, mode="r", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3389
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3390
        Class method for opening an instance of Storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3391
        @param path: path to storage, which will determine what type of storage is initiated. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3392
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3393
        # import all storage instances
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3394
        from cone.storage import storages
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3395
        for storagename in storages:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3396
            storagemodule = 'cone.storage.'+storagename
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3397
            module = __import__(storagemodule)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3398
        for storage_class in utils.all_subclasses(Storage):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3399
            if storage_class.supported_storage(path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3400
                if hasattr(storage_class, '__open__'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3401
                    return storage_class.__open__(path, mode, **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3402
                else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3403
                    return storage_class(path, mode, **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3404
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3405
        obj = Storage(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3406
        return obj
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3407
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3408
    @classmethod
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3409
    def supported_storage(cls, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3410
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3411
        Class method for determing if the given clas supports a storage by given path. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3412
        E.g. foo.zip, foo.cpd, foo/bar, http://foo.com/
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3413
        @param path:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3414
        @return: Boolean value. True if the storage of the path is supported. False if not.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3415
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3416
        return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3417
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3418
    def set_path(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3419
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3420
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3421
        self.rootpath = path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3422
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3423
    def get_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3424
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3425
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3426
        return self.rootpath
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3427
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3428
    def push(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3429
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3430
        Set the current path under the Storage to the given path and push the possible existing path to a stack. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3431
        The current path can be reverted with pop method.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3432
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3433
        @return: None 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3434
        @param path: The path which is set as current path.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3435
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3436
        self.cpath_stack.append(self.curpath)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3437
        self.curpath = path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3438
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3439
    def pop(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3440
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3441
        Pop a path from path stack and set the current path to the popped element. The path can be pushed to the 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3442
        current path stack with push. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3443
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3444
        NOTE! if the pop is called when the current path stack is empty, the path will just remain is empty path 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3445
        keeping the active path in the storages root path. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3446
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3447
        @return: The new path.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3448
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3449
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3450
            path = self.cpath_stack.pop()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3451
            self.curpath = path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3452
        except IndexError:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3453
            pass
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3454
        return self.curpath
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3455
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3456
    def set_current_path(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3457
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3458
        @param path: the current path under the Storage. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3459
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3460
        self.curpath = utils.resourceref.remove_end_slash(utils.resourceref.remove_begin_slash(path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3461
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3462
    def get_current_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3463
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3464
        get the current path under the Storage. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3465
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3466
        return self.curpath
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3467
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3468
    def close(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3469
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3470
        Close the repository, which will save and close all open resources.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3471
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3472
        for openref in self.__opened_res__.keys():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3473
            for res in self.__get_open__(openref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3474
                self.close_resource(res)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3475
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3476
    def save(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3477
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3478
        Flush changes from all resources to the repository.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3479
        """        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3480
        for openref in self.__opened_res__.keys():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3481
            for res in self.__get_open__(openref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3482
                self.save_resource(res)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3483
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3484
    def open_resource(self, path, mode="r"):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3485
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3486
        Open the given resource and return a File object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3487
        @param path : reference to the resource 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3488
        @param mode : the mode in which to open. Can be one of r = read, w = write, a = append.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3489
        raises a NotResource exception if the ref item is not a resource.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3490
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3491
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3492
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3493
    def delete_resource(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3494
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3495
        Delete the given resource from storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3496
        @param path: reference to the resource 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3497
        raises a NotSupportedException exception if delete operation is not supported by the storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3498
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3499
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3500
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3501
    def close_resource(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3502
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3503
        Close a given resource instance. Normally this is called by the Resource object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3504
        in its own close.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3505
        @param path the reference to the resource to close. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3506
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3507
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3508
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3509
    def is_resource(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3510
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3511
        Return true if the ref is a resource
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3512
        @param ref : reference to path where resources are searched
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3513
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3514
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3515
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3516
    def list_resources(self, path, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3517
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3518
        find the resources under certain ref/path 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3519
        @param ref : reference to path where resources are searched
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3520
        @param recurse : defines whether to return resources directly under the path or does the listing recurse to subfolders. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3521
        Default value is False. Set to True to enable recursion.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3522
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3523
        return []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3524
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3525
    def import_resources(self, paths, storage):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3526
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3527
        import resources from a list of resources to this storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3528
        @param paths : a list of Resourse objects.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3529
        @param storage : the external storage from which files are imported.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3530
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3531
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3532
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3533
    def export_resources(self, paths, storage):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3534
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3535
        export resources from this storage based on a list of reference to this storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3536
        @param path : a list of resource paths in this storage (references).
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3537
        @param storage : the external storage where to export.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3538
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3539
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3540
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3541
    def save_resource(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3542
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3543
        Flush the changes of a given resource instance. Normally this is called by the Resource object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3544
        in its own save.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3545
        @param ref the reference to the resource to close. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3546
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3547
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3548
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3549
    def create_folder(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3550
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3551
        Create a folder entry to a path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3552
        @param path : path to the folder
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3553
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3554
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3555
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3556
    def delete_folder(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3557
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3558
        Delete a folder entry from a path. The path must be empty.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3559
        @param path : path to the folder
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3560
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3561
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3562
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3563
    def is_folder(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3564
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3565
        Check if the given path is an existing folder in the storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3566
        @param path : path to the folder
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3567
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3568
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3569
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3570
    def get_mode(self, mode_str):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3571
        if mode_str.find("w") != -1: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3572
            return self.MODE_WRITE
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3573
        elif mode_str.find("r") != -1:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3574
            return self.MODE_READ
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3575
        elif mode_str.find("a") != -1:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3576
            return self.MODE_APPEND
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3577
        elif mode_str.find("d") != -1:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3578
            return self.MODE_DELETE
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3579
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3580
            return self.MODE_UNKNOWN
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3581
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3582
    def unload(self, path, object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3583
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3584
        Dump a given object to the storage 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3585
        @param object: The object to dump to the storage, which is expected to be an instance 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3586
        of Base class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3587
        @param path: The reference where to store the object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3588
        @param object: The object instance to dump 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3589
        @raise StorageException: if the given object cannot be dumped to this storage 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3590
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3591
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3592
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3593
    def load(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3594
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3595
        Load an object from a reference.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3596
        @param path: The reference where to load the object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3597
        @raise StorageException: if the given object cannot be loaded as an object from this storage 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3598
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3599
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3600
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3601
    path = property(get_path, set_path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3602
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3603
class Resource(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3604
    STATE_OPEN = 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3605
    STATE_CLOSE = 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3606
    def __init__(self, storage, path, mode=Storage.MODE_READ):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3607
        self.storage = storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3608
        self.path = path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3609
        self.mode = mode
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3610
        self.state = Resource.STATE_OPEN
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3611
        self.content_info = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3612
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3613
    def get_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3614
        return self.path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3615
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3616
    def close(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3617
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3618
        Close the resource. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3619
        Note1: the resource object cannot be accessed anymore after it has been closed.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3620
        Note2: the changes are not automatically saved. The save operation must be explicitly called, 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3621
        to save data. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3622
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3623
        self.storage.close_resource(self.path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3624
        self.state = Resource.STATE_OPEN
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3625
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3626
    def read(self, bytes=0):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3627
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3628
        Read data.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3629
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3630
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3631
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3632
    def write(self, string):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3633
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3634
        Write data.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3635
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3636
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3637
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3638
    def truncate(self, size=0):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3639
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3640
        Trunkate this resource data to the given size.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3641
        @param size: The size to trunkate. Default value is zero, which make the resource empty. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3642
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3643
        raise exceptions.NotSupportedException()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3644
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3645
    def save(self, size=0):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3646
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3647
        Save all changes to data to storage.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3648
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3649
        raise exceptions.NotSupportedException()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3650
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3651
    def get_mode(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3652
        return self.storage.get_mode(self.mode)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3653
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3654
    def get_size(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3655
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3656
        Return the size of this resource in bytes.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3657
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3658
        Note that this does not work in write mode.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3659
        @return: The resource size in bytes:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3660
        @raise exceptions.StorageException: The resource was opened in write mode.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3661
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3662
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3663
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3664
    def get_content_info(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3665
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3666
        Return the ContentInfo class that contains content information about
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3667
        resource.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3668
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3669
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3670
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3671
class ContentInfo(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3672
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3673
    A ContentInfo object is used to describe content of Resource. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3674
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3675
    logger = logging.getLogger('cone.contentinfo')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3676
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3677
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3678
    def __init__(self, mimetype, mimesubtype):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3679
        #: MIME Media type (http://www.iana.org/assignments/media-types/)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3680
        #: as a string. E.g. 'image' or 'application'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3681
        self.mimetype = mimetype
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3682
        #: MIME Media subtype as a string. E.g. 'svg+xml' or 'bmp'.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3683
        self.mimesubtype = mimesubtype
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3684
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3685
    @property
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3686
    def content_type(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3687
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3688
        Returns MIME Media type (http://www.iana.org/assignments/media-types/) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3689
        and subtype as a string. E.g. 'image/bmp'. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3690
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3691
        return self.mimetype + '/' + self.mimesubtype
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3692
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3693
class ImageContentInfo(ContentInfo):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3694
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3695
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3696
    A ImageContentInfo object is used to describe content of image Resources.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3697
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3698
    def __init__(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3699
        ContentInfo.__init__(self, 'image', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3700
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3701
class BmpImageContentInfo(ImageContentInfo):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3702
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3703
    A BmpImageContentInfo object is used to describe content of bmp image 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3704
    Resources.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3705
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3706
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3707
    _BMP_BITS_PER_PIXEL_OFFSET_ = int('0x1C', 16)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3708
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3709
    def __init__(self, resource, data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3710
        ContentInfo.__init__(self, 'image', 'bmp')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3711
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3712
        #: Color depth as bits per pixel.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3713
        self.color_depth = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3714
        if (resource != None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3715
            try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3716
                self.color_depth = ord(data[self._BMP_BITS_PER_PIXEL_OFFSET_])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3717
            except Exception, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3718
                self.logger.warning("Invalid BMP-file: %s" % resource.get_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3719
        
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3720
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3721
class currentdir(object):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3722
    def __init__(self, storage, curdir):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3723
        self.storage = storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3724
        # make sure that the curdir does not contain path prefix
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3725
        self.curdir = curdir.lstrip('/')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3726
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3727
    def __enter__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3728
        self.storage.push(self.curdir)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3729
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3730
    def __exit__(self, type, value, tb):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3731
        self.storage.pop()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3732
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3733
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3734
class Folder(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3735
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3736
    A Folder object is a subfolder of a Storage, offering access to part of the Storages resources.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3737
    """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3738
    def __init__(self, storage, path, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3739
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3740
        Create a layer folder to the storage if it does not exist.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3741
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3742
        self.curpath = path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3743
        self.storage = storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3744
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3745
    def set_path(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3746
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3747
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3748
        self.curpath = path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3749
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3750
    def get_path(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3751
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3752
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3753
        return self.curpath
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3754
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3755
    def set_current_path(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3756
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3757
        @param path: the current path under the Storage. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3758
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3759
        self.curpath = utils.resourceref.remove_end_slash(utils.resourceref.remove_begin_slash(path))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3760
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3761
    def get_current_path(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3762
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3763
        get the current path under the Storage. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3764
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3765
        return self.curpath
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3766
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3767
    def close(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3768
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3769
        Close the repository, which will save and close all open resources.  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3770
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3771
        self.storage.close()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3772
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3773
    def save(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3774
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3775
        Flush changes from all resources to the repository.  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3776
        """        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3777
        return self.storage.save()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3778
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3779
    def open_resource(self, path, mode="r"):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3780
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3781
        Open the given resource and return a File object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3782
        @param path : reference to the resource 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3783
        @param mode : the mode in which to open. Can be one of r = read, w = write, a = append.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3784
        raises a NotResource exception if the ref item is not a resource.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3785
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3786
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3787
            res = self.storage.open_resource(path, mode)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3788
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3789
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3790
    def delete_resource(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3791
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3792
        Delete the given resource from storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3793
        @param path: reference to the resource 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3794
        raises a NotSupportedException exception if delete operation is not supported by the storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3795
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3796
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3797
            res = self.storage.delete_resource(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3798
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3799
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3800
    def close_resource(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3801
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3802
        Close a given resource instance. Normally this is called by the Resource object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3803
        in its own close.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3804
        @param path the reference to the resource to close. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3805
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3806
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3807
            res = self.storage.close_resource(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3808
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3809
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3810
    def is_resource(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3811
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3812
        Return true if the ref is a resource
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3813
        @param ref : reference to path where resources are searched
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3814
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3815
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3816
            res = self.storage.is_resource(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3817
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3818
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3819
    def list_resources(self, path, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3820
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3821
        find the resources under certain ref/path 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3822
        @param ref : reference to path where resources are searched
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3823
        @param recurse : defines whether to return resources directly under the path or does the listing recurse to subfolders. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3824
        Default value is False. Set to True to enable recursion.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3825
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3826
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3827
            res = self.storage.list_resources(path, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3828
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3829
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3830
    def import_resources(self, paths, storage):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3831
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3832
        import resources from a list of resources to this storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3833
        @param paths : a list of Resourse objects.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3834
        @param storage : the external storage from which files are imported.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3835
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3836
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3837
            res = self.storage.import_resources(paths, storage)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3838
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3839
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3840
    def export_resources(self, paths, storage):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3841
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3842
        export resources from this storage based on a list of reference to this storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3843
        @param path : a list of resource paths in this storage (references).
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3844
        @param storage : the external storage where to export.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3845
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3846
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3847
            res = self.storage.export_resources(paths, storage)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3848
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3849
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3850
    def save_resource(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3851
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3852
        Flush the changes of a given resource instance. Normally this is called by the Resource object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3853
        in its own save.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3854
        @param ref the reference to the resource to close. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3855
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3856
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3857
            res = self.storage.save_resource(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3858
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3859
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3860
    def create_folder(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3861
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3862
        Create a folder entry to a path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3863
        @param path : path to the folder
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3864
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3865
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3866
            res = self.storage.create_folder(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3867
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3868
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3869
    def delete_folder(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3870
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3871
        Delete a folder entry from a path. The path must be empty.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3872
        @param path : path to the folder
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3873
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3874
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3875
            res = self.storage.delete_folder(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3876
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3877
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3878
    def is_folder(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3879
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3880
        Check if the given path is an existing folder in the storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3881
        @param path : path to the folder
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3882
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3883
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3884
            res = self.storage.is_folder(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3885
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3886
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3887
    def get_mode(self, mode_str):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3888
        return self.storage.get_mode()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3889
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3890
    def unload(self, path, object):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3891
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3892
        Dump a given object to the storage 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3893
        @param object: The object to dump to the storage, which is expected to be an instance 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3894
        of Base class.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3895
        @param path: The reference where to store the object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3896
        @param object: The object instance to dump 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3897
        @raise StorageException: if the given object cannot be dumped to this storage 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3898
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3899
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3900
            res = self.storage.unload(path, object)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3901
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3902
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3903
    def load(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3904
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3905
        Load an object from a reference.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3906
        @param path: The reference where to load the object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3907
        @raise StorageException: if the given object cannot be loaded as an object from this storage 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3908
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3909
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3910
            res = self.storage.load(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3911
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3912
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3913
    path = property(get_path, set_path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3914
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3915
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3916
class CompositeLayer(Folder):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3917
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3918
    A base class for composite Configuration objects.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3919
    """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3920
    def __init__(self, storage, path="", **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3921
        super(CompositeLayer, self).__init__(storage, path, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3922
        self.layers = kwargs.get('layers', [])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3923
        self.path = path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3924
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3925
    def add_layer(self, layer):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3926
        self.layers.append(layer)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3927
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3928
    def remove_layer(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3929
        if self.get_layer(path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3930
            self.layers.remove(self.get_layer(path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3931
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3932
            raise exceptions.NotFound('Layer with given path %s not found!' % path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3933
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3934
    def get_layer(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3935
        for layer in self.layers:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3936
            if layer.get_current_path() == path:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3937
                return layer
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3938
        return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3939
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3940
    def list_layers(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3941
        return [layer.get_current_path() for layer in self.layers]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3942
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3943
    def list_confml(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3944
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3945
        @return: array of confml file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3946
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3947
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3948
        for layerpath in self.list_layers():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3949
            for respath in self.get_layer(layerpath).list_confml():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3950
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3951
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3952
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3953
    def list_implml(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3954
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3955
        @return: array of implml file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3956
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3957
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3958
        for layerpath in self.list_layers():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3959
            for respath in self.get_layer(layerpath).list_implml():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3960
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3961
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3962
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3963
    def list_content(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3964
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3965
        @return: array of content file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3966
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3967
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3968
        for layerpath in self.list_layers():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3969
            for respath in self.get_layer(layerpath).list_content():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3970
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3971
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3972
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3973
    def list_doc(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3974
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3975
        @return: array of document file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3976
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3977
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3978
        for layerpath in self.list_layers():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3979
            for respath in self.get_layer(layerpath).list_doc():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3980
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3981
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3982
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3983
    def list_all_resources(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3984
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3985
        Returns a list of all layer related resource paths with full path in the storage.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3986
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3987
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3988
        for layerpath in self.list_layers():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3989
            sublayer = self.get_layer(layerpath)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3990
            for respath in sublayer.list_all_resources(**kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3991
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3992
        return lres
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3993
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3994
    def list_all_related(self, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3995
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3996
        Returns a list of all (non confml) layer related resource paths with full path in the storage.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3997
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3998
        lres = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3999
        for layerpath in self.list_layers():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4000
            sublayer = self.get_layer(layerpath)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4001
            for respath in sublayer.list_all_related(**kwargs):                
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4002
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4003
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4004
        return lres
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4005
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4006
class Layer(CompositeLayer):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4007
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4008
    A Layer object is a subfolder of a Storage, offering access to part of the Storages resources.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4009
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4010
    def __init__(self, storage, path, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4011
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4012
        Create a layer folder to the storage if it does not exist.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4013
        @param storage: a reference to the Storage object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4014
        @param path: path for the layer 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4015
        @param confml_path: optional parameter for confml files path (give in confml_path="something") 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4016
        @param imlpml_path: optional parameter for implml files path (give in implml_path="something")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4017
        @param content_path: optional parameter for content files path (give in content_path="something")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4018
        @param doc_path: optional parameter for doc files path (give in doc_path="something")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4019
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4020
        super(Layer, self).__init__(storage, path, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4021
        #if not storage.is_folder(path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4022
        #    storage.create_folder(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4023
        self.predefined = {'confml_path' : 'confml', 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4024
                           'implml_path' : 'implml', 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4025
                           'content_path' : 'content', 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4026
                           'doc_path' : 'doc'}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4027
        # list through all "hardcoded" paths and check whether the 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4028
        # hardcoded or given path exists under this Layer. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4029
        # if it does then create a folder instance to that path 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4030
        for (pretag, prevalue) in self.predefined.items():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4031
            self.predefined[pretag] = kwargs.get(pretag, prevalue)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4032
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4033
    def __getattr__(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4034
        return getattr(self.storage, name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4035
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4036
    def __getstate__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4037
        state = {}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4038
        state['predefined'] = self.predefined
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4039
        state['path'] = self.path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4040
        state['layers'] = self.layers
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4041
        return state
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4042
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4043
    def __setstate__(self, state):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4044
        state = {}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4045
        self.predefined = state.get('predefined',{})
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4046
        self.path = state.get('path','')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4047
        self.layers = state.get('layers',[])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4048
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4049
        return state
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4050
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4051
    def list_confml(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4052
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4053
        @return: array of confml file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4054
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4055
        res = self.list_resources(self.predefined['confml_path'], recurse=True)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4056
        res += super(Layer, self).list_confml()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4057
        return res 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4058
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4059
    def list_implml(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4060
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4061
        @return: array of implml file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4062
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4063
        res = self.list_resources(self.predefined['implml_path'], recurse=True)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4064
        res += super(Layer, self).list_implml()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4065
        return res 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4066
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4067
    def list_content(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4068
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4069
        @return: array of content file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4070
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4071
        res = self.list_resources(self.predefined['content_path'], recurse=True)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4072
        res += super(Layer, self).list_content()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4073
        return res
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4074
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4075
    def list_doc(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4076
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4077
        @return: array of document file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4078
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4079
        res = self.list_resources(self.predefined['doc_path'], recurse=True)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4080
        res += super(Layer, self).list_doc()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4081
        return res
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4082
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4083
    def confml_folder(self):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4084
        cpath = self.get_current_path()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4085
        spath = self.predefined['confml_path']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4086
        return Folder(self.storage,  utils.resourceref.join_refs([cpath, spath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4087
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4088
    def implml_folder(self):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4089
        cpath = self.get_current_path()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4090
        spath = self.predefined['implml_path']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4091
        return Folder(self.storage,  utils.resourceref.join_refs([cpath, spath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4092
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4093
    def content_folder(self):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4094
        cpath = self.get_current_path()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4095
        spath = self.predefined['content_path']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4096
        return Folder(self.storage,  utils.resourceref.join_refs([cpath, spath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4097
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4098
    def doc_folder(self):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4099
        cpath = self.get_current_path()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4100
        spath = self.predefined['doc_path']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4101
        return Folder(self.storage,  utils.resourceref.join_refs([cpath, spath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4102
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4103
    def list_all_resources(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4104
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4105
        Returns a list of all layer related resource paths with full path in the storage.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4106
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4107
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4108
        for folderpath in sorted(self.predefined.values()):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4109
            lres += self.list_resources(folderpath, recurse=True)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4110
                 
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4111
        lres += super(Layer, self).list_all_resources()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4112
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4113
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4114
    def list_all_related(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4115
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4116
        Returns a list of all (non confml) layer related resource paths with full path in the storage.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4117
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4118
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4119
        lres = []
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4120
        exclude_filters = kwargs.get('exclude_filters', {})
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4121
        kwargs['recurse'] = True
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4122
        predef = self.predefined.copy()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4123
        del predef['confml_path']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4124
        for folderpath in sorted(predef.values()):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4125
            filter = exclude_filters.get(folderpath, None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4126
            resources = self.list_resources(folderpath, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4127
            if filter:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4128
                lres += [res for res in resources if not re.search(filter, res, re.IGNORECASE)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4129
            else:            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4130
                lres += resources
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4131
        lres += super(Layer, self).list_all_related(**kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4132
       
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4133
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4134
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4135
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4136
class Include(Base, container.LoadLink):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4137
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4138
    A common include element that automatically loads a resource 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4139
    and its object under this include element.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4140
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4141
    def __init__(self, ref="", **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4142
        path = kwargs.get('path') or ref
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4143
        store_interface = kwargs.get('store_interface',None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4144
        ref = utils.resourceref.to_objref(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4145
        container.LoadLink.__init__(self, path, store_interface)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4146
        Base.__init__(self, ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4147
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4148
    def get_store_interface(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4149
        if not self._storeint and self._parent:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4150
            try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4151
                self._storeint = self._parent.get_store_interface()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4152
            except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4153
                # If project is not found, let the store interface be None 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4154
                pass
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4155
        return self._storeint
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4156
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4157
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4158
class Rule(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4159
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4160
    Base class for Rules in the system.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4161
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4162
    def __init__(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4163
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4164
            
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4165
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4166
class FactoryBase(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4167
    pass
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4168
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4169
class Factory(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4170
    def __getattr__(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4171
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4172
        The Factory getattr find all subclasses for the Factory and searches for given attr 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4173
        in those.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4174
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4175
        for sub_factory in utils.all_subclasses(FactoryBase):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4176
            try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4177
                return getattr(sub_factory(), name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4178
            except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4179
                continue 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4180
        raise AttributeError("type object %s has no attribute '%s'" % (self.__class__, name))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4181
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4182
def get_mapper(modelname):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4183
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4184
    Return a instance of appropriate mapper for given model.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4185
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4186
    mapmodule = __import__('cone.public.mapping')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4187
    return mapmodule.public.mapping.BaseMapper()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4188
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4189
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4190
class Problem(object):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4191
    SEVERITY_ERROR      = "error"
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4192
    SEVERITY_WARNING    = "warning"
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4193
    SEVERITY_INFO       = "info"
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4194
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4195
    def __init__(self, msg, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4196
        self.msg = msg
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4197
        self.type = kwargs.get('type', '')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4198
        self.line = kwargs.get('line', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4199
        self.file = kwargs.get('file', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4200
        self.severity = kwargs.get('severity', self.SEVERITY_ERROR)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4201
        self.traceback = kwargs.get('traceback', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4202
        # A slot for any problem specific data 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4203
        self.problem_data = kwargs.get('problem_data', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4204
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4205
    def log(self, logger, current_file=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4206
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4207
        Log this problem with the given logger.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4208
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4209
        file = self.file or current_file
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4210
        if self.line is None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4211
            msg = "(%s) %s" % (file, self.msg)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4212
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4213
            msg = "(%s:%d) %s" % (file, self.line, self.msg)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4214
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4215
        mapping = {self.SEVERITY_ERROR:   logging.ERROR,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4216
                   self.SEVERITY_WARNING: logging.WARNING,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4217
                   self.SEVERITY_INFO:    logging.INFO}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4218
        level = mapping.get(self.severity, logging.ERROR)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4219
        logger.log(level, msg)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4220
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4221
        if self.traceback:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4222
            logger.debug(self.traceback)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4223
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4224
    @classmethod
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4225
    def from_exception(cls, ex):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4226
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4227
        Create a Problem object from an exception instance.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4228
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4229
        If the exception is a sub-class of ConeException, then it may contain
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4230
        extra information (like a line number) for the problem.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4231
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4232
        if isinstance(ex, exceptions.ConeException):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4233
            return Problem(msg      = ex.problem_msg or unicode(ex),
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4234
                           type     = ex.problem_type or '',
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4235
                           line     = ex.problem_lineno,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4236
                           severity = cls.SEVERITY_ERROR)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4237
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4238
            return Problem(msg      = unicode(ex),
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4239
                           severity = cls.SEVERITY_ERROR)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4240
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4241
    def __repr__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4242
        var_data = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4243
        for varname in ('msg', 'type', 'line', 'file', 'severity'):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4244
            var_data.append("%s=%r" % (varname, getattr(self, varname)))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4245
        return "%s(%s)" % (self.__class__.__name__, ', '.join(var_data))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4246
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4247
    def __eq__(self, other):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4248
        if not isinstance(other, Problem):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4249
            return False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4250
        for varname in ('msg', 'type', 'line', 'file', 'severity'):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4251
            self_val = getattr(self, varname)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4252
            other_val = getattr(other, varname)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4253
            if self_val != other_val:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4254
                return False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4255
        return True
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4256
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4257
    def __ne__(self, other):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4258
        return self == other
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4259
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4260
    def __lt__(self, other):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4261
        if not isinstance(other, Problem):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4262
            return False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4263
        return (self.file, self.line) < (other.file, other.line)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4264
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4265
def make_content_info(resource, data):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4266
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4267
    Factory for ContentInfo
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4268
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4269
    cnt_inf = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4270
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4271
    if resource != None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4272
        guessed_type = mimetypes.guess_type(resource.get_path())
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4273
        mimetype = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4274
        mimesubtype = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4275
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4276
        if guessed_type != None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4277
            mimetype, mimesubtype = guessed_type[0].split('/') 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4278
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4279
        if mimetype == 'image' and mimesubtype == 'x-ms-bmp':
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4280
            cnt_inf = BmpImageContentInfo(resource, data)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4281
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4282
            cnt_inf = ContentInfo(mimetype, mimesubtype)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4283
    return cnt_inf
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4284
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4285
def open_storage(path, mode="r", **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4286
    return Storage.open(path, mode="r", **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4287
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4288
class NullHandler(logging.Handler):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4289
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4290
    Default handler that does not do anything.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4291
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4292
    def emit(self, record):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4293
        pass
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4294
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4295
#Initialization of default logger that contains NullHandler.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4296
logger = logging.getLogger('cone')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4297
logger.addHandler(NullHandler())