#include <sipcon.h>
Inheritance diagram for SIPConnection:
anonymous enum [protected] |
enum SIPConnection::HoldState [protected] |
SIPConnection::SIPConnection | ( | OpalCall & | call, | |
SIPEndPoint & | endpoint, | |||
const PString & | token, | |||
const SIPURL & | address, | |||
OpalTransport * | transport, | |||
unsigned int | options = 0 , |
|||
OpalConnection::StringOptions * | stringOptions = NULL | |||
) |
Create a new connection.
call | Owner call for connection |
endpoint | Owner endpoint for connection |
token | token to identify the connection |
address | Destination address for outgoing call |
transport | Transport INVITE came in on |
options | Connection options |
stringOptions | complex string options |
SIPConnection::~SIPConnection | ( | ) |
Destroy connection.
virtual bool SIPConnection::AnswerSDPMediaDescription | ( | const SDPSessionDescription & | sdpIn, | |
unsigned | sessionIndex, | |||
SDPSessionDescription & | sdpOut | |||
) | [protected, virtual] |
TypeOfINVITE SIPConnection::CheckINVITE | ( | const SIP_PDU & | pdu | ) | const |
Indicate if this is a duplicate or multi-path INVITE.
virtual bool SIPConnection::CloseMediaStream | ( | OpalMediaStream & | stream | ) | [virtual] |
Request close of a specific media stream. Note that this is usually asymchronous, the OnClosedMediaStream() function is called when the stream is really closed.
stream | Stream to close |
Reimplemented from OpalConnection.
virtual PBoolean SIPConnection::ForwardCall | ( | const PString & | forwardParty | ) | [virtual] |
Forward incoming connection to the specified address. This would typically be called from within the OnIncomingConnection() function when an application wishes to redirect an unwanted incoming call.
The return value is PTrue if the call is to be forwarded, PFalse otherwise. Note that if the call is forwarded, the current connection is cleared with the ended call code set to EndedByCallForwarded.
forwardParty | Party to forward call to. |
Reimplemented from OpalConnection.
virtual PString SIPConnection::GetAlertingType | ( | ) | const [virtual] |
Get alerting type information of an incoming call. The type of "distinctive ringing" for the call. The string is protocol dependent, so the caller would need to be aware of the type of call being made. Some protocols may ignore the field completely.
For SIP this corresponds to the string contained in the "Alert-Info" header field of the INVITE. This is typically a URI for the ring file.
For H.323 this must be a string representation of an integer from 0 to 7 which will be contained in the Q.931 SIGNAL (0x34) Information Element.
Default behaviour returns an empty string.
Reimplemented from OpalConnection.
SIPAuthentication* SIPConnection::GetAuthenticator | ( | ) | const [inline] |
virtual PString SIPConnection::GetCalledPartyURL | ( | ) | [virtual] |
Get the fulll URL being indicated by the remote for incoming calls. This may not have any relation to the local name of the endpoint.
The default behaviour returns GetDestinationAddress() normalised to a URL. The remote may provide a full URL, if it does not then the prefix for the endpoint is prepended to the destination address.
Reimplemented from OpalConnection.
OpalTransportAddress SIPConnection::GetDefaultSDPConnectAddress | ( | WORD | port = 0 |
) | const |
virtual PString SIPConnection::GetDestinationAddress | ( | ) | [virtual] |
Get the destination address of an incoming connection. This will, for example, collect a phone number from a POTS line, or get the fields from the H.225 SETUP pdu in a H.323 connection.
The default behaviour for sip returns the request URI in the INVITE.
Reimplemented from OpalConnection.
const SIPDialogContext& SIPConnection::GetDialog | ( | ) | const [inline] |
SIPDialogContext& SIPConnection::GetDialog | ( | ) | [inline] |
SIPEndPoint& SIPConnection::GetEndPoint | ( | ) | const [inline] |
Get the owner endpoint for this connection.
Reimplemented from OpalConnection.
virtual PString SIPConnection::GetIdentifier | ( | ) | const [virtual] |
Get the protocol-specific unique identifier for this connection.
Reimplemented from OpalConnection.
PString SIPConnection::GetLocalPartyURL | ( | ) | const [virtual] |
Get the local name/alias.
Reimplemented from OpalConnection.
virtual OpalMediaFormatList SIPConnection::GetMediaFormats | ( | ) | const [virtual] |
Get the data formats this endpoint is capable of operating in.
Reimplemented from OpalConnection.
virtual PString SIPConnection::GetPrefixName | ( | ) | const [virtual] |
Get this connections protocol prefix for URLs.
Reimplemented from OpalConnection.
virtual SendUserInputModes SIPConnection::GetRealSendUserInputMode | ( | ) | const [virtual] |
Get the real user input indication transmission mode. This will return the user input mode that will actually be used for transmissions. It will be the value of GetSendUserInputMode() provided the remote endpoint is capable of that mode.
Reimplemented from OpalConnection.
OpalTransport& SIPConnection::GetTransport | ( | ) | const [inline, virtual] |
Reimplemented from OpalConnection.
virtual bool SIPConnection::HoldConnection | ( | ) | [virtual] |
Put the current connection on hold, suspending all media streams.
Reimplemented from OpalConnection.
virtual bool SIPConnection::IsConnectionOnHold | ( | bool | fromRemote | ) | [virtual] |
Return true if the current connection is on hold. The bool parameter indicates if we are testing if the remote system has us on hold, or we have them on hold.
fromRemote | Test if remote has us on hold, or we have them |
Reimplemented from OpalConnection.
virtual bool SIPConnection::IsNetworkConnection | ( | ) | const [inline, virtual] |
Get indication of connection being to a "network". This indicates the if the connection may be regarded as a "network" connection. The distinction is about if there is a concept of a "remote" party being connected to and is best described by example: sip, h323, iax and pstn are all "network" connections as they connect to something "remote". While pc, pots and ivr are not as the entity being connected to is intrinsically local.
Implements OpalConnection.
void SIPConnection::NotifyDialogState | ( | SIPDialogNotification::States | state, | |
SIPDialogNotification::Events | eventType = SIPDialogNotification::NoEvent , |
|||
unsigned | eventCode = 0 | |||
) | [protected] |
virtual bool SIPConnection::OfferSDPMediaDescription | ( | const OpalMediaType & | mediaType, | |
unsigned | sessionID, | |||
OpalRTPSessionManager & | rtpSessions, | |||
SDPSessionDescription & | sdpOut, | |||
bool | offerOpenMediaStreamOnly = false | |||
) | [protected, virtual] |
virtual void SIPConnection::OnAllowedEventNotify | ( | const PString & | eventName | ) | [virtual] |
Callback function on receipt of an allowed NOTIFY message. Allowed events are determined by the m_allowedEvents member variable.
eventName | Name of event |
virtual void SIPConnection::OnCreatingINVITE | ( | SIPInvite & | pdu | ) | [virtual] |
Handle a sending INVITE request
virtual void SIPConnection::OnMediaCommand | ( | OpalMediaCommand & | note, | |
INT | extra | |||
) | [virtual] |
Notifier function for OpalVideoUpdatePicture. Calls the SendIntraFrameRequest on the rtp session
Reimplemented from OpalRTPConnection.
virtual PBoolean SIPConnection::OnMediaControlXML | ( | SIP_PDU & | pdu | ) | [virtual] |
Call when SIP INFO of type application/media_control+xml is received.
Return PFalse if default reponse of Failure_UnsupportedMediaType is to be returned
virtual void SIPConnection::OnReceivedACK | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming ACK PDU
virtual PBoolean SIPConnection::OnReceivedAuthenticationRequired | ( | SIPTransaction & | transaction, | |
SIP_PDU & | response | |||
) | [virtual] |
Handle an incoming Proxy Authentication Required response PDU Returns: PTrue if handled, if PFalse is returned connection is released.
virtual void SIPConnection::OnReceivedBYE | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming BYE PDU
virtual void SIPConnection::OnReceivedCANCEL | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming CANCEL PDU
virtual void SIPConnection::OnReceivedINFO | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming INFO PDU
virtual void SIPConnection::OnReceivedINVITE | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming INVITE request
virtual void SIPConnection::OnReceivedMESSAGE | ( | SIP_PDU & | pdu | ) | [virtual] |
virtual void SIPConnection::OnReceivedNOTIFY | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming NOTIFY PDU
virtual void SIPConnection::OnReceivedOK | ( | SIPTransaction & | transaction, | |
SIP_PDU & | response | |||
) | [virtual] |
Handle an incoming OK response PDU. This actually gets any PDU of the class 2xx not just 200.
virtual void SIPConnection::OnReceivedOPTIONS | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming OPTIONS PDU
virtual void SIPConnection::OnReceivedPDU | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming SIP PDU that has been full decoded
virtual void SIPConnection::OnReceivedPING | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming PING PDU
virtual void SIPConnection::OnReceivedRedirection | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming redirect response PDU
virtual void SIPConnection::OnReceivedREFER | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming REFER PDU
virtual void SIPConnection::OnReceivedReINVITE | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming Re-INVITE request
virtual void SIPConnection::OnReceivedResponse | ( | SIPTransaction & | transaction, | |
SIP_PDU & | response | |||
) | [virtual] |
Handle an incoming response PDU.
virtual void SIPConnection::OnReceivedResponseToINVITE | ( | SIPTransaction & | transaction, | |
SIP_PDU & | response | |||
) | [virtual] |
Handle an incoming response PDU to our INVITE. Note this is called before th ACK is sent and thus should do as little as possible. All the hard work (SDP processing etc) should be in the usual OnReceivedResponse().
virtual void SIPConnection::OnReceivedRinging | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming Ringing response PDU
virtual void SIPConnection::OnReceivedSDP | ( | SIP_PDU & | pdu | ) | [protected, virtual] |
virtual bool SIPConnection::OnReceivedSDPMediaDescription | ( | SDPSessionDescription & | sdp, | |
unsigned | sessionId | |||
) | [protected, virtual] |
virtual void SIPConnection::OnReceivedSessionProgress | ( | SIP_PDU & | pdu | ) | [virtual] |
Handle an incoming Session Progress response PDU
virtual void SIPConnection::OnReceivedTrying | ( | SIPTransaction & | transaction, | |
SIP_PDU & | response | |||
) | [virtual] |
Handle an incoming Trying response PDU
virtual void SIPConnection::OnReleased | ( | ) | [virtual] |
Clean up the termination of the connection. This function can do any internal cleaning up and waiting on background threads that may be using the connection object.
Note that there is not a one to one relationship with the OnEstablishedConnection() function. This function may be called without that function being called. For example if SetUpConnection() was used but the call never completed.
Classes that override this function should make sure they call the ancestor version for correct operation.
An application will not typically call this function as it is used by the OpalManager during a release of the connection.
The default behaviour calls the OpalEndPoint function of the same name.
Reimplemented from OpalConnection.
virtual void SIPConnection::OnRTPStatistics | ( | const RTP_Session & | session | ) | const [virtual] |
Callback from the RTP session for statistics monitoring. This is called every so many packets on the transmitter and receiver threads of the RTP session indicating that the statistics have been updated.
The default behaviour does nothing.
session | Session with statistics |
virtual bool SIPConnection::OnSendSDP | ( | bool | isAnswerSDP, | |
OpalRTPSessionManager & | rtpSessions, | |||
SDPSessionDescription & | sdpOut | |||
) | [protected, virtual] |
virtual void SIPConnection::OnStartTransaction | ( | SIPTransaction & | transaction | ) | [virtual] |
virtual void SIPConnection::OnTransactionFailed | ( | SIPTransaction & | transaction | ) | [virtual] |
Handle the fail of a transaction we initiated.
virtual OpalMediaStreamPtr SIPConnection::OpenMediaStream | ( | const OpalMediaFormat & | mediaFormat, | |
unsigned | sessionID, | |||
bool | isSource | |||
) | [virtual] |
Open source or sink media stream for session.
mediaFormat | Media format to open |
sessionID | Session to start stream on |
isSource | Stream is a source/sink |
Reimplemented from OpalConnection.
SIPConnection::P_REMOVE_VIRTUAL_VOID | ( | OnMessageReceived(const SIP_PDU &) | ) |
SIPConnection::PDECLARE_NOTIFIER | ( | PTimer | , | |
SIPConnection | , | |||
OnAckTimeout | ||||
) | [protected] |
SIPConnection::PDECLARE_NOTIFIER | ( | PTimer | , | |
SIPConnection | , | |||
OnInviteResponseRetry | ||||
) | [protected] |
SIPConnection::PDECLARE_NOTIFIER | ( | PTimer | , | |
SIPConnection | , | |||
OnSessionTimeout | ||||
) | [protected] |
virtual bool SIPConnection::RetrieveConnection | ( | ) | [virtual] |
Retrieve the current connection from hold, activating all media streams.
Reimplemented from OpalConnection.
virtual PBoolean SIPConnection::SendInviteOK | ( | const SDPSessionDescription & | sdp | ) | [virtual] |
Send a "200 OK" response for the received INVITE message.
virtual PBoolean SIPConnection::SendInviteResponse | ( | SIP_PDU::StatusCodes | code, | |
const char * | contact = NULL , |
|||
const char * | extra = NULL , |
|||
const SDPSessionDescription * | sdp = NULL | |||
) | [virtual] |
Send a response for the received INVITE message.
bool SIPConnection::SendReINVITE | ( | PTRACE_PARAM(const char *msg) | ) | [protected] |
PBoolean SIPConnection::SendUserInputTone | ( | char | tone, | |
unsigned | duration | |||
) | [virtual] |
Send a user input indication to the remote endpoint. This sends DTMF emulation user input. If something more sophisticated than the simple tones that can be sent using the SendUserInput() function.
A duration of zero indicates that no duration is to be indicated. A non-zero logical channel indicates that the tone is to be syncronised with the logical channel at the rtpTimestamp value specified.
The tone parameter must be one of "0123456789#*ABCD!" where '!' indicates a hook flash. If tone is a ' ' character then a signalUpdate PDU is sent that updates the last tone indication sent. See the H.245 specifcation for more details on this.
The default behaviour sends the tone using RFC2833.
Reimplemented from OpalRTPConnection.
virtual PBoolean SIPConnection::SetAlerting | ( | const PString & | calleeName, | |
PBoolean | withMedia | |||
) | [virtual] |
Indicate to remote endpoint an alert is in progress. If this is an incoming connection and the AnswerCallResponse is in a AnswerCallDeferred or AnswerCallPending state, then this function is used to indicate to that endpoint that an alert is in progress. This is usually due to another connection which is in the call (the B party) has received an OnAlerting() indicating that its remote endpoint is "ringing".
The default behaviour does nothing.
calleeName | Name of endpoint being alerted. |
Implements OpalConnection.
virtual bool SIPConnection::SetAlertingType | ( | const PString & | info | ) | [virtual] |
Set alerting type information for outgoing call. The type of "distinctive ringing" for the call. The string is protocol dependent, so the caller would need to be aware of the type of call being made. Some protocols may ignore the field completely.
For SIP this corresponds to the string contained in the "Alert-Info" header field of the INVITE. This is typically a URI for the ring file.
For H.323 this must be a string representation of an integer from 0 to 7 which will be contained in the Q.931 SIGNAL (0x34) Information Element.
Default behaviour returns false.
Reimplemented from OpalConnection.
virtual PBoolean SIPConnection::SetConnected | ( | ) | [virtual] |
Indicate to remote endpoint we are connected.
The default behaviour does nothing.
Reimplemented from OpalConnection.
void SIPConnection::SetRemoteMediaFormats | ( | SDPSessionDescription * | sdp | ) | [protected] |
bool SIPConnection::SetTransport | ( | OpalTransport * | transport | ) |
virtual PBoolean SIPConnection::SetUpConnection | ( | ) | [virtual] |
Start an outgoing connection. This function will initiate the connection to the remote entity, for example in H.323 it sends a SETUP, in SIP it sends an INVITE etc.
The default behaviour is .
Implements OpalConnection.
virtual OpalMediaSession* SIPConnection::SetUpMediaSession | ( | const unsigned | rtpSessionId, | |
const OpalMediaType & | mediaType, | |||
SDPMediaDescription * | mediaDescription, | |||
OpalTransportAddress & | localAddress, | |||
bool & | remoteChanged | |||
) | [protected, virtual] |
void SIPConnection::StartPendingReINVITE | ( | ) | [protected] |
virtual bool SIPConnection::TransferConnection | ( | const PString & | remoteParty | ) | [virtual] |
Initiate the transfer of an existing call (connection) to a new remote party.
If remoteParty is a valid call token, then the remote party is transferred to that party (consultation transfer) and both calls are cleared.
remoteParty | Remote party to transfer the existing call to |
Reimplemented from OpalConnection.
virtual bool SIPConnection::TransmitExternalIM | ( | const OpalMediaFormat & | format, | |
RTP_IMFrame & | body | |||
) | [virtual] |
Called to transmit an IM to the other end of the connection
Reimplemented from OpalConnection.
void SIPConnection::UpdateRemoteAddresses | ( | ) | [protected] |
bool SIPConnection::WriteINVITE | ( | ) | [protected] |
static PBoolean SIPConnection::WriteINVITE | ( | OpalTransport & | transport, | |
void * | param | |||
) | [static, protected] |
friend class SIPInvite [friend] |
friend class SIPTransaction [friend] |
SIP_PDU SIPConnection::ackPacket [protected] |
bool SIPConnection::ackReceived [protected] |
PTimer SIPConnection::ackRetry [protected] |
unsigned SIPConnection::ackRetryCount [protected] |
PTimer SIPConnection::ackTimer [protected] |
bool SIPConnection::deleteTransport [protected] |
SIPEndPoint& SIPConnection::endpoint [protected] |
Reimplemented from OpalConnection.
PSafeList<SIPTransaction> SIPConnection::forkedInvitations [protected] |
PString SIPConnection::forwardParty [protected] |
PString SIPConnection::m_alertInfo [protected] |
PStringList SIPConnection::m_allowedEvents [protected] |
OpalMediaFormatList SIPConnection::m_answerFormatList [protected] |
int SIPConnection::m_appearanceCode [protected] |
unsigned SIPConnection::m_authenticatedCseq [protected] |
SIPAuthentication* SIPConnection::m_authentication [protected] |
SIPDialogContext SIPConnection::m_dialog [protected] |
OpalGloballyUniqueID SIPConnection::m_dialogNotifyId [protected] |
bool SIPConnection::m_handlingINVITE [protected] |
bool SIPConnection::m_holdFromRemote [protected] |
HoldState SIPConnection::m_holdToRemote [protected] |
std::map<SIP_PDU::Methods, unsigned> SIPConnection::m_lastRxCSeq [protected] |
bool SIPConnection::m_needReINVITE [protected] |
PSafeList<SIPTransaction> SIPConnection::m_pendingTransactions [protected] |
bool SIPConnection::m_referInProgress [protected] |
OpalMediaFormatList SIPConnection::m_remoteFormatList [protected] |
time_t SIPConnection::m_sdpSessionId [protected] |
unsigned SIPConnection::m_sdpVersion [protected] |
bool SIPConnection::m_switchedToFaxMode [protected] |
bool SIPConnection::m_symmetricOpenStream [protected] |
SIP_PDU* SIPConnection::originalInvite [protected] |
PTime SIPConnection::originalInviteTime [protected] |
PSafeList<SIPTransaction> SIPConnection::pendingInvitations [protected] |
enum { ... } SIPConnection::releaseMethod [protected] |
PTimer SIPConnection::sessionTimer [protected] |
OpalTransport* SIPConnection::transport [protected] |