Update of /usr/cvsroot/asterisk/channels
In directory mongoose.digium.com:/tmp/cvs-serv20063/channels

Modified Files:
        chan_sip.c 
Log Message:
add SIPPEER dialplan function (bug #4728)


Index: chan_sip.c
===================================================================
RCS file: /usr/cvsroot/asterisk/channels/chan_sip.c,v
retrieving revision 1.782
retrieving revision 1.783
diff -u -d -r1.782 -r1.783
--- chan_sip.c  19 Jul 2005 23:55:43 -0000      1.782
+++ chan_sip.c  20 Jul 2005 00:44:35 -0000      1.783
@@ -8179,6 +8179,83 @@
        .read = func_header_read,
 };
 
+static char *function_sippeer(struct ast_channel *chan, char *cmd, char *data, 
char *buf, size_t len)
+{
+       char *ret = NULL;
+       struct sip_peer *peer;
+       char *peername, *colname;
+       char iabuf[INET_ADDRSTRLEN];
+
+       if (!(peername = ast_strdupa(data))) {
+               ast_log(LOG_ERROR, "Memory Error!\n");
+               return ret;
+       }
+
+       if ((colname = strchr(peername, ':'))) {
+               *colname = '\0';
+               colname++;
+       } else {
+               colname = "ip";
+       }
+       if (!(peer = find_peer(peername, NULL, 1)))
+               return ret;
+
+       if (!strcasecmp(colname, "ip")) {
+               ast_copy_string(buf, peer->addr.sin_addr.s_addr ? 
ast_inet_ntoa(iabuf, sizeof(iabuf), peer->addr.sin_addr) : "", len);
+       } else  if (!strcasecmp(colname, "mailbox")) {
+               ast_copy_string(buf, peer->mailbox, len);
+       } else  if (!strcasecmp(colname, "context")) {
+               ast_copy_string(buf, peer->context, len);
+       } else  if (!strcasecmp(colname, "expire")) {
+               snprintf(buf, len, "%d", peer->expire);
+       } else  if (!strcasecmp(colname, "dynamic")) {
+               ast_copy_string(buf, (ast_test_flag(peer, SIP_DYNAMIC) ? "yes" 
: "no"), len);
+       } else  if (!strcasecmp(colname, "callerid_name")) {
+               ast_copy_string(buf, peer->cid_name, len);
+       } else  if (!strcasecmp(colname, "callerid_num")) {
+               ast_copy_string(buf, peer->cid_num, len);
+       } else  if (!strcasecmp(colname, "codecs")) {
+               ast_getformatname_multiple(buf, len -1, peer->capability);
+       } else  if (!strncasecmp(colname, "codec[", 6)) {
+               char *codecnum, *ptr;
+               int index = 0, codec = 0;
+               
+               codecnum = strchr(colname, '[');
+               *codecnum = '\0';
+               codecnum++;
+               if ((ptr = strchr(codecnum, ']'))) {
+                       *ptr = '\0';
+               }
+               index = atoi(codecnum);
+               if((codec = ast_codec_pref_index(&peer->prefs, index))) {
+                       ast_copy_string(buf, ast_getformatname(codec), len);
+               }
+       }
+       ret = buf;
+
+       ASTOBJ_UNREF(peer, sip_destroy_peer);
+
+       return ret;
+}
+
+struct ast_custom_function sippeer_function = {
+    .name = "SIPPEER",
+    .synopsis = "Gets SIP peer information",
+    .syntax = "SIPPEER(<peername>[:item])",
+    .read = function_sippeer,
+       .desc = "Valid items are:\n"
+       "- ip (default)          The IP address.\n"
+       "- mailbox               The configured mailbox.\n"
+       "- context               The configured context.\n"
+       "- expire                The epoch time of the next expire.\n"
+       "- dynamic               Is it dynamic? (yes/no).\n"
+       "- callerid_name         The configured Caller ID name.\n"
+       "- callerid_num          The configured Caller ID number.\n"
+       "- codecs                The configured codecs.\n"
+       "- codec[x]              Preferred codec index number 'x' (beginning 
with zero).\n"
+       "\n"
+};
+
 /*--- parse_moved_contact: Parse 302 Moved temporalily response */
 static void parse_moved_contact(struct sip_pvt *p, struct sip_request *req)
 {
@@ -11516,6 +11593,7 @@
                              "Show SIP peer (text format)", 
mandescr_show_peer);
 
        ast_custom_function_register(&sip_header_function);
+       ast_custom_function_register(&sippeer_function);
 
        sip_poke_all_peers();
        sip_send_all_registers();
@@ -11533,6 +11611,7 @@
        /* First, take us out of the channel type list */
        ast_channel_unregister(&sip_tech);
 
+       ast_custom_function_unregister(&sippeer_function);
        ast_custom_function_unregister(&sip_header_function);
 
        ast_unregister_application(app_dtmfmode);

_______________________________________________
Asterisk-Cvs mailing list
[email protected]
http://lists.digium.com/mailman/listinfo/asterisk-cvs

Reply via email to