** **
\*****************************************************************************/
+#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_UNKNOWN,
+ INFO_NTYPE_UNKNOWN = 0,
INFO_NTYPE_SUBSCRIBER,
INFO_NTYPE_NATIONAL,
- INFO_NTYPE_INTERNATIONAL,
+ INFO_NTYPE_INTERNATIONAL
};
enum { /* number presentation */
- INFO_PRESENT_NULL,
+ INFO_PRESENT_NULL = 0,
INFO_PRESENT_ALLOWED,
INFO_PRESENT_RESTRICTED,
- INFO_PRESENT_NOTAVAIL,
+ INFO_PRESENT_NOTAVAIL
};
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_REMOTE, /* bchannel assigned to remote application */
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 */
-};
-
/* call-info structure CALLER */
struct caller_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 */
/* 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 handle; /* bchannel stack/portid */
+ 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 */
};
/* 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);