configurationengine/source/cone/storage/common.py
author terytkon
Thu, 11 Mar 2010 17:04:37 +0200
changeset 0 2e8eeb919028
child 3 e7e0ae78773e
permissions -rw-r--r--
Adding EPL version of configurationengine.
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
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    20
from cone.public import api, utils
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    21
from cone.storage import metadata
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    22
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    23
class StorageBase(api.Storage):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    24
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    25
    A general base class for all storage type classes
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    26
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    27
    METADATA_FILENAME = ".metadata"
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    28
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    29
    def __init__(self,path):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    30
        super(StorageBase, self).__init__(path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    31
        self.meta = self.read_metadata()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    32
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    33
    def get_active_configuration(self): 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    34
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    35
        Return the active configuration. 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    36
        If the storage holds only one configuration, it will be always active  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    37
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    38
        root_confmls = self.list_resources("/")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    39
        root_confmls = utils.resourceref.filter_resources(root_confmls,"\.confml")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    40
        if self.meta.get_root_file() == '' and len(root_confmls) == 1:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    41
            return root_confmls[0]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    42
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    43
            return self.meta.get_root_file()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    44
            
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    45
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    46
    def set_active_configuration(self, ref):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    47
        self.meta.set_root_file(ref)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    48
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    49
    def read_metadata(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    50
        meta = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    51
        if not self.is_resource(self.METADATA_FILENAME):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    52
            logging.getLogger('cone').info("No metadata found for: %s" % (self.get_path()))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    53
            # return empty metadata object
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    54
            meta = metadata.Metadata()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    55
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    56
            res = self.open_resource(self.METADATA_FILENAME)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    57
            try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    58
                try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    59
                    meta = metadata.MetadataReader().fromstring(res.read())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    60
                except xml.parsers.expat.ExpatError:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    61
                    """ in case of xml parsing error return empty metadata """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    62
                    meta = metadata.Metadata()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    63
            finally:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    64
                res.close()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    65
        return meta
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    66
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    67
    def write_metadata(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    68
        # Try to update the metadata, which might fail on ZipStorage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    69
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    70
        try:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    71
            if self.get_mode(self.mode) != api.Storage.MODE_READ:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    72
                # update the active configuration
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    73
                self.set_active_configuration(self.get_active_configuration())
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    74
                metares = self.open_resource(self.METADATA_FILENAME,"wb")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    75
                metadata.MetadataWriter().toresource(self.meta,metares)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    76
                metares.close()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    77
        except Exception,e:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    78
            logging.getLogger('cone').error("Could not save metadata. Exception %s" % e)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    79
        return
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    80
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    81
    def close(self):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    82
        if self.get_current_path() == "": 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    83
            self.write_metadata()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    84
        super(StorageBase, self).close()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    85