📄 osip.h
字号:
ICT_COMPLETED, ICT_TERMINATED, /* STATES for invite server transaction */ IST_PRE_PROCEEDING, IST_PROCEEDING, IST_COMPLETED, IST_CONFIRMED, IST_TERMINATED, /* STATES for NON-invite client transaction */ NICT_PRE_TRYING, NICT_TRYING, NICT_PROCEEDING, NICT_COMPLETED, NICT_TERMINATED, /* STATES for NON-invite server transaction */ NIST_PRE_TRYING, NIST_TRYING, NIST_PROCEEDING, NIST_COMPLETED, NIST_TERMINATED,#ifndef DOXYGEN DIALOG_EARLY, DIALOG_CONFIRMED, DIALOG_CLOSE /* ?? */#endif } state_t;/** * Enumeration for event type. * <BR>The list of values that you need to know is reduced to this: * <BR> RCV_REQINVITE, * <BR> RCV_REQACK, * <BR> RCV_REQUEST, * <BR> RCV_STATUS_1XX, * <BR> RCV_STATUS_2XX, * <BR> RCV_STATUS_3456XX, *<BR> * <BR> SND_REQINVITE, * <BR> SND_REQACK, * <BR> SND_REQUEST, * <BR> SND_STATUS_1XX, * <BR> SND_STATUS_2XX, * <BR> SND_STATUS_3456XX, */ typedef enum type_t { /* TIMEOUT EVENTS for ICT */ TIMEOUT_A, /**< Timer A */ TIMEOUT_B, /**< Timer B */ TIMEOUT_D, /**< Timer D */ /* TIMEOUT EVENTS for NICT */ TIMEOUT_E, /**< Timer E */ TIMEOUT_F, /**< Timer F */ TIMEOUT_K, /**< Timer K */ /* TIMEOUT EVENTS for IST */ TIMEOUT_G, /**< Timer G */ TIMEOUT_H, /**< Timer H */ TIMEOUT_I, /**< Timer I */ /* TIMEOUT EVENTS for NIST */ TIMEOUT_J, /**< Timer J */ /* FOR INCOMING MESSAGE */ RCV_REQINVITE, /**< Event is an incoming INVITE request */ RCV_REQACK, /**< Event is an incoming ACK request */ RCV_REQUEST, /**< Event is an incoming NON-INVITE and NON-ACK request */ RCV_STATUS_1XX, /**< Event is an incoming informational response */ RCV_STATUS_2XX, /**< Event is an incoming 2XX response */ RCV_STATUS_3456XX,/**< Event is an incoming final response (not 2XX) */ /* FOR OUTGOING MESSAGE */ SND_REQINVITE, /**< Event is an outgoing INVITE request */ SND_REQACK, /**< Event is an outgoing ACK request */ SND_REQUEST, /**< Event is an outgoing NON-INVITE and NON-ACK request */ SND_STATUS_1XX, /**< Event is an outgoing informational response */ SND_STATUS_2XX, /**< Event is an outgoing 2XX response */ SND_STATUS_3456XX,/**< Event is an outgoing final response (not 2XX) */ KILL_TRANSACTION, /**< Event to 'kill' the transaction before termination */ UNKNOWN_EVT } type_t;/** * Enumeration for transaction type. * A transaction can be either of: * ICT, * IST, * NICT, * NIST, */ typedef enum osip_fsm_type_t { ICT, /**< Invite Client (outgoing) Transaction */ IST, /**< Invite Server (incoming) Transaction */ NICT,/**< Non-Invite Client (outgoing) Transaction */ NIST /**< Non-Invite Server (incoming) Transaction */ } osip_fsm_type_t;#ifndef DEFAULT_T1/** * You can re-define the default value for T1. (T1 is defined in rfcxxxx) * The default value is 500ms. */#define DEFAULT_T1 500 /* 500 ms */#endif#ifndef DEFAULT_T2/** * You can re-define the default value for T2. (T2 is defined in rfcxxxx) * The default value is 4000ms. */#define DEFAULT_T2 4000 /* 4s */#endif#ifndef DEFAULT_T4/** * You can re-define the default value for T4. (T1 is defined in rfcxxxx) * The default value is 5000ms. */#define DEFAULT_T4 5000 /* 5s */#endif/** * Structure for INVITE CLIENT TRANSACTION (outgoing INVITE transaction). * @defvar osip_ict_t */ typedef struct osip_ict osip_ict_t; struct osip_ict { /* state machine is implied... */ int timer_a_length; /* A=T1, A=2xT1... (unreliable tr only) */ struct timeval timer_a_start; int timer_b_length; /* B = 64* T1 */ struct timeval timer_b_start; /* fire when transaction timeouts */ int timer_d_length; /* D >= 32s for unreliable tr (or 0) */ struct timeval timer_d_start; /* should be equal to timer H */ char *destination; /* url used to send requests */ int port; /* port of next hop */ };/** * Structure for NON-INVITE CLIENT TRANSACTION (outgoing NON-INVITE transaction). * @defvar osip_nict_t */ typedef struct osip_nict osip_nict_t; struct osip_nict { /* state machine is implied... */ int timer_e_length; /* A=T1, A=2xT1... (unreliable tr. only) */ struct timeval timer_e_start; /* (else = -1) not active */ int timer_f_length; /* B = 64* T1 */ struct timeval timer_f_start; /* fire when transaction timeouts */ int timer_k_length; /* K = T4 (else = 0) */ struct timeval timer_k_start; char *destination; /* url used to send requests */ int port; /* port of next hop */ };/** * Structure for INVITE SERVER TRANSACTION (incoming INVITE transaction). * @defvar osip_ist_t */ typedef struct osip_ist osip_ist_t; struct osip_ist { int timer_g_length; /* G=MIN(T1*2,T2) for unreliable trans. */ struct timeval timer_g_start; /* 0 when reliable transport is used! */ int timer_h_length; /* H = 64* T1 */ struct timeval timer_h_start; /* fire when if no ACK is received */ int timer_i_length; /* I = T4 for unreliable transport (or 0) */ struct timeval timer_i_start; /* absorb all ACK */ };/** * Structure for NON-INVITE SERVER TRANSACTION (incoming SERVER transaction). * @defvar osip_nist_t */ typedef struct osip_nist osip_nist_t; struct osip_nist { int timer_j_length; /* J = 64*T1 (else 0) */ struct timeval timer_j_start; };/** * Structure for transaction handling. * @defvar osip_transaction_t */ typedef struct osip_transaction osip_transaction_t; struct osip_transaction { void *your_instance; /* add whatever you want here. */ int transactionid; /* simple id used to identify the tr. */ osip_fifo_t *transactionff; /* events must be added in this fifo */ osip_via_t *topvia; /* CALL-LEG definition */ osip_from_t *from; /* CALL-LEG definition */ osip_to_t *to; osip_call_id_t *callid; osip_cseq_t *cseq; osip_message_t *orig_request; /* last request sent */ osip_message_t *last_response; /* last response received */ osip_message_t *ack; /* ack request sent */ state_t state; /* state of transaction */ time_t birth_time; /* birth_date of transaction */ time_t completed_time; /* end date of transaction */ /* RESPONSE are received on this socket */ int in_socket; /* REQUESTS are sent on this socket */ int out_socket; void *config; /* transaction is managed by config */ osip_fsm_type_t ctx_type; osip_ict_t *ict_context; osip_ist_t *ist_context; osip_nict_t *nict_context; osip_nist_t *nist_context; };/** * Enumeration for callback type. */ typedef enum osip_message_callback_type { OSIP_ICT_INVITE_SENT = 0, /**< INVITE MESSAGE SENT */ OSIP_ICT_INVITE_SENT_AGAIN, /**< INVITE MESSAGE RETRANSMITTED */ OSIP_ICT_ACK_SENT, /**< ACK MESSAGE SENT */ OSIP_ICT_ACK_SENT_AGAIN, /**< ACK MESSAGE RETRANSMITTED */ OSIP_ICT_STATUS_1XX_RECEIVED, /**< 1XX FOR INVITE RECEIVED */ OSIP_ICT_STATUS_2XX_RECEIVED, /**< 2XX FOR INVITE RECEIVED */ OSIP_ICT_STATUS_2XX_RECEIVED_AGAIN, /**< 2XX FOR INVITE RECEIVED AGAIN */ OSIP_ICT_STATUS_3XX_RECEIVED, /**< 3XX FOR INVITE RECEIVED */ OSIP_ICT_STATUS_4XX_RECEIVED, /**< 4XX FOR INVITE RECEIVED */ OSIP_ICT_STATUS_5XX_RECEIVED, /**< 5XX FOR INVITE RECEIVED */ OSIP_ICT_STATUS_6XX_RECEIVED, /**< 6XX FOR INVITE RECEIVED */ OSIP_ICT_STATUS_3456XX_RECEIVED_AGAIN, /**< RESPONSE RECEIVED AGAIN */ OSIP_IST_INVITE_RECEIVED, /**< INVITE MESSAGE RECEIVED */ OSIP_IST_INVITE_RECEIVED_AGAIN, /**< INVITE MESSAGE RECEIVED AGAN */ OSIP_IST_ACK_RECEIVED, /**< ACK MESSAGE RECEIVED */ OSIP_IST_ACK_RECEIVED_AGAIN, /**< ACK MESSAGE RECEIVED AGAIN */ OSIP_IST_STATUS_1XX_SENT, /**< 1XX FOR INVITE SENT */ OSIP_IST_STATUS_2XX_SENT, /**< 2XX FOR INVITE SENT */ OSIP_IST_STATUS_2XX_SENT_AGAIN, /**< 2XX FOR INVITE RETRANSMITTED */ OSIP_IST_STATUS_3XX_SENT, /**< 3XX FOR INVITE SENT */ OSIP_IST_STATUS_4XX_SENT, /**< 4XX FOR INVITE SENT */ OSIP_IST_STATUS_5XX_SENT, /**< 5XX FOR INVITE SENT */ OSIP_IST_STATUS_6XX_SENT, /**< 6XX FOR INVITE SENT */ OSIP_IST_STATUS_3456XX_SENT_AGAIN, /**< RESPONSE RETRANSMITTED */ OSIP_NICT_REGISTER_SENT, /**< REGISTER MESSAGE SENT */ OSIP_NICT_BYE_SENT, /**< BYE MESSAGE SENT */ OSIP_NICT_OPTIONS_SENT, /**< OPTIONS MESSAGE SENT */ OSIP_NICT_INFO_SENT, /**< INFO MESSAGE SENT */ OSIP_NICT_CANCEL_SENT, /**< CANCEL MESSAGE SENT */ OSIP_NICT_NOTIFY_SENT, /**< NOTIFY MESSAGE SENT */ OSIP_NICT_SUBSCRIBE_SENT, /**< SUBSCRIBE MESSAGE SENT */ OSIP_NICT_UNKNOWN_REQUEST_SENT, /**< UNKNOWN REQUEST MESSAGE SENT */ OSIP_NICT_REQUEST_SENT_AGAIN, /**< REQUEST MESSAGE RETRANMITTED */ OSIP_NICT_STATUS_1XX_RECEIVED, /**< 1XX FOR MESSAGE RECEIVED */ OSIP_NICT_STATUS_2XX_RECEIVED, /**< 2XX FOR MESSAGE RECEIVED */ OSIP_NICT_STATUS_2XX_RECEIVED_AGAIN, /**< 2XX FOR MESSAGE RECEIVED AGAIN */ OSIP_NICT_STATUS_3XX_RECEIVED, /**< 3XX FOR MESSAGE RECEIVED */ OSIP_NICT_STATUS_4XX_RECEIVED, /**< 4XX FOR MESSAGE RECEIVED */ OSIP_NICT_STATUS_5XX_RECEIVED, /**< 5XX FOR MESSAGE RECEIVED */ OSIP_NICT_STATUS_6XX_RECEIVED, /**< 6XX FOR MESSAGE RECEIVED */ OSIP_NICT_STATUS_3456XX_RECEIVED_AGAIN, /**< RESPONSE RECEIVED AGAIN */ OSIP_NIST_REGISTER_RECEIVED, /**< REGISTER RECEIVED */ OSIP_NIST_BYE_RECEIVED, /**< BYE RECEIVED */ OSIP_NIST_OPTIONS_RECEIVED, /**< OPTIONS RECEIVED */ OSIP_NIST_INFO_RECEIVED, /**< INFO RECEIVED */ OSIP_NIST_CANCEL_RECEIVED, /**< CANCEL RECEIVED */ OSIP_NIST_NOTIFY_RECEIVED, /**< NOTIFY RECEIVED */ OSIP_NIST_SUBSCRIBE_RECEIVED, /**< SUBSCRIBE RECEIVED */ OSIP_NIST_UNKNOWN_REQUEST_RECEIVED, /**< UNKNWON REQUEST RECEIVED */ OSIP_NIST_REQUEST_RECEIVED_AGAIN, /**< UNKNWON REQUEST RECEIVED AGAIN */ OSIP_NIST_STATUS_1XX_SENT, /**< 1XX FOR MESSAGE SENT */ OSIP_NIST_STATUS_2XX_SENT, /**< 2XX FOR MESSAGE SENT */ OSIP_NIST_STATUS_2XX_SENT_AGAIN, /**< 2XX FOR MESSAGE RETRANSMITTED */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -