[svn-commits] rizzo: branch rizzo/astobj2 r77629 - /team/rizzo/astobj2/channels/chan_sip.c
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Sat Jul 28 04:03:22 CDT 2007
Author: rizzo
Date: Sat Jul 28 04:03:18 2007
New Revision: 77629
URL: http://svn.digium.com/view/asterisk?view=rev&rev=77629
Log:
merge from trunk register= handling
Modified:
team/rizzo/astobj2/channels/chan_sip.c
Modified: team/rizzo/astobj2/channels/chan_sip.c
URL: http://svn.digium.com/view/asterisk/team/rizzo/astobj2/channels/chan_sip.c?view=diff&rev=77629&r1=77628&r2=77629
==============================================================================
--- team/rizzo/astobj2/channels/chan_sip.c (original)
+++ team/rizzo/astobj2/channels/chan_sip.c Sat Jul 28 04:03:18 2007
@@ -962,25 +962,39 @@
/*! \brief Parameters to know status of transfer */
enum referstatus {
- REFER_IDLE, /*!< No REFER is in progress */
- REFER_SENT, /*!< Sent REFER to transferee */
- REFER_RECEIVED, /*!< Received REFER from transferrer */
- REFER_CONFIRMED, /*!< Refer confirmed with a 100 TRYING */
- REFER_ACCEPTED, /*!< Accepted by transferee */
- REFER_RINGING, /*!< Target Ringing */
- REFER_200OK, /*!< Answered by transfer target */
- REFER_FAILED, /*!< REFER declined - go on */
- REFER_NOAUTH /*!< We had no auth for REFER */
+ REFER_IDLE, /*!< No REFER is in progress */
+ REFER_SENT, /*!< Sent REFER to transferee */
+ REFER_RECEIVED, /*!< Received REFER from transferrer */
+ REFER_CONFIRMED, /*!< Refer confirmed with a 100 TRYING (unused) */
+ REFER_ACCEPTED, /*!< Accepted by transferee */
+ REFER_RINGING, /*!< Target Ringing */
+ REFER_200OK, /*!< Answered by transfer target */
+ REFER_FAILED, /*!< REFER declined - go on */
+ REFER_NOAUTH /*!< We had no auth for REFER */
};
-/*!
- * generic struct to map between strings and integers.
- * Must be terminated by s = NULL;
+/*! \brief generic struct to map between strings and integers.
+ * Fill it with x-s pairs, terminate with an entry with s = NULL;
+ * Then you can call map_x_s(...) to map an integer to a string,
+ * and map_s_x() for the string -> integer mapping.
*/
struct _map_x_s {
int x;
const char *s;
};
+
+static const struct _map_x_s referstatusstrings[] = {
+ { REFER_IDLE, "<none>" },
+ { REFER_SENT, "Request sent" },
+ { REFER_RECEIVED, "Request received" },
+ { REFER_CONFIRMED, "Confirmed" },
+ { REFER_ACCEPTED, "Accepted" },
+ { REFER_RINGING, "Target ringing" },
+ { REFER_200OK, "Done" },
+ { REFER_FAILED, "Failed" },
+ { REFER_NOAUTH, "Failed - auth failure" },
+ { -1, NULL} /* terminator */
+} ;
/*! \brief Structure to handle SIP transfers. Dynamically allocated when needed
\note OEJ: Should be moved to string fields */
@@ -1004,12 +1018,10 @@
enum referstatus status; /*!< REFER status */
};
-/*!
- * PVT structures are used for each SIP dialog, ie. a call, a registration, a subscribe.
+/*! \brief sip_pvt: structures used for each SIP dialog, ie. a call, a registration, a subscribe.
* Created and initialized by sip_alloc(), the descriptor goes into the list of
- * descriptors (dialoglist), and there it stays i suppose forever
+ * descriptors (dialoglist).
*/
-
struct sip_pvt {
#ifndef USE_AO2
struct sip_pvt *next; /*!< Next dialog in chain */
@@ -1801,28 +1813,31 @@
.description = "Session Initiation Protocol (SIP)",
.capabilities = ((AST_FORMAT_MAX_AUDIO << 1) - 1),
.properties = AST_CHAN_TP_WANTSJITTER | AST_CHAN_TP_CREATESJITTER,
- .requester = sip_request_call, /* called with chan unlocked */
- .devicestate = sip_devicestate, /* called with chan unlocked (not chan-specific) */
- .call = sip_call, /* called with chan locked */
- .hangup = sip_hangup, /* called with chan locked */
- .answer = sip_answer, /* called with chan locked */
- .read = sip_read, /* called with chan locked */
- .write = sip_write, /* called with chan locked */
- .write_video = sip_write, /* called with chan locked */
- .write_text = sip_write, /* XXX */
- .indicate = sip_indicate, /* called with chan locked */
- .transfer = sip_transfer, /* called with chan locked */
- .fixup = sip_fixup, /* called with chan locked */
+ .requester = sip_request_call,
+ .devicestate = sip_devicestate,
+ .call = sip_call,
+ .hangup = sip_hangup,
+ .answer = sip_answer,
+ .read = sip_read,
+ .write = sip_write,
+ .write_video = sip_write,
+ .write_text = sip_write,
+ .indicate = sip_indicate,
+ .transfer = sip_transfer,
+ .fixup = sip_fixup,
.send_digit_end = sip_senddigit_end,
- .bridge = ast_rtp_bridge, /* XXX chan unlocked ? */
+ .bridge = ast_rtp_bridge,
.early_bridge = ast_rtp_early_bridge,
- .send_text = sip_sendtext, /* called with chan locked */
+ .send_text = sip_sendtext,
+ .func_channel_read = acf_channel_read,
};
/* wrapper macro to tell whether t points to one of the sip_tech descriptors */
#define IS_SIP_TECH(t) ((t) == &sip_tech || (t) == &sip_tech_info)
-/*! \begin map from an integer value to a string */
+/*! \begin map from an integer value to a string.
+ * If no match is found, return errorstring
+ */
static const char *map_x_s(const struct _map_x_s *table, int x, const char *errorstring)
{
const struct _map_x_s *cur;
@@ -1833,7 +1848,9 @@
return errorstring;
}
-/*! \begin map from a string to an integer value */
+/*! \begin map from a string to an integer value, case insensitive.
+ * If no match is found, return errorvalue.
+ */
static int map_s_x(const struct _map_x_s *table, const char *s, int errorvalue)
{
const struct _map_x_s *cur;
@@ -1973,17 +1990,6 @@
static void append_history_full(struct sip_pvt *p, const char *fmt, ...)
__attribute__ ((format (printf, 2, 3)));
-static const struct _map_x_s referstatusstrings[] = {
- { REFER_IDLE, "<none>" },
- { REFER_SENT, "Request sent" },
- { REFER_RECEIVED, "Request received" },
- { REFER_ACCEPTED, "Accepted" },
- { REFER_RINGING, "Target ringing" },
- { REFER_200OK, "Done" },
- { REFER_FAILED, "Failed" },
- { REFER_NOAUTH, "Failed - auth failure" },
- { -1, NULL} /* terminator */
-} ;
/*! \brief Convert transfer status to string */
static const char *referstatus2str(enum referstatus rstatus)
@@ -8306,9 +8312,10 @@
else if (!ast_strlen_zero(r->nonce)) {
char digest[1024];
- /* We have auth data to reuse, build a digest header!
- * Actually this doesn't seem terribly useful, as some parties usually
- * do not like the old nonce (for good reasons) and challenge us again.
+ /* We have auth data to reuse, build a digest header.
+ * Note, this is not always useful because some parties do not
+ * like nonces to be reused (for good reasons!) so they will
+ * challenge us anyways.
*/
if (sipdebug)
ast_debug(1, " >>> Re-using Auth data for %s@%s\n", r->username, r->hostname);
@@ -9154,6 +9161,7 @@
/* If they put someone on hold, increment the value... otherwise decrement it */
ast_atomic_fetchadd_int(&peer->onHold, (hold ? +1 : -1) );
+
/* Request device state update */
ast_device_state_changed("SIP/%s", peer->name);
@@ -9176,6 +9184,8 @@
static int cb_extensionstate(char *context, char* exten, int state, void *data)
{
struct sip_pvt *p = data;
+
+ sip_pvt_lock(p);
switch(state) {
case AST_EXTENSION_DEACTIVATED: /* Retry after a while */
@@ -9195,8 +9205,10 @@
if (p->subscribed != NONE) /* Only send state NOTIFY if we know the format */
transmit_state_notify(p, state, 1, FALSE);
- if (option_verbose > 1)
- ast_verbose(VERBOSE_PREFIX_1 "Extension Changed %s new state %s for Notify User %s\n", exten, ast_extension_state2str(state), p->username);
+ ast_verb(1, "Extension Changed %s new state %s for Notify User %s\n", exten, ast_extension_state2str(state), p->username);
+
+ sip_pvt_unlock(p);
+
return 0;
}
@@ -9901,8 +9913,13 @@
/*! \brief check received= and rport= in a SIP response.
* If we get a response with received= and/or rport= in the Via:
- * line, we can use them as 'ourip' (see RFC 3581 for rport,
- * and RFC 3261 for received (?)
+ * line, use them as 'p->ourip' (see RFC 3581 for rport,
+ * and RFC 3261 for received).
+ * Using these two fields SIP can produce the correct
+ * address and port in the SIP headers without the need for STUN.
+ * The address part is also reused for the media sessions.
+ * Note that ast_sip_ouraddrfor() still rewrites p->ourip
+ * if you specify externip/seternaddr/stunaddr.
*/
static void check_via_response(struct sip_pvt *p, struct sip_request *req)
{
@@ -9917,21 +9934,18 @@
*opts = '\0';
/* parse all relevant options */
- ast_log(LOG_WARNING, "doing Via: %s\n", via);
opts = strchr(via, ';');
if (!opts)
- return; /* no options to parse */
+ return; /* no options to parse */
*opts++ = '\0';
while ( (cur = strsep(&opts, ";")) ) {
if (!strncmp(cur, "rport=", 6)) {
int port = strtol(cur+6, NULL, 10);
- ast_log(LOG_WARNING, "found rport: %s\n", cur);
- /* XXX error checking */
+ /* XXX add error checking */
p->ourip.sin_port = ntohs(port);
} else if (!strncmp(cur, "received=", 9)) {
- ast_log(LOG_WARNING, "found received: %s\n", cur);
if (ast_parse_arg(cur+9, PARSE_INADDR, &p->ourip))
- ; /* XXX error checking */
+ ; /* XXX add error checking */
}
}
}
@@ -11741,6 +11755,7 @@
);
arg->numchans++;
}
+
return 0; /* don't care, we scan all channels */
}
@@ -14126,31 +14141,27 @@
}
ast_channel_unlock(transferer);
if (!transferer || !transferee) {
- if (!transferer)
+ if (!transferer) {
ast_debug(1, "No transferer channel, giving up parking\n");
- if (!transferee)
+ }
+ if (!transferee) {
ast_debug(1, "No transferee channel, giving up parking\n");
+ }
return -1;
}
if ((d = ast_calloc(1, sizeof(*d)))) {
- pthread_attr_t attr;
-
- pthread_attr_init(&attr);
- pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
-
+
/* Save original request for followup */
copy_request(&d->req, req);
d->chan1 = transferee; /* Transferee */
d->chan2 = transferer; /* Transferer */
d->seqno = seqno;
- if (ast_pthread_create_background(&th, &attr, sip_park_thread, d) < 0) {
+ if (ast_pthread_create_detached_background(&th, NULL, sip_park_thread, d) < 0) {
/* Could not start thread */
ast_free(d); /* We don't need it anymore. If thread is created, d will be free'd
by sip_park_thread() */
- pthread_attr_destroy(&attr);
return 0;
}
- pthread_attr_destroy(&attr);
}
return -1;
}
@@ -16522,9 +16533,11 @@
}
/*! \todo Check video RTP keepalives
+
Do we need to move the lastrtptx to the RTP structure to have one for audio and one
for video? It really does belong to the RTP structure.
*/
+
/* XXX probably wrong check if rtptimeout == 0 */
/* Check AUDIO RTP timers */
if (! (dialog->lastrtprx && (ast_rtp_get_rtptimeout(dialog->rtp) || ast_rtp_get_rtpholdtimeout(dialog->rtp)) &&
@@ -16650,9 +16663,9 @@
}
ast_mutex_unlock(&monlock);
}
+
/* Never reached */
return NULL;
-
}
/*! \brief Start the channel monitor thread */
@@ -17871,6 +17884,7 @@
#if 0 /* XXX fixme */
M_F("outboundproxy", {
char *name, *port = NULL, *force;
+
name = ast_strdupa(v->value);
/* XXX use strsep here */
if ((port = strchr(name, ':'))) {
@@ -18386,6 +18400,7 @@
return res;
}
+
/*! \brief Set the RTP peer for this call */
static int sip_set_rtp_peer(struct ast_channel *chan, struct ast_rtp *rtp, struct ast_rtp *vrtp, struct ast_rtp *trtp, int codecs, int nat_active)
{
More information about the svn-commits
mailing list