** **
\*****************************************************************************/
+#define ISDN_TRANSMIT 256 // samples
+
enum { /* interface types */
INFO_ITYPE_ISDN,
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_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
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 */
B_STATE_IMPORTING, /* BCHANNEL_REMOVE sent */
};
enum {
- B_EVENT_USE, /* activate/export bchannel */
- B_EVENT_EXPORTREQUEST, /* remote app requests bchannel */
- B_EVENT_ACTIVATED, /* DL_ESTABLISH received */
- B_EVENT_DROP, /* deactivate/re-import bchannel */
- B_EVENT_DEACTIVATED, /* DL_RELEASE received */
- B_EVENT_EXPORTED, /* BCHANNEL_ASSIGN received */
- B_EVENT_IMPORTED, /* BCHANNEL_REMOVE received */
+ 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) */
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 */
};
/* call-info structure DIALING */
int itype; /* type of interface */
int ntype; /* type of number */
int sending_complete; /* end of dialing */
+ char display[84]; /* display information */
};
/* call-info structure CONNECT */
/* 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,... */
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 */
/* DATA */
struct param_data {
- unsigned char data[512]; /* audio/hdlc data */
+ unsigned char data[ISDN_TRANSMIT]; /* audio/hdlc data */
int len; /* audio/hdlc data */
};
struct param_mISDNsignal {
int message;
- int rxvol;
- int txvol;
+ int tx_gain;
+ int rx_gain;
int conf;
int joindata;
int tone;
struct param_bchannel {
int type; /* BCHANNEL_* */
- unsigned long addr; /* bchannel stack address */
+ 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 */
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 */
};
/* 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;
};
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 */
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_NONE", \
"MESSAGE_TONE", \
"MESSAGE_DTMF", \
+ "MESSAGE_ENABLEKEYPAD", \
"MESSAGE_mISDNSIGNAL", \
"MESSAGE_SETUP", \
"MESSAGE_INFORMATION", \
};
-struct message *message_create(int id_from, int id_to, int flow, int type);
-void message_put(struct message *message);
-struct message *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);