diff options
-rw-r--r-- | include/plugin.h | 48 | ||||
-rw-r--r-- | media/pluginManager.cpp | 147 |
2 files changed, 81 insertions, 114 deletions
diff --git a/include/plugin.h b/include/plugin.h index e957505..d24f7e5 100644 --- a/include/plugin.h +++ b/include/plugin.h @@ -55,6 +55,8 @@ namespace resource { } +class PropertyValidator; + /** * Metadata class * @@ -166,6 +168,7 @@ public: typedef multimap<string, Property> PropertyMap; typedef pair<PropertyMap::iterator,PropertyMap::iterator> PropertyRange; typedef list<Resource> ResourceList; + typedef map<string, PropertyValidator*> ValidatorMap; bool AddProperty(Property property); bool SetProperty(Property property, int index = 0); @@ -176,54 +179,19 @@ public: bool SetObjectID(string objectID); bool SetObjectIDByUri(string uri); - string GetObjectID() const { return objectID; } + string GetObjectID(); bool SetParentID(string parentID); bool SetParentIDByUri(string uri); - string GetParentID() const { return parentID; } - bool SetTitle(string title); - string GetTitle() const { return title; } - bool SetCreator(string creator); - string GetCreator() const { return creator; } - bool SetUpnpClass(string upnpClass); - string GetUpnpClass() const { return upnpClass; } - bool SetRestricted(bool restricted); - bool GetRestricted() const { return restricted; } - bool SetDescription(string description); - string GetDescription() const { return description; } - bool SetLongDescription(string longDescription); - string GetLongDescription() const { return longDescription; } - bool SetDate(string date); - string GetDate() const { return date; } - bool SetLanguage(string language); - string GetLanguage() const { return language; } - bool SetChannelNr(int channelNr); - int GetChannelNr() const { return channelNr; } - bool SetChannelName(string channelName); - string GetChannelName() const { return channelName; } - bool SetScheduledStart(string scheduledStart); - string GetScheduledStart() const { return scheduledStart; } - bool SetScheduledEnd(string scheduledEnd); - string GetScheduledEnd() const { return scheduledEnd; } + string GetParentID(); + + static void RegisterPropertyValidator(PropertyValidator* validator); private: PropertyMap properties; ResourceList resources; - string objectID; - string parentID; - string title; - string creator; - string upnpClass; - bool restricted; - string description; - string longDescription; - string date; - string language; - int channelNr; - string channelName; - string scheduledStart; - string scheduledEnd; + static ValidatorMap validators; }; diff --git a/media/pluginManager.cpp b/media/pluginManager.cpp index e677d6a..ec23ea4 100644 --- a/media/pluginManager.cpp +++ b/media/pluginManager.cpp @@ -13,6 +13,38 @@ using namespace std; namespace upnp { +class PropertyValidator { + PropertyValidator(){ + cMetadata::RegisterPropertyValidator(this); + } + virtual ~PropertyValidator(){} + virtual string GetPropertyKey() = 0; + virtual bool Validate(cMetadata::Property property) = 0; +}; + +class ClassValidator : PropertyValidator { + virtual string GetPropertyKey(){ + return property::object::KEY_CLASS; + } + virtual bool Validate(cMetadata::Property property){ + string value = property.GetString(); + + if(value.find("object.container", 0) == 0 || + value.find("object.item", 0) == 0) + { + return true; + } + else + { + return false; + } + } +} ClassValidatorInst; + +void cMetadata::RegisterPropertyValidator(PropertyValidator* validator){ + validators[validator->GetPropertyKey()] = validator; +} + bool cMetadata::SetObjectIDByUri(string uri){ return SetObjectID(tools::GenerateUUIDFromURL(uri)); } @@ -24,93 +56,60 @@ bool cMetadata::SetParentIDByUri(string uri){ bool cMetadata::SetObjectID(string objectID){ if(objectID.empty() || objectID.compare("0") == 0) return false; - this->objectID = objectID; + SetProperty(Property(property::object::KEY_OBJECTID, objectID)); return true; }; bool cMetadata::SetParentID(string parentID){ - if(objectID.compare("-1") == 0) return false; - - this->parentID = parentID; - - return true; -}; + if(parentID.compare("-1") == 0) return false; -bool cMetadata::SetTitle(string title){ - this->title = title; + SetProperty(Property(property::object::KEY_PARENTID, parentID)); return true; }; -bool cMetadata::SetUpnpClass(string upnpClass){ - //TODO: Validiere upnpClass. - this->upnpClass = upnpClass; - - return true; -}; - -bool cMetadata::SetRestricted(bool restricted){ - this->restricted = restricted; - - return true; -}; - -bool cMetadata::SetDescription(string description){ - this->description = description; - - return true; -}; - -bool cMetadata::SetLongDescription(string longDescription){ - this->longDescription = longDescription; - - return true; -}; - -bool cMetadata::SetDate(string date){ - this->date = date; - - return true; -}; - -bool cMetadata::SetLanguage(string language){ - this->language = language; - - return true; -}; - -bool cMetadata::SetChannelNr(int channelNr){ - this->channelNr = channelNr; - - return true; -}; - -bool cMetadata::SetChannelName(string channelName){ - this->channelName = channelName; - - return true; -}; - -bool cMetadata::SetScheduledStart(string scheduledStart){ - this->scheduledStart = scheduledStart; - - return true; -}; - -bool cMetadata::SetScheduledEnd(string scheduledEnd){ - this->scheduledEnd = scheduledEnd; - - return true; -}; - - bool cMetadata::AddProperty(Property property){ + string key = property.GetKey(); + + // Try to find a validator + PropertyValidator* validator = validators[key]; + // If there is one and it fails to validate the property, return false. + // Otherwise ignore it. + if(validator && !validator->Validate(property)) return false; + + if(properties.find(key) != properties.end()){ + if(key.compare(property::object::KEY_CHANNEL_NAME) == 0 || + key.compare(property::object::KEY_CHANNEL_NR) == 0 || + key.compare(property::object::KEY_CLASS) == 0 || + key.compare(property::object::KEY_CREATOR) == 0 || + key.compare(property::object::KEY_DATE) == 0 || + key.compare(property::object::KEY_DESCRIPTION) == 0 || + key.compare(property::object::KEY_LANGUAGE) == 0 || + key.compare(property::object::KEY_LONG_DESCRIPTION) == 0 || + key.compare(property::object::KEY_OBJECTID) == 0 || + key.compare(property::object::KEY_PARENTID) == 0 || + key.compare(property::object::KEY_RESTRICTED) == 0 || + key.compare(property::object::KEY_SCHEDULED_END) == 0 || + key.compare(property::object::KEY_SCHEDULED_START) == 0 || + key.compare(property::object::KEY_TITLE) == 0) + { + esyslog("UPnP\tProperty '%s' already exist!", key); + return false; + } + } + properties.insert(pair<string, Property>(property.GetKey(), property)); return true; } bool cMetadata::SetProperty(Property property, int index){ + // Try to find a validator + PropertyValidator* validator = validators[property.GetKey()]; + // If there is one and it fails to validate the property, return false. + // Otherwise ignore it. + if(validator && !validator->Validate(property)) return false; + PropertyRange ret = properties.equal_range(property.GetKey()); // No property with the given name found. Let's add it to the map. @@ -230,11 +229,11 @@ cMetadata* cUPnPResourceProvider::GetMetadata(string uri){ cMetadata* metadata = new cMetadata; - metadata->SetTitle(uri.substr(uri.find_last_of("/")+1)); - metadata->SetUpnpClass("object.container"); metadata->SetObjectIDByUri(uri); metadata->SetParentIDByUri(uri.substr(0,uri.find_last_of("/"))); - metadata->SetRestricted(true); + metadata->SetProperty(cMetadata::Property(property::object::KEY_TITLE, uri.substr(uri.find_last_of("/")+1))); + metadata->SetProperty(cMetadata::Property(property::object::KEY_CLASS, "object.container")); + metadata->SetProperty(cMetadata::Property(property::object::KEY_RESTRICTED, true)); return metadata; |