diff options
| author | Jeremy Lainé <jeremy.laine@m4x.org> | 2015-08-27 17:13:21 +0200 |
|---|---|---|
| committer | Jeremy Lainé <jeremy.laine@m4x.org> | 2015-08-27 17:23:17 +0200 |
| commit | 5f144d0f0a10e2f55de00f838bea43748a27d8ab (patch) | |
| tree | a9f84273986ed10de1a4c4ff468ddf6020f69976 /src/base/QXmppJingleIq.cpp | |
| parent | 44cbba5d6538b998b5b5fbb4264d78ab135f669f (diff) | |
| download | qxmpp-5f144d0f0a10e2f55de00f838bea43748a27d8ab.tar.gz | |
parse SDP parameters
Diffstat (limited to 'src/base/QXmppJingleIq.cpp')
| -rw-r--r-- | src/base/QXmppJingleIq.cpp | 40 |
1 files changed, 38 insertions, 2 deletions
diff --git a/src/base/QXmppJingleIq.cpp b/src/base/QXmppJingleIq.cpp index 3422734d..f2dd6a95 100644 --- a/src/base/QXmppJingleIq.cpp +++ b/src/base/QXmppJingleIq.cpp @@ -24,6 +24,7 @@ #include <QDate> #include <QDateTime> #include <QDomElement> +#include <QRegExp> #include "QXmppConstants.h" #include "QXmppJingleIq.h" @@ -318,6 +319,29 @@ bool QXmppJingleIq::Content::parseSdp(const QString &sdp) return false; } addTransportCandidate(candidate); + } else if (attrName == "fmtp") { + int spIdx = attrValue.indexOf(' '); + if (spIdx == -1) { + qWarning() << "Could not parse payload parameters" << line; + return false; + } + const int id = attrValue.left(spIdx).toInt(); + const QString paramStr = attrValue.mid(spIdx + 1); + for (int i = 0; i < payloads.size(); ++i) { + if (payloads[i].id() == id) { + QMap<QString, QString> params; + if (payloads[i].name() == "telephone-event") { + params.insert("events", paramStr); + } else { + foreach (const QString p, paramStr.split(QRegExp(";\\s*"))) { + QStringList bits = p.split('='); + if (bits.size() == 2) + params.insert(bits[0], bits[1]); + } + } + payloads[i].setParameters(params); + } + } } else if (attrName == "rtpmap") { // payload type map const QStringList bits = attrValue.split(' '); @@ -409,8 +433,20 @@ QString QXmppJingleIq::Content::toSdp() const if (payload.channels() > 1) rtpmap += "/" + QString::number(payload.channels()); attrs << "a=rtpmap:" + rtpmap; - if (payload.name() == "telephone-event") - attrs << "a=fmtp:" + QByteArray::number(payload.id()) + " 0-15"; + + // payload parameters + QStringList paramList; + const QMap<QString, QString> params = payload.parameters(); + if (payload.name() == "telephone-event") { + if (params.contains("events")) + paramList << params.value("events"); + } else { + QMap<QString, QString>::const_iterator i; + for (i = params.begin(); i != params.end(); ++i) + paramList << i.key() + "=" + i.value(); + } + if (!paramList.isEmpty()) + attrs << "a=fmtp:" + QByteArray::number(payload.id()) + " " + paramList.join("; "); } sdp << QString("m=%1 %2 RTP/AVP%3").arg(m_descriptionMedia, QString::number(localRtpPort), payloads); sdp << QString("c=%1").arg(addressToSdp(localRtpAddress)); |
