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

org.apache.activemq.tool.properties.JmsProducerProperties Maven / Gradle / Ivy

The 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.activemq.tool.properties;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class JmsProducerProperties extends JmsClientProperties {

    private static final Logger LOG = LoggerFactory.getLogger(ReflectionUtil.class);

    public static final String TIME_BASED_SENDING  = "time"; // Produce messages base on a time interval
    public static final String COUNT_BASED_SENDING = "count"; // Produce a specific count of messages
    public static final String DELIVERY_MODE_PERSISTENT     = "persistent"; // Persistent message delivery
    public static final String DELIVERY_MODE_NON_PERSISTENT = "nonpersistent"; // Non-persistent message delivery

    protected String deliveryMode = DELIVERY_MODE_NON_PERSISTENT; // Message delivery mode
    protected int messageSize = 1024; // Send 1kb messages by default
    protected long sendCount  = 1000000; // Send a million messages by default
    protected long sendDuration = 5 * 60 * 1000; // Send for 5 mins by default
    protected String sendType = TIME_BASED_SENDING;
    protected long sendDelay = 0;  // delay in milliseconds between each producer send
    protected String msgFileName = null; // for sending a particular msg from a file

    protected Map headerMap = null;


    // If true, create a different message on each send, otherwise reuse.
    protected boolean createNewMsg;

    public JmsProducerProperties() {
        this.headerMap = new HashMap();
    }

    public String getDeliveryMode() {
        return deliveryMode;
    }

    public void setDeliveryMode(String deliveryMode) {
        this.deliveryMode = deliveryMode;
    }

    public int getMessageSize() {
        return messageSize;
    }

    public void setMessageSize(int messageSize) {
        this.messageSize = messageSize;
    }

    public long getSendCount() {
        return sendCount;
    }

    public void setSendCount(long sendCount) {
        this.sendCount = sendCount;
    }

    public long getSendDuration() {
        return sendDuration;
    }

    public void setSendDuration(long sendDuration) {
        this.sendDuration = sendDuration;
    }

    public String getSendType() {
        return sendType;
    }

    public void setSendType(String sendType) {
        this.sendType = sendType;
    }

    public boolean isCreateNewMsg() {
        return createNewMsg;
    }

    public void setCreateNewMsg(boolean createNewMsg) {
        this.createNewMsg = createNewMsg;
    }

    public void setSendDelay(long delay) {
        this.sendDelay = delay;
    }

    public long getSendDelay() {
        return this.sendDelay;
    }


    /* Operations for supporting message headers */

    /**
     * Method for setting a message header.
     * @param encodedHeader - the header is encoded as a string using this syntax:
     * encodedHeader = [headerkey '=' headervalue ':' ]*
     * E.g. an encodedHeader could read "JMSType=car", or
     * "JMSType=car:MyHeader=MyValue"
     *
     * That implies neither the header key nor the value
     * can contain any of the characters ':' and '='.
     */
    public void setHeader(String encodedHeader) {

        // remove any trailing ':' characters
        if (encodedHeader.endsWith(":")) {
            encodedHeader = encodedHeader.substring(0, encodedHeader.length()-1);
        }

        // split headers
        String headers[] = encodedHeader.split(":");
        for (String h : headers) {

            // split into header name and value
            String tokens[] = h.split("=");

            // sanity check, don't allow empty string for header names
            if (tokens.length != 2 || tokens[0].equals("") || tokens[1].equals("") ) {
                LOG.error("Error parsing message headers. Header: \"" + h +
                        "\". This header will be ignored.");
            } else {
                this.headerMap.put(tokens[0], tokens[1]);
            }
        }
    }

    public Set getHeaderKeys() {
        return this.headerMap.keySet();
    }

    public Object getHeaderValue(String key) {
        return this.headerMap.get(key);
    }

    public void clearHeaders() {
        this.headerMap.clear();
    }

    public void setMsgFileName(String file) {
        LOG.info("\"producer.msgFileName\" specified. " +
                "Will ignore setting \"producer.messageSize\".");
        this.msgFileName = file;
    }

    public String getMsgFileName() {
        return this.msgFileName;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy