[sr-dev] git:sr_3.0: modules/mediaproxy: take boundary string from Content-Type header.
Juha Heinanen
jh at tutpro.com
Tue Feb 2 09:10:54 CET 2010
Module: sip-router
Branch: sr_3.0
Commit: 2031721948bfa6b444d9b18f7e3f195cfd7e1427
URL: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=2031721948bfa6b444d9b18f7e3f195cfd7e1427
Author: Juha Heinanen <jh at tutpro.com>
Committer: Juha Heinanen <jh at tutpro.com>
Date: Tue Feb 2 10:09:32 2010 +0200
modules/mediaproxy: take boundary string from Content-Type header.
---
modules/mediaproxy/mediaproxy.c | 53 ++++++++++++++++++++++++++++++++++++---
1 files changed, 49 insertions(+), 4 deletions(-)
diff --git a/modules/mediaproxy/mediaproxy.c b/modules/mediaproxy/mediaproxy.c
index acedf5b..3f44595 100644
--- a/modules/mediaproxy/mediaproxy.c
+++ b/modules/mediaproxy/mediaproxy.c
@@ -45,6 +45,7 @@
#include "../../parser/msg_parser.h"
#include "../../parser/parse_from.h"
#include "../../parser/parse_to.h"
+#include "../../parser/parse_param.h"
#include "../../msg_translator.h"
#include "../../modules_k/dialog/dlg_load.h"
#include "../../modules_k/dialog/dlg_hash.h"
@@ -658,10 +659,12 @@ get_media_relay(struct sip_msg* msg)
static int
find_content_type_application_sdp(struct sip_msg *msg, str *sdp)
{
- str type;
+ str type, params, boundary;
char *start, *s;
unsigned int len;
Bool done;
+ param_hooks_t hooks;
+ param_t *p, *list;
if (!msg->content_type) {
LM_WARN("the Content-Type header is missing! Assume the content type is text/plain\n");
@@ -688,6 +691,44 @@ find_content_type_application_sdp(struct sip_msg *msg, str *sdp)
if (done) return 1;
// Hack to find application/sdp bodypart
+ params.s = memchr(msg->content_type->body.s, ';',
+ msg->content_type->body.len);
+ if (params.s == NULL) {
+ LM_ERR("Content-Type hdr has no params\n");
+ return -1;
+ }
+ params.len = msg->content_type->body.len -
+ (params.s - msg->content_type->body.s);
+ if (parse_params(¶ms, CLASS_ANY, &hooks, &list) < 0) {
+ LM_ERR("while parsing Content-Type params\n");
+ return -1;
+ }
+ boundary.s = NULL;
+ boundary.len = 0;
+ for (p = list; p; p = p->next) {
+ if ((p->name.len == 8)
+ && (strncasecmp(p->name.s, "boundary", 8) == 0)) {
+ boundary.s = pkg_malloc(p->body.len + 2 + 1);
+ if (boundary.s == NULL) {
+ free_params(list);
+ LM_ERR("no memory for boundary string\n");
+ return -1;
+ }
+ *(boundary.s) = '-';
+ *(boundary.s + 1) = '-';
+ memcpy(boundary.s + 2, p->body.s, p->body.len);
+ boundary.len = 2 + p->body.len;
+ *(boundary.s + boundary.len) = 0;
+ LM_DBG("boundary is <%.*s>\n", boundary.len, boundary.s);
+ break;
+ }
+ }
+ free_params(list);
+ if (boundary.s == NULL) {
+ LM_ERR("no mandatory param \";boundary\"\n");
+ return -1;
+ }
+
while ((s = find_line_starting_with(sdp, "Content-Type: ", True))) {
start = s + 14;
len = sdp->len - (s - sdp->s) - 14;
@@ -696,7 +737,7 @@ find_content_type_application_sdp(struct sip_msg *msg, str *sdp)
start = start + 15;
if ((*start != 13) || (*(start + 1) != 10)) {
LM_ERR("no CRLF found after content type\n");
- return -1;
+ goto err;
}
start = start + 2;
len = len - 15 - 2;
@@ -706,17 +747,21 @@ find_content_type_application_sdp(struct sip_msg *msg, str *sdp)
}
sdp->s = start;
sdp->len = len;
- s = find_line_starting_with(sdp, "--Boundary", False);
+ s = find_line_starting_with(sdp, boundary.s, False);
if (s == NULL) {
LM_ERR("boundary not found after bodypart\n");
- return -1;
+ goto err;
}
sdp->len = s - start - 2;
+ pkg_free(boundary.s);
return 1;
}
}
}
LM_ERR("no application/sdp bodypart found\n");
+
+ err:
+ pkg_free(boundary.s);
return -1;
}
More information about the sr-dev
mailing list