blob: d33b8c882a2df09c73cb0ef746c34ec0ed1460d4 [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.synapse.message.processors;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.synapse.SynapseException;
import org.apache.synapse.config.SynapseConfiguration;
import org.apache.synapse.core.SynapseEnvironment;
import org.apache.synapse.message.store.MessageStore;
import java.util.Map;
/**
* Class <code>AbstractMessageProcessor</code> is handles Message processing of the messages
* in Message Store. Abstract Message Store is assumes that Message processors can be implemented
* using the quartz scheduler jobs. If in case we user wants a different implementation They can
* directly use <code>MessageProcessor</code> interface for that implementations
*/
public abstract class AbstractMessageProcessor implements MessageProcessor {
protected Log log = LogFactory.getLog(this.getClass());
/** Message Store associated with Message processor */
protected String messageStore;
protected String description;
protected String name;
protected String fileName;
/** This attribute is only need for forwarding message processor. However, it here because
* then we don't need to implement this in sampling processor with nothing */
protected String targetEndpoint;
protected SynapseConfiguration configuration;
protected enum State {
INITIALIZED,
START,
STOP,
DESTROY
}
/**message store parameters */
protected Map<String, Object> parameters = null;
/** Keep the state of the message processor */
private State state = State.DESTROY;
public void init(SynapseEnvironment se) {
configuration = se.getSynapseConfiguration();
}
public void setMessageStoreName(String messageStore) {
if (messageStore != null) {
this.messageStore = messageStore;
} else {
throw new SynapseException("Error Can't set Message store to null");
}
}
public String getMessageStoreName() {
return messageStore;
}
public void setParameters(Map<String, Object> parameters) {
this.parameters = parameters;
}
public Map<String, Object> getParameters() {
return parameters;
}
public boolean isStarted() {
return state == State.START;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public void setDescription(String description) {
this.description=description;
}
public String getDescription() {
return description;
}
public void setFileName(String filename) {
this.fileName = filename;
}
public String getFileName() {
return fileName;
}
public void setTargetEndpoint(String targetEndpoint) {
this.targetEndpoint = targetEndpoint;
}
public String getTargetEndpoint() {
return targetEndpoint;
}
}