org.mobicents.protocols.ss7.tcapAnsi.api.TCAPProvider Maven / Gradle / Ivy
/*
* TeleStax, Open Source Cloud Communications
* Copyright 2012, Telestax Inc and individual contributors
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.mobicents.protocols.ss7.tcapAnsi.api;
import java.io.Serializable;
import org.mobicents.protocols.ss7.sccp.parameter.SccpAddress;
import org.mobicents.protocols.ss7.tcapAnsi.api.tc.dialog.Dialog;
import org.mobicents.protocols.ss7.tcapAnsi.api.tc.dialog.events.DraftParsedMessage;
/**
*
* @author baranowb
*
*/
public interface TCAPProvider extends Serializable {
/**
* Create new structured dialog.
*
* @param localAddress - desired local address
* @param remoteAddress - initial remote address, it can change after first TCContinue.
* @return
*/
Dialog getNewDialog(SccpAddress localAddress, SccpAddress remoteAddress) throws TCAPException;
/**
* Create new structured dialog with predefined local TransactionId.
* We do not normally invoke this method. Use it only when you need this and only this local TransactionId
* (for example if we need of recreating a Dialog for which a peer already has in memory)
* If a Dialog with local TransactionId is already present there will be TCAPException
*
* @param localAddress - desired local address
* @param remoteAddress - initial remote address, it can change after first TCContinue.
* @param localTrId - predefined local TransactionId
* @return
*/
Dialog getNewDialog(SccpAddress localAddress, SccpAddress remoteAddress, Long localTrId) throws TCAPException;
/**
* Create new unstructured dialog.
*
* @param localAddress
* @param remoteAddress
* @return
* @throws TCAPException
*/
Dialog getNewUnstructuredDialog(SccpAddress localAddress, SccpAddress remoteAddress) throws TCAPException;
// /////////////
// Factories //
// /////////////
DialogPrimitiveFactory getDialogPrimitiveFactory();
ComponentPrimitiveFactory getComponentPrimitiveFactory();
// /////////////
// Listeners //
// /////////////
void addTCListener(TCListener lst);
void removeTCListener(TCListener lst);
boolean getPreviewMode();
/**
* @return current count of active TCAP dialogs
*/
int getCurrentDialogsCount();
/**
* Parsing of encoded TCAP-ANSI message for getting only message type, origination/destination dialogId
*
* @param data
* @return
*/
DraftParsedMessage parseMessageDraft(byte[] data);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy