diff --git a/src/mod/endpoints/mod_sofia/sofia.c b/src/mod/endpoints/mod_sofia/sofia.c index 6a40b1de63..da0cd3deac 100644 --- a/src/mod/endpoints/mod_sofia/sofia.c +++ b/src/mod/endpoints/mod_sofia/sofia.c @@ -8437,13 +8437,15 @@ void sofia_handle_sip_i_invite(switch_core_session_t *session, nua_t *nua, sofia for (mp = sip->sip_multipart; mp; mp = mp->mp_next) { if (mp->mp_payload && mp->mp_payload->pl_data && mp->mp_content_type && mp->mp_content_type->c_type) { char *name = switch_core_session_strdup(session, mp->mp_content_type->c_type); - char *encoded_name; - int len = (strlen(name) * 3) + 1; + char *p; + + for (p = name; p && *p; p++) { + if (*p == '/') { + *p = '_'; + } + } - encoded_name = switch_core_session_alloc(session, len); - switch_url_encode(name, encoded_name, len); - - switch_channel_set_variable_name_printf(channel, mp->mp_payload->pl_data, SOFIA_MULTIPART_PREFIX "_enc_%s", encoded_name); + switch_channel_set_variable_name_printf(channel, mp->mp_payload->pl_data, SOFIA_MULTIPART_PREFIX "%s", name); } } } diff --git a/src/mod/endpoints/mod_sofia/sofia_media.c b/src/mod/endpoints/mod_sofia/sofia_media.c index 280af38cef..87a4dc7eb5 100644 --- a/src/mod/endpoints/mod_sofia/sofia_media.c +++ b/src/mod/endpoints/mod_sofia/sofia_media.c @@ -115,13 +115,6 @@ char *sofia_media_get_multipart(switch_core_session_t *session, const char *pref if (!strncasecmp(name, prefix, strlen(prefix))) { const char *hname = name + strlen(prefix); - - if (*hname == '_' && strncmp(hname, "_enc_", 4)) { - char *dname = switch_core_session_strdup(session, hname); - switch_url_decode(dname); - hname = dname; - } - if (*value == '~') { stream.write_function(&stream, "--%s\nContent-Type: %s\nContent-Length: %d\n%s\n", boundary, hname, strlen(value), value + 1); } else {