All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.camel.model.transformer.TransformerDefinition Maven / Gradle / Ivy

There is a newer version: 4.6.0
Show newest version
/**
 * 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.camel.model.transformer;

import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlType;
import org.apache.camel.CamelContext;
import org.apache.camel.model.InputTypeDefinition;
import org.apache.camel.model.OutputTypeDefinition;
import org.apache.camel.spi.DataType;
import org.apache.camel.spi.Metadata;
import org.apache.camel.spi.Transformer;

/**
 * 

Represents a {@link Transformer} which declaratively transforms message content * according to the input type declared by {@link InputTypeDefinition} and/or output type * declared by {@link OutputTypeDefinition}.

*

If you specify from='java:com.example.ABC' and to='xml:XYZ', the transformer * will be picked up when current message type is 'java:com.example.ABC' and expected * message type is 'xml:XYZ'. * If you specify from='java' to='xml', then it will be picked up for all of java * to xml transformation. * Also it's possible to specify scheme='xml' so that the transformer will be picked up * for all of java to xml and xml to java transformation.

* * {@see Transformer} * {@see InputTypeDefinition} * {@see OutputTypeDefinition} */ @Metadata(label = "transformation") @XmlType(name = "transformer") @XmlAccessorType(XmlAccessType.FIELD) public abstract class TransformerDefinition { @XmlAttribute private String scheme; @XmlAttribute private String fromType; @XmlAttribute private String toType; public Transformer createTransformer(CamelContext context) throws Exception { return doCreateTransformer(context); }; protected abstract Transformer doCreateTransformer(CamelContext context) throws Exception; public String getScheme() { return scheme; } /** * Set a scheme name supported by the transformer. * If you specify 'csv', the transformer will be picked up for all of 'csv' from/to * Java transformation. Note that the scheme matching is performed only when * no exactly matched transformer exists. * * @param scheme scheme name */ public void setScheme(String scheme) { this.scheme = scheme; } public String getFromType() { return fromType; } /** * Set the 'from' data type name. * If you specify 'xml:XYZ', the transformer will be picked up if source type is * 'xml:XYZ'. If you specify just 'xml', the transformer matches with all of * 'xml' source type like 'xml:ABC' or 'xml:DEF'. * * @param from 'from' data type name */ public void setFromType(String from) { this.fromType = from; } /** * Set the 'from' data type using Java class. * * @param clazz 'from' Java class */ public void setFromType(Class clazz) { this.fromType = new DataType(clazz).toString(); } public String getToType() { return toType; } /** * Set the 'to' data type name. * If you specify 'json:XYZ', the transformer will be picked up if destination type is * 'json:XYZ'. If you specify just 'json', the transformer matches with all of * 'json' destination type like 'json:ABC' or 'json:DEF'. * * @param to 'to' data type name */ public void setToType(String to) { this.toType = to; } /** * Set the 'to' data type using Java class. * * @param clazz 'to' Java class */ public void setToType(Class clazz) { this.toType = new DataType(clazz).toString(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy