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