133 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* $Id: isdn_divert.h,v 1.5.6.1 2001/09/23 22:24:36 kai Exp $
 | |
|  *
 | |
|  * Header for the diversion supplementary ioctl interface.
 | |
|  *
 | |
|  * Copyright 1998       by Werner Cornelius (werner@ikt.de)
 | |
|  *
 | |
|  * This software may be used and distributed according to the terms
 | |
|  * of the GNU General Public License, incorporated herein by reference.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #include <linux/ioctl.h>
 | |
| #include <linux/types.h>
 | |
| 
 | |
| /******************************************/
 | |
| /* IOCTL codes for interface to user prog */
 | |
| /******************************************/
 | |
| #define DIVERT_IIOC_VERSION 0x01 /* actual version */
 | |
| #define IIOCGETVER   _IO('I', 1)  /* get version of interface */
 | |
| #define IIOCGETDRV   _IO('I', 2)  /* get driver number */
 | |
| #define IIOCGETNAM   _IO('I', 3)  /* get driver name */
 | |
| #define IIOCGETRULE  _IO('I', 4)  /* read one rule */
 | |
| #define IIOCMODRULE  _IO('I', 5)  /* modify/replace a rule */
 | |
| #define IIOCINSRULE  _IO('I', 6)  /* insert/append one rule */
 | |
| #define IIOCDELRULE  _IO('I', 7)  /* delete a rule */
 | |
| #define IIOCDODFACT  _IO('I', 8)  /* hangup/reject/alert/immediately deflect a call */
 | |
| #define IIOCDOCFACT  _IO('I', 9)  /* activate control forwarding in PBX */
 | |
| #define IIOCDOCFDIS  _IO('I', 10)  /* deactivate control forwarding in PBX */
 | |
| #define IIOCDOCFINT  _IO('I', 11)  /* interrogate control forwarding in PBX */
 | |
| 
 | |
| /*************************************/
 | |
| /* states reported through interface */
 | |
| /*************************************/
 | |
| #define DEFLECT_IGNORE    0  /* ignore incoming call */
 | |
| #define DEFLECT_REPORT    1  /* only report */
 | |
| #define DEFLECT_PROCEED   2  /* deflect when externally triggered */
 | |
| #define DEFLECT_ALERT     3  /* alert and deflect after delay */
 | |
| #define DEFLECT_REJECT    4  /* reject immediately */
 | |
| #define DIVERT_ACTIVATE   5  /* diversion activate */
 | |
| #define DIVERT_DEACTIVATE 6  /* diversion deactivate */
 | |
| #define DIVERT_REPORT     7  /* interrogation result */
 | |
| #define DEFLECT_AUTODEL 255  /* only for internal use */
 | |
| 
 | |
| #define DEFLECT_ALL_IDS   0xFFFFFFFF /* all drivers selected */
 | |
| 
 | |
| typedef struct {
 | |
| 	ulong drvid;     /* driver ids, bit mapped */
 | |
| 	char my_msn[35]; /* desired msn, subaddr allowed */
 | |
| 	char caller[35]; /* caller id, partial string with * + subaddr allowed */
 | |
| 	char to_nr[35];  /* deflected to number incl. subaddress */
 | |
| 	u_char si1, si2;  /* service indicators, si1=bitmask, si1+2 0 = all */
 | |
| 	u_char screen;   /* screening: 0 = no info, 1 = info, 2 = nfo with nr */
 | |
| 	u_char callopt;  /* option for call handling:
 | |
| 			    0 = all calls
 | |
| 			    1 = only non waiting calls
 | |
| 			    2 = only waiting calls */
 | |
| 	u_char action;   /* desired action:
 | |
| 			    0 = don't report call -> ignore
 | |
| 			    1 = report call, do not allow/proceed for deflection
 | |
| 			    2 = report call, send proceed, wait max waittime secs
 | |
| 			    3 = report call, alert and deflect after waittime
 | |
| 			    4 = report call, reject immediately
 | |
| 			    actions 1-2 only take place if interface is opened
 | |
| 			 */
 | |
| 	u_char waittime; /* maximum wait time for proceeding */
 | |
| } divert_rule;
 | |
| 
 | |
| typedef union {
 | |
| 	int drv_version; /* return of driver version */
 | |
| 	struct {
 | |
| 		int drvid;		/* id of driver */
 | |
| 		char drvnam[30];	/* name of driver */
 | |
| 	} getid;
 | |
| 	struct {
 | |
| 		int ruleidx;	/* index of rule */
 | |
| 		divert_rule rule;	/* rule parms */
 | |
| 	} getsetrule;
 | |
| 	struct {
 | |
| 		u_char subcmd;  /* 0 = hangup/reject,
 | |
| 			     1 = alert,
 | |
| 			     2 = deflect */
 | |
| 		ulong callid;   /* id of call delivered by ascii output */
 | |
| 		char to_nr[35]; /* destination when deflect,
 | |
| 				   else uus1 string (maxlen 31),
 | |
| 				   data from rule used if empty */
 | |
| 	} fwd_ctrl;
 | |
| 	struct {
 | |
| 		int drvid;      /* id of driver */
 | |
| 		u_char cfproc;  /* cfu = 0, cfb = 1, cfnr = 2 */
 | |
| 		ulong procid;   /* process id returned when no error */
 | |
| 		u_char service; /* basically coded service, 0 = all */
 | |
| 		char msn[25];   /* desired msn, empty = all */
 | |
| 		char fwd_nr[35];/* forwarded to number + subaddress */
 | |
| 	} cf_ctrl;
 | |
| } divert_ioctl;
 | |
| 
 | |
| #ifdef __KERNEL__
 | |
| 
 | |
| #include <linux/isdnif.h>
 | |
| #include <linux/isdn_divertif.h>
 | |
| 
 | |
| #define AUTODEL_TIME 30 /* timeout in s to delete internal entries */
 | |
| 
 | |
| /**************************************************/
 | |
| /* structure keeping ascii info for device output */
 | |
| /**************************************************/
 | |
| struct divert_info {
 | |
| 	struct divert_info *next;
 | |
| 	ulong usage_cnt; /* number of files still to work */
 | |
| 	char info_start[2]; /* info string start */
 | |
| };
 | |
| 
 | |
| 
 | |
| /**************/
 | |
| /* Prototypes */
 | |
| /**************/
 | |
| extern spinlock_t divert_lock;
 | |
| 
 | |
| extern ulong if_used; /* number of interface users */
 | |
| extern int divert_dev_deinit(void);
 | |
| extern int divert_dev_init(void);
 | |
| extern void put_info_buffer(char *);
 | |
| extern int ll_callback(isdn_ctrl *);
 | |
| extern isdn_divert_if divert_if;
 | |
| extern divert_rule *getruleptr(int);
 | |
| extern int insertrule(int, divert_rule *);
 | |
| extern int deleterule(int);
 | |
| extern void deleteprocs(void);
 | |
| extern int deflect_extern_action(u_char, ulong, char *);
 | |
| extern int cf_command(int, int, u_char, char *, u_char, char *, ulong *);
 | |
| 
 | |
| #endif /* __KERNEL__ */
 | 
