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

org.apache.camel.component.smpp.SmppConfiguration Maven / Gradle / Ivy

/*
 * 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.component.smpp;

import java.net.URI;
import java.nio.charset.Charset;
import java.util.Map;

import org.apache.camel.RuntimeCamelException;
import org.apache.camel.spi.UriParam;
import org.apache.camel.spi.UriParams;
import org.apache.camel.spi.UriPath;
import org.jsmpp.bean.*;
import org.jsmpp.session.SessionStateListener;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * Contains the SMPP component configuration properties
 */
@UriParams
public class SmppConfiguration implements Cloneable {
    private static final Logger LOG = LoggerFactory.getLogger(SmppConfiguration.class);

    @UriPath(defaultValue = "localhost")
    private String host = "localhost";
    @UriPath(defaultValue = "2775")
    private Integer port = 2775;
    @UriParam(label = "security", defaultValue = "smppclient", secret = true)
    private String systemId = "smppclient";
    @UriParam(label = "security", secret = true)
    private String password;
    @UriParam(label = "common", defaultValue = "")
    private String systemType = "";
    @UriParam(label = "codec")
    private byte dataCoding = (byte) 0;
    @UriParam(label = "codec", enums = "0,4,8")
    private byte alphabet = Alphabet.ALPHA_DEFAULT.value();
    @UriParam(label = "codec", defaultValue = "ISO-8859-1")
    private String encoding = "ISO-8859-1";
    @UriParam(label = "advanced", defaultValue = "60000")
    private Integer enquireLinkTimer = 60000;
    @UriParam(label = "advanced", defaultValue = "10000")
    private Integer transactionTimer = 10000;
    @UriParam(label = "producer", enums = "0,1,2")
    private byte registeredDelivery = SMSCDeliveryReceipt.SUCCESS_FAILURE.value();
    @UriParam(label = "producer", defaultValue = "", enums = "CMT,CPT,VMN,VMA,WAP,USSD")
    private String serviceType = "";
    @UriParam(label = "producer", defaultValue = "1616")
    private String sourceAddr = "1616";
    @UriParam(label = "producer", defaultValue = "1717")
    private String destAddr = "1717";
    @UriParam(label = "producer", enums = "0,1,2,3,4,5,6")
    private byte sourceAddrTon = TypeOfNumber.UNKNOWN.value();
    @UriParam(label = "producer", enums = "0,1,2,3,4,5,6")
    private byte destAddrTon = TypeOfNumber.UNKNOWN.value();
    @UriParam(label = "producer", enums = "0,1,2,3,6,8,9,10,13,18")
    private byte sourceAddrNpi = NumberingPlanIndicator.UNKNOWN.value();
    @UriParam(label = "producer", enums = "0,1,2,3,6,8,9,10,13,18")
    private byte destAddrNpi = NumberingPlanIndicator.UNKNOWN.value();
    @UriParam(label = "consumer")
    private String addressRange = "";
    @UriParam(label = "producer")
    private byte protocolId = (byte) 0;
    @UriParam(label = "producer", enums = "0,1,2,3")
    private byte priorityFlag = (byte) 1;
    @UriParam(label = "producer", enums = "0,1")
    private byte replaceIfPresentFlag = ReplaceIfPresentFlag.DEFAULT.value();
    @UriParam(label = "producer", enums = "0,1,2,3,4,5,6")
    private byte typeOfNumber = TypeOfNumber.UNKNOWN.value();
    @UriParam(label = "producer", enums = "0,1,2,3,6,8,9,10,13,18")
    private byte numberingPlanIndicator = NumberingPlanIndicator.UNKNOWN.value();
    @UriParam(label = "security")
    private boolean usingSSL;
    @UriParam(label = "common", defaultValue = "5000")
    private long initialReconnectDelay = 5000;
    @UriParam(label = "common", defaultValue = "5000")
    private long reconnectDelay = 5000;
    @UriParam(label = "common", defaultValue = "2147483647")
    private int maxReconnect = Integer.MAX_VALUE;
    @UriParam(label = "producer")
    private boolean lazySessionCreation;
    @UriParam(label = "producer")
    private String messageReceiverRouteId;
    @UriParam(label = "proxy")
    private String httpProxyHost;
    @UriParam(label = "proxy", defaultValue = "3128")
    private Integer httpProxyPort = 3128;
    @UriParam(label = "proxy")
    private String httpProxyUsername;
    @UriParam(label = "proxy")
    private String httpProxyPassword;
    @UriParam(label = "proxy")
    private Map proxyHeaders;
    @UriParam(label = "advanced")
    private SessionStateListener sessionStateListener;
    @UriParam(defaultValue = "ALLOW")
    private SmppSplittingPolicy splittingPolicy = SmppSplittingPolicy.ALLOW;
    @UriParam(label = "advanced", defaultValue = "3")
    private Integer pduProcessorDegree = 3;
    @UriParam(label = "advanced", defaultValue = "100")
    private Integer pduProcessorQueueCapacity = 100;
    @UriParam(label = "advanced", defaultValue = "false")
    private boolean singleDLR;
    @UriParam(label = "advanced", enums = "legacy,3.3,3.4,5.0", defaultValue = "3.4")
    private String interfaceVersion = "3.4";

    /**
     * A POJO which contains all necessary configuration parameters for the SMPP connection
     *
     * @param uri the full URI of the endpoint
     */
    public void configureFromURI(URI uri) {
        String userInfo = uri.getUserInfo();
        if (userInfo != null) {
            setSystemId(uri.getUserInfo());
        }

        String host = uri.getHost();
        if (host != null) {
            setHost(host);
        }

        int port = uri.getPort();
        if (port > 0) {
            setPort(port);
        }

        if (uri.getScheme().startsWith("smpps")) {
            setUsingSSL(true);
        }
    }

    public SmppConfiguration copy() {
        try {
            return (SmppConfiguration) clone();
        } catch (CloneNotSupportedException e) {
            throw new RuntimeCamelException(e);
        }
    }

    public String getHost() {
        return host;
    }

    /**
     * Hostname for the SMSC server to use.
     */
    public void setHost(String host) {
        this.host = host;
    }

    public Integer getPort() {
        return port;
    }

    /**
     * Port number for the SMSC server to use.
     */
    public void setPort(Integer port) {
        this.port = port;
    }

    public String getSystemId() {
        return systemId;
    }

    /**
     * The system id (username) for connecting to SMSC server.
     */
    public void setSystemId(String systemId) {
        this.systemId = systemId;
    }

    /**
     * The password for connecting to SMSC server.
     */
    public String getPassword() {
        return password;
    }

    public byte getDataCoding() {
        return dataCoding;
    }

    /**
     * Defines the data coding according the SMPP 3.4 specification, section 5.2.19. Example data encodings are:
     * 
    *
  • 0: SMSC Default Alphabet
  • *
  • 3: Latin 1 (ISO-8859-1)
  • *
  • 4: Octet unspecified (8-bit binary)
  • *
  • 8: UCS2 (ISO/IEC-10646)
  • *
  • 13: Extended Kanji JIS(X 0212-1990)
  • *
*/ public void setDataCoding(byte dataCoding) { this.dataCoding = dataCoding; } public byte getAlphabet() { return alphabet; } /** * Defines encoding of data according the SMPP 3.4 specification, section 5.2.19. *
    *
  • 0: SMSC Default Alphabet *
  • 4: 8 bit Alphabet
  • *
  • 8: UCS2 Alphabet
  • *
*/ public void setAlphabet(byte alphabet) { this.alphabet = alphabet; } public String getEncoding() { return encoding; } /** * Defines the encoding scheme of the short message user data. Only for SubmitSm, ReplaceSm and SubmitMulti. */ public void setEncoding(String encoding) { if (!Charset.isSupported(encoding)) { LOG.warn("Unsupported encoding \"{}\" is being set.", encoding); } this.encoding = encoding; } public void setPassword(String password) { this.password = password; } public Integer getEnquireLinkTimer() { return enquireLinkTimer; } /** * Defines the interval in milliseconds between the confidence checks. The confidence check is used to test the * communication path between an ESME and an SMSC. */ public void setEnquireLinkTimer(Integer enquireLinkTimer) { this.enquireLinkTimer = enquireLinkTimer; } public Integer getTransactionTimer() { return transactionTimer; } /** * Defines the maximum period of inactivity allowed after a transaction, after which an SMPP entity may assume that * the session is no longer active. This timer may be active on either communicating SMPP entity (i.e. SMSC or * ESME). */ public void setTransactionTimer(Integer transactionTimer) { this.transactionTimer = transactionTimer; } public String getSystemType() { return systemType; } /** * This parameter is used to categorize the type of ESME (External Short Message Entity) that is binding to the SMSC * (max. 13 characters). */ public void setSystemType(String systemType) { this.systemType = systemType; } public byte getRegisteredDelivery() { return registeredDelivery; } /** * Is used to request an SMSC delivery receipt and/or SME originated acknowledgements. The following values are * defined: *
    *
  • 0: No SMSC delivery receipt requested.
  • *
  • 1: SMSC delivery receipt requested where final delivery outcome is success or failure.
  • *
  • 2: SMSC delivery receipt requested where the final delivery outcome is delivery failure.
  • *
*/ public void setRegisteredDelivery(byte registeredDelivery) { this.registeredDelivery = registeredDelivery; } public String getServiceType() { return serviceType; } /** * The service type parameter can be used to indicate the SMS Application service associated with the message. The * following generic service_types are defined: *
    *
  • CMT: Cellular Messaging
  • *
  • CPT: Cellular Paging
  • *
  • VMN: Voice Mail Notification
  • *
  • VMA: Voice Mail Alerting
  • *
  • WAP: Wireless Application Protocol
  • *
  • USSD: Unstructured Supplementary Services Data
  • *
*/ public void setServiceType(String serviceType) { this.serviceType = serviceType; } public byte getSourceAddrTon() { return sourceAddrTon; } /** * Defines the type of number (TON) to be used in the SME originator address parameters. The following TON values * are defined: *
    *
  • 0: Unknown
  • *
  • 1: International
  • *
  • 2: National
  • *
  • 3: Network Specific
  • *
  • 4: Subscriber Number
  • *
  • 5: Alphanumeric
  • *
  • 6: Abbreviated
  • *
*/ public void setSourceAddrTon(byte sourceAddrTon) { this.sourceAddrTon = sourceAddrTon; } public byte getDestAddrTon() { return destAddrTon; } /** * Defines the type of number (TON) to be used in the SME destination address parameters. Only for SubmitSm, * SubmitMulti, CancelSm and DataSm. The following TON values are defined: *
    *
  • 0: Unknown
  • *
  • 1: International
  • *
  • 2: National
  • *
  • 3: Network Specific
  • *
  • 4: Subscriber Number
  • *
  • 5: Alphanumeric
  • *
  • 6: Abbreviated
  • *
*/ public void setDestAddrTon(byte destAddrTon) { this.destAddrTon = destAddrTon; } public byte getSourceAddrNpi() { return sourceAddrNpi; } /** * Defines the numeric plan indicator (NPI) to be used in the SME originator address parameters. The following NPI * values are defined: *
    *
  • 0: Unknown
  • *
  • 1: ISDN (E163/E164)
  • *
  • 2: Data (X.121)
  • *
  • 3: Telex (F.69)
  • *
  • 6: Land Mobile (E.212)
  • *
  • 8: National
  • *
  • 9: Private
  • *
  • 10: ERMES
  • *
  • 13: Internet (IP)
  • *
  • 18: WAP Client Id (to be defined by WAP Forum)
  • *
*/ public void setSourceAddrNpi(byte sourceAddrNpi) { this.sourceAddrNpi = sourceAddrNpi; } public byte getDestAddrNpi() { return destAddrNpi; } /** * Defines the type of number (TON) to be used in the SME destination address parameters. Only for SubmitSm, * SubmitMulti, CancelSm and DataSm. The following NPI values are defined: *
    *
  • 0: Unknown
  • *
  • 1: ISDN (E163/E164)
  • *
  • 2: Data (X.121)
  • *
  • 3: Telex (F.69)
  • *
  • 6: Land Mobile (E.212)
  • *
  • 8: National
  • *
  • 9: Private
  • *
  • 10: ERMES
  • *
  • 13: Internet (IP)
  • *
  • 18: WAP Client Id (to be defined by WAP Forum)
  • *
*/ public void setDestAddrNpi(byte destAddrNpi) { this.destAddrNpi = destAddrNpi; } public byte getProtocolId() { return protocolId; } /** * The protocol id */ public void setProtocolId(byte protocolId) { this.protocolId = protocolId; } public byte getPriorityFlag() { return priorityFlag; } /** * Allows the originating SME to assign a priority level to the short message. Only for SubmitSm and SubmitMulti. * Four Priority Levels are supported: *
    *
  • 0: Level 0 (lowest) priority
  • *
  • 1: Level 1 priority
  • *
  • 2: Level 2 priority
  • *
  • 3: Level 3 (highest) priority
  • *
*/ public void setPriorityFlag(byte priorityFlag) { this.priorityFlag = priorityFlag; } public byte getReplaceIfPresentFlag() { return replaceIfPresentFlag; } /** * Used to request the SMSC to replace a previously submitted message, that is still pending delivery. The SMSC will * replace an existing message provided that the source address, destination address and service type match the same * fields in the new message. The following replace if present flag values are defined: *
    *
  • 0: Don't replace
  • *
  • 1: Replace
  • *
*/ public void setReplaceIfPresentFlag(byte replaceIfPresentFlag) { this.replaceIfPresentFlag = replaceIfPresentFlag; } public String getSourceAddr() { return sourceAddr; } /** * Defines the address of SME (Short Message Entity) which originated this message. */ public void setSourceAddr(String sourceAddr) { this.sourceAddr = sourceAddr; } public String getDestAddr() { return destAddr; } /** * Defines the destination SME address. For mobile terminated messages, this is the directory number of the * recipient MS. Only for SubmitSm, SubmitMulti, CancelSm and DataSm. */ public void setDestAddr(String destAddr) { this.destAddr = destAddr; } public byte getTypeOfNumber() { return typeOfNumber; } /** * Defines the type of number (TON) to be used in the SME. The following TON values are defined: *
    *
  • 0: Unknown
  • *
  • 1: International
  • *
  • 2: National
  • *
  • 3: Network Specific
  • *
  • 4: Subscriber Number
  • *
  • 5: Alphanumeric
  • *
  • 6: Abbreviated
  • *
*/ public void setTypeOfNumber(byte typeOfNumber) { this.typeOfNumber = typeOfNumber; } public byte getNumberingPlanIndicator() { return numberingPlanIndicator; } /** * Defines the numeric plan indicator (NPI) to be used in the SME. The following NPI values are defined: *
    *
  • 0: Unknown
  • *
  • 1: ISDN (E163/E164)
  • *
  • 2: Data (X.121)
  • *
  • 3: Telex (F.69)
  • *
  • 6: Land Mobile (E.212)
  • *
  • 8: National
  • *
  • 9: Private
  • *
  • 10: ERMES
  • *
  • 13: Internet (IP)
  • *
  • 18: WAP Client Id (to be defined by WAP Forum)
  • *
*/ public void setNumberingPlanIndicator(byte numberingPlanIndicator) { this.numberingPlanIndicator = numberingPlanIndicator; } public boolean isUsingSSL() { return usingSSL; } /** * Whether using SSL with the smpps protocol */ public void setUsingSSL(boolean usingSSL) { this.usingSSL = usingSSL; } public long getInitialReconnectDelay() { return initialReconnectDelay; } /** * Defines the initial delay in milliseconds after the consumer/producer tries to reconnect to the SMSC, after the * connection was lost. */ public void setInitialReconnectDelay(long initialReconnectDelay) { this.initialReconnectDelay = initialReconnectDelay; } public long getReconnectDelay() { return reconnectDelay; } /** * Defines the interval in milliseconds between the reconnect attempts, if the connection to the SMSC was lost and * the previous was not succeed. */ public void setReconnectDelay(long reconnectDelay) { this.reconnectDelay = reconnectDelay; } /** * Defines the maximum number of attempts to reconnect to the SMSC, if SMSC returns a negative bind response */ public int getMaxReconnect() { return maxReconnect; } public void setMaxReconnect(int maxReconnect) { this.maxReconnect = maxReconnect; } public boolean isLazySessionCreation() { return lazySessionCreation; } /** * Sessions can be lazily created to avoid exceptions, if the SMSC is not available when the Camel producer is * started. Camel will check the in message headers 'CamelSmppSystemId' and 'CamelSmppPassword' of the first * exchange. If they are present, Camel will use these data to connect to the SMSC. */ public void setLazySessionCreation(boolean lazySessionCreation) { this.lazySessionCreation = lazySessionCreation; } public String getMessageReceiverRouteId() { return messageReceiverRouteId; } /** * Set this on producer in order to benefit from transceiver (TRX) binding type. So once set, you don't need to * define an 'SMTPP consumer' endpoint anymore. You would set this to a 'Direct consumer' endpoint instead. * * DISCALIMER: This feature is only tested with 'Direct consumer' endpoint. The behavior with any other consumer * type is unknown and not tested. */ public void setMessageReceiverRouteId(String messageReceiverRouteId) { this.messageReceiverRouteId = messageReceiverRouteId; } public String getHttpProxyHost() { return httpProxyHost; } /** * If you need to tunnel SMPP through a HTTP proxy, set this attribute to the hostname or ip address of your HTTP * proxy. */ public void setHttpProxyHost(String httpProxyHost) { this.httpProxyHost = httpProxyHost; } public Integer getHttpProxyPort() { return httpProxyPort; } /** * If you need to tunnel SMPP through a HTTP proxy, set this attribute to the port of your HTTP proxy. */ public void setHttpProxyPort(Integer httpProxyPort) { this.httpProxyPort = httpProxyPort; } public String getHttpProxyUsername() { return httpProxyUsername; } /** * If your HTTP proxy requires basic authentication, set this attribute to the username required for your HTTP * proxy. */ public void setHttpProxyUsername(String httpProxyUsername) { this.httpProxyUsername = httpProxyUsername; } public String getHttpProxyPassword() { return httpProxyPassword; } /** * If your HTTP proxy requires basic authentication, set this attribute to the password required for your HTTP * proxy. */ public void setHttpProxyPassword(String httpProxyPassword) { this.httpProxyPassword = httpProxyPassword; } public SessionStateListener getSessionStateListener() { return sessionStateListener; } /** * You can refer to a org.jsmpp.session.SessionStateListener in the Registry to receive callbacks when the session * state changed. */ public void setSessionStateListener(SessionStateListener sessionStateListener) { this.sessionStateListener = sessionStateListener; } public String getAddressRange() { return addressRange; } /** * You can specify the address range for the SmppConsumer as defined in section 5.2.7 of the SMPP 3.4 specification. * The SmppConsumer will receive messages only from SMSC's which target an address (MSISDN or IP address) within * this range. */ public void setAddressRange(String addressRange) { this.addressRange = addressRange; } public SmppSplittingPolicy getSplittingPolicy() { return splittingPolicy; } /** * You can specify a policy for handling long messages: *
    *
  • ALLOW - the default, long messages are split to 140 bytes per message
  • *
  • TRUNCATE - long messages are split and only the first fragment will be sent to the SMSC. Some carriers drop * subsequent fragments so this reduces load on the SMPP connection sending parts of a message that will never be * delivered.
  • *
  • REJECT - if a message would need to be split, it is rejected with an SMPP NegativeResponseException and the * reason code signifying the message is too long.
  • *
*/ public void setSplittingPolicy(SmppSplittingPolicy splittingPolicy) { this.splittingPolicy = splittingPolicy; } /** * These headers will be passed to the proxy server while establishing the connection. */ public void setProxyHeaders(Map proxyHeaders) { this.proxyHeaders = proxyHeaders; } public Map getProxyHeaders() { return proxyHeaders; } public Integer getPduProcessorDegree() { return pduProcessorDegree; } /** * Sets the number of threads which can read PDU and process them in parallel. */ public void setPduProcessorDegree(Integer pduProcessorDegree) { this.pduProcessorDegree = pduProcessorDegree; } public Integer getPduProcessorQueueCapacity() { return pduProcessorQueueCapacity; } /** * Sets the capacity of the working queue for PDU processing. */ public void setPduProcessorQueueCapacity(Integer pduProcessorQueueCapacity) { this.pduProcessorQueueCapacity = pduProcessorQueueCapacity; } public boolean isSingleDLR() { return singleDLR; } /** * When true, the SMSC delivery receipt would be requested only for the last segment of a multi-segment (long) * message. For short messages, with only 1 segment the behaviour is unchanged. */ public void setSingleDLR(boolean singleDLR) { this.singleDLR = singleDLR; } public String getInterfaceVersion() { return interfaceVersion; } /** * Defines the interface version to be used in the binding request with the SMSC. The following values are allowed, * as defined in the SMPP protocol (and the underlying implementation using the jSMPP library, respectively): * "legacy" (0x00), "3.3" (0x33), "3.4" (0x34), and "5.0" (0x50). The default (fallback) value is version 3.4. */ public void setInterfaceVersion(String interfaceVersion) { this.interfaceVersion = interfaceVersion; } public InterfaceVersion getInterfaceVersionByte() { return switch (interfaceVersion) { case "legacy" -> InterfaceVersion.IF_00; case "3.3" -> InterfaceVersion.IF_33; case "3.4" -> InterfaceVersion.IF_34; case "5.0" -> InterfaceVersion.IF_50; default -> InterfaceVersion.IF_34; }; } @Override public String toString() { return "SmppConfiguration[usingSSL=" + usingSSL + ", enquireLinkTimer=" + enquireLinkTimer + ", host=" + host + ", password=" + password + ", port=" + port + ", systemId=" + systemId + ", systemType=" + systemType + ", dataCoding=" + dataCoding + ", alphabet=" + alphabet + ", encoding=" + encoding + ", transactionTimer=" + transactionTimer + ", pduProcessorQueueCapacity=" + pduProcessorQueueCapacity + ", pduProcessorDegree=" + pduProcessorDegree + ", registeredDelivery=" + registeredDelivery + ", singleDLR=" + singleDLR + ", serviceType=" + serviceType + ", sourceAddrTon=" + sourceAddrTon + ", destAddrTon=" + destAddrTon + ", sourceAddrNpi=" + sourceAddrNpi + ", destAddrNpi=" + destAddrNpi + ", addressRange=" + addressRange + ", protocolId=" + protocolId + ", priorityFlag=" + priorityFlag + ", replaceIfPresentFlag=" + replaceIfPresentFlag + ", sourceAddr=" + sourceAddr + ", destAddr=" + destAddr + ", typeOfNumber=" + typeOfNumber + ", numberingPlanIndicator=" + numberingPlanIndicator + ", initialReconnectDelay=" + initialReconnectDelay + ", reconnectDelay=" + reconnectDelay + ", maxReconnect=" + maxReconnect + ", lazySessionCreation=" + lazySessionCreation + ", messageReceiverRouteId=" + messageReceiverRouteId + ", httpProxyHost=" + httpProxyHost + ", httpProxyPort=" + httpProxyPort + ", httpProxyUsername=" + httpProxyUsername + ", httpProxyPassword=" + httpProxyPassword + ", splittingPolicy=" + splittingPolicy + ", proxyHeaders=" + proxyHeaders + ", interfaceVersion=" + interfaceVersion + "]"; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy