X-Git-Url: http://git.eversberg.eu/gitweb.cgi?p=lcr.git;a=blobdiff_plain;f=message.h;h=63abc65117a8754ea809b0f43173fdf34d59d398;hp=ae1e8fdbebcaf63a81d9c2c01e820e1d5a19091f;hb=3ac6881c22bce18091f19b06958ac66016bf9a32;hpb=701b046a45c2c79cc6d07ac3a4f84f499f7ed376 diff --git a/message.h b/message.h index ae1e8fd..63abc65 100644 --- a/message.h +++ b/message.h @@ -9,39 +9,43 @@ ** ** \*****************************************************************************/ +#define ISDN_TRANSMIT 256 // samples + enum { /* interface types */ - INFO_ITYPE_ISDN, + INFO_ITYPE_ISDN, /* call from external */ INFO_ITYPE_ISDN_EXTENSION, /* call from internal extension */ INFO_ITYPE_CHAN, - INFO_ITYPE_VBOX, + INFO_ITYPE_VBOX }; enum { /* number types */ + INFO_NTYPE_NOTPRESENT = 0, INFO_NTYPE_UNKNOWN, INFO_NTYPE_SUBSCRIBER, INFO_NTYPE_NATIONAL, - INFO_NTYPE_INTERNATIONAL, + INFO_NTYPE_INTERNATIONAL }; enum { /* number presentation */ - INFO_PRESENT_NULL, - INFO_PRESENT_ALLOWED, - INFO_PRESENT_RESTRICTED, INFO_PRESENT_NOTAVAIL, + INFO_PRESENT_ALLOWED, + INFO_PRESENT_RESTRICTED }; enum { /* number presentation */ INFO_SCREEN_USER, /* user provided */ - INFO_SCREEN_NETWORK, /* network provided */ + INFO_SCREEN_USER_VERIFIED_PASSED, + INFO_SCREEN_USER_VERIFIED_FAILED, + INFO_SCREEN_NETWORK /* network provided */ }; enum { /* redirection reason */ - INFO_REDIR_UNKNOWN, + INFO_REDIR_UNKNOWN = 0, INFO_REDIR_BUSY, INFO_REDIR_NORESPONSE, INFO_REDIR_UNCONDITIONAL, INFO_REDIR_OUTOFORDER, - INFO_REDIR_CALLDEFLECT, + INFO_REDIR_CALLDEFLECT }; #define INFO_NOTIFY_NONE 0x00 @@ -125,6 +129,28 @@ enum { /* isdnsignal */ mISDNSIGNAL_DELAY, /* use delay or adaptive jitter */ }; +enum { /* bchannel assignment */ + BCHANNEL_REQUEST, /* application requests bchannel */ + BCHANNEL_RELEASE, /* application releases bchannel */ + BCHANNEL_ASSIGN, /* bchannel assigned by LCR */ + BCHANNEL_ASSIGN_ACK, /* application acknowledges */ + BCHANNEL_REMOVE, /* bchannel removed by LCR */ + BCHANNEL_REMOVE_ACK, /* application acknowledges */ +}; +enum { + B_STATE_IDLE, /* not open */ + B_STATE_ACTIVATING, /* DL_ESTABLISH sent */ + B_STATE_ACTIVE, /* channel active */ + B_STATE_DEACTIVATING, /* DL_RELEASE sent */ + B_STATE_EXPORTING, /* BCHANNEL_ASSIGN sent */ + B_STATE_REMOTE, /* bchannel assigned to remote application */ + B_STATE_IMPORTING, /* BCHANNEL_REMOVE sent */ +}; +enum { + B_MODE_TRANSPARENT, /* normal transparent audio */ + B_MODE_HDLC, /* hdlc data mode */ +}; + /* call-info structure CALLER */ struct caller_info { char id[32]; /* id of caller (user number) */ @@ -137,6 +163,11 @@ struct caller_info { int present; /* presentation */ int screen; /* who provided the number */ char display[84]; /* display information */ + char id2[32]; /* second callerid */ + int ntype2; /* second type of number */ + int present2; /* second presentation */ + int screen2; /* second who provided the number */ + char imsi[16]; /* IMSI for gsm originated calls */ }; /* call-info structure DIALING */ @@ -146,6 +177,8 @@ struct dialing_info { int itype; /* type of interface */ int ntype; /* type of number */ int sending_complete; /* end of dialing */ + char display[84]; /* display information */ + char keypad[33]; /* send keypad facility */ }; /* call-info structure CONNECT */ @@ -160,6 +193,7 @@ struct connect_info { int present; /* presentation */ int screen; /* who provided the number */ char display[84]; /* display information */ + char imsi[16]; /* IMSI for gsm terminated calls */ }; /* call-info structure DISCONNECT */ @@ -183,6 +217,7 @@ struct redir_info { /* call-info structure capability */ struct capa_info { + int source_mode; /* forward mode */ int bearer_capa; /* capability */ int bearer_mode; /* circuit/packet */ int bearer_info1; /* alaw,ulaw,... */ @@ -220,13 +255,14 @@ struct useruser_info { struct message_setup { int isdn_port; /* card number 1...n (only on calls from isdn port) */ int port_type; /* type of port (only required if message is port -> epoint) */ - int dtmf; /* used to enabled dtmf dialing at setup state */ int partyline; /* if set, call will be a conference room */ + int partyline_jingle; /* if set, the jingle will be played on conference join */ struct caller_info callerinfo; /* information about the caller */ struct dialing_info dialinginfo; /* information about dialing */ struct redir_info redirinfo; /* info on redirection (to the calling user) */ struct capa_info capainfo; /* info on l2,l3 capability */ struct useruser_info useruser; /* user-user */ + char context[128]; /* asterisk context */ }; /* call-info structure PARK */ @@ -237,7 +273,7 @@ struct park_info { /* DATA */ struct param_data { - unsigned char data[512]; /* audio/hdlc data */ + unsigned char data[ISDN_TRANSMIT]; /* audio/hdlc data */ int len; /* audio/hdlc data */ }; @@ -258,8 +294,8 @@ struct param_counter { struct param_mISDNsignal { int message; - int rxvol; - int txvol; + int tx_gain; + int rx_gain; int conf; int joindata; int tone; @@ -278,6 +314,16 @@ struct param_hello { char application[32]; /* name of remote application */ }; +struct param_bchannel { + int type; /* BCHANNEL_* */ + unsigned int handle; /* bchannel stack/portid */ + int tx_gain, rx_gain; + char pipeline[256]; + unsigned char crypt[128]; + int crypt_len; + int crypt_type; /* 1 = blowfish */ +}; + /* structure of message parameter */ union parameter { struct param_tone tone; /* MESSAGE_TONE */ @@ -300,6 +346,8 @@ union parameter { struct extension ext; /* tell port about extension information */ struct param_crypt crypt; /* MESSAGE_CRYPT */ struct param_hello hello; /* MESSAGE_HELLO */ + struct param_bchannel bchannel; /* MESSAGE_BCHANNEL */ + int direction; /* MESSAGE_NEWREF */ }; enum { /* message flow */ @@ -310,12 +358,12 @@ enum { /* message flow */ }; /* message structure */ -struct message { - struct message *next; +struct lcr_msg { + struct lcr_msg *next; int type; /* type of message */ int flow; /* from where to where */ - unsigned long id_from; /* in case of flow==PORT_TO_EPOINT: id_from is the port's serial, id_to is the epoint's serial */ - unsigned long id_to; + unsigned int id_from; /* in case of flow==PORT_TO_EPOINT: id_from is the port's serial, id_to is the epoint's serial */ + unsigned int id_to; int keep; union parameter param; }; @@ -324,8 +372,8 @@ enum { /* messages between entities */ MESSAGE_NONE, /* no message */ MESSAGE_TONE, /* set information tone (to isdn port) */ MESSAGE_DTMF, /* dtmf digit (from isdn port) */ + MESSAGE_ENABLEKEYPAD, /* remote application requests keypad/dtmf */ MESSAGE_mISDNSIGNAL, /* special mixer command (down to isdn port) */ - MESSAGE_SETUP, /* setup message */ MESSAGE_INFORMATION, /* additional digit information */ MESSAGE_OVERLAP, /* call accepted, send more information */ @@ -337,24 +385,20 @@ enum { /* messages between entities */ MESSAGE_TIMEOUT, /* protocol state has timed out (port->epoint) */ MESSAGE_NOTIFY, /* used to send progress and notify infos */ MESSAGE_FACILITY, /* used to facility infos, like aocd */ - MESSAGE_SUSPEND, /* suspend port */ MESSAGE_RESUME, /* resume port */ - MESSAGE_AUDIOPATH, /* set status of audio path to endpoint (to call, audio is also set) */ // MESSAGE_REMOTE_AUDIO, /* tell remote to set audio status */ MESSAGE_PATTERN, /* pattern information tones available */ MESSAGE_NOPATTERN, /* pattern information tones unavailable */ MESSAGE_CRYPT, /* encryption message */ - MESSAGE_DATA, /* audio/hdlc data */ - MESSAGE_VBOX_PLAY, /* play recorded file */ MESSAGE_VBOX_PLAY_SPEED,/* change speed of file */ MESSAGE_VBOX_TONE, /* set answering VBOX tone */ MESSAGE_TONE_COUNTER, /* tone counter (for VBOX tone use) */ MESSAGE_TONE_EOF, /* tone is end of file */ - MESSAGE_BCHANNEL, /* request/assign bchannel */ + MESSAGE_BCHANNEL, /* request/assign/remove bchannel */ MESSAGE_HELLO, /* hello message for remote application */ MESSAGE_NEWREF, /* special message to create and inform ref */ }; @@ -363,6 +407,7 @@ enum { /* messages between entities */ "MESSAGE_NONE", \ "MESSAGE_TONE", \ "MESSAGE_DTMF", \ + "MESSAGE_ENABLEKEYPAD", \ "MESSAGE_mISDNSIGNAL", \ "MESSAGE_SETUP", \ "MESSAGE_INFORMATION", \ @@ -394,11 +439,11 @@ enum { /* messages between entities */ }; -struct message *message_create(int id_from, int id_to, int flow, int type); -void message_put(struct message *message); -void message_forward(int id_from, int id_to, int flow, union parameter *param); -struct message *message_get(void); -void message_free(struct message *message); +struct lcr_msg *message_create(int id_from, int id_to, int flow, int type); +void message_put(struct lcr_msg *message); +struct lcr_msg *message_forward(int id_from, int id_to, int flow, union parameter *param); +struct lcr_msg *message_get(void); +void message_free(struct lcr_msg *message);