configurationengine/source/cone/storage/common.py
author m2lahtel
Tue, 10 Aug 2010 14:29:28 +0300
changeset 3 e7e0ae78773e
parent 0 2e8eeb919028
permissions -rw-r--r--
ConE 1.2.11 release
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     1
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     2
# Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     3
# All rights reserved.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     4
# This component and the accompanying materials are made available
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     5
# under the terms of "Eclipse Public License v1.0"
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     6
# which accompanies this distribution, and is available
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     7
# at the URL "http://www.eclipse.org/legal/epl-v10.html".
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     8
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     9
# Initial Contributors:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    10
# Nokia Corporation - initial contribution.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    11
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    12
# Contributors:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    13
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    14
# Description: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    15
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    16
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    17
import logging
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    18
import xml.parsers.expat
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    19
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    20
from cone.public.api import Storage
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    21
from cone.public import utils
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    22
from cone.storage import metadata
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    23
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    24
class StorageBase(Storage):
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    25
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    26
    A general base class for all storage type classes
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    27
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    28
    METADATA_FILENAME = ".metadata"
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    29
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    30
    def __init__(self, path, mode):
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    31
        super(StorageBase, self).__init__(path, mode)
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    32
        self.meta = self.read_metadata()
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    33
        
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    34
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    35
    def get_active_configuration(self): 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    36
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    37
        Return the active configuration. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    38
        If the storage holds only one configuration, it will be always active  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    39
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    40
        root_confmls = self.list_resources("/")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    41
        root_confmls = utils.resourceref.filter_resources(root_confmls,"\.confml")
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    42
        if self.meta.get_root_file() == None and len(root_confmls) == 1:
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    43
            return root_confmls[0]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    44
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    45
            return self.meta.get_root_file()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    46
            
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    47
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    48
    def set_active_configuration(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    49
        self.meta.set_root_file(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    50
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    51
    def read_metadata(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    52
        meta = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    53
        if not self.is_resource(self.METADATA_FILENAME):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    54
            logging.getLogger('cone').info("No metadata found for: %s" % (self.get_path()))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    55
            # return empty metadata object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    56
            meta = metadata.Metadata()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    57
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    58
            res = self.open_resource(self.METADATA_FILENAME)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    59
            try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    60
                try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    61
                    meta = metadata.MetadataReader().fromstring(res.read())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    62
                except xml.parsers.expat.ExpatError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    63
                    """ in case of xml parsing error return empty metadata """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    64
                    meta = metadata.Metadata()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    65
            finally:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    66
                res.close()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    67
        return meta
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    68
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    69
    def write_metadata(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    70
        # Try to update the metadata, which might fail on ZipStorage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    71
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    72
        try:
3
e7e0ae78773e ConE 1.2.11 release
m2lahtel
parents: 0
diff changeset
    73
            if self.get_mode(self.mode) != Storage.MODE_READ:
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    74
                # update the active configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    75
                self.set_active_configuration(self.get_active_configuration())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    76
                metares = self.open_resource(self.METADATA_FILENAME,"wb")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    77
                metadata.MetadataWriter().toresource(self.meta,metares)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    78
                metares.close()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    79
        except Exception,e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    80
            logging.getLogger('cone').error("Could not save metadata. Exception %s" % e)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    81
        return
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    82
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    83
    def close(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    84
        if self.get_current_path() == "": 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    85
            self.write_metadata()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    86
        super(StorageBase, self).close()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    87