001    package org.apache.archiva.metadata.generic;
002    
003    /*
004     * Licensed to the Apache Software Foundation (ASF) under one
005     * or more contributor license agreements.  See the NOTICE file
006     * distributed with this work for additional information
007     * regarding copyright ownership.  The ASF licenses this file
008     * to you under the Apache License, Version 2.0 (the
009     * "License"); you may not use this file except in compliance
010     * with the License.  You may obtain a copy of the License at
011     *
012     *   http://www.apache.org/licenses/LICENSE-2.0
013     *
014     * Unless required by applicable law or agreed to in writing,
015     * software distributed under the License is distributed on an
016     * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
017     * KIND, either express or implied.  See the License for the
018     * specific language governing permissions and limitations
019     * under the License.
020     */
021    
022    import java.util.Map;
023    import java.util.TreeMap;
024    
025    import org.apache.archiva.metadata.model.MetadataFacet;
026    
027    public class GenericMetadataFacet
028        implements MetadataFacet
029    {
030        private Map<String, String> additionalProperties;
031    
032        public static final String FACET_ID = "org.apache.archiva.metadata.generic";
033    
034        public String getFacetId()
035        {
036            return FACET_ID;
037        }
038    
039        public String getName()
040        {
041            return "";
042        }
043    
044        public void fromProperties( Map<String, String> properties )
045        {
046            if ( additionalProperties == null )
047            {
048                additionalProperties = new TreeMap<String, String>();
049            }
050    
051            additionalProperties.putAll( properties );
052        }
053    
054        public Map<String, String> toProperties()
055        {
056            Map<String, String> properties = new TreeMap<String, String>();
057    
058            if ( additionalProperties != null )
059            {
060                for ( String key : additionalProperties.keySet() )
061                {
062                    properties.put( key, additionalProperties.get( key ) );
063                }
064            }
065    
066            return properties;
067        }
068    
069        public Map<String, String> getAdditionalProperties()
070        {
071            return additionalProperties;
072        }
073    
074        public void setAdditionalProperties( Map<String, String> additionalProperties )
075        {
076            this.additionalProperties = additionalProperties;
077        }
078    
079    }