blob: 2af517d189a112addb510b825cb124943ceaf7ef [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.ws.commons.schema.extensions;
import java.util.HashMap;
import java.util.Map;
import javax.xml.namespace.QName;
import org.w3c.dom.Node;
import org.apache.ws.commons.schema.XmlSchemaObject;
/**
* The task of the extension serializer is to delegate the serilization of the extensions. The extension
* serializers/deserializers are retained in seperate maps and there are also two seperate references to
* default serializers and deserializers which would jump into action when there are no specifically attached
* serializers/deserializers
*/
public class ExtensionRegistry {
/**
* Maps for the storage of extension serializers /deserializers
*/
private Map<Class<?>, ExtensionSerializer> extensionSerializers
= new HashMap<Class<?>, ExtensionSerializer>();
private Map<QName, ExtensionDeserializer> extensionDeserializers
= new HashMap<QName, ExtensionDeserializer>();
/**
* Default serializer and serializer
*/
private ExtensionSerializer defaultExtensionSerializer = new DefaultExtensionSerializer();
private ExtensionDeserializer defaultExtensionDeserializer = new DefaultExtensionDeserializer();
public ExtensionSerializer getDefaultExtensionSerializer() {
return defaultExtensionSerializer;
}
public void setDefaultExtensionSerializer(ExtensionSerializer defaultExtensionSerializer) {
this.defaultExtensionSerializer = defaultExtensionSerializer;
}
public ExtensionDeserializer getDefaultExtensionDeserializer() {
return defaultExtensionDeserializer;
}
public void setDefaultExtensionDeserializer(ExtensionDeserializer defaultExtensionDeserializer) {
this.defaultExtensionDeserializer = defaultExtensionDeserializer;
}
/**
* Register a deserializer with a QName
*
* @param name - the QName of the element/attribute
* @param deserializer - an instance of the deserializer
*/
public void registerDeserializer(QName name, ExtensionDeserializer deserializer) {
extensionDeserializers.put(name, deserializer);
}
/**
* Register a serializer with a Class
*
* @param classOfType - the class of the object that would be serialized
* @param serializer - an instance of the deserializer
*/
public void registerSerializer(Class<?> classOfType, ExtensionSerializer serializer) {
extensionSerializers.put(classOfType, serializer);
}
/**
* remove the registration for a serializer with a Class
*
* @param classOfType - the Class of the element/attribute the serializer is associated with
*/
public void unregisterSerializer(Class<?> classOfType) {
extensionSerializers.remove(classOfType);
}
/**
* remove the registration for a deserializer with a QName
*
* @param name - the QName fo the element that the deserializer is associated with
*/
public void unregisterDeserializer(QName name) {
extensionDeserializers.remove(name);
}
/**
* Serialize a given extension element
*
* @param parentSchemaObject - the parent schema object. This is what would contain the extension object,
* probably in side its meta information map
* @param classOfType - The class of type to be serialized
* @param node - the parent DOM Node that will ultimately be serialized. The XMLSchema serialization
* mechanism is to create a DOM tree first and serialize it
*/
public void serializeExtension(XmlSchemaObject parentSchemaObject, Class<?> classOfType, Node node) {
Object serializerObject = extensionSerializers.get(classOfType);
if (serializerObject != null) {
// perform the serialization
ExtensionSerializer ser = (ExtensionSerializer)serializerObject;
ser.serialize(parentSchemaObject, classOfType, node);
} else if (defaultExtensionSerializer != null) {
defaultExtensionSerializer.serialize(parentSchemaObject, classOfType, node);
}
}
/**
* Deserialize a given extension element
*
* @param parentSchemaObject - the parent schema object. This is anticipated to be created already and the
* relevant object would contain the extension object, probably in side its meta information
* map
* @param name - The qname of the element/attribute to be deserialized. This will be used to search for
* the extension as well as by the deserializer if a single deserializer is registered against
* a number of qnames
* @param rawNode - the raw DOM Node read from the source. This will be the extension element itself if
* for an element or extension attribute itself in case of an attribute
*/
public void deserializeExtension(XmlSchemaObject parentSchemaObject, QName name, Node rawNode) {
Object deserializerObject = extensionDeserializers.get(name);
if (deserializerObject != null) {
// perform the serialization
ExtensionDeserializer deser = (ExtensionDeserializer)deserializerObject;
deser.deserialize(parentSchemaObject, name, rawNode);
} else if (defaultExtensionDeserializer != null) {
defaultExtensionDeserializer.deserialize(parentSchemaObject, name, rawNode);
}
}
}