Version 0.3.0 from FTP
[asterisk/asterisk.git] / apps / app_flash.c
1 /*
2  * Asterisk -- A telephony toolkit for Linux.
3  *
4  * App to flash a zap trunk
5  * 
6  * Copyright (C) 1999, Mark Spencer
7  *
8  * Mark Spencer <markster@linux-support.net>
9  *
10  * This program is free software, distributed under the terms of
11  * the GNU General Public License
12  */
13  
14 #include <asterisk/lock.h>
15 #include <asterisk/file.h>
16 #include <asterisk/logger.h>
17 #include <asterisk/channel.h>
18 #include <asterisk/pbx.h>
19 #include <asterisk/module.h>
20 #include <asterisk/translate.h>
21 #include <asterisk/image.h>
22 #include <asterisk/options.h>
23 #include <sys/ioctl.h>
24 #include <linux/zaptel.h>
25 #include <string.h>
26 #include <errno.h>
27 #include <stdlib.h>
28 #include <pthread.h>
29
30 static char *tdesc = "Flash zap trunk application";
31
32 static char *app = "Flash";
33
34 static char *synopsis = "Flashes a Zap Trunk";
35
36 static char *descrip = 
37 "  Flash(): Sends a flash on a zap trunk.  This is only a hack for\n"
38 "people who want to perform transfers and such via AGI and is generally\n"
39 "quite useless otherwise.  Returns 0 on success or -1 if this is not\n"
40 "a zap trunk\n";
41
42 STANDARD_LOCAL_USER;
43
44 LOCAL_USER_DECL;
45
46 static inline int zt_wait_event(int fd)
47 {
48         /* Avoid the silly zt_waitevent which ignores a bunch of events */
49         int i,j=0;
50         i = ZT_IOMUX_SIGEVENT;
51         if (ioctl(fd, ZT_IOMUX, &i) == -1) return -1;
52         if (ioctl(fd, ZT_GETEVENT, &j) == -1) return -1;
53         return j;
54 }
55
56 static int flash_exec(struct ast_channel *chan, void *data)
57 {
58         int res = -1;
59         int x;
60         struct localuser *u;
61         struct zt_params ztp;
62         LOCAL_USER_ADD(u);
63         if (!strcasecmp(chan->type, "Zap")) {
64                 memset(&ztp, 0, sizeof(ztp));
65                 res = ioctl(chan->fds[0], ZT_GET_PARAMS, &ztp);
66                 if (!res) {
67                         if (ztp.sigtype & __ZT_SIG_FXS) {
68                                 x = ZT_FLASH;
69                                 res = ioctl(chan->fds[0], ZT_HOOK, &x);
70                                 if (!res || (errno == EINPROGRESS)) {
71                                         if (res) {
72                                                 /* Wait for the event to finish */
73                                                 zt_wait_event(chan->fds[0]);
74                                         }
75                                         res = ast_safe_sleep(chan, 1000);
76                                         if (option_verbose > 2)
77                                                 ast_verbose(VERBOSE_PREFIX_3 "Flashed channel %s\n", chan->name);
78                                 } else
79                                         ast_log(LOG_WARNING, "Unable to flash channel %s: %s\n", chan->name, strerror(errno));
80                         } else
81                                 ast_log(LOG_WARNING, "%s is not an FXO Channel\n", chan->name);
82                 } else
83                         ast_log(LOG_WARNING, "Unable to get parameters of %s: %s\n", chan->name, strerror(errno));
84         } else
85                 ast_log(LOG_WARNING, "%s is not a Zap channel\n", chan->name);
86         LOCAL_USER_REMOVE(u);
87         return res;
88 }
89
90 int unload_module(void)
91 {
92         STANDARD_HANGUP_LOCALUSERS;
93         return ast_unregister_application(app);
94 }
95
96 int load_module(void)
97 {
98         return ast_register_application(app, flash_exec, synopsis, descrip);
99 }
100
101 char *description(void)
102 {
103         return tdesc;
104 }
105
106 int usecount(void)
107 {
108         int res;
109         STANDARD_USECOUNT(res);
110         return res;
111 }
112
113 char *key()
114 {
115         return ASTERISK_GPL_KEY;
116 }