Search in sources :

Example 6 with TlvConvertException

use of com.cloudhopper.smpp.tlv.TlvConvertException in project smscgateway by RestComm.

the class TxSmppServerSbb method onDataSmLocal.

private void onDataSmLocal(final TxSmppServerSbbUsage anSbbUsage, final com.cloudhopper.smpp.pdu.DataSm event, ActivityContextInterface aci) {
    SmppTransaction smppServerTransaction = (SmppTransaction) aci.getActivity();
    Esme esme = smppServerTransaction.getEsme();
    String esmeName = esme.getName();
    if (this.logger.isFineEnabled()) {
        this.logger.fine("Received DATA_SM = " + event + " from Esme name=" + esmeName);
    }
    CheckMessageLimitResult cres = esme.onMessageReceived(1);
    if (cres.getResult() != CheckMessageLimitResult.Result.ok) {
        if (cres.getResult() == CheckMessageLimitResult.Result.firstFault) {
            this.updateOverrateCounters(cres);
            this.logger.info(cres.getMessage());
        }
        if (smscPropertiesManagement.isGenerateRejectionCdr()) {
            generateCDR(parseShortMessageText(event), esme.getNetworkId(), esme.getSystemId(), event.getSourceAddress().getAddress(), event.getSourceAddress().getTon(), event.getSourceAddress().getNpi(), event.getDestAddress().getAddress(), event.getDestAddress().getTon(), event.getDestAddress().getNpi(), CdrGenerator.CDR_SUBMIT_FAILED_ESME, cres.getMessage(), true);
        }
        DataSmResp response = event.createResponse();
        response.setCommandStatus(SmppConstants.STATUS_THROTTLED);
        String s = cres.getMessage();
        if (s.length() > 255)
            s = s.substring(0, 255);
        Tlv tlv;
        try {
            tlv = TlvUtil.createNullTerminatedStringTlv(SmppConstants.TAG_ADD_STATUS_INFO, s);
            response.addOptionalParameter(tlv);
        } catch (TlvConvertException e) {
            anSbbUsage.incrementCounterErrorDataSm(ONE);
            this.logger.severe("TlvConvertException while storing TAG_ADD_STATUS_INFO Tlv parameter", e);
        }
        // Lets send the Response with error here
        try {
            this.smppServerSessions.sendResponsePdu(esme, event, response);
        } catch (Exception e) {
            anSbbUsage.incrementCounterErrorDataSmResponding(ONE);
            this.logger.severe("Error while trying to send DataSmResponse=" + response, e);
        }
        try {
            TargetAddress ta = createDestTargetAddress(event.getDestAddress(), esme.getNetworkId());
            Sms sms = this.createSmsEvent(event, esme, ta, persistence);
            sms.setTimestampB(System.currentTimeMillis());
            generateFailureDetailedCdr(sms, EventType.IN_SMPP_REJECT_CONG, ErrorCode.REJECT_INCOMING, CdrDetailedGenerator.CDR_MSG_TYPE_DATASM, SmppConstants.STATUS_THROTTLED, esme.getRemoteAddressAndPort(), event.getSequenceNumber());
        } catch (SmscProcessingException e1) {
        }
        return;
    }
    Sms sms = null;
    try {
        TargetAddress ta = createDestTargetAddress(event.getDestAddress(), esme.getNetworkId());
        sms = this.createSmsEvent(event, esme, ta, persistence);
        this.processSms(sms, persistence, esme, null, event, null, IncomingMessageType.data_sm, CdrDetailedGenerator.CDR_MSG_TYPE_DATASM, event.getSequenceNumber());
    } catch (SmscProcessingException e1) {
        anSbbUsage.incrementCounterErrorDataSm(ONE);
        SbbStatsUtils.handleProcessingException(e1, anSbbUsage);
        if (!e1.isSkipErrorLogging()) {
            if (e1.isIsWarning()) {
                this.logger.warning(e1.getMessage());
            } else {
                this.logger.severe(e1.getMessage(), e1);
            }
            smscStatAggregator.updateMsgInFailedAll();
        }
        if (smscPropertiesManagement.isGenerateRejectionCdr() && !e1.isMessageRejectCdrCreated()) {
            if (sms != null) {
                generateCDR(sms, CdrGenerator.CDR_SUBMIT_FAILED_ESME, e1.getMessage(), false, true);
            } else {
                generateCDR(parseShortMessageText(event), esme.getNetworkId(), esme.getSystemId(), event.getSourceAddress().getAddress(), event.getSourceAddress().getTon(), event.getSourceAddress().getNpi(), event.getDestAddress().getAddress(), event.getDestAddress().getTon(), event.getDestAddress().getNpi(), CdrGenerator.CDR_SUBMIT_FAILED_ESME, e1.getMessage(), true);
            }
        }
        DataSmResp response = event.createResponse();
        response.setCommandStatus(e1.getSmppErrorCode());
        String s = e1.getMessage();
        if (s != null) {
            if (s.length() > 255)
                s = s.substring(0, 255);
            Tlv tlv;
            try {
                tlv = TlvUtil.createNullTerminatedStringTlv(SmppConstants.TAG_ADD_STATUS_INFO, s);
                response.addOptionalParameter(tlv);
            } catch (TlvConvertException e) {
                this.logger.severe("TlvConvertException while storing TAG_ADD_STATUS_INFO Tlv parameter", e);
            }
        }
        // Lets send the Response with error here
        long timestampB = 0L;
        try {
            this.smppServerSessions.sendResponsePdu(esme, event, response);
            timestampB = System.currentTimeMillis();
        } catch (Exception e) {
            anSbbUsage.incrementCounterErrorDataSmResponding(ONE);
            this.logger.severe("Error while trying to send DataSmResponse=" + response, e);
        }
        EventType eventType = null;
        if (e1.getInternalErrorCode() == SmscProcessingException.INTERNAL_ERROR_STATE_OVERLOADED) {
            eventType = EventType.IN_SMPP_REJECT_CONG;
        } else {
            eventType = EventType.IN_SMPP_REJECT_FORBIDDEN;
        }
        if (sms != null) {
            sms.setTimestampB(System.currentTimeMillis());
            generateRejectDetailedCdr(e1.getInternalErrorCode(), sms, eventType, ErrorCode.REJECT_INCOMING, CdrDetailedGenerator.CDR_MSG_TYPE_DATASM, e1.getSmppErrorCode(), esme.getRemoteAddressAndPort(), event.getSequenceNumber());
        } else {
            generateRejectDetailedCdr(e1.getInternalErrorCode(), event, esme, eventType, ErrorCode.REJECT_INCOMING, CdrDetailedGenerator.CDR_MSG_TYPE_SUBMITSM, e1.getSmppErrorCode(), parseShortMessageText(event), timestampB);
        }
        return;
    } catch (Throwable e1) {
        anSbbUsage.incrementCounterErrorDataSm(ONE);
        String s = "Exception when processing dataSm message: " + e1.getMessage();
        this.logger.severe(s, e1);
        smscStatAggregator.updateMsgInFailedAll();
        if (smscPropertiesManagement.isGenerateRejectionCdr()) {
            generateCDR(parseShortMessageText(event), esme.getNetworkId(), esme.getSystemId(), event.getSourceAddress().getAddress(), event.getSourceAddress().getTon(), event.getSourceAddress().getNpi(), event.getDestAddress().getAddress(), event.getDestAddress().getTon(), event.getDestAddress().getNpi(), CdrGenerator.CDR_SUBMIT_FAILED_ESME, e1.getMessage(), true);
        }
        DataSmResp response = event.createResponse();
        response.setCommandStatus(SmppConstants.STATUS_SYSERR);
        if (s.length() > 255)
            s = s.substring(0, 255);
        Tlv tlv;
        try {
            tlv = TlvUtil.createNullTerminatedStringTlv(SmppConstants.TAG_ADD_STATUS_INFO, s);
            response.addOptionalParameter(tlv);
        } catch (TlvConvertException e) {
            this.logger.severe("TlvConvertException while storing TAG_ADD_STATUS_INFO Tlv parameter", e);
        }
        // Lets send the Response with error here
        try {
            this.smppServerSessions.sendResponsePdu(esme, event, response);
            if (sms != null) {
                sms.setTimestampB(System.currentTimeMillis());
                generateFailureDetailedCdr(sms, EventType.IN_SMPP_ERROR, ErrorCode.REJECT_INCOMING, CdrDetailedGenerator.CDR_MSG_TYPE_DATASM, SmppConstants.STATUS_SYSERR, esme.getRemoteAddressAndPort(), event.getSequenceNumber());
            }
        } catch (Exception e) {
            anSbbUsage.incrementCounterErrorDataSmResponding(ONE);
            this.logger.severe("Error while trying to send SubmitSmResponse=" + response, e);
        }
        return;
    }
    DataSmResp response = event.createResponse();
    response.setMessageId(sms.getMessageIdText());
    // Lets send the Response with success here
    try {
        if (sms.getMessageDeliveryResultResponse() == null) {
            this.smppServerSessions.sendResponsePdu(esme, event, response);
            sms.setTimestampB(System.currentTimeMillis());
            generateDetailedCDR(sms, EventType.IN_SMPP_RECEIVED, CdrDetailedGenerator.CDR_MSG_TYPE_DATASM, SmppConstants.STATUS_OK, esme.getRemoteAddressAndPort(), event.getSequenceNumber());
        }
    } catch (Exception e) {
        anSbbUsage.incrementCounterErrorDataSmResponding(ONE);
        this.logger.severe("Error while trying to send DataSmResponse=" + response, e);
    }
}
Also used : TlvConvertException(com.cloudhopper.smpp.tlv.TlvConvertException) SmppTransaction(org.restcomm.slee.resource.smpp.SmppTransaction) Esme(org.restcomm.smpp.Esme) CheckMessageLimitResult(org.restcomm.smpp.CheckMessageLimitResult) DataSmResp(com.cloudhopper.smpp.pdu.DataSmResp) ParseException(java.text.ParseException) TlvConvertException(com.cloudhopper.smpp.tlv.TlvConvertException) RecoverablePduException(com.cloudhopper.smpp.type.RecoverablePduException) CharacterCodingException(java.nio.charset.CharacterCodingException) SmppInvalidArgumentException(com.cloudhopper.smpp.type.SmppInvalidArgumentException) PersistenceException(org.mobicents.smsc.cassandra.PersistenceException) Tlv(com.cloudhopper.smpp.tlv.Tlv)

Example 7 with TlvConvertException

use of com.cloudhopper.smpp.tlv.TlvConvertException in project smscgateway by RestComm.

the class TxSmppServerSbb method createSmsEventMulti.

protected SubmitMultiParseResult createSmsEventMulti(SubmitMulti event, Esme origEsme, PersistenceRAInterface store, int networkId) throws SmscProcessingException {
    List<Address> addrList = event.getDestAddresses();
    if (addrList == null || addrList.size() == 0) {
        throw new SmscProcessingException("For received SubmitMulti no DestAddresses found: ", SmppConstants.STATUS_INVDLNAME, MAPErrorCode.systemFailure, SmscProcessingException.HTTP_ERROR_CODE_NOT_SET, null, SmscProcessingException.INTERNAL_ERROR_MISC_DST_ADDR_INVALID);
    }
    if (event.getSourceAddress() == null || event.getSourceAddress().getAddress() == null || event.getSourceAddress().getAddress().isEmpty()) {
        throw new SmscProcessingException("SourceAddress digits are absent", SmppConstants.STATUS_INVSRCADR, MAPErrorCode.systemFailure, SmscProcessingException.HTTP_ERROR_CODE_NOT_SET, null, SmscProcessingException.INTERNAL_ERROR_MISC_SRC_ADDR_INVALID);
    }
    // checking parameters first
    String sourceAddr = event.getSourceAddress().getAddress();
    int sourceAddrTon = event.getSourceAddress().getTon();
    int sourceAddrNpi = event.getSourceAddress().getNpi();
    int dcs = event.getDataCoding();
    String err = MessageUtil.checkDataCodingSchemeSupport(dcs);
    if (err != null) {
        throw new SmscProcessingException("TxSmpp DataCoding scheme does not supported: " + dcs + " - " + err, SmppExtraConstants.ESME_RINVDCS, MAPErrorCode.systemFailure, SmscProcessingException.HTTP_ERROR_CODE_NOT_SET, null, SmscProcessingException.INTERNAL_ERROR_MISC_DATA_CODING_INVALID);
    }
    DataCodingScheme dataCodingScheme = new DataCodingSchemeImpl(dcs);
    boolean udhPresent = (event.getEsmClass() & SmppConstants.ESM_CLASS_UDHI_MASK) != 0;
    Tlv sarMsgRefNum = event.getOptionalParameter(SmppConstants.TAG_SAR_MSG_REF_NUM);
    Tlv sarTotalSegments = event.getOptionalParameter(SmppConstants.TAG_SAR_TOTAL_SEGMENTS);
    Tlv sarSegmentSeqnum = event.getOptionalParameter(SmppConstants.TAG_SAR_SEGMENT_SEQNUM);
    boolean segmentTlvFlag = (sarMsgRefNum != null && sarTotalSegments != null && sarSegmentSeqnum != null);
    // short message data
    byte[] data = event.getShortMessage();
    if (event.getShortMessageLength() == 0) {
        // Probably the message_payload Optional Parameter is being used
        Tlv messagePaylod = event.getOptionalParameter(SmppConstants.TAG_MESSAGE_PAYLOAD);
        if (messagePaylod != null) {
            data = messagePaylod.getValue();
        }
    }
    if (data == null) {
        data = new byte[0];
    }
    byte[] udhData;
    byte[] textPart;
    String msg;
    udhData = null;
    textPart = data;
    if (udhPresent && data.length > 2) {
        // UDH exists
        int udhLen = (textPart[0] & 0xFF) + 1;
        if (udhLen <= textPart.length) {
            textPart = new byte[textPart.length - udhLen];
            udhData = new byte[udhLen];
            System.arraycopy(data, udhLen, textPart, 0, textPart.length);
            System.arraycopy(data, 0, udhData, 0, udhLen);
        }
    }
    msg = parseShortMessageText(event);
    // checking max message length
    int nationalLanguageLockingShift = 0;
    int nationalLanguageSingleShift = 0;
    if (udhPresent || segmentTlvFlag) {
        // here splitting by SMSC is not supported
        UserDataHeader udh = null;
        int lenSolid = MessageUtil.getMaxSolidMessageBytesLength();
        if (udhPresent)
            udh = new UserDataHeaderImpl(udhData);
        else {
            udh = createNationalLanguageUdh(origEsme, dataCodingScheme);
            if (udh != null && udh.getNationalLanguageLockingShift() != null) {
                lenSolid -= 3;
                nationalLanguageLockingShift = udh.getNationalLanguageLockingShift().getNationalLanguageIdentifier().getCode();
            }
            if (udh != null && udh.getNationalLanguageSingleShift() != null) {
                lenSolid -= 3;
                nationalLanguageSingleShift = udh.getNationalLanguageSingleShift().getNationalLanguageIdentifier().getCode();
            }
        }
        int messageLen = MessageUtil.getMessageLengthInBytes(dataCodingScheme, msg, udh);
        if (udhData != null)
            messageLen += udhData.length;
        if (messageLen > lenSolid) {
            throw new SmscProcessingException("Message length in bytes is too big for solid message: " + messageLen + ">" + lenSolid, SmppConstants.STATUS_INVPARLEN, MAPErrorCode.systemFailure, SmscProcessingException.HTTP_ERROR_CODE_NOT_SET, null, SmscProcessingException.INTERNAL_ERROR_MISC_MSG_TOO_LONG);
        }
    } else {
        // here splitting by SMSC is supported
        int lenSegmented = MessageUtil.getMaxSegmentedMessageBytesLength();
        if (msg.length() * 2 > (lenSegmented - 6) * 255) {
            // firstly draft length check
            UserDataHeader udh = createNationalLanguageUdh(origEsme, dataCodingScheme);
            int messageLen = MessageUtil.getMessageLengthInBytes(dataCodingScheme, msg, udh);
            if (udh != null && udh.getNationalLanguageLockingShift() != null) {
                lenSegmented -= 3;
                nationalLanguageLockingShift = udh.getNationalLanguageLockingShift().getNationalLanguageIdentifier().getCode();
            }
            if (udh != null && udh.getNationalLanguageSingleShift() != null) {
                lenSegmented -= 3;
                nationalLanguageSingleShift = udh.getNationalLanguageSingleShift().getNationalLanguageIdentifier().getCode();
            }
            if (messageLen > lenSegmented * 255) {
                throw new SmscProcessingException("Message length in bytes is too big for segmented message: " + messageLen + ">" + lenSegmented, SmppConstants.STATUS_INVPARLEN, MAPErrorCode.systemFailure, SmscProcessingException.HTTP_ERROR_CODE_NOT_SET, null, SmscProcessingException.INTERNAL_ERROR_MISC_MSG_TOO_LONG);
            }
        }
    }
    // ValidityPeriod processing
    Tlv tlvQosTimeToLive = event.getOptionalParameter(SmppConstants.TAG_QOS_TIME_TO_LIVE);
    Date validityPeriod;
    if (tlvQosTimeToLive != null) {
        long valTime;
        try {
            valTime = (new Date()).getTime() + tlvQosTimeToLive.getValueAsInt();
        } catch (TlvConvertException e) {
            throw new SmscProcessingException("TlvConvertException when getting TAG_QOS_TIME_TO_LIVE tlv field: " + e.getMessage(), SmppConstants.STATUS_INVOPTPARAMVAL, MAPErrorCode.systemFailure, SmscProcessingException.HTTP_ERROR_CODE_NOT_SET, null, e, SmscProcessingException.INTERNAL_ERROR_MISC_VALIDITY_PERIOD_PARSING);
        }
        validityPeriod = new Date(valTime);
    } else {
        try {
            validityPeriod = MessageUtil.parseSmppDate(event.getValidityPeriod());
        } catch (ParseException e) {
            throw new SmscProcessingException("ParseException when parsing ValidityPeriod field: " + e.getMessage(), SmppConstants.STATUS_INVEXPIRY, MAPErrorCode.systemFailure, SmscProcessingException.HTTP_ERROR_CODE_NOT_SET, null, e, SmscProcessingException.INTERNAL_ERROR_MISC_VALIDITY_PERIOD_PARSING);
        }
    }
    // ScheduleDeliveryTime processing
    Date scheduleDeliveryTime;
    try {
        scheduleDeliveryTime = MessageUtil.parseSmppDate(event.getScheduleDeliveryTime());
    } catch (ParseException e) {
        throw new SmscProcessingException("ParseException when parsing ScheduleDeliveryTime field: " + e.getMessage(), SmppConstants.STATUS_INVSCHED, MAPErrorCode.systemFailure, SmscProcessingException.HTTP_ERROR_CODE_NOT_SET, null, e, SmscProcessingException.INTERNAL_ERROR_MISC_SCHEDULER_DELIVERY_TIME_PARSING);
    }
    long messageId = store.c2_getNextMessageId();
    SmscStatProvider.getInstance().setCurrentMessageId(messageId);
    ArrayList<Sms> msgList = new ArrayList<Sms>(addrList.size());
    ArrayList<UnsucessfulSME> badAddresses = new ArrayList<UnsucessfulSME>(addrList.size());
    for (Address address : addrList) {
        boolean succAddr = false;
        TargetAddress ta = null;
        try {
            ta = createDestTargetAddress(address, networkId);
            succAddr = true;
        } catch (SmscProcessingException e) {
            Address addr = (Address) e.getExtraErrorData();
            if (addr != null) {
                UnsucessfulSME asme = new UnsucessfulSME(e.getSmppErrorCode(), addr);
                badAddresses.add(asme);
            }
        }
        if (succAddr) {
            Sms sms = new Sms();
            sms.setDbId(UUID.randomUUID());
            sms.setOriginationType(OriginationType.SMPP);
            sms.setSourceAddr(sourceAddr);
            sms.setSourceAddrTon(sourceAddrTon);
            sms.setSourceAddrNpi(sourceAddrNpi);
            sms.setOrigNetworkId(networkId);
            sms.setDataCoding(dcs);
            sms.setNationalLanguageLockingShift(nationalLanguageLockingShift);
            sms.setNationalLanguageSingleShift(nationalLanguageSingleShift);
            sms.setOrigSystemId(origEsme.getSystemId());
            sms.setOrigEsmeName(origEsme.getName());
            sms.setSubmitDate(new Timestamp(System.currentTimeMillis()));
            sms.setServiceType(event.getServiceType());
            sms.setEsmClass(event.getEsmClass());
            sms.setProtocolId(event.getProtocolId());
            sms.setPriority(event.getPriority());
            sms.setRegisteredDelivery(event.getRegisteredDelivery());
            sms.setReplaceIfPresent(event.getReplaceIfPresent());
            sms.setDefaultMsgId(event.getDefaultMsgId());
            sms.setShortMessageText(msg);
            sms.setShortMessageBin(udhData);
            MessageUtil.applyValidityPeriod(sms, validityPeriod, true, smscPropertiesManagement.getMaxValidityPeriodHours(), smscPropertiesManagement.getDefaultValidityPeriodHours());
            MessageUtil.applyScheduleDeliveryTime(sms, scheduleDeliveryTime);
            // storing additional parameters
            ArrayList<Tlv> optionalParameters = event.getOptionalParameters();
            if (optionalParameters != null && optionalParameters.size() > 0) {
                for (Tlv tlv : optionalParameters) {
                    if (tlv.getTag() != SmppConstants.TAG_MESSAGE_PAYLOAD) {
                        sms.getTlvSet().addOptionalParameter(tlv);
                    }
                }
            }
            SmsSet smsSet;
            smsSet = new SmsSet();
            smsSet.setDestAddr(ta.getAddr());
            smsSet.setDestAddrNpi(ta.getAddrNpi());
            smsSet.setDestAddrTon(ta.getAddrTon());
            smsSet.setNetworkId(origEsme.getNetworkId());
            smsSet.addSms(sms);
            sms.setSmsSet(smsSet);
            sms.setMessageId(messageId);
            msgList.add(sms);
        }
    }
    return new SubmitMultiParseResult(msgList, badAddresses);
}
Also used : DataCodingScheme(org.restcomm.protocols.ss7.map.api.smstpdu.DataCodingScheme) UserDataHeaderImpl(org.restcomm.protocols.ss7.map.smstpdu.UserDataHeaderImpl) Address(com.cloudhopper.smpp.type.Address) UnsucessfulSME(com.cloudhopper.smpp.type.UnsucessfulSME) ArrayList(java.util.ArrayList) DataCodingSchemeImpl(org.restcomm.protocols.ss7.map.smstpdu.DataCodingSchemeImpl) Timestamp(java.sql.Timestamp) UserDataHeader(org.restcomm.protocols.ss7.map.api.smstpdu.UserDataHeader) Tlv(com.cloudhopper.smpp.tlv.Tlv) TlvConvertException(com.cloudhopper.smpp.tlv.TlvConvertException) Date(java.util.Date) ParseException(java.text.ParseException)

Example 8 with TlvConvertException

use of com.cloudhopper.smpp.tlv.TlvConvertException in project smscgateway by RestComm.

the class MessageUtil method isSmsNotLastSegment.

public static boolean isSmsNotLastSegment(Sms sms) {
    boolean isPartial = false;
    Tlv sarMsgRefNum = sms.getTlvSet().getOptionalParameter(SmppConstants.TAG_SAR_MSG_REF_NUM);
    Tlv sarTotalSegments = sms.getTlvSet().getOptionalParameter(SmppConstants.TAG_SAR_TOTAL_SEGMENTS);
    Tlv sarSegmentSeqnum = sms.getTlvSet().getOptionalParameter(SmppConstants.TAG_SAR_SEGMENT_SEQNUM);
    if ((sms.getEsmClass() & SmppConstants.ESM_CLASS_UDHI_MASK) != 0) {
        // message already contains UDH - checking for segment
        // number
        byte[] shortMessage = sms.getShortMessageBin();
        if (shortMessage != null && shortMessage.length > 2) {
            // UDH exists
            int udhLen = (shortMessage[0] & 0xFF) + 1;
            if (udhLen <= shortMessage.length) {
                byte[] udhData = new byte[udhLen];
                System.arraycopy(shortMessage, 0, udhData, 0, udhLen);
                UserDataHeaderImpl userDataHeader = new UserDataHeaderImpl(udhData);
                ConcatenatedShortMessagesIdentifier csm = userDataHeader.getConcatenatedShortMessagesIdentifier();
                if (csm != null) {
                    int mSCount = csm.getMesageSegmentCount();
                    int mSNumber = csm.getMesageSegmentNumber();
                    if (mSNumber < mSCount)
                        isPartial = true;
                }
            }
        }
    } else if (sarMsgRefNum != null && sarTotalSegments != null && sarSegmentSeqnum != null) {
        // count/number/reference
        try {
            int mSCount = sarTotalSegments.getValueAsUnsignedByte();
            int mSNumber = sarSegmentSeqnum.getValueAsUnsignedByte();
            if (mSNumber < mSCount)
                isPartial = true;
        } catch (TlvConvertException e) {
        }
    }
    return isPartial;
}
Also used : TlvConvertException(com.cloudhopper.smpp.tlv.TlvConvertException) UserDataHeaderImpl(org.restcomm.protocols.ss7.map.smstpdu.UserDataHeaderImpl) ConcatenatedShortMessagesIdentifier(org.restcomm.protocols.ss7.map.api.smstpdu.ConcatenatedShortMessagesIdentifier) Tlv(com.cloudhopper.smpp.tlv.Tlv)

Example 9 with TlvConvertException

use of com.cloudhopper.smpp.tlv.TlvConvertException in project smscgateway by RestComm.

the class MessageUtil method parseDeliveryReceipt.

public static DeliveryReceiptData parseDeliveryReceipt(String msg, TlvSet tlvSet) {
    if (msg == null || msg.length() < 102)
        return null;
    String[] namesList = new String[] { DELIVERY_ACK_ID, DELIVERY_ACK_SUB, DELIVERY_ACK_DLVRD, DELIVERY_ACK_SUBMIT_DATE, DELIVERY_ACK_DONE_DATE, DELIVERY_ACK_STAT, DELIVERY_ACK_ERR, DELIVERY_ACK_TEXT };
    String lcMessage = msg.toLowerCase();
    int pos = 0;
    ArrayList<String> values = new ArrayList<String>(8);
    for (int i1 = 0; i1 < namesList.length; i1++) {
        String fieldName = namesList[i1];
        int newPos = lcMessage.indexOf(fieldName, pos);
        if (newPos < 0) {
            if (fieldName.equals(DELIVERY_ACK_TEXT))
                break;
            else
                return null;
        }
        if (i1 == 0) {
            if (newPos != 0)
                return null;
        } else {
            if (newPos >= 0) {
                values.add(msg.substring(pos, newPos));
            }
        }
        pos = newPos + fieldName.length();
    }
    values.add(msg.substring(pos));
    DeliveryReceiptDataImpl deliveryReceiptData = new DeliveryReceiptDataImpl();
    String idVal = values.get(0);
    String submittedVal = values.get(1);
    String deliveredVal = values.get(2);
    String submitDateVal = values.get(3);
    String doneDateVal = values.get(4);
    String statusVal = values.get(5);
    String errorVal = values.get(6);
    String textVal = null;
    if (values.size() >= 8)
        textVal = values.get(7);
    SimpleDateFormat sdf = new SimpleDateFormat("yyMMddHHmm");
    SimpleDateFormat sdf2 = new SimpleDateFormat("yyMMddHHmmss");
    deliveryReceiptData.setMessageId(idVal);
    try {
        int msgSubmitted = Integer.parseInt(submittedVal);
        deliveryReceiptData.setMsgSubmitted(msgSubmitted);
    } catch (NumberFormatException e) {
    }
    try {
        int msgDelivered = Integer.parseInt(deliveredVal);
        deliveryReceiptData.setMsgDelivered(msgDelivered);
    } catch (NumberFormatException e) {
    }
    try {
        Date submitDate;
        if (submitDateVal.length() == 10)
            submitDate = sdf.parse(submitDateVal);
        else
            submitDate = sdf2.parse(submitDateVal);
        deliveryReceiptData.setSubmitDate(submitDate);
    } catch (ParseException e) {
    }
    try {
        Date doneDate;
        if (doneDateVal.length() == 10)
            doneDate = sdf.parse(doneDateVal);
        else
            doneDate = sdf2.parse(doneDateVal);
        deliveryReceiptData.setDoneDate(doneDate);
    } catch (ParseException e) {
    }
    deliveryReceiptData.setStatus(statusVal);
    try {
        int error = Integer.parseInt(errorVal);
        deliveryReceiptData.setError(error);
    } catch (NumberFormatException e) {
    }
    deliveryReceiptData.setText(textVal);
    Tlv tlv = tlvSet.getOptionalParameter(SmppConstants.TAG_RECEIPTED_MSG_ID);
    if (tlv != null) {
        // String val = new String(data);
        try {
            String val = tlv.getValueAsString();
            deliveryReceiptData.setTlvReceiptedMessageId(val);
        } catch (TlvConvertException e) {
        }
    }
    tlv = tlvSet.getOptionalParameter(SmppConstants.TAG_MSG_STATE);
    if (tlv != null) {
        try {
            byte val = tlv.getValueAsByte();
            deliveryReceiptData.setTlvMessageState(new Integer(val));
        } catch (TlvConvertException e) {
        }
    }
    return deliveryReceiptData;
}
Also used : TlvConvertException(com.cloudhopper.smpp.tlv.TlvConvertException) ArrayList(java.util.ArrayList) Date(java.util.Date) DeliveryReceiptDataImpl(org.mobicents.smsc.mproc.impl.DeliveryReceiptDataImpl) ParseException(java.text.ParseException) SimpleDateFormat(java.text.SimpleDateFormat) Tlv(com.cloudhopper.smpp.tlv.Tlv)

Aggregations

Tlv (com.cloudhopper.smpp.tlv.Tlv)9 TlvConvertException (com.cloudhopper.smpp.tlv.TlvConvertException)9 ParseException (java.text.ParseException)7 RecoverablePduException (com.cloudhopper.smpp.type.RecoverablePduException)4 SmppInvalidArgumentException (com.cloudhopper.smpp.type.SmppInvalidArgumentException)4 CharacterCodingException (java.nio.charset.CharacterCodingException)4 Date (java.util.Date)4 PersistenceException (org.mobicents.smsc.cassandra.PersistenceException)4 SmppTransaction (org.restcomm.slee.resource.smpp.SmppTransaction)4 CheckMessageLimitResult (org.restcomm.smpp.CheckMessageLimitResult)4 Esme (org.restcomm.smpp.Esme)4 UserDataHeaderImpl (org.restcomm.protocols.ss7.map.smstpdu.UserDataHeaderImpl)3 Address (com.cloudhopper.smpp.type.Address)2 UnsucessfulSME (com.cloudhopper.smpp.type.UnsucessfulSME)2 Timestamp (java.sql.Timestamp)2 ArrayList (java.util.ArrayList)2 DataCodingScheme (org.restcomm.protocols.ss7.map.api.smstpdu.DataCodingScheme)2 UserDataHeader (org.restcomm.protocols.ss7.map.api.smstpdu.UserDataHeader)2 DataCodingSchemeImpl (org.restcomm.protocols.ss7.map.smstpdu.DataCodingSchemeImpl)2 DataSmResp (com.cloudhopper.smpp.pdu.DataSmResp)1