configurationengine/source/cone/public/api.py
author m2lahtel
Tue, 10 Aug 2010 14:29:28 +0300
changeset 3 e7e0ae78773e
parent 0 2e8eeb919028
child 4 0951727b8815
permissions -rw-r--r--
ConE 1.2.11 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
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   912
    def __reduce_ex__(self, protocol_version):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   913
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   914
        Make the Configuration pickle a ConfigurationProxy object that would load this configuration
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   915
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   916
        proxy = ConfigurationProxy(self.path, store_interface = self.get_project())
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   917
        tpl = proxy.__reduce_ex__(protocol_version)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   918
        return tpl
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   919
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   920
    def __getstate__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   921
        return None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   922
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   923
    def _default_object(self, name):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   924
        return self._default_class()(name)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   925
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   926
    def _default_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   927
        return self._feature_class()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   928
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   929
    def _feature_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   930
        return Feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   931
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   932
    def _view_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   933
        return View
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   934
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   935
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   936
        if isinstance(obj, Configuration) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   937
        or isinstance(obj, Feature) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   938
        or isinstance(obj, Data) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   939
        or isinstance(obj, ConfigurationProxy) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   940
        or isinstance(obj, View) \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   941
        or isinstance(obj, Base): 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   942
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   943
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   944
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   945
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   946
    def _dict(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   947
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   948
        Return the public variables in a dictionary
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   949
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   950
        dict = super(Configuration, self)._dict(**kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   951
        dict['namespace'] = self.namespace
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   952
        return dict
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   953
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   954
    def get_name(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   955
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   956
        Return the name of the configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   957
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   958
        return self.name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   959
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   960
    def set_name(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   961
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   962
        Set the name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   963
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   964
        self.name = name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   965
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   966
    def get_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   967
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   968
        Return the path of the configuration resource
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   969
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   970
        return self.path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   971
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   972
    def set_path(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   973
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   974
        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
   975
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   976
        self.path = path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   977
        self.set_ref(utils.resourceref.to_objref(self.path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   978
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   979
    def get_full_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   980
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   981
        Return the path of the configuration resource
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   982
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   983
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   984
            parentconfig = self._find_parent(type=Configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   985
            parent_path = utils.resourceref.get_path(parentconfig.get_path()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   986
        except exceptions.NotFound:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   987
            parent_path = ""
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   988
        return utils.resourceref.join_refs([parent_path, self.path])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   989
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   990
    def get_path_for_parent(self, parent):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   991
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   992
        Return the path to this configuration for a defined parent Configuration object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   993
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   994
        parent_path = ""
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   995
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   996
            parentconfig = self._find_parent(type=Configuration)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   997
            if parent != parentconfig:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   998
                parent_path = utils.resourceref.get_path(parentconfig.get_path_for_parent(parent)) 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
   999
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1000
            pass
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1001
        return utils.resourceref.join_refs([parent_path, self.path])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1002
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1003
    def get_layer(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1004
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1005
        Get the layer object where this Configuration is located. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1006
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1007
        if not hasattr(self, "layer"):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1008
            layerpath = utils.resourceref.get_path(self.get_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1009
            # hardcoded removal of confml folder from the layer path it is there
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1010
            layerpath = utils.resourceref.remove_end(layerpath, '/confml')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1011
            self.layer = Layer(self.get_storage(), layerpath)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1012
            """ Add the sublayers to this layer if they are different from this configuration """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1013
            for configpath in self.list_configurations():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1014
                sublayer_path = utils.resourceref.get_path(self.get_configuration(configpath).get_full_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1015
                sublayer_path = utils.resourceref.remove_end(sublayer_path, '/confml')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1016
                if sublayer_path != utils.resourceref.get_path(self.get_path()):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1017
                    self.layer.add_layer(self.get_configuration(configpath).get_layer())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1018
        return self.layer
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1019
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1020
    def set_namespace(self, namespace):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1021
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1022
        @param namespace: The new namespace of the object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1023
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1024
        self._namespace =  namespace
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1025
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1026
    def get_namespace(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1027
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1028
        @return: The reference of the object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1029
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1030
        return self._namespace
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1031
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1032
    def del_namespace(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1033
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1034
        @return: The reference of the object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1035
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1036
        self._namespace = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1037
    namespace = property(get_namespace, set_namespace, del_namespace)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1038
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1039
    def list_resources(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1040
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1041
        List all resources used in this configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1042
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1043
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1044
        1. First ensure that all configuration resource files are added 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1045
        2. Then add all layer resources 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1046
        3. Make the list distinct
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1047
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1048
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1049
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1050
        resources = [self.get_full_path()]
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1051
        for config in self._traverse(type=(Configuration,ConfigurationProxy)):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1052
            resources.append(config.get_full_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1053
        layer = self.get_layer()
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1054
        for resref in layer.list_all_resources():
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1055
            resources.append(utils.resourceref.join_refs([layer.get_current_path(), resref]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1056
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1057
        return utils.distinct_array(resources)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1058
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1059
    def get_resource(self, ref, mode="r"):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1060
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1061
        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
  1062
        Configuration path, e.g. Configuration('test/foo/root.confml') => searches from 'test/foo'.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1063
        @param ref: the reference path to the requested resource
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1064
        @return: a instance of Resource. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1065
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1066
        mypath = utils.resourceref.get_path(self.path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1067
        myref = utils.resourceref.join_refs([mypath, ref])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1068
        return self.get_storage().open_resource(myref, mode)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1069
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1070
    def get_all_resources(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1071
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1072
        Get all resources in resource list of Resource objects
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1073
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1074
        resources = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1075
        res_list = self.list_resources()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1076
        for res in res_list:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1077
            resources.append(self.get_storage().open_resource(res))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1078
        return resources
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1079
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1080
    def get_root_resource(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1081
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1082
        Get the configuration reference resource.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1083
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1084
        return self.get_storage().open_resource(self.get_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1085
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1086
    def get_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1087
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1088
        Get a feature object by its reference.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1089
        @param ref: The reference to the feature object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1090
        @return: A Feature object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1091
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1092
        return self._get(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1093
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1094
    def create_feature(self, ref, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1095
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1096
        Create a feature object to the configuration.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1097
        @param ref: The ref for the Feature object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1098
        @param **kwargs: keyword arguments  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1099
        e.g. to add fea2 under fea1 add_feature(fea2, 'fea1')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1100
        @return: the new feature object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1101
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1102
        fea = self._feature_class()(ref, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1103
        self._add(fea)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1104
        return fea
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1105
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1106
    def add_feature(self, feature, namespace=""):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1107
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1108
        Add a feature object to the configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1109
        @param feature: The Feature object to add.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1110
        @param namespace: The sub namespace for the feature. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1111
        e.g. to add fea2 under fea1 add_feature(fea2, 'fea1')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1112
        @return: None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1113
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1114
        if namespace and self._has(namespace):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1115
            # Add the feature directly with an existing feature's add_feature functionality
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1116
            self.get_feature(namespace).add_feature(feature)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1117
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1118
            self._add_to_path(namespace, feature)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1119
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1120
    def remove_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1121
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1122
        remove feature by its reference
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1123
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1124
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1125
        self._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1126
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1127
    def list_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1128
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1129
        List immediate features found under the this configuration (the top nodes). 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1130
        The features are also available via the _default_view of the configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1131
        @return: a list of feature references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1132
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1133
        return [fea.get_ref() for fea in self._objects(type=Feature)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1134
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1135
    def list_all_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1136
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1137
        List all features found under the this configuration. The features are also 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1138
        available via the _default_view of the configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1139
        @return: a list of feature references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1140
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1141
        return [fea.fqr for fea in self._traverse(type=Feature)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1142
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1143
    def add_data(self, data, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1144
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1145
        Add a data object to this configuration object.
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1146
        @param data: The Data object or list of Data objects to add.
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1147
        @return: None
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1148
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1149
        data_objs = utils.get_list(data)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1150
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1151
        if policy == container.PREPEND:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1152
            data_objs = reversed(data_objs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1153
            policy_first = container.PREPEND
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1154
            policy_rest = container.PREPEND
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1155
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1156
            policy_first = policy
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1157
            policy_rest = container.APPEND
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1158
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1159
        for i, data_obj in enumerate(data_objs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1160
            if not self._has(data_obj.attr):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1161
                self._add(DataContainer(data_obj.attr, container=True))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1162
            (namespace, name) = utils.dottedref.psplit_ref(data_obj.get_fearef())
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1163
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1164
            if i == 0:  p = policy_first
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1165
            else:       p = policy_rest
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1166
            self._get(data_obj.attr)._add_to_path(namespace, data_obj, p)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1167
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1168
    def get_data(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1169
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1170
        Get a data object by its reference.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1171
        @param ref: The reference to the data object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1172
        @return: A Data object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1173
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1174
        return self.data._get(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1175
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1176
    def remove_data(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1177
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1178
        remove feature by its reference
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1179
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1180
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1181
        self.data._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1182
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1183
    def list_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1184
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1185
        List all datas found under the this configuration. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1186
        @return: a list of Data references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1187
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1188
        if self._has('data'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1189
            return [dataelem.fqr for dataelem in self.data._objects(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1190
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1191
            return []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1192
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1193
    def get_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1194
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1195
        List immediate datas found under the this configuration (the top nodes). 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1196
        @return: a list of Data references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1197
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1198
        if self._has('data'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1199
            return [dataelem for dataelem in self.data._objects(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1200
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1201
            return []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1202
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1203
    def list_all_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1204
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1205
        List all Data elements found under the this configuration (or subconfigurations). 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1206
        @return: a list of Data references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1207
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1208
        return [dataelem.fqr for dataelem in self._traverse(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1209
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1210
    def get_all_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1211
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1212
        List all Data elements found under the this configuration (or subconfigurations). 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1213
        @return: a list of Data references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1214
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1215
        return [dataelem for dataelem in self._traverse(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1216
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1217
    def list_leaf_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1218
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1219
        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
  1220
        @return: A list of Data references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1221
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1222
        return [dataelem.fqr for dataelem in self._find_leaves(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1223
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1224
    def get_leaf_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1225
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1226
        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
  1227
        @return: A list of Data objects. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1228
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1229
        return [dataelem for dataelem in self._find_leaves(type=Data)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1230
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1231
    def get_view(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1232
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1233
        Get a view object by its reference.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1234
        @param ref: The reference to the view object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1235
        @return: A View object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1236
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1237
        # Populate the view object before returning it
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1238
        view = self._get(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1239
        view.populate()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1240
        return view
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1241
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1242
    def create_view(self, viewname):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1243
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1244
        Create a view object to the configuration.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1245
        @param viewname: The name of the view to add. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1246
        @return: view object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1247
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1248
        viewobj = self._view_class()(viewname)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1249
        self.add_view(viewobj)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1250
        return viewobj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1251
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1252
    def add_view(self, viewobj):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1253
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1254
        Add a view object to the configuration.
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1255
        @param viewobj: The existing view object to add. 
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1256
        @return: None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1257
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1258
        assert(isinstance(viewobj, View))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1259
        return self._add(viewobj)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1260
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1261
    def remove_view(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1262
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1263
        Remove a view object from the configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1264
        @param ref: The reference to the View. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1265
        @return: None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1266
        @raise NotFound: when view is not found.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1267
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1268
        return self._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1269
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1270
    def list_views(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1271
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1272
        List all views found under the this configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1273
        @return: a list of view references. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1274
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1275
        return [view._path(self) for view in self._traverse(type=View)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1276
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1277
    def save(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1278
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1279
        Save the object to the permanent Storage object. Calls the save operation of 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1280
        all the children.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1281
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1282
        # Change the recursion order so that the current object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1283
        # is saved first and then its childen.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1284
        # 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
  1285
        self.get_project().unload(self.get_full_path(), self)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1286
        for child in self._objects():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1287
            if isinstance(child, (Configuration,ConfigurationProxy)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1288
                child.save()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1289
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1290
    def close(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1291
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1292
        Close the configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1293
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1294
        for child in self._objects():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1295
            if isinstance(child, (Configuration, ConfigurationProxy)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1296
                child.close()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1297
#        if self.get_full_path() != "":
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1298
#            self.get_project().unload(self.get_full_path(), self)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1299
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1300
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1301
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1302
        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
  1303
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1304
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1305
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1306
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1307
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1308
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1309
        if isinstance(child, Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1310
            self.add_feature(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1311
        elif isinstance(child, View):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1312
            self._add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1313
        elif isinstance(child, (Data)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1314
            self.add_data(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1315
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1316
            super(Configuration, self).add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1317
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1318
    def get_default_view(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1319
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1320
        Get the default view from this configuration hierarchy.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1321
        This returns always the view from the Root configuration point of view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1322
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1323
        try:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1324
            parent = self._find_parent_or_default()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1325
            if parent and isinstance(parent, Configuration):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1326
                return parent.get_default_view()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1327
            else:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1328
                if not self._has('?default_view'):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1329
                    self._create_default_view()
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1330
                return self._get('?default_view')
0
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 recreate_default_view(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1336
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1337
            parent = self._find_parent_or_default() 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1338
            if parent and isinstance(parent, Configuration):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1339
                parent.recreate_default_view()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1340
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1341
                self._create_default_view()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1342
        except exceptions.NotFound, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1343
            raise e
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1344
        # raise exceptions.NotFound("Default View is not found! No root configuration?")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1345
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1346
    def _create_default_view(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1347
        # Rebuild the default view for this Configuration
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1348
        default_view = View("?default_view", data=True)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1349
        #self._default_view._parent= self
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1350
        self._add(default_view)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1351
        # First add all features of the configuration to the view. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1352
        # Then add all data elements under the features
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1353
        for child in self._traverse(type=Feature):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1354
            # TODO print "Adding : %s -> %s" % (child.namespace, child)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1355
            default_view.add_feature(child, child.namespace)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1356
        for child in self._traverse(type=Data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1357
            #parent_config = child._find_parent_or_default(type=Configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1358
            #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
  1359
            try:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1360
                fea = default_view.get_feature(child.fqr)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1361
                fea.add_data(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1362
            except exceptions.NotFound, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1363
                data_parent_config = child._find_parent_or_default(type=Configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1364
                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
  1365
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1366
class ConfigurationProxy(container.LoadProxy):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1367
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1368
    Configuration loading proxy. Loads the configuration from the given reference, when needed.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1369
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1370
    def __init__(self, path, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1371
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1372
        The ConfigurationProxy that represents a configuration that is included in another configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1373
        @param ref: the reference to the storage resource 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1374
        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
  1375
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1376
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1377
        super(ConfigurationProxy,self).__init__(path, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1378
        self.set('_name', utils.resourceref.to_objref(path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1379
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1380
    def __reduce_ex__(self, protocol_version):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1381
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1382
        Make the Configuration pickle a ConfigurationProxy object that would load this configuration
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1383
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1384
        return super(ConfigurationProxy, self).__reduce_ex__(protocol_version)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1385
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1386
    def _clone(self, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1387
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1388
        A ConfigurationProxy specific implementation for cloning.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1389
        Copies all (public) members in dictionary.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1390
        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
  1391
        @param recursion: Boolean to define recursion on or off
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1392
        @param recursion_depth: positive integer to define recursion depth. default is -1 which will 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1393
        perform recursion to all objects.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1394
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1395
        dict = self._dict()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1396
        obj = self.__class__(**dict)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1397
        # handle the recursion argument
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1398
        recursion = kwargs.get('recursion', False)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1399
        if recursion:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1400
            recursion_depth = kwargs.get('recursion_depth', -1)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1401
            if recursion_depth < 0 or recursion_depth > 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1402
                # decrease the recursion
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1403
                kwargs['recursion_depth'] = recursion_depth - 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1404
                newobj = self._get_obj()._clone(**kwargs) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1405
                obj._set_obj(newobj)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1406
        return obj
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1407
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1408
    def _dict(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1409
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1410
        Return the public variables in a dictionary
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1411
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1412
        dict = {}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1413
        for key in self.__dict__.keys():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1414
            if key.startswith('_'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1415
                continue
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1416
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1417
                dict[key] = self.__dict__[key]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1418
        return dict
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1419
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1420
    def _get_mapper(self,modelname):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1421
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1422
        Return a instance of appropriate mapper for given model.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1423
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1424
        return mapping.BaseMapper()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1425
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1426
class Group(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1427
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1428
    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
  1429
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1430
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1431
        super(Group, self).__init__(ref, **kwargs)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1432
        self.name = kwargs.get('name', ref)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1433
        self.support_data = kwargs.get("data", False)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1434
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1435
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1436
        if isinstance(obj, (Group, \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1437
                           Base, \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1438
                           _FeatureProxy, \
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1439
                           FeatureLink, \
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1440
                           ConfigurationProxy)): 
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1441
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1442
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1443
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1444
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1445
    def _default_object(self, name):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1446
        return self._group_class()(name)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1447
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1448
    def _group_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1449
        return Group
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1450
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1451
    def _featurelink_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1452
        return FeatureLink
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1453
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1454
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1455
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1456
        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
  1457
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1458
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1459
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1460
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1461
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1462
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1463
        if self._supported_type(child):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1464
            self._add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1465
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1466
            raise exceptions.IncorrectClassError("Cannot add %s to %s" % (child, self))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1467
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1468
    def get_name(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1469
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1470
        Return the name of the configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1471
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1472
        return self.name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1473
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1474
    def set_name(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1475
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1476
        Set the name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1477
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1478
        self.name = name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1479
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1480
    def create_featurelink(self, feature_ref, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1481
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1482
        create a feature link object to this element, with the given ref
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1483
        @param feature_ref: the reference for the featurelink which should
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1484
        point to a exising feature in the configuration.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1485
        @param **kwargs: keyword arguments are passed to the featurelink object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1486
        directly.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1487
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1488
        fealink = self._featurelink_class()(feature_ref, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1489
        self.add(fealink)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1490
        return fealink
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1491
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1492
    def get_featurelink(self, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1493
        return self._get(FeatureLink.get_featurelink_ref(ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1494
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1495
    def add_feature(self, feature, path=""):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1496
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1497
        Add feature to this Group.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1498
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1499
        if not isinstance(feature, Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1500
            raise exceptions.IncorrectClassError("add_feature requires instance of Feature!! Given %s" % feature)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1501
        if not self.support_data:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1502
            self._add_to_path(path, _FeatureProxy(feature._name, feature))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1503
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1504
            self._add_to_path(path, _FeatureDataProxy(feature._name, feature))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1505
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1506
    def remove_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1507
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1508
        remove a given feature from this view by reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1509
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1510
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1511
        self._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1512
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1513
    def get_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1514
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1515
        @param path: The path (ref) to the given feature 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1516
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1517
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1518
            return self._get(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1519
        except exceptions.NotFound:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1520
            raise exceptions.NotFound("Feature '%s' not found." % ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1521
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1522
    def get_features(self, refs, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1523
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1524
        Get a list of features that match the ref. 
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1525
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1526
        @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
  1527
        argument can be a single reference or a list of references to features. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1528
        @return: A list of features.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1529
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1530
        NOTE! the invalid references will not raise an exception.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1531
         
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1532
        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
  1533
        always a list [<Feature>].
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1534
        Example2: get_features('foo.*') would try to retrieve a list of all foo children.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1535
        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
  1536
        that have a defined type.
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1537
        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
  1538
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1539
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1540
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1541
        if utils.is_list(refs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1542
            features = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1543
            for ref in refs:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1544
                features += self.get_matching_features(ref, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1545
            return features
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1546
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1547
            return self.get_matching_features(refs, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1548
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1549
    def get_matching_features(self, ref, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1550
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1551
        Get a list of features that match the ref. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1552
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1553
        @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
  1554
        argument can be a single reference or a list of references to features. 
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1555
        @return: A list of features.
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1556
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1557
        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
  1558
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1559
        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
  1560
        always a list [<Feature>].
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1561
        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
  1562
        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
  1563
        that have a defined type.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1564
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1565
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1566
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1567
            (startref, last) = utils.dottedref.psplit_ref(ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1568
            startelem = self._get(startref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1569
            kwargs['type'] = _FeatureProxy
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1570
            if last == '**':
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1571
                return [fea for fea in startelem._traverse(**kwargs)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1572
            elif last == '*':
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1573
                return [fea for fea in startelem._objects(**kwargs)] 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1574
            elif ref != "":
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1575
                return [self._get(ref)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1576
            else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1577
                return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1578
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1579
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1580
         
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1581
    def list_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1582
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1583
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1584
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1585
        return [fea.get_ref() for fea in self._objects(type=(_FeatureProxy))]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1586
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1587
    def list_all_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1588
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1589
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1590
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1591
        return [fea.fqr for fea in self._traverse(type=(_FeatureProxy))]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1592
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1593
    def create_group(self, groupname, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1594
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1595
        create a group object to this element with given group name.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1596
        @param groupname: the name for the new group
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1597
        @param **kwargs: keyword arguments are passed on to the new group object.  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1598
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1599
        grp = self._group_class()(groupname, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1600
        self.add_group(grp)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1601
        return grp
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1602
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1603
    def add_group(self, grp):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1604
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1605
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1606
        self._add(grp)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1607
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1608
    def remove_group(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1609
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1610
        remove a given feature from this view by reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1611
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1612
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1613
        self._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1614
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1615
    def get_group(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1616
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1617
        @param path: The path (ref) to the given feature 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1618
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1619
        return self._get(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1620
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1621
    def list_groups(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1622
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1623
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1624
        return [group.ref for group in self._objects(type=Group)]
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1625
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1626
    def populate(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1627
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1628
        Populate or fetch the link to the actual feature for this featureproxy.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1629
        This method fetches the feature to the _obj member variable and populates also 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1630
        subfeatures. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1631
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1632
        for child in self._traverse(type=FeatureLink):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1633
            child.populate()
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
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1637
class View(Group):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1638
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1639
    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
  1640
    """
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(View, self).__init__(self.to_ref(ref), **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1643
        self.container = True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1644
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1645
    @classmethod
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1646
    def to_ref(cls, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1647
        """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1648
        return a view reference converted from name 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1649
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1650
        return ref.replace('.', '').replace('/', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1651
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1652
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1653
class Feature(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1654
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1655
    A Feature class. Feature is the base for all Configurable items in a Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1656
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1657
    PROPERTIES = ['value']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1658
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1659
        super(Feature, self).__init__(ref, **kwargs)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1660
        self.name = kwargs.get('name', None)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1661
        self.type = kwargs.get('type', None)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1662
        self.relevant = kwargs.get('relevant', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1663
        self.constraint = kwargs.get('constraint', None)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1664
        self._dataproxy = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1665
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1666
    def __copy__(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1667
        dict = {}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1668
        for key in self.__dict__.keys():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1669
            if key.startswith('_') or key == 'ref':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1670
                continue
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1671
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1672
                dict[key] = self.__dict__[key]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1673
        fea = self.__class__(self.ref, **dict)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1674
        return fea
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1675
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1676
    def __getstate__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1677
        state = super(Feature, self).__getstate__()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1678
        # remove the dataproxy value so that it is not stored in serializings
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1679
        state.pop('_dataproxy', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1680
        return state
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1681
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1682
    def __setstate__(self, state):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1683
        super(Feature, self).__setstate__(state)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1684
        self._dataproxy = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1685
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1686
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1687
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1688
        # For now support added for desc element via support for Base
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1689
        if isinstance(obj, (Feature, Option, Base)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1690
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1691
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1692
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1693
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1694
    def _feature_class(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1695
        return Feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1696
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1697
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1698
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1699
        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
  1700
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1701
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1702
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1703
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1704
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1705
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1706
        if isinstance(child, Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1707
            self.add_feature(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1708
        elif isinstance(child, Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1709
            self._add(child, policy)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1710
        elif isinstance(child, Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1711
            self._add(child, policy)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1712
        elif isinstance(child, Property):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1713
            self._add(child, policy)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1714
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1715
            raise exceptions.IncorrectClassError("Cannot add %s to %s" % (child, self))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1716
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1717
    def get_name(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1718
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1719
        Return the name of the configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1720
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1721
        return self.name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1722
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1723
    def set_name(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1724
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1725
        Set the name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1726
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1727
        self.name = name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1728
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1729
    def get_relevant(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 relevant 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.relevant
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_relevant(self, relevant):
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 relevant 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.relevant = relevant
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1740
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1741
    def get_constraint(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1742
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1743
        Return the constraint attribute of the feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1744
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1745
        return self.constraint
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1746
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1747
    def set_constraint(self, constraint):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1748
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1749
        Set the constraint attribute
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1750
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1751
        self.constraint = constraint
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1752
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1753
    def get_type(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1754
        return self.type
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1755
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1756
    def set_type(self, type):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1757
        self.type = type
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1758
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1759
    def create_feature(self, ref, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1760
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1761
        Create a feature object to the configuration.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1762
        @param ref: The ref for the Feature object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1763
        @param **kwargs: keyword arguments  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1764
        e.g. to add fea2 under fea1 add_feature(fea2, 'fea1')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1765
        @return: the new feature object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1766
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1767
        fea = self._feature_class()(ref, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1768
        self.add_feature(fea)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1769
        return fea
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1770
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1771
    def add_feature(self, feature, path=""):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1772
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1773
        @param feature: The Feature object to add 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1774
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1775
        self._add_to_path(path, feature)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1776
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1777
    def get_feature(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1778
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1779
        @param path: The path (ref) to the given feature 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1780
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1781
        return self._get(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1782
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1783
    def remove_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1784
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1785
        remove a given feature from this view by reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1786
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1787
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1788
        self._remove(ref)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1789
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1790
    def list_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1791
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1792
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1793
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1794
        return [fea.get_ref() for fea in self._objects(type=Feature)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1795
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1796
    def list_all_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1797
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1798
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1799
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1800
        return [fea._path(self) for fea in self._traverse(type=Feature)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1801
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1802
    def add_option(self, option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1803
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1804
        @param option: option object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1805
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1806
        if not isinstance(option, Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1807
            raise TypeError("%r is not an instance of Option!" % option)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1808
        self._add(option)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1809
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1810
    def create_option(self, name, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1811
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1812
        @param name: option name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1813
        @param value: option value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1814
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1815
        self._add(Option(name, value))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1816
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1817
    def get_option(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1818
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1819
        @param name: The option reference of the option (as returned by list_options()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1820
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1821
        real_ref = 'opt_' + ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1822
        obj = self._get(real_ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1823
        if not isinstance(obj, Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1824
            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
  1825
        return obj
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1826
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1827
    def remove_option(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1828
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1829
        remove a given option from this feature by option reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1830
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1831
        real_ref = 'opt_' + ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1832
        obj = self._get(real_ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1833
        if not isinstance(obj, Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1834
            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
  1835
        self._remove(real_ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1836
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1837
    def list_options(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1838
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1839
        Return a array of all Option children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1840
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1841
        # Return option refs without the leading 'opt_'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1842
        return [opt.ref[4:] for opt in self._objects(type=Option)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1843
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1844
    def add_property(self, property):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1845
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1846
        @param property: property object to add
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1847
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1848
        if not isinstance(property, Property):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1849
            raise TypeError("%r is not an instance of Property!" % property)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1850
        self._add(property)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1851
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1852
    def create_property(self, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1853
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1854
        @param name=str: property name 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1855
        @param value=str: property value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1856
        @param unit=str: property unit, e.g. kB
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1857
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1858
        self._add(Property(**kwargs))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1859
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1860
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1861
    def get_property(self, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1862
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1863
        @param ref: The ref of the property
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1864
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1865
        obj = self._get(Property.to_propertyref(ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1866
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1867
        if not isinstance(obj, Property):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1868
            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
  1869
        return obj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1870
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1871
    def remove_property(self, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1872
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1873
        remove a given property from this feature by ref. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1874
        @param ref: 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1875
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1876
        obj = self._get(Property.to_propertyref(ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1877
        if not isinstance(obj, Property):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1878
            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
  1879
        self._remove(Property.to_propertyref(ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1880
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1881
    def list_properties(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1882
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1883
        Return a array of all Feature properties under this object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1884
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1885
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1886
        return [Property.to_normref(property.ref) for property in self._objects(type=Property)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1887
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1888
    def get_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1889
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1890
        Get the current value of the feature. 
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1891
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1892
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1893
        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
  1894
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1895
    def set_value(self, value, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1896
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1897
        Set the current value for this feature. Set the value on the topmost layer.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1898
        @param value: the value to set
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1899
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1900
        data_objs = self.convert_value_to_data(value, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1901
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1902
        # Set the created data objects to the dataproxy and the
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1903
        # last configuration, overriding any existing elements
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1904
        self.dataproxy._set_datas(data_objs, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1905
        last_config = self.get_root_configuration().get_last_configuration()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1906
        last_config.add_data(data_objs, container.REPLACE)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1907
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1908
    def convert_data_to_value(self, data_objects, cast=True, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1909
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1910
        Convert the given list of Data objects into a suitable value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1911
        for this setting.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1912
        @param data_objects: The Data object list.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1913
        @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
  1914
            (e.g. int), if False, the value should remain in the string form
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1915
            it was in the data objects.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1916
        @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
  1917
        @return: The converted value.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1918
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1919
        if not data_objects:    return None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1920
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1921
        data_obj = data_objects[-1]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1922
        if data_obj.map:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1923
            value = self._resolve_name_id_mapped_value(data_obj.map, cast_value=cast)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1924
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1925
            value = data_obj.value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1926
            if cast: value = self.get_value_cast(value, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1927
        return value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1928
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1929
    def convert_value_to_data(self, value, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1930
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1931
        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
  1932
        in the configuration's last layer's data section (DataContainer object).
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1933
        @param value: The value to convert.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1934
        @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
  1935
        @return: The converted Data objects.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1936
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1937
        value = self.set_value_cast(value, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1938
        return [Data(fqr=self.fqr, value=value, attr=attr)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1939
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1940
    def del_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1941
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1942
        Delete the topmost value for this feature.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1943
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1944
        self.dataproxy._del_value(attr)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1945
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1946
    def get_value_cast(self, value, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1947
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1948
        A function to perform the value type casting in get operation  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1949
        @param value: the value to cast 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1950
        @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
  1951
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1952
        return value 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1953
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1954
    def set_value_cast(self, value, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1955
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1956
        A function to perform the value type casting in the set operation  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1957
        @param value: the value to cast 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1958
        @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
  1959
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1960
        return value 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1961
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1962
    def get_original_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1963
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1964
        Get the current value of the feature
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1965
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1966
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  1967
        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
  1968
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1969
    def add_data(self, data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1970
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1971
        Add a data value.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1972
        @param data: A Data object  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1973
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1974
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1975
            return self.dataproxy._add_data(data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1976
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1977
            self.dataproxy = self.get_default_view().get_feature(self.get_fullfqr()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1978
            return self.dataproxy._add_data(data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1979
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1980
    def get_data(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1981
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1982
        Helper function to get the topmost data value from the default view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1983
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1984
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1985
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1986
            return self.dataproxy._get_data(attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1987
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1988
            self.dataproxy = self.get_default_view().get_feature(self.get_fullfqr()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1989
            return self.dataproxy._get_data(attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1990
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1991
    def get_datas(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1992
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1993
        Helper function to get the data values from the default view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1994
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1995
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1996
            return self.dataproxy._get_datas()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1997
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1998
            self.dataproxy = self.get_default_view().get_feature(self.get_fullfqr()) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  1999
            return self.dataproxy._get_datas()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2000
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2001
    def get_valueset(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2002
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2003
        Get the ValueSet object for this feature, that has the list of available values.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2004
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2005
        if self.get_type() == 'boolean':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2006
            return ValueSet([True, False])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2007
        elif self.get_type() == 'int':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2008
            return ValueRange(0, sys.maxint)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2009
        elif self.get_type() == 'string':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2010
            return ValueRe('.*')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2011
        elif self.get_type() in ('selection', 'multiSelection'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2012
            values = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2013
            for opt in self._objects(type=Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2014
                v = opt.get_value()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2015
                if v is not None: values.append(v)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2016
            return ValueSet(values)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2017
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2018
    def is_sequence(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2019
        """ Return true if the feature is a sequence or part of a sequence """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2020
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2021
            return self._parent.is_sequence()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2022
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2023
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2024
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2025
    def is_sequence_root(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2026
        """ Return true if this feature is a sequence object it self """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2027
        return False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2028
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2029
    def get_sequence_parent(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2030
        """ Try to get a FeatureSequence object for this Feature if it is found """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2031
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2032
            return self._parent.get_sequence_parent()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2033
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2034
            return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2035
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2036
    def getdataproxy(self): 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2037
        if self._dataproxy == None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2038
            self.dataproxy = self.get_default_view().get_feature(self.get_fullfqr())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2039
        return self._dataproxy
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2040
    def setdataproxy(self, value): self._dataproxy = value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2041
    def deldataproxy(self): self._dataproxy = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2042
    dataproxy = property(getdataproxy, setdataproxy, deldataproxy)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2043
    """ Use custom OProperty to enable overriding value methods in subclasses """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2044
    value = utils.OProperty(get_value, set_value, del_value)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2045
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2046
    def get_column_value(self, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2047
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2048
        Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2049
        @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2050
        @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
  2051
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2052
        """ get the feature specific data from sequence => a column of data table """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2053
        seq_parent = self.get_sequence_parent()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2054
        if seq_parent._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2055
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2056
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2057
        coldata =  []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2058
        colref = self.path(seq_parent)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2059
        for row in seq_parent.data:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2060
            feadata = row.get_feature(colref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2061
            coldata.append(feadata.get_value(attr))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2062
        return coldata
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2063
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2064
    def get_column_original_value(self, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2065
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2066
        Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2067
        @param feasequence: the feature sequence object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2068
        @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2069
        @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
  2070
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2071
        """ get the feature specific data from sequence => a column of data table """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2072
        seq_parent = self.get_sequence_parent()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2073
        if seq_parent._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2074
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2075
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2076
        coldata =  []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2077
        colref = self.path(seq_parent)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2078
        for row in seq_parent.data:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2079
            feadata = row.get_feature(colref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2080
            coldata.append(feadata.get_original_value(attr))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2081
        return coldata
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2082
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2083
    def set_column_value(self, value, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2084
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2085
        Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2086
        @param feasequence: the feature sequence object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2087
        @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2088
        @param value: the value to set. This must be a list instance. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2089
        @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
  2090
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2091
        seq_parent = self.get_sequence_parent()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2092
        colref = self.path(seq_parent)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2093
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2094
        if not isinstance(value,list): 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2095
            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
  2096
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2097
        # Handle the special case where the sequence is marked as empty
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2098
        # with the empty sequence marker (single empty data element)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2099
        if seq_parent._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2100
            seqrows = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2101
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2102
            seqrows = seq_parent.data
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2103
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2104
        if len(seqrows) < len(value):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2105
            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
  2106
        for i in range(0, len(value)):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2107
            feadata = seqrows[i].get_feature(colref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2108
            feadata.set_value(value[i])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2109
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2110
    def add_sequence_feature(self, feature, path=""):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2111
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2112
        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
  2113
        as columns of the feature sequence
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2114
        @param feature: The Feature object to add 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2115
        @param path: path to feature if it not added directly under parent_fea 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2116
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2117
        # modify all possible children of feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2118
        for fea in feature._traverse(type=Feature):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2119
            to_sequence_feature(fea)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2120
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2121
        # Finally modify and add this feature to parent_feat
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2122
        to_sequence_feature(feature)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2123
        self._add_to_path(path, feature)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2124
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2125
    def _resolve_name_id_mapped_value(self, mapping_string, cast_value=True):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2126
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2127
        Resolve the name-ID mapped value based on the given mapping string.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2128
        @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
  2129
            "FooFeature/FooSequence[@key='123']"
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2130
        @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
  2131
            Python type, otherwise the raw string representation of the value in the
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2132
            data element will be returned.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2133
        @return: The resolved value.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2134
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2135
        def fail(msg): raise exceptions.NameIdMappingError(msg)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2136
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2137
        pattern = r"^([\w/]+)\[@key='(.*)'\]$"
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2138
        m = re.match(pattern, mapping_string)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2139
        if m is None: fail("Malformed mapping expression: %s" % mapping_string)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2140
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2141
        source_seq_ref = m.group(1).replace('/', '.')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2142
        mapping_key = m.group(2)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2143
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2144
        dview = self.get_root_configuration().get_default_view()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2145
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2146
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2147
            source_seq = dview.get_feature(source_seq_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2148
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2149
            fail("Mapping source sequence '%s' does not exist" % source_seq_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2150
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2151
        if source_seq.type != 'sequence':
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2152
            fail("Mapping source setting '%s' is not a sequence setting" % source_seq_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2153
        if not source_seq.mapKey or not source_seq.mapValue:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2154
            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
  2155
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2156
        def get_subsetting(ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2157
            """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2158
            Return the sub-setting by the given mapKey or mapValue ref from the
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2159
            source sequence.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2160
            @param ref: The reference in the format it is in the ConfML file.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2161
                E.g. 'SubSetting', 'FileSubSetting/localPath', 'FileSubSetting/targetPath'
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2162
            """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2163
            subsetting = source_seq.get_feature(ref.replace('/', '.'))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2164
            # Use localPath for file and folder settings by default
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2165
            if subsetting.type in ('file', 'folder'):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2166
                subsetting = subsetting.get_feature('localPath')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2167
            return subsetting
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2168
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2169
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2170
            key_subsetting = get_subsetting(source_seq.mapKey)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2171
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2172
            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
  2173
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2174
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2175
        # Get possible override for mapValue from options
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2176
        value_subsetting_ref = source_seq.mapValue
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2177
        value_subsetting_ref_overridden = False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2178
        for opt in self._objects(type=Option):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2179
            if not opt.map or not opt.map_value: continue
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2180
            if opt.map.replace('/', '.') == source_seq_ref:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2181
                value_subsetting_ref = opt.map_value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2182
                value_subsetting_ref_overridden = True
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2183
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2184
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2185
            value_subsetting = get_subsetting(value_subsetting_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2186
        except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2187
            if value_subsetting_ref_overridden:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2188
                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
  2189
            else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2190
                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
  2191
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2192
        key_list = key_subsetting.get_original_value()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2193
        if mapping_key not in key_list:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2194
            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
  2195
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2196
        if cast_value:  value_list = value_subsetting.get_value()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2197
        else:           value_list = value_subsetting.get_original_value()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2198
        return value_list[key_list.index(mapping_key)]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2199
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2200
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2201
class FeatureSequence(Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2202
    POLICY_REPLACE = 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2203
    POLICY_APPEND = 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2204
    POLICY_PREPEND = 2
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2205
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2206
    A Feature class. Feature is the base for all Configurable items in a Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2207
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2208
    dataelem_name = '?datarows'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2209
    template_name = '?template'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2210
    def __init__(self, ref="", **kwargs):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2211
        super(FeatureSequence, self).__init__(ref, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2212
        self.name = kwargs.get('name', ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2213
        self.type = 'sequence'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2214
        self._templatedata = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2215
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2216
    def _get_policy(self, data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2217
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2218
        parse the policy from a policy string and return a constant
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2219
        @return: POLICY_* constant
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2220
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2221
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2222
            containerdata = utils.get_list(data._get_parent()._get(data.get_ref()))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2223
            firstdata = containerdata[0]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2224
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2225
            firstdata = data
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2226
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2227
        if firstdata.policy == 'append':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2228
            return self.POLICY_APPEND
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2229
        elif firstdata.policy == 'prefix':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2230
            return self.POLICY_PREPEND
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2231
        elif firstdata == data:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2232
            # otherwise the policy is either replace or undefined
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2233
            # (firstdata.policy == 'replace' or firstdata.policy == ''):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2234
            return self.POLICY_REPLACE
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2235
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2236
            return self.POLICY_APPEND
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2237
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2238
    def _set_template_data(self, data=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2239
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2240
        Set the template of the feature sequence  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2241
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2242
        if data != None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2243
            self._templatedata = data
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2244
            for feaname in self.list_features():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2245
                if self._templatedata._has(feaname):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2246
                    self.get_feature(feaname)._templatedata = self._templatedata._get(feaname)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2247
                else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2248
                    subdata = Data(ref=feaname)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2249
                    self.get_feature(feaname)._templatedata = subdata
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2250
                    self._templatedata._add(subdata) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2251
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2252
    def _add_datarow(self, dataobj=None, policy=POLICY_APPEND):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2253
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2254
        Add a feature data row for a new data in this sequence 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2255
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2256
        create_sub_data_objs = True
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2257
        if dataobj == None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2258
            dataobj = Data(fqr=self.fqr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2259
        elif dataobj.attr != 'data':
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2260
            # Add data rows only for data objects (not e.g. RFS)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2261
            return
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2262
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2263
            # If the data object is given, but it doesn't contain any child
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2264
            # elements, don't add them automatically. This is to account for the
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2265
            # case where there is only one empty data element that specifies
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2266
            # that the sequence is set to be empty
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2267
            if len(dataobj._order) == 0:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2268
                create_sub_data_objs = False
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2269
        fea = FeatureSequenceSub(self.dataelem_name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2270
        rowproxy = _FeatureDataProxy(fea._name, fea)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2271
        """ the imaginary features share the parent relation of the proxy objects """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2272
        self.dataproxy._add(rowproxy, policy)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2273
        fea._parent = rowproxy._parent
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2274
        rowproxy._add_data(dataobj)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2275
        """ update the FeatureSequenceSub index from the index number of dataproxy """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2276
        fea._index = utils.get_list(self.dataproxy._get(self.dataelem_name)).index(rowproxy)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2277
        # Create a the subfeatures / columns for the parent feature and 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2278
        # add a data element under each feature.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2279
        for feaname in self.list_all_features():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2280
            (pathto_fea, fearef) = utils.dottedref.psplit_ref(feaname)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2281
            subfea = self.get_feature(feaname)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2282
            cellfea = FeatureSequenceSub(fearef)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2283
            cellfea.set_value_cast = subfea.set_value_cast
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2284
            cellfea.get_value_cast = subfea.get_value_cast
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2285
            cellfea.convert_data_to_value = subfea.convert_data_to_value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2286
            cellfea.convert_value_to_data = subfea.convert_value_to_data
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2287
            rowproxy.add_feature(cellfea, pathto_fea)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2288
            subproxy = rowproxy.get_feature(feaname)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2289
            subproxy._obj._parent = subproxy._parent
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2290
            if create_sub_data_objs and not dataobj._has(feaname):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2291
                dataobj._add_to_path(pathto_fea, Data(ref=fearef))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2292
            subproxy._add_data(dataobj._get(feaname))
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2293
        return dataobj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2294
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2295
    def _has_empty_sequence_marker(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2296
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2297
        Return True if the sequence setting has the empty sequence marker (a single
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2298
        empty data element), which denotes that the sequence is set to empty.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2299
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2300
        datatable = self.get_data()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2301
        if len(datatable) == 1:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2302
            data_elem = datatable[0].get_datas()[0]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2303
            if len(data_elem._order) == 0:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2304
                return True
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2305
        return False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2306
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2307
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2308
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2309
        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
  2310
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2311
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2312
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2313
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2314
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2315
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2316
        if isinstance(child, Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2317
            self.add_feature(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2318
        elif isinstance(child, Option):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2319
            self._add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2320
        elif isinstance(child, Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2321
            self._add(child)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2322
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2323
            raise exceptions.IncorrectClassError("Cannot add %s to %s" % (child, self))
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2324
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2325
    def add_feature(self, feature, path=""):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2326
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2327
        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
  2328
        as columns of the feature sequence
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2329
        @param feature: The Feature object to add 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2330
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2331
        add_sequence_feature(self, feature, path)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2332
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2333
    def add_sequence(self, data=None, policy=POLICY_APPEND):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2334
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2335
        Add a feature data row for a new data in this sequence 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2336
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2337
        if self._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2338
            # We currently have the empty sequence marker (single empty data
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2339
            # element), so this one that we are adding should replace it
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2340
            policy = self.POLICY_REPLACE
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2341
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2342
        datarow = self._add_datarow(None, policy)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2343
        # add the new data sequence/row to the last configuration layer
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2344
        last_config = self.get_root_configuration().get_last_configuration()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2345
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2346
        container_policy = {self.POLICY_REPLACE: container.REPLACE,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2347
                            self.POLICY_APPEND:  container.APPEND,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2348
                            self.POLICY_PREPEND: container.PREPEND}[policy]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2349
        last_config.add_data(datarow, container_policy)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2350
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2351
        # set the initial data if it is given
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2352
        rowproxy = utils.get_list(self.dataproxy._get(self.dataelem_name))[-1]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2353
        if data != None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2354
            for index in range(len(data)):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2355
                if data[index] != None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2356
                    rowproxy[index].set_value(data[index])
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2357
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2358
    def set_template(self, data=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2359
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2360
        Set the template of the feature sequence  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2361
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2362
        if data is None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2363
            self._templatedata = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2364
            return
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2365
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2366
        if not isinstance(data, list):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2367
            raise TypeError('data must be a list (got %r)' % data)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2368
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2369
        # Create the new template data object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2370
        templatedata = Data(fqr=self.fqr, template=True)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2371
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2372
        # Add all sub-objects to the data object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2373
        def add_data_objects(feature, data_obj, value_list):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2374
            refs = feature.list_features()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2375
            if len(refs) != len(value_list):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2376
                raise ValueError("Data value list is invalid")
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2377
            for i, ref in enumerate(refs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2378
                value = value_list[i]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2379
                subfea = feature.get_feature(ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2380
                if isinstance(value, list):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2381
                    subdata = Data(ref=ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2382
                    data_obj.add(subdata)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2383
                    add_data_objects(feature.get_feature(ref), subdata, value)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2384
                else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2385
                    if value is not None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2386
                        subdata = Data(ref=ref, value=subfea.set_value_cast(value))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2387
                        data_obj.add(subdata)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2388
        add_data_objects(self, templatedata, data)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2389
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2390
        self._set_template_data(templatedata)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2391
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2392
        # Remove any existing template data
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2393
        pconfig = self.find_parent(type=Configuration)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2394
        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
  2395
        if dataobjs:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2396
            for dataobj in dataobjs:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2397
                dataobj._parent._remove(dataobj.get_fullref())
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2398
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2399
        # Add the template data to the parent config (beginning of the data section)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2400
        pconfig.add_data(self._templatedata, policy=container.PREPEND)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2401
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2402
    def get_template(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2403
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2404
        Add a feature data row for a new data in this sequence 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2405
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2406
        #self._set_template(None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2407
        # set the initial data if it is given
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2408
        if self._templatedata:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2409
            def get_data_items(feature, data_obj):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2410
                refs = feature.list_features()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2411
                if refs:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2412
                    result = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2413
                    for ref in refs:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2414
                        if data_obj._has(ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2415
                            result.append(get_data_items(feature.get_feature(ref), data_obj._get(ref)))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2416
                        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2417
                            result.append(None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2418
                    return result
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2419
                else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2420
                    return data_obj.value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2421
            return get_data_items(self, self._templatedata)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2422
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2423
            return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2424
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2425
    def get_data(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2426
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2427
        Helper function to get the topmost data value from the default view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2428
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2429
        if self.dataproxy._has(self.dataelem_name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2430
            return utils.get_list(self.dataproxy._get(self.dataelem_name))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2431
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2432
            return []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2433
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2434
    def add_data(self, data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2435
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2436
        Add a data value.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2437
        @param data: A Data object  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2438
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2439
        # Skip template data adding
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2440
        if data.template:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2441
            self._set_template_data(data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2442
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2443
            # Get the data index
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2444
            self._add_datarow(data, self._get_policy(data))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2445
        return
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2446
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2447
    def get_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2448
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2449
        Helper function to get the topmost data value from the default view.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2450
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2451
        if self._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2452
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2453
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2454
        datatable =  self.get_data()
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2455
        rettable = []
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2456
        for row in datatable:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2457
            rowvalues = row.value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2458
            rettable.append(rowvalues)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2459
        return rettable
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2460
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2461
    def get_original_value(self, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2462
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2463
        Get the current value of the feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2464
        @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
  2465
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2466
        if self._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2467
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2468
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2469
        datatable =  self.get_data()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2470
        rettable = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2471
        for row in datatable:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2472
            rowvalues = row.get_original_value()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2473
            rettable.append(rowvalues)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2474
        return rettable
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2475
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2476
    def set_value(self, value, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2477
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2478
        Set the current value for this feature. Set the value on the topmost layer.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2479
        @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
  2480
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2481
        if value:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2482
            # Add the first item with replace policy
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2483
            self.add_sequence(value[0], self.POLICY_REPLACE)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2484
            for row in value[1:]:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2485
                self.add_sequence(row)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2486
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2487
            # Setting the sequence to empty, so add one empty item-setting
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2488
            # to signify that
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2489
            self.add_sequence(None, self.POLICY_REPLACE)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2490
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2491
            # Strip all sub-elements from the data element just created,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2492
            # since the ConfML spec says that an empty sequence is denoted
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2493
            # by a single empty data element
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2494
            data_elem = self.get_data()[0].get_datas()[0]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2495
            for r in list(data_elem._order):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2496
                data_elem._remove(r)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2497
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2498
    def is_sequence(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2499
        """ Return always true from a sequence object """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2500
        return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2501
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2502
    def is_sequence_root(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2503
        """ Return true if this feature is a sequence object it self """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2504
        return True
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2505
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2506
    def get_column_features(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2507
        """ Return a list of sequence subfeature, which are the columns of the sequence """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2508
        columns = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2509
        for subref in self.list_features():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2510
            columns.append(self.get_feature(subref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2511
        return columns
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2512
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2513
    def get_sequence_parent(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2514
        """ Return this object as a sequence parent """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2515
        return self
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2516
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2517
    value = property(get_value, set_value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2518
    data = property(get_data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2519
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2520
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2521
def add_sequence_feature(parent_feature, feature, path=""):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2522
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2523
    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
  2524
    as columns of the feature sequence
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2525
    @param parent_feature: The parent feature where the feature object is added 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2526
    @param feature: The Feature object to add 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2527
    @param path: path to feature if it not added directly under parent_fea 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2528
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2529
    # modify all possible children of feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2530
    for fea in feature._traverse(type=Feature):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2531
        to_sequence_feature(fea)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2532
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2533
    # Finally modify and add this feature to parent_feat
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2534
    to_sequence_feature(feature)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2535
    parent_feature._add_to_path(path, feature)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2536
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2537
def to_sequence_feature(feature):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2538
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2539
    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
  2540
    @param feature: The Feature object for which is modified.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2541
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2542
    feature.get_value = feature.get_column_value 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2543
    feature.get_original_value = feature.get_column_original_value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2544
    feature.set_value = feature.set_column_value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2545
    feature.add_feature = feature.add_sequence_feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2546
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2547
def get_column_value(feasequence, ref, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2548
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2549
    Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2550
    @param feasequence: the feature sequence object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2551
    @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2552
    @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
  2553
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2554
    """ get the feature specific data from sequence => a column of data table """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2555
    coldata =  []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2556
    for row in feasequence.data:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2557
        feadata = row.get_feature(ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2558
        coldata.append(feadata.get_value(attr))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2559
    return coldata
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2560
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2561
def get_column_original_value(feasequence, ref, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2562
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2563
    Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2564
    @param feasequence: the feature sequence object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2565
    @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2566
    @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
  2567
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2568
    """ get the feature specific data from sequence => a column of data table """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2569
    coldata =  []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2570
    for row in feasequence.data:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2571
        feadata = row.get_feature(ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2572
        coldata.append(feadata.get_original_value(attr))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2573
    return coldata
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2574
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2575
def set_column_value(feasequence, ref, value, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2576
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2577
    Get the value of the featuresequence column
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2578
    @param feasequence: the feature sequence object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2579
    @param ref: the reference to the column   
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2580
    @param value: the value to set. This must be a list instance. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2581
    @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
  2582
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2583
    if not isinstance(value,list): 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2584
        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
  2585
    seqrows = feasequence.data
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2586
    if len(seqrows) < len(value): 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2587
        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
  2588
    for i in range(0, len(value)):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2589
        feadata = seqrows[i].get_feature(ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2590
        feadata.set_value(value[i])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2591
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2592
class FeatureSequenceCell(Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2593
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2594
    A Feature class. Feature is the base for all Configurable items in a Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2595
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2596
    def __init__(self, ref="", **kwargs):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2597
        super(FeatureSequenceCell, self).__init__(ref)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2598
        self.name = kwargs.get('name', ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2599
        self.type = 'seqcell'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2600
 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2601
    def get_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2602
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2603
        Get the current value of the feature
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2604
        @param attr: The attribute name of the data. E.g. attr='data', attr='rfs' 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2605
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2606
        return self.dataproxy._get_value(attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2607
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2608
    def set_value(self, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2609
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2610
        Set the current value for this feature. Set the value on the topmost layer.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2611
        @param value: the value to set
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2612
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2613
        # The sequence cell only updates the latest value in the proxy  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2614
        self.dataproxy.get_data().set_value(value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2615
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2616
    value = property(get_value, set_value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2617
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2618
class FeatureSequenceSub(Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2619
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2620
    A Feature class. Feature is the base for all Configurable items in a Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2621
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2622
    def __init__(self, ref="", **kwargs):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2623
        super(FeatureSequenceSub, self).__init__(ref)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2624
        self.name = kwargs.get('name', ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2625
        self.type = 'subseq'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2626
        self._index = 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2627
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2628
    def __getstate__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2629
        state = super(FeatureSequenceSub,self).__getstate__()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2630
        state['_children'].pop('?datarows', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2631
        return state
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2632
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2633
    def get_index(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2634
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2635
        @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
  2636
        0 for normal data.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2637
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2638
        return self._index
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2639
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2640
    def set_value(self, value, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2641
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2642
        Set the current value for this sequence row.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2643
        @param value: the value row to set
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2644
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2645
        if utils.is_list(value):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2646
            for subindex in range(0, len(value)):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2647
                self.dataproxy[subindex].get_data().set_value(value[subindex])
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2648
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2649
            data_objs = self.convert_value_to_data(value)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2650
            data_object_where_to_add = self._parent._get_data()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2651
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2652
            self.dataproxy._set_datas(data_objs, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2653
            data_object_where_to_add._add(data_objs, container.REPLACE)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2654
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2655
    def get_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2656
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2657
        Set the current value for this feature. Set the value on the topmost layer.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2658
        @param value: the value to set
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2659
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2660
        # Handle empty sequences
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2661
        if self.get_sequence_parent()._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2662
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2663
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2664
        # The sequence cell only updates the latest value in the proxy
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2665
        childdatas = self.dataproxy._objects()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2666
        if len(childdatas) > 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2667
            return [subdata.value for subdata in childdatas]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2668
        else: 
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2669
            return super(FeatureSequenceSub,self).get_value(attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2670
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2671
    def get_original_value(self, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2672
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2673
        Get the current value of the feature
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2674
        @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
  2675
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2676
        # Handle empty sequences
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2677
        if self.get_sequence_parent()._has_empty_sequence_marker():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2678
            return []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2679
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2680
        childdatas = self.dataproxy._objects()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2681
        if len(childdatas) > 0:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2682
            return [subdata.get_original_value() for subdata in childdatas]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2683
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2684
            return self.dataproxy._get_value(attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2685
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2686
    value = property(get_value, set_value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2687
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2688
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2689
class FeatureLink(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2690
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2691
    A _FeatureProxy class. _FeatureProxy is the object that is added to View as a 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2692
    link to the actual Feature object. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2693
    """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2694
    """ class variable for defining the override attributes"""
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2695
    override_attributes = ['name']
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2696
    ref_prefix = 'link_'
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2697
    PROXYREF_PREFIX = 'proxy_'
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2698
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2699
    def __init__(self, ref="", **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2700
        # Store the fully qualified reference to this object
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2701
        self.link = kwargs.get('link', ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2702
        self.name = kwargs.get('name', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2703
        ref = self.get_featurelink_ref(self.link)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2704
        # the reference of this particular object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2705
        super(FeatureLink, self).__init__(ref, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2706
        self._obj = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2707
        self._populated = False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2708
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2709
    def add(self, child, policy=container.REPLACE):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2710
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2711
        Add an override to enable adding any override attribute to a featurelink object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2712
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2713
        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
  2714
        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
  2715
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2716
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2717
        @param child: the child object to add
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2718
        @raise IncorrectClassError: if the given class cannot be added to this object.  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2719
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2720
        if isinstance(child, Base):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2721
            self._add(child, policy)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2722
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2723
            raise exceptions.IncorrectClassError("Cannot add %s to %s" % (child, self))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2724
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2725
    def get_name(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2726
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2727
        Return the name of the featurelink
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2728
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2729
        return self.name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2730
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2731
    def set_name(self, name):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2732
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2733
        Set the name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2734
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2735
        self.name = name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2736
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2737
    @property
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2738
    def fqr(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2739
        return self.link
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2740
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2741
    def populate(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2742
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2743
        Populate or fetch the link to the actual feature for this featureproxy.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2744
        This method fetches the feature to the _obj member variable and populates also 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2745
        subfeatures. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2746
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2747
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2748
            if not self._populated:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2749
                feas = self.get_default_view().get_features(self.link)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2750
                # get the non wildcard part of ref
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2751
                static_ref = utils.dottedref.get_static_ref(self.link)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2752
                # add the found features to the parent
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2753
                for fea in feas:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2754
                    override_attrs = {}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2755
                    # override the FeatureProxy object with exactly same reference 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2756
                    # (in feat/* case dont override the children features)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2757
                    if fea.fqr == static_ref:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2758
                        override_attrs = self.get_attributes()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2759
                    feature = fea._obj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2760
                    proxy_ref = self.get_featureproxy_ref(feature.fqr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2761
                    proxy = _FeatureProxy(proxy_ref, feature, **override_attrs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2762
                    self._get_parent()._add(proxy)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2763
                    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2764
        except exceptions.NotFound, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2765
                parent_view = self._find_parent_or_default(type=View)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2766
                view_name = parent_view.get_name()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2767
                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
  2768
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2769
    def get_attributes(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2770
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2771
        Returns a list of FeatureLink attributes that override settings of the original feature.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2772
        @return: a dictionary of attribute key : value pairs.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2773
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2774
        attrs = {}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2775
        for attr in self.override_attributes:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2776
            # try to get the attribute from this object
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2777
            # and set it to the attribute list if it not None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2778
            try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2779
                value = getattr(self, attr)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2780
                if value != None: attrs[attr] = value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2781
            except AttributeError:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2782
                pass
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2783
        return attrs
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2784
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2785
    @classmethod
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2786
    def get_featurelink_ref(cls, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2787
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2788
        return a featurelink ref from a feature ref. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2789
        This is needed to make the featurelink object refs unique in a container
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2790
        that has Features. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2791
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2792
        return cls.ref_prefix + ref.replace('.', '_').replace('/','_')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2793
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2794
    @classmethod
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2795
    def get_featureproxy_ref(cls, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2796
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2797
        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
  2798
        This is needed to make the featureproxy object refs unique in a container
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2799
        that has Features. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2800
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2801
        return cls.PROXYREF_PREFIX + ref.replace('.', '_').replace('/','_')
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2802
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2803
class _FeatureProxy(container.ObjectProxyContainer, Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2804
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2805
    A _FeatureProxy class. _FeatureProxy is the object that is added to View as a 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2806
    link to the actual Feature object. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2807
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2808
    def __init__(self, ref="", obj=None, **kwargs):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2809
        container.ObjectProxyContainer.__init__(self, obj, ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2810
        Base.__init__(self, ref, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2811
        self.support_data = False
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2812
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2813
    def __getattr__(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2814
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2815
        First check if the requested attr is a children then 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2816
        direct all not found attribute calls to the sub object getattr
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2817
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2818
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2819
            return self.__dict__['_children'][name] 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2820
        except KeyError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2821
            return getattr(self._obj, name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2822
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2823
    def __getitem__(self, index):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2824
        return self._objects()[index]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2825
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2826
    def __setitem__(self, index, value):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2827
        raise exceptions.NotSupportedException()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2828
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2829
    def __delitem__(self, index):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2830
        item = self.__getitem__(index)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2831
        return self._remove(item.get_ref())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2832
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2833
    def __len__(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2834
        return len(self._order)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2835
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2836
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2837
        if isinstance(obj, _FeatureProxy):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2838
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2839
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2840
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2841
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2842
    def _default_object(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2843
        return Group(name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2844
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2845
    def _set_parent(self, newparent):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2846
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2847
        @param newparent:  The new parent object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2848
        @return: None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2849
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2850
        self._parent = newparent
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2851
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2852
    def get_proxied_obj(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2853
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2854
        @return: Returns proxied object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2855
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2856
        return self._obj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2857
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2858
    def add_feature(self, feature, path=""):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2859
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2860
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2861
        if not isinstance(feature, Feature):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2862
            raise exceptions.IncorrectClassError("add_feature requires instance of Feature!! Given %s" % feature)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2863
        if not self.support_data:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2864
            self._add_to_path(path, _FeatureProxy(feature._name, feature))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2865
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2866
            self._add_to_path(path, _FeatureDataProxy(feature._name, feature))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2867
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2868
    def remove_feature(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2869
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2870
        remove a given feature from this view by reference. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2871
        @param ref: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2872
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2873
        self._remove(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2874
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2875
    def get_feature(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2876
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2877
        @param path: The path (ref) to the given feature 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2878
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2879
        return self._get(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2880
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2881
    def list_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2882
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2883
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2884
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2885
        return self._list()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2886
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2887
    def list_all_features(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2888
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2889
        Return a array of all Feature children references under this object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2890
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2891
        return [fea._path(self) for fea in self._traverse(type=_FeatureProxy)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2892
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2893
    def populate(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2894
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2895
        Dummy implementation of populate
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2896
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2897
        pass
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2898
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2899
    def has_attribute(self, name):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2900
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2901
        Perform a check whether an attribute with given name is stored inside the 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2902
        _FeatureProxy. The check does not extend to the proxied (_obj) insanses or 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2903
        children of this proxy.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2904
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2905
        @return: True when an attribute is a real attribute in this _FeatureProxy object. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2906
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2907
        return self.__dict__.has_key(name)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2908
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2909
    def get_option(self, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2910
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2911
        @param name: The option reference of the option (as returned by 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
        real_ref = 'opt_' + ref
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2914
        for op in self.options.values():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2915
            if op.ref == real_ref:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2916
                return op
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2917
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2918
            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2919
            obj = self.get_proxied_obj()._get(real_ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2920
            if not isinstance(obj, Option):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2921
                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
  2922
            return obj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2923
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2924
    def list_options(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2925
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2926
        Return a array of all Option children references under this object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2927
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2928
        opts = self.get_proxied_obj().list_options()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2929
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2930
        for opt in self.options:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2931
            opts.append(self.options[opt].ref[4:])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2932
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2933
        return opts
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2934
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2935
    def get_property(self, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2936
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2937
        @param name: The property reference of the property (as returned by list_properties()) 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2938
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2939
        for prop in self.properties.values():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2940
            if prop.ref == Property.to_propertyref(ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2941
                return prop
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2942
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2943
            obj = self.get_proxied_obj()._get(Property.to_propertyref(ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2944
            return obj
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2945
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2946
    def list_properties(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2947
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2948
        Return a array of all Property children references under this object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2949
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2950
        props = self.get_proxied_obj().list_properties()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2951
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2952
        for pr in self.properties:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2953
            props.append(Property.to_normref(self.properties[pr].ref))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2954
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2955
        return props
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2956
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2957
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2958
class _FeatureDataProxy(_FeatureProxy):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2959
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2960
    A Feature class. Feature is the base for all Configurable items in a Configuration.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2961
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2962
    DEFAULT_KEY = 'data'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2963
    def __init__(self, ref="", obj=None, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2964
        # Initialize _obj to None, because __getattr__(), __setattr__()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2965
        # and __delattr__() access it.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2966
        # Note that we cannot use self._obj = None here, since that would
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2967
        # invoke __setattr__(), causing a kind of a chicken-and-egg problem
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2968
        object.__setattr__(self, '_obj', None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2969
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2970
        super(_FeatureDataProxy, self).__init__(ref, obj)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2971
        self.support_data = True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2972
        """ 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
  2973
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2974
        self.defaultkey = _FeatureDataProxy.DEFAULT_KEY
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2975
        self.datas = {self.defaultkey : []}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2976
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2977
    def __getattr__(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2978
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2979
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2980
        if object.__getattribute__(self, '_obj') is not None:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2981
            self.get_proxied_obj().dataproxy = self
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2982
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2983
        if name in Feature.PROPERTIES:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2984
            return getattr(self.get_proxied_obj(), name)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2985
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2986
            return super(_FeatureDataProxy, self).__getattr__(name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2987
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2988
    def __setattr__(self, name, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2989
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2990
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2991
        if object.__getattribute__(self, '_obj') is not None:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2992
            self.get_proxied_obj().dataproxy = self
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2993
            
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2994
        if name in Feature.PROPERTIES:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  2995
            return setattr(self.get_proxied_obj(), name, value)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2996
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2997
            super(_FeatureDataProxy, self).__setattr__(name, value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2998
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  2999
    def __delattr__(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3000
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3001
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3002
        if name in Feature.PROPERTIES:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3003
            return delattr(self.get_proxied_obj(), name)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3004
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3005
            return super(_FeatureDataProxy, self).__delattr__(name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3006
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3007
    def _add_data(self, data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3008
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3009
        Add a data value or a list of data values.
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3010
        @param data: A Data object  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3011
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3012
        if isinstance(data, list):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3013
            for d in data: self._add_data(d)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3014
            return
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3015
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3016
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3017
            self.datas[data.attr].append(data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3018
        except KeyError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3019
            """ Create a list object for missing attribute """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3020
            self.datas[data.attr] = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3021
            self.datas[data.attr].append(data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3022
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3023
    def _get_data(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3024
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3025
        Get the data value. in sequence setting cases returns an array of data.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3026
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3027
        dataattr = attr or self.defaultkey
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3028
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3029
            if len(self.datas[dataattr]) > 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3030
                return self.datas[dataattr][-1]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3031
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3032
                return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3033
        except KeyError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3034
            """ return None for missing attribute """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3035
            return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3036
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3037
    def _get_datas(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3038
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3039
        Get the entire data array.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3040
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3041
        dataattr = attr or self.defaultkey
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3042
        return self.datas.get(dataattr, [])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3043
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3044
    def _set_datas(self, datas, attr=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3045
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3046
        Set the entire data array.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3047
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3048
        dataattr = attr or self.defaultkey
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3049
        self.datas[dataattr] = list(datas)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3050
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3051
    def _get_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3052
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3053
        Get the topmost data value.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3054
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3055
        if self._get_data(attr):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3056
            return self._get_data(attr).get_value()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3057
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3058
            return None
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3059
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3060
    def _set_value(self, datavalue, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3061
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3062
        Set the value for the feature the last configuration in the current hierarchy
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3063
        @param value: The value for the feature.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3064
        @return: The created Data object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3065
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3066
        # Make sure that data value exists only once the the last configuration layer
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3067
        # 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
  3068
        # otherwise create a new data elem to the topmost layer
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3069
        dataobj = self._get_data(attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3070
        last_config = self.get_root_configuration().get_last_configuration()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3071
        if dataobj and dataobj.find_parent(type=Configuration) == last_config:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3072
            dataobj.set_value(datavalue)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3073
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3074
            dataobj = Data(fqr=self.fqr, value=datavalue, attr=attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3075
            last_config.add_data(dataobj)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3076
            self._add_data(dataobj)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3077
        return dataobj
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3078
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3079
    def _del_value(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3080
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3081
        Remove the 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3082
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3083
        data = self._get_data(attr)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3084
        if data:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3085
            dataattr = attr or self.defaultkey
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3086
            parentconfig = data.find_parent(type=Configuration)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3087
            if parentconfig:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3088
                parentconfig.remove_data(data.get_fullfqr())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3089
            del self.datas[dataattr][-1]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3090
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3091
    def _get_values(self, attr=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3092
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3093
        Get the topmost data value.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3094
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3095
        dataattr = attr or self.defaultkey
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3096
        return [dataelem.get_value() for dataelem in self.datas[dataattr]]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3097
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3098
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3099
class DataBase(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3100
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3101
        super(DataBase, self).__init__(ref, **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3102
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3103
    def _supported_type(self, obj):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3104
        if isinstance(obj, (DataContainer, DataBase)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3105
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3106
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3107
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3108
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3109
    def _default_object(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3110
        return Data(ref=name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3111
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3112
    def count(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3113
        return len(self._objects())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3114
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3115
    def add(self, child, policy=container.REPLACE):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3116
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3117
        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
  3118
        proxy function that call the correct add function based on the child objects class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3119
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3120
        Example: obj.add(Feature("test")), actually obj.add_feature(Feature("test"))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3121
        @param child: the child object to add
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3122
        @raise IncorrectClassError: if the given class cannot be added to this object.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3123
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3124
        if isinstance(child, (Data)):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3125
                self._add(child, container.APPEND)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3126
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3127
            raise exceptions.IncorrectClassError("Cannot add %s object to %s" % (child, self))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3128
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3129
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3130
class DataContainer(DataBase):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3131
    def __init__(self, ref="", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3132
        super(DataContainer, self).__init__(ref, **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3133
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3134
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3135
class Data(DataBase):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3136
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3137
    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
  3138
    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
  3139
    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
  3140
    is 'rfs'.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3141
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3142
    def __init__(self, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3143
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3144
        @param ref: the reference to the feature. E.g. foo
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3145
        @param fqr: the full reference to the feature. E.g. 'foo.bar' 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3146
        @param value: the value of the data
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3147
        @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
  3148
        for example 'rfs'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3149
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3150
        name = kwargs.get('ref', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3151
        self.fearef = kwargs.get('fqr', None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3152
        if self.fearef:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3153
            (namespace, name) = utils.dottedref.psplit_ref(self.fearef)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3154
        super(Data, self).__init__(name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3155
        self.value  = kwargs.get('value', None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3156
        self.attr   = kwargs.get('attr') or 'data'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3157
        self.policy = kwargs.get('policy', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3158
        self.template = kwargs.get('template', False)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3159
        self.map    = kwargs.get('map')
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3160
        self.empty  = kwargs.get('empty', False)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3161
        self.lineno = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3162
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3163
    def __setstate__(self, state):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3164
        super(Data, self).__setstate__(state)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3165
        self.value = state.get('value', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3166
        self.attr = state.get('attr', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3167
        self.policy = state.get('policy', '')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3168
        self.map = state.get('map', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3169
        self.template = state.get('template', False)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3170
        self.lineno = state.get('lineno', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3171
        self.fearef = state.get('fearef', None)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3172
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3173
    def get_fearef(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3174
        if self.fearef:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3175
            return self.fearef
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3176
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3177
            return self.fqr
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3178
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3179
    def get_value(self):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3180
        return self.value
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3181
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3182
    def get_map(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3183
        return self.map
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3184
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3185
    def set_map(self, map):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3186
        self.map = map
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3187
        if self.value:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3188
            #Either value or mapping can be defined. Not both.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3189
            self.value = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3190
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3191
    def set_value(self, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3192
        self.value = value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3193
        if self.map:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3194
            #Either value or mapping can be defined. Not both.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3195
            self.map = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3196
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3197
    def get_policy(self): return self._policy
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3198
    def set_policy(self, value): self._policy = value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3199
    def del_policy(self):  self._policy = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3200
    policy = property(get_policy, set_policy, del_policy)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3201
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3202
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3203
class ValueSet(set):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3204
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3205
    A value set object to indicate a set of possible values for a feature. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3206
    e.g. A boolean feature ValueSet([True, False])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3207
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3208
    def __init__(self, initial_set=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3209
        super(ValueSet, self).__init__(initial_set or [])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3210
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3211
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3212
class ValueRange(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3213
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3214
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3215
    def __init__(self, fromvalue, tovalue, step=1):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3216
        self.fromvalue = fromvalue
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3217
        self.tovalue = tovalue
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3218
        self.step = step
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3219
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3220
    def __contains__(self, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3221
        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
  3222
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3223
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3224
class ValueRe(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3225
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3226
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3227
    def __init__(self, regexp):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3228
        self.regexp = re.compile(regexp)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3229
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3230
    def __contains__(self, value):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3231
        if isinstance(value, str):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3232
            return self.regexp.match(value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3233
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3234
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3235
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3236
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3237
class Property(Base):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3238
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3239
    Confml property class
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3240
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3241
    def __init__(self, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3242
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3243
        @param name=str: name string (mandatory)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3244
        @param value=str: value for the property, string 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3245
        @param unit=str: unit of the property
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3246
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3247
        if kwargs.get('name',None) == None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3248
            raise ValueError("Property name cannot be None!")
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3249
        super(Property,self).__init__(Property.to_propertyref(kwargs.get('name',None)))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3250
        self.name = kwargs.get('name',None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3251
        self.value = kwargs.get('value',None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3252
        self.unit = kwargs.get('unit',None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3253
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3254
    @classmethod
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3255
    def to_propertyref(cls, name):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3256
        """ 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3257
        @param name: name of the property 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3258
        @return: A property reference.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3259
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3260
        if name is not None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3261
            return "property_%s" % name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3262
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3263
            raise ValueError("Property name cannot be None!")
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3264
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3265
    @classmethod
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3266
    def to_normref(cls, ref):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3267
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3268
        @param ref: a property reference 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3269
        @return: normalized property reference
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3270
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3271
        return ref[9:]
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3272
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3273
    def get_name(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3274
        return self.name
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3275
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3276
    def get_value(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3277
        return self.value
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3278
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3279
    def get_unit(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3280
        return self.unit
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3281
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3282
class Option(Base):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3283
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3284
    Confml option class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3285
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3286
    def __init__(self, name, value, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3287
        super(Option, self).__init__(Option.to_optref(value, kwargs.get('map', None)))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3288
        self.name = name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3289
        self.value = value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3290
        self.map = kwargs.get('map', None)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3291
        self.relevant = kwargs.get('relevant', None)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3292
        self.map_value = kwargs.get('map_value', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3293
        self.display_name = kwargs.get('display_name', None)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3294
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3295
    @classmethod
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3296
    def to_optref(cls, value, map):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3297
        """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3298
        @return: An option reference converted from value or map, depending
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3299
            on which one is not None.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3300
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3301
        if value is not None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3302
            return "opt_value_%s" % value.replace('.', '').replace('/', '').replace(' ', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3303
        elif map is not None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3304
            return "opt_map_%s" % map.replace('.', '').replace('/', '').replace(' ', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3305
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3306
            raise ValueError("Both value and map are None!")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3307
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3308
    def get_name(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3309
        return self.name
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3310
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3311
    def get_value(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3312
        return self.value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3313
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3314
    def __cmp__(self, other):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3315
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3316
            ref = getattr(other, 'ref')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3317
        except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3318
            ref = other
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3319
        if self.ref < ref:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3320
            return -1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3321
        elif self.ref == ref:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3322
            return 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3323
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3324
            return 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3325
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3326
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3327
class Storage(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3328
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3329
    A general base class for all storage type classes
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3330
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3331
    """ File open modes """ 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3332
    MODE_UNKNOWN= -1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3333
    MODE_READ   = 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3334
    MODE_WRITE  = 2
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3335
    MODE_APPEND = 3
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3336
    MODE_DELETE = 4
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3337
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3338
    def __init__(self, path, mode=''):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3339
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3340
        @param path: the reference to the root of the storage.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3341
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3342
        self.rootpath = path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3343
        self.curpath = ""
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3344
        self.container = True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3345
        self.__opened_res__ = {}
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3346
        self.mode = mode
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3347
        self.cpath_stack = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3348
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3349
    def __reduce_ex__(self, protocol_version):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3350
        return  (open_storage, 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3351
                 (self.path, self.mode),
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3352
                 None,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3353
                 None,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3354
                 None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3355
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3356
    def __opened__(self, res):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3357
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3358
        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
  3359
        @param res: The resource object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3360
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3361
        if self.__opened_res__.has_key(res.path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3362
            self.__opened_res__[res.path].append(res)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3363
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3364
            self.__opened_res__[res.path] = [res]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3365
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3366
    def __closed__(self, res):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3367
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3368
        Internal function to remove a Resource object from the list of open resources.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3369
        @param res: The resource object to remove
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3370
        @raise StorageException if the given resource object is not found: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3371
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3372
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3373
            self.__opened_res__[res.path].remove(res)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3374
            if len(self.__opened_res__[res.path]) == 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3375
                del self.__opened_res__[res.path]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3376
        except KeyError, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3377
            raise exceptions.StorageException("No such %s open resource! %s" % (res, e))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3378
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3379
    def __has_open__(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3380
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3381
        Internal function to find out if any Resource objects are open from given ref.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3382
        @param ref: The resource ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3383
        @return: True if resources found. Otherwise False.   
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3384
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3385
        return self.__opened_res__.has_key(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3386
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3387
    def __get_open__(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3388
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3389
        Internal function to get all resource opened on a certain ref .
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3390
        @param ref: The resource ref
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3391
        @return: A list of open resources. Empty list if nothing is found   
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3392
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3393
        if self.__has_open__(path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3394
            # return a copy of currently open resources
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3395
            return self.__opened_res__[path][:]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3396
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3397
            return []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3398
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3399
    def __has_resource__(self, res):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3400
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3401
        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
  3402
        @param ref: The resource object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3403
        @return: True if resources found. Otherwise False.   
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3404
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3405
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3406
            res = self.__opened_res__[res.path].index(res)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3407
            return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3408
        except KeyError, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3409
            return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3410
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3411
    @classmethod
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3412
    def open(cls,path, mode="r", **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3413
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3414
        Class method for opening an instance of Storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3415
        @param path: path to storage, which will determine what type of storage is initiated. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3416
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3417
        # import all storage instances
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3418
        from cone.storage import storages
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3419
        for storagename in storages:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3420
            storagemodule = 'cone.storage.'+storagename
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3421
            module = __import__(storagemodule)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3422
        for storage_class in utils.all_subclasses(Storage):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3423
            if storage_class.supported_storage(path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3424
                if hasattr(storage_class, '__open__'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3425
                    return storage_class.__open__(path, mode, **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3426
                else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3427
                    return storage_class(path, mode, **kwargs)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3428
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3429
        obj = Storage(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3430
        return obj
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3431
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3432
    @classmethod
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3433
    def supported_storage(cls, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3434
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3435
        Class method for determing if the given clas supports a storage by given path. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3436
        E.g. foo.zip, foo.cpd, foo/bar, http://foo.com/
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3437
        @param path:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3438
        @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
  3439
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3440
        return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3441
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3442
    def set_path(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3443
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3444
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3445
        self.rootpath = path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3446
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3447
    def get_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3448
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3449
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3450
        return self.rootpath
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3451
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3452
    def push(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3453
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3454
        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
  3455
        The current path can be reverted with pop method.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3456
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3457
        @return: None 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3458
        @param path: The path which is set as current path.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3459
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3460
        self.cpath_stack.append(self.curpath)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3461
        self.curpath = path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3462
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3463
    def pop(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3464
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3465
        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
  3466
        current path stack with push. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3467
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3468
        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
  3469
        keeping the active path in the storages root path. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3470
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3471
        @return: The new path.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3472
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3473
        try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3474
            path = self.cpath_stack.pop()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3475
            self.curpath = path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3476
        except IndexError:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3477
            pass
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3478
        return self.curpath
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3479
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3480
    def set_current_path(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3481
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3482
        @param path: the current path under the Storage. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3483
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3484
        self.curpath = utils.resourceref.remove_end_slash(utils.resourceref.remove_begin_slash(path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3485
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3486
    def get_current_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3487
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3488
        get the current path under the Storage. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3489
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3490
        return self.curpath
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3491
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3492
    def close(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3493
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3494
        Close the repository, which will save and close all open resources.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3495
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3496
        for openref in self.__opened_res__.keys():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3497
            for res in self.__get_open__(openref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3498
                self.close_resource(res)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3499
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3500
    def save(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3501
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3502
        Flush changes from all resources to the repository.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3503
        """        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3504
        for openref in self.__opened_res__.keys():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3505
            for res in self.__get_open__(openref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3506
                self.save_resource(res)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3507
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3508
    def open_resource(self, path, mode="r"):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3509
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3510
        Open the given resource and return a File object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3511
        @param path : reference to the resource 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3512
        @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
  3513
        raises a NotResource exception if the ref item is not a resource.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3514
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3515
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3516
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3517
    def delete_resource(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3518
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3519
        Delete the given resource from storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3520
        @param path: reference to the resource 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3521
        raises a NotSupportedException exception if delete operation is not supported by the storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3522
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3523
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3524
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3525
    def close_resource(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3526
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3527
        Close a given resource instance. Normally this is called by the Resource object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3528
        in its own close.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3529
        @param path the reference to the resource to close. 
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 is_resource(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3534
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3535
        Return true if the ref is a resource
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3536
        @param ref : reference to path where resources are searched
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3537
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3538
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3539
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3540
    def list_resources(self, path, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3541
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3542
        find the resources under certain ref/path 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3543
        @param ref : reference to path where resources are searched
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3544
        @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
  3545
        Default value is False. Set to True to enable recursion.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3546
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3547
        return []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3548
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3549
    def import_resources(self, paths, storage):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3550
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3551
        import resources from a list of resources to this storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3552
        @param paths : a list of Resourse objects.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3553
        @param storage : the external storage from which files are imported.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3554
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3555
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3556
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3557
    def export_resources(self, paths, storage):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3558
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3559
        export resources from this storage based on a list of reference to this storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3560
        @param path : a list of resource paths in this storage (references).
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3561
        @param storage : the external storage where to export.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3562
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3563
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3564
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3565
    def save_resource(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3566
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3567
        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
  3568
        in its own save.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3569
        @param ref the reference to the resource to close. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3570
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3571
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3572
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3573
    def create_folder(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3574
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3575
        Create a folder entry to a path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3576
        @param path : path to the folder
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3577
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3578
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3579
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3580
    def delete_folder(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3581
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3582
        Delete a folder entry from a path. The path must be empty.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3583
        @param path : path to the folder
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3584
        """  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3585
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3586
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3587
    def is_folder(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3588
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3589
        Check if the given path is an existing folder in the storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3590
        @param path : path to the folder
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3591
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3592
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3593
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3594
    def get_mode(self, mode_str):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3595
        if mode_str.find("w") != -1: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3596
            return self.MODE_WRITE
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3597
        elif mode_str.find("r") != -1:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3598
            return self.MODE_READ
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3599
        elif mode_str.find("a") != -1:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3600
            return self.MODE_APPEND
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3601
        elif mode_str.find("d") != -1:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3602
            return self.MODE_DELETE
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3603
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3604
            return self.MODE_UNKNOWN
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3605
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3606
    def unload(self, path, object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3607
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3608
        Dump a given object to the storage 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3609
        @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
  3610
        of Base class.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3611
        @param path: The reference where to store the object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3612
        @param object: The object instance to dump 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3613
        @raise StorageException: if the given object cannot be dumped to this storage 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3614
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3615
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3616
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3617
    def load(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3618
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3619
        Load an object from a reference.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3620
        @param path: The reference where to load the object 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3621
        @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
  3622
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3623
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3624
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3625
    path = property(get_path, set_path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3626
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3627
class Resource(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3628
    STATE_OPEN = 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3629
    STATE_CLOSE = 1
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3630
    def __init__(self, storage, path, mode=Storage.MODE_READ):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3631
        self.storage = storage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3632
        self.path = path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3633
        self.mode = mode
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3634
        self.state = Resource.STATE_OPEN
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3635
        self.content_info = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3636
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3637
    def get_path(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3638
        return self.path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3639
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3640
    def close(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3641
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3642
        Close the resource. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3643
        Note1: the resource object cannot be accessed anymore after it has been closed.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3644
        Note2: the changes are not automatically saved. The save operation must be explicitly called, 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3645
        to save data. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3646
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3647
        self.storage.close_resource(self.path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3648
        self.state = Resource.STATE_OPEN
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3649
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3650
    def read(self, bytes=0):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3651
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3652
        Read data.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3653
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3654
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3655
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3656
    def write(self, string):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3657
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3658
        Write data.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3659
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3660
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3661
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3662
    def truncate(self, size=0):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3663
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3664
        Trunkate this resource data to the given size.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3665
        @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
  3666
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3667
        raise exceptions.NotSupportedException()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3668
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3669
    def save(self, size=0):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3670
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3671
        Save all changes to data to storage.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3672
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3673
        raise exceptions.NotSupportedException()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3674
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3675
    def get_mode(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3676
        return self.storage.get_mode(self.mode)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3677
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3678
    def get_size(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3679
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3680
        Return the size of this resource in bytes.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3681
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3682
        Note that this does not work in write mode.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3683
        @return: The resource size in bytes:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3684
        @raise exceptions.StorageException: The resource was opened in write mode.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3685
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3686
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3687
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3688
    def get_content_info(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3689
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3690
        Return the ContentInfo class that contains content information about
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3691
        resource.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3692
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3693
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3694
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3695
class ContentInfo(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3696
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3697
    A ContentInfo object is used to describe content of Resource. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3698
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3699
    logger = logging.getLogger('cone.contentinfo')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3700
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3701
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3702
    def __init__(self, mimetype, mimesubtype):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3703
        #: MIME Media type (http://www.iana.org/assignments/media-types/)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3704
        #: as a string. E.g. 'image' or 'application'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3705
        self.mimetype = mimetype
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3706
        #: MIME Media subtype as a string. E.g. 'svg+xml' or 'bmp'.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3707
        self.mimesubtype = mimesubtype
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3708
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3709
    @property
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3710
    def content_type(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3711
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3712
        Returns MIME Media type (http://www.iana.org/assignments/media-types/) 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3713
        and subtype as a string. E.g. 'image/bmp'. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3714
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3715
        return self.mimetype + '/' + self.mimesubtype
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3716
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3717
class ImageContentInfo(ContentInfo):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3718
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3719
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3720
    A ImageContentInfo object is used to describe content of image Resources.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3721
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3722
    def __init__(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3723
        ContentInfo.__init__(self, 'image', '')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3724
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3725
class BmpImageContentInfo(ImageContentInfo):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3726
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3727
    A BmpImageContentInfo object is used to describe content of bmp image 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3728
    Resources.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3729
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3730
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3731
    _BMP_BITS_PER_PIXEL_OFFSET_ = int('0x1C', 16)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3732
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3733
    def __init__(self, resource, data):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3734
        ContentInfo.__init__(self, 'image', 'bmp')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3735
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3736
        #: Color depth as bits per pixel.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3737
        self.color_depth = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3738
        if (resource != None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3739
            try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3740
                self.color_depth = ord(data[self._BMP_BITS_PER_PIXEL_OFFSET_])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3741
            except Exception, e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3742
                self.logger.warning("Invalid BMP-file: %s" % resource.get_path())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3743
        
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3744
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3745
class currentdir(object):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3746
    def __init__(self, storage, curdir):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3747
        self.storage = storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3748
        # make sure that the curdir does not contain path prefix
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3749
        self.curdir = curdir.lstrip('/')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3750
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3751
    def __enter__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3752
        self.storage.push(self.curdir)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3753
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3754
    def __exit__(self, type, value, tb):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3755
        self.storage.pop()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3756
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3757
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3758
class Folder(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3759
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3760
    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
  3761
    """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3762
    def __init__(self, storage, path, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3763
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3764
        Create a layer folder to the storage if it does not exist.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3765
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3766
        self.curpath = path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3767
        self.storage = storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3768
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3769
    def set_path(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3770
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3771
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3772
        self.curpath = path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3773
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3774
    def get_path(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3775
        """
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.curpath
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 set_current_path(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3780
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3781
        @param path: the current path under the Storage. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3782
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3783
        self.curpath = utils.resourceref.remove_end_slash(utils.resourceref.remove_begin_slash(path))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3784
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3785
    def get_current_path(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3786
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3787
        get the current path under the Storage. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3788
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3789
        return self.curpath
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3790
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3791
    def close(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3792
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3793
        Close the repository, which will save and close all open resources.  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3794
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3795
        self.storage.close()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3796
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3797
    def save(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3798
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3799
        Flush changes from all resources to the repository.  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3800
        """        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3801
        return self.storage.save()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3802
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3803
    def open_resource(self, path, mode="r"):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3804
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3805
        Open the given resource and return a File object.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3806
        @param path : reference to the resource 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3807
        @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
  3808
        raises a NotResource exception if the ref item is not a resource.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3809
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3810
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3811
            res = self.storage.open_resource(path, mode)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3812
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3813
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3814
    def delete_resource(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3815
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3816
        Delete the given resource from storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3817
        @param path: reference to the resource 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3818
        raises a NotSupportedException exception if delete operation is not supported by the storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3819
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3820
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3821
            res = self.storage.delete_resource(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3822
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3823
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3824
    def close_resource(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3825
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3826
        Close a given resource instance. Normally this is called by the Resource object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3827
        in its own close.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3828
        @param path the reference to the resource to close. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3829
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3830
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3831
            res = self.storage.close_resource(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3832
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3833
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3834
    def is_resource(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3835
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3836
        Return true if the ref is a resource
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3837
        @param ref : reference to path where resources are searched
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3838
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3839
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3840
            res = self.storage.is_resource(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3841
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3842
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3843
    def list_resources(self, path, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3844
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3845
        find the resources under certain ref/path 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3846
        @param ref : reference to path where resources are searched
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3847
        @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
  3848
        Default value is False. Set to True to enable recursion.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3849
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3850
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3851
            res = self.storage.list_resources(path, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3852
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3853
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3854
    def import_resources(self, paths, storage):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3855
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3856
        import resources from a list of resources to this storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3857
        @param paths : a list of Resourse objects.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3858
        @param storage : the external storage from which files are imported.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3859
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3860
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3861
            res = self.storage.import_resources(paths, storage)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3862
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3863
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3864
    def export_resources(self, paths, storage):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3865
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3866
        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
  3867
        @param path : a list of resource paths in this storage (references).
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3868
        @param storage : the external storage where to export.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3869
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3870
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3871
            res = self.storage.export_resources(paths, storage)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3872
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3873
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3874
    def save_resource(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3875
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3876
        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
  3877
        in its own save.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3878
        @param ref the reference to the resource to close. 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3879
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3880
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3881
            res = self.storage.save_resource(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3882
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3883
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3884
    def create_folder(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3885
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3886
        Create a folder entry to a path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3887
        @param path : path to the folder
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3888
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3889
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3890
            res = self.storage.create_folder(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3891
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3892
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3893
    def delete_folder(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3894
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3895
        Delete a folder entry from a path. The path must be empty.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3896
        @param path : path to the folder
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3897
        """  
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3898
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3899
            res = self.storage.delete_folder(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3900
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3901
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3902
    def is_folder(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3903
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3904
        Check if the given path is an existing folder in the storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3905
        @param path : path to the folder
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3906
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3907
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3908
            res = self.storage.is_folder(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3909
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3910
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3911
    def get_mode(self, mode_str):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3912
        return self.storage.get_mode()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3913
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3914
    def unload(self, path, object):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3915
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3916
        Dump a given object to the storage 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3917
        @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
  3918
        of Base class.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3919
        @param path: The reference where to store the object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3920
        @param object: The object instance to dump 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3921
        @raise StorageException: if the given object cannot be dumped to this storage 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3922
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3923
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3924
            res = self.storage.unload(path, object)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3925
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3926
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3927
    def load(self, path):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3928
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3929
        Load an object from a reference.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3930
        @param path: The reference where to load the object 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3931
        @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
  3932
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3933
        with currentdir(self.storage, self.curpath):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3934
            res = self.storage.load(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3935
            return res
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3936
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3937
    path = property(get_path, set_path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3938
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3939
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3940
class CompositeLayer(Folder):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3941
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3942
    A base class for composite Configuration objects.  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3943
    """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3944
    def __init__(self, storage, path="", **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  3945
        super(CompositeLayer, self).__init__(storage, path, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3946
        self.layers = kwargs.get('layers', [])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3947
        self.path = path
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3948
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3949
    def add_layer(self, layer):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3950
        self.layers.append(layer)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3951
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3952
    def remove_layer(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3953
        if self.get_layer(path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3954
            self.layers.remove(self.get_layer(path))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3955
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3956
            raise exceptions.NotFound('Layer with given path %s not found!' % path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3957
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3958
    def get_layer(self, path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3959
        for layer in self.layers:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3960
            if layer.get_current_path() == path:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3961
                return layer
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3962
        return None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3963
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3964
    def list_layers(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3965
        return [layer.get_current_path() for layer in self.layers]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3966
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3967
    def list_confml(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3968
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3969
        @return: array of confml file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3970
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3971
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3972
        for layerpath in self.list_layers():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3973
            for respath in self.get_layer(layerpath).list_confml():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3974
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3975
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3976
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3977
    def list_implml(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3978
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3979
        @return: array of implml file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3980
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3981
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3982
        for layerpath in self.list_layers():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3983
            for respath in self.get_layer(layerpath).list_implml():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3984
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3985
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3986
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3987
    def list_content(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3988
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3989
        @return: array of content file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3990
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3991
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3992
        for layerpath in self.list_layers():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3993
            for respath in self.get_layer(layerpath).list_content():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3994
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3995
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3996
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3997
    def list_doc(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3998
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  3999
        @return: array of document file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4000
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4001
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4002
        for layerpath in self.list_layers():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4003
            for respath in self.get_layer(layerpath).list_doc():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4004
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4005
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4006
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4007
    def list_all_resources(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4008
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4009
        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
  4010
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4011
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4012
        for layerpath in self.list_layers():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4013
            sublayer = self.get_layer(layerpath)
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4014
            for respath in sublayer.list_all_resources(**kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4015
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4016
        return lres
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4017
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4018
    def list_all_related(self, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4019
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4020
        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
  4021
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4022
        lres = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4023
        for layerpath in self.list_layers():
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4024
            sublayer = self.get_layer(layerpath)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4025
            for respath in sublayer.list_all_related(**kwargs):                
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4026
                lres.append(utils.resourceref.join_refs([layerpath, respath]))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4027
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4028
        return lres
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4029
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4030
class Layer(CompositeLayer):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4031
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4032
    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
  4033
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4034
    def __init__(self, storage, path, **kwargs):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4035
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4036
        Create a layer folder to the storage if it does not exist.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4037
        @param storage: a reference to the Storage object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4038
        @param path: path for the layer 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4039
        @param confml_path: optional parameter for confml files path (give in confml_path="something") 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4040
        @param imlpml_path: optional parameter for implml files path (give in implml_path="something")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4041
        @param content_path: optional parameter for content files path (give in content_path="something")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4042
        @param doc_path: optional parameter for doc files path (give in doc_path="something")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4043
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4044
        super(Layer, self).__init__(storage, path, **kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4045
        #if not storage.is_folder(path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4046
        #    storage.create_folder(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4047
        self.predefined = {'confml_path' : 'confml', 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4048
                           'implml_path' : 'implml', 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4049
                           'content_path' : 'content', 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4050
                           'doc_path' : 'doc'}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4051
        # list through all "hardcoded" paths and check whether the 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4052
        # hardcoded or given path exists under this Layer. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4053
        # if it does then create a folder instance to that path 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4054
        for (pretag, prevalue) in self.predefined.items():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4055
            self.predefined[pretag] = kwargs.get(pretag, prevalue)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4056
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4057
    def __getattr__(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4058
        return getattr(self.storage, name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4059
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4060
    def __getstate__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4061
        state = {}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4062
        state['predefined'] = self.predefined
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4063
        state['path'] = self.path
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4064
        state['layers'] = self.layers
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4065
        return state
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4066
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4067
    def __setstate__(self, state):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4068
        state = {}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4069
        self.predefined = state.get('predefined',{})
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4070
        self.path = state.get('path','')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4071
        self.layers = state.get('layers',[])
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4072
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4073
        return state
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4074
    
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4075
    def list_confml(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 confml 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['confml_path'], recurse=True)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4080
        res += super(Layer, self).list_confml()
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 list_implml(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4084
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4085
        @return: array of implml file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4086
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4087
        res = self.list_resources(self.predefined['implml_path'], recurse=True)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4088
        res += super(Layer, self).list_implml()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4089
        return res 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4090
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4091
    def list_content(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4092
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4093
        @return: array of content file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4094
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4095
        res = self.list_resources(self.predefined['content_path'], recurse=True)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4096
        res += super(Layer, self).list_content()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4097
        return res
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4098
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4099
    def list_doc(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4100
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4101
        @return: array of document file references.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4102
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4103
        res = self.list_resources(self.predefined['doc_path'], recurse=True)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4104
        res += super(Layer, self).list_doc()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4105
        return res
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4106
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4107
    def confml_folder(self):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4108
        cpath = self.get_current_path()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4109
        spath = self.predefined['confml_path']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4110
        return Folder(self.storage,  utils.resourceref.join_refs([cpath, spath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4111
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4112
    def implml_folder(self):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4113
        cpath = self.get_current_path()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4114
        spath = self.predefined['implml_path']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4115
        return Folder(self.storage,  utils.resourceref.join_refs([cpath, spath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4116
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4117
    def content_folder(self):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4118
        cpath = self.get_current_path()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4119
        spath = self.predefined['content_path']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4120
        return Folder(self.storage,  utils.resourceref.join_refs([cpath, spath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4121
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4122
    def doc_folder(self):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4123
        cpath = self.get_current_path()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4124
        spath = self.predefined['doc_path']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4125
        return Folder(self.storage,  utils.resourceref.join_refs([cpath, spath]))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4126
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4127
    def list_all_resources(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4128
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4129
        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
  4130
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4131
        lres = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4132
        for folderpath in sorted(self.predefined.values()):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4133
            lres += self.list_resources(folderpath, recurse=True)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4134
                 
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4135
        lres += super(Layer, self).list_all_resources()
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4136
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4137
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4138
    def list_all_related(self, **kwargs):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4139
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4140
        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
  4141
        """
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4142
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4143
        lres = []
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4144
        exclude_filters = kwargs.get('exclude_filters', {})
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4145
        kwargs['recurse'] = True
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4146
        predef = self.predefined.copy()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4147
        del predef['confml_path']
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4148
        for folderpath in sorted(predef.values()):
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4149
            filter = exclude_filters.get(folderpath, None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4150
            resources = self.list_resources(folderpath, **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4151
            if filter:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4152
                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
  4153
            else:            
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4154
                lres += resources
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4155
        lres += super(Layer, self).list_all_related(**kwargs)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4156
       
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4157
        return lres
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4158
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4159
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4160
class Include(Base, container.LoadLink):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4161
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4162
    A common include element that automatically loads a resource 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4163
    and its object under this include element.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4164
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4165
    def __init__(self, ref="", **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4166
        path = kwargs.get('path') or ref
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4167
        store_interface = kwargs.get('store_interface',None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4168
        ref = utils.resourceref.to_objref(path)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4169
        container.LoadLink.__init__(self, path, store_interface)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4170
        Base.__init__(self, ref)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4171
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4172
    def get_store_interface(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4173
        if not self._storeint and self._parent:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4174
            try:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4175
                self._storeint = self._parent.get_store_interface()
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4176
            except exceptions.NotFound:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4177
                # If project is not found, let the store interface be None 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4178
                pass
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4179
        return self._storeint
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4180
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4181
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4182
class Rule(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4183
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4184
    Base class for Rules in the system.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4185
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4186
    def __init__(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4187
        raise exceptions.NotSupportedException()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4188
            
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4189
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4190
class FactoryBase(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4191
    pass
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4192
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4193
class Factory(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4194
    def __getattr__(self, name):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4195
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4196
        The Factory getattr find all subclasses for the Factory and searches for given attr 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4197
        in those.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4198
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4199
        for sub_factory in utils.all_subclasses(FactoryBase):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4200
            try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4201
                return getattr(sub_factory(), name)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4202
            except AttributeError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4203
                continue 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4204
        raise AttributeError("type object %s has no attribute '%s'" % (self.__class__, name))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4205
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4206
def get_mapper(modelname):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4207
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4208
    Return a instance of appropriate mapper for given model.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4209
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4210
    mapmodule = __import__('cone.public.mapping')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4211
    return mapmodule.public.mapping.BaseMapper()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4212
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4213
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4214
class Problem(object):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4215
    SEVERITY_ERROR      = "error"
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4216
    SEVERITY_WARNING    = "warning"
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4217
    SEVERITY_INFO       = "info"
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4218
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4219
    def __init__(self, msg, **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4220
        self.msg = msg
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4221
        self.type = kwargs.get('type', '')
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4222
        self.line = kwargs.get('line', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4223
        self.file = kwargs.get('file', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4224
        self.severity = kwargs.get('severity', self.SEVERITY_ERROR)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4225
        self.traceback = kwargs.get('traceback', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4226
        # A slot for any problem specific data 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4227
        self.problem_data = kwargs.get('problem_data', None)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4228
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4229
    def log(self, logger, current_file=None):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4230
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4231
        Log this problem with the given logger.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4232
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4233
        file = self.file or current_file
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4234
        if self.line is None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4235
            msg = "(%s) %s" % (file, self.msg)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4236
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4237
            msg = "(%s:%d) %s" % (file, self.line, self.msg)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4238
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4239
        mapping = {self.SEVERITY_ERROR:   logging.ERROR,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4240
                   self.SEVERITY_WARNING: logging.WARNING,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4241
                   self.SEVERITY_INFO:    logging.INFO}
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4242
        level = mapping.get(self.severity, logging.ERROR)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4243
        logger.log(level, msg)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4244
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4245
        if self.traceback:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4246
            logger.debug(self.traceback)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4247
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4248
    @classmethod
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4249
    def from_exception(cls, ex):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4250
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4251
        Create a Problem object from an exception instance.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4252
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4253
        If the exception is a sub-class of ConeException, then it may contain
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4254
        extra information (like a line number) for the problem.
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4255
        """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4256
        if isinstance(ex, exceptions.ConeException):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4257
            return Problem(msg      = ex.problem_msg or unicode(ex),
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4258
                           type     = ex.problem_type or '',
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4259
                           line     = ex.problem_lineno,
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4260
                           severity = cls.SEVERITY_ERROR)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4261
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4262
            return Problem(msg      = unicode(ex),
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4263
                           severity = cls.SEVERITY_ERROR)
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 __repr__(self):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4266
        var_data = []
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4267
        for varname in ('msg', 'type', 'line', 'file', 'severity'):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4268
            var_data.append("%s=%r" % (varname, getattr(self, varname)))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4269
        return "%s(%s)" % (self.__class__.__name__, ', '.join(var_data))
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4270
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4271
    def __eq__(self, other):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4272
        if not isinstance(other, Problem):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4273
            return False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4274
        for varname in ('msg', 'type', 'line', 'file', 'severity'):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4275
            self_val = getattr(self, varname)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4276
            other_val = getattr(other, varname)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4277
            if self_val != other_val:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4278
                return False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4279
        return True
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4280
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4281
    def __ne__(self, other):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4282
        return self == other
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4283
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4284
    def __lt__(self, other):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4285
        if not isinstance(other, Problem):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4286
            return False
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4287
        return (self.file, self.line) < (other.file, other.line)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4288
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4289
def make_content_info(resource, data):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4290
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4291
    Factory for ContentInfo
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4292
    """
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4293
    cnt_inf = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4294
    
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4295
    if resource != None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4296
        guessed_type = mimetypes.guess_type(resource.get_path())
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4297
        mimetype = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4298
        mimesubtype = None
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4299
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4300
        if guessed_type != None:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4301
            mimetype, mimesubtype = guessed_type[0].split('/') 
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4302
        
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4303
        if mimetype == 'image' and mimesubtype == 'x-ms-bmp':
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4304
            cnt_inf = BmpImageContentInfo(resource, data)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4305
        else:
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4306
            cnt_inf = ContentInfo(mimetype, mimesubtype)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4307
    return cnt_inf
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4308
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4309
def open_storage(path, mode="r", **kwargs):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4310
    return Storage.open(path, mode="r", **kwargs)
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
  4311
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4312
class NullHandler(logging.Handler):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4313
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4314
    Default handler that does not do anything.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4315
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4316
    def emit(self, record):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4317
        pass
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4318
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4319
#Initialization of default logger that contains NullHandler.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4320
logger = logging.getLogger('cone')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
  4321
logger.addHandler(NullHandler())