another few errno.h removals
[asterisk/asterisk.git] / channels / iax2-provision.c
index 8c20ab8..5a06a8f 100644 (file)
 
 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 
 
 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 
-#include <unistd.h>
-#include <stdlib.h>
-#include <string.h>
-#include <stdio.h>
 #include <netdb.h>
 #include <netinet/in.h>
 #include <netinet/in_systm.h>
 #include <netdb.h>
 #include <netinet/in.h>
 #include <netinet/in_systm.h>
@@ -38,7 +34,6 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 #include <sys/socket.h>
 
 #include "asterisk/config.h"
 #include <sys/socket.h>
 
 #include "asterisk/config.h"
-#include "asterisk/logger.h"
 #include "asterisk/cli.h"
 #include "asterisk/lock.h"
 #include "asterisk/frame.h"
 #include "asterisk/cli.h"
 #include "asterisk/lock.h"
 #include "asterisk/frame.h"
@@ -51,10 +46,6 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 #include "iax2-provision.h"
 #include "iax2-parser.h"
 
 #include "iax2-provision.h"
 #include "iax2-parser.h"
 
-#ifndef IPTOS_MINCOST
-#define IPTOS_MINCOST 0x02
-#endif
-
 static int provinit = 0;
 
 struct iax_template {
 static int provinit = 0;
 
 struct iax_template {
@@ -69,7 +60,7 @@ struct iax_template {
        unsigned int server;
        unsigned short serverport;
        unsigned int altserver;
        unsigned int server;
        unsigned short serverport;
        unsigned int altserver;
-       uint64_t flags;
+       unsigned int flags;
        unsigned int format;
        unsigned int tos;       
 } *templates;
        unsigned int format;
        unsigned int tos;       
 } *templates;
@@ -88,7 +79,7 @@ static struct iax_flag {
        { "disable3way", PROV_FLAG_DIS_THREEWAY },
 };
 
        { "disable3way", PROV_FLAG_DIS_THREEWAY },
 };
 
-char *iax_provflags2str(char *buf, int buflen, uint64_t flags)
+char *iax_provflags2str(char *buf, int buflen, unsigned int flags)
 {
        int x;
 
 {
        int x;
 
@@ -117,7 +108,7 @@ static unsigned int iax_str2flags(const char *buf)
        int x;
        int len;
        int found;
        int x;
        int len;
        int found;
-       uint64_t flags = 0;
+       unsigned int flags = 0;
        char *e;
        while(buf && *buf) {
                e = strchr(buf, ',');
        char *e;
        while(buf && *buf) {
                e = strchr(buf, ',');
@@ -166,15 +157,16 @@ char *iax_prov_complete_template(const char *line, const char *word, int pos, in
        char *ret = NULL;
        int wordlen = strlen(word);
 
        char *ret = NULL;
        int wordlen = strlen(word);
 
-       ast_mutex_lock(&provlock);
-       for (c = templates; c; c = c->next) {
-               if (!strncasecmp(word, c->name, wordlen) && ++which > state) {
-                       ret = ast_strdup(c->name);
-                       break;
+       if (pos == 3) {
+               ast_mutex_lock(&provlock);
+               for (c = templates; c; c = c->next) {
+                       if (!strncasecmp(word, c->name, wordlen) && ++which > state) {
+                               ret = ast_strdup(c->name);
+                               break;
+                       }
                }
                }
+               ast_mutex_unlock(&provlock);
        }
        }
-       ast_mutex_unlock(&provlock);
-       
        return ret;
 }
 
        return ret;
 }
 
@@ -398,11 +390,6 @@ static int iax_process_template(struct ast_config *cfg, char *s, char *def)
        return 0;
 }
 
        return 0;
 }
 
-static const char show_provisioning_usage[] = 
-"Usage: iax list provisioning [template]\n"
-"       Lists all known IAX provisioning templates or a\n"
-"       specific one if specified.\n";
-
 static const char *ifthere(const char *s)
 {
        if (strlen(s))
 static const char *ifthere(const char *s)
 {
        if (strlen(s))
@@ -424,51 +411,62 @@ static const char *iax_server(unsigned int addr)
 }
 
 
 }
 
 
-static int iax_show_provisioning(int fd, int argc, char *argv[])
+static char *iax_show_provisioning(struct ast_cli_entry *e, int cmd, struct ast_cli_args *a)
 {
        struct iax_template *cur;
        char server[INET_ADDRSTRLEN];
        char alternate[INET_ADDRSTRLEN];
        char flags[80]; /* Has to be big enough for 'flags' too */
        int found = 0;
 {
        struct iax_template *cur;
        char server[INET_ADDRSTRLEN];
        char alternate[INET_ADDRSTRLEN];
        char flags[80]; /* Has to be big enough for 'flags' too */
        int found = 0;
-       if ((argc != 3) && (argc != 4))
-               return RESULT_SHOWUSAGE;
+
+       switch (cmd) {
+       case CLI_INIT:
+               e->command = "iax2 show provisioning";
+               e->usage =
+                       "Usage: iax2 show provisioning [template]\n"
+                       "       Lists all known IAX provisioning templates or a\n"
+                       "       specific one if specified.\n";
+               return NULL;
+       case CLI_GENERATE:
+               return iax_prov_complete_template(a->line, a->word, a->pos, a->n);
+       }
+
+       if ((a->argc != 3) && (a->argc != 4))
+               return CLI_SHOWUSAGE;
        ast_mutex_lock(&provlock);
        for (cur = templates;cur;cur = cur->next) {
        ast_mutex_lock(&provlock);
        for (cur = templates;cur;cur = cur->next) {
-               if ((argc == 3) || (!strcasecmp(argv[3], cur->name)))  {
+               if ((a->argc == 3) || (!strcasecmp(a->argv[3], cur->name)))  {
                        if (found) 
                        if (found) 
-                               ast_cli(fd, "\n");
+                               ast_cli(a->fd, "\n");
                        ast_copy_string(server, iax_server(cur->server), sizeof(server));
                        ast_copy_string(alternate, iax_server(cur->altserver), sizeof(alternate));
                        ast_copy_string(server, iax_server(cur->server), sizeof(server));
                        ast_copy_string(alternate, iax_server(cur->altserver), sizeof(alternate));
-                       ast_cli(fd, "== %s ==\n", cur->name);
-                       ast_cli(fd, "Base Templ:   %s\n", strlen(cur->src) ? cur->src : "<none>");
-                       ast_cli(fd, "Username:     %s\n", ifthere(cur->user));
-                       ast_cli(fd, "Secret:       %s\n", ifthere(cur->pass));
-                       ast_cli(fd, "Language:     %s\n", ifthere(cur->lang));
-                       ast_cli(fd, "Bind Port:    %d\n", cur->port);
-                       ast_cli(fd, "Server:       %s\n", server);
-                       ast_cli(fd, "Server Port:  %d\n", cur->serverport);
-                       ast_cli(fd, "Alternate:    %s\n", alternate);
-                       ast_cli(fd, "Flags:        %s\n", iax_provflags2str(flags, sizeof(flags), cur->flags));
-                       ast_cli(fd, "Format:       %s\n", ast_getformatname(cur->format));
-                       ast_cli(fd, "TOS:          0x%x\n", cur->tos);
+                       ast_cli(a->fd, "== %s ==\n", cur->name);
+                       ast_cli(a->fd, "Base Templ:   %s\n", strlen(cur->src) ? cur->src : "<none>");
+                       ast_cli(a->fd, "Username:     %s\n", ifthere(cur->user));
+                       ast_cli(a->fd, "Secret:       %s\n", ifthere(cur->pass));
+                       ast_cli(a->fd, "Language:     %s\n", ifthere(cur->lang));
+                       ast_cli(a->fd, "Bind Port:    %d\n", cur->port);
+                       ast_cli(a->fd, "Server:       %s\n", server);
+                       ast_cli(a->fd, "Server Port:  %d\n", cur->serverport);
+                       ast_cli(a->fd, "Alternate:    %s\n", alternate);
+                       ast_cli(a->fd, "Flags:        %s\n", iax_provflags2str(flags, sizeof(flags), cur->flags));
+                       ast_cli(a->fd, "Format:       %s\n", ast_getformatname(cur->format));
+                       ast_cli(a->fd, "TOS:          0x%x\n", cur->tos);
                        found++;
                }
        }
        ast_mutex_unlock(&provlock);
        if (!found) {
                        found++;
                }
        }
        ast_mutex_unlock(&provlock);
        if (!found) {
-               if (argc == 3)
-                       ast_cli(fd, "No provisioning templates found\n");
+               if (a->argc == 3)
+                       ast_cli(a->fd, "No provisioning templates found\n");
                else
                else
-                       ast_cli(fd, "No provisioning template matching '%s' found\n", argv[3]);
+                       ast_cli(a->fd, "No provisioning template matching '%s' found\n", a->argv[3]);
        }
        }
-       return RESULT_SUCCESS;
+       return CLI_SUCCESS;
 }
 
 static struct ast_cli_entry cli_iax2_provision[] = {
 }
 
 static struct ast_cli_entry cli_iax2_provision[] = {
-       { { "iax2", "show", "provisioning", NULL },
-       iax_show_provisioning, "Display iax provisioning",
-       show_provisioning_usage, iax_prov_complete_template, },
+       AST_CLI_DEFINE(iax_show_provisioning, "Display iax provisioning"),
 };
 
 static int iax_provision_init(void)
 };
 
 static int iax_provision_init(void)
@@ -485,12 +483,13 @@ int iax_provision_unload(void)
        return 0;
 }
 
        return 0;
 }
 
-int iax_provision_reload(void)
+int iax_provision_reload(int reload)
 {
        struct ast_config *cfg;
        struct iax_template *cur, *prev, *next;
        char *cat;
        int found = 0;
 {
        struct ast_config *cfg;
        struct iax_template *cur, *prev, *next;
        char *cat;
        int found = 0;
+       struct ast_flags config_flags = { reload ? CONFIG_FLAG_FILEUNCHANGED : 0 };
        if (!provinit)
                iax_provision_init();
        /* Mark all as dead.  No need for locking */
        if (!provinit)
                iax_provision_init();
        /* Mark all as dead.  No need for locking */
@@ -499,21 +498,22 @@ int iax_provision_reload(void)
                cur->dead = 1;
                cur = cur->next;
        }
                cur->dead = 1;
                cur = cur->next;
        }
-       cfg = ast_config_load("iaxprov.conf");
-       if (cfg) {
+       cfg = ast_config_load("iaxprov.conf", config_flags);
+       if (cfg != NULL && cfg != CONFIG_STATUS_FILEUNCHANGED) {
                /* Load as appropriate */
                cat = ast_category_browse(cfg, NULL);
                while(cat) {
                        if (strcasecmp(cat, "general")) {
                                iax_process_template(cfg, cat, found ? "default" : NULL);
                                found++;
                /* Load as appropriate */
                cat = ast_category_browse(cfg, NULL);
                while(cat) {
                        if (strcasecmp(cat, "general")) {
                                iax_process_template(cfg, cat, found ? "default" : NULL);
                                found++;
-                               if (option_verbose > 2)
-                                       ast_verbose(VERBOSE_PREFIX_3 "Loaded provisioning template '%s'\n", cat);
+                               ast_verb(3, "Loaded provisioning template '%s'\n", cat);
                        }
                        cat = ast_category_browse(cfg, cat);
                }
                ast_config_destroy(cfg);
                        }
                        cat = ast_category_browse(cfg, cat);
                }
                ast_config_destroy(cfg);
-       } else
+       } else if (cfg == CONFIG_STATUS_FILEUNCHANGED)
+               return 0;
+       else
                ast_log(LOG_NOTICE, "No IAX provisioning configuration found, IAX provisioning disabled.\n");
        ast_mutex_lock(&provlock);
        /* Drop dead entries while locked */
                ast_log(LOG_NOTICE, "No IAX provisioning configuration found, IAX provisioning disabled.\n");
        ast_mutex_lock(&provlock);
        /* Drop dead entries while locked */