This source file includes following definitions.
- StartList
 
- EndList
 
- StartElement
 
- EndAttributes
 
- EndElement
 
- StartAttribute
 
- EndAttribute
 
- DumpInt
 
- DumpLargeInt
 
- DumpBool
 
- DumpData
 
- DumpData_16
 
- DumpBin128
 
- DumpDate
 
- gf_ipmpx_dump_ByteArray
 
- gf_ipmpx_dump_AUTH
 
- gf_ipmpx_dump_BaseData
 
- gf_ipmpx_dump_OpaqueData
 
- gf_ipmpx_dump_KeyData
 
- gf_ipmpx_dump_SecureContainer
 
- gf_ipmpx_dump_InitAuthentication
 
- gf_ipmpx_dump_TrustSecurityMetadata
 
- gf_ipmpx_dump_MutualAuthentication
 
- gf_ipmpx_dump_GetToolsResponse
 
- gf_ipmpx_dump_ParametricDescription
 
- gf_ipmpx_dump_ToolParamCapabilitiesQuery
 
- gf_ipmpx_dump_ToolParamCapabilitiesResponse
 
- gf_ipmpx_dump_ConnectTool
 
- gf_ipmpx_dump_DisconnectTool
 
- gf_ipmpx_dump_GetToolContext
 
- gf_ipmpx_dump_GetToolContextResponse
 
- gf_ipmpx_dump_AddToolNotificationListener
 
- gf_ipmpx_dump_RemoveToolNotificationListener
 
- gf_ipmpx_dump_NotifyToolEvent
 
- gf_ipmpx_dump_CanProcess
 
- gf_ipmpx_dump_ToolAPI_Config
 
- gf_ipmpx_dump_WatermarkingInit
 
- gf_ipmpx_dump_SendWatermark
 
- gf_ipmpx_dump_SelectiveDecryptionInit
 
- gf_ipmpx_dump_ISMACryp
 
- gf_ipmpx_dump_data
 
#include <gpac/internal/odf_dev.h>
#if !defined(GPAC_DISABLE_OD_DUMP) && !defined(GPAC_MINIMAL_ODF)
#define GF_IPMPX_MAX_TREE               100
#define GF_IPMPX_FORMAT_INDENT( ind_buf, indent ) \
        { \
                u32 z;  \
                assert(GF_IPMPX_MAX_TREE>indent);       \
                for (z=0; z<indent; z++) ind_buf[z] = ' '; \
                ind_buf[z] = 0; \
        } \
 
static void StartList(FILE *trace, const char *name, u32 indent, Bool XMTDump)
{
        char ind_buf[GF_IPMPX_MAX_TREE];
        GF_IPMPX_FORMAT_INDENT(ind_buf, indent);
        if (XMTDump) {
                fprintf(trace, "%s<%s>\n", ind_buf, name);
        } else {
                fprintf(trace, "%s%s [\n", ind_buf, name);
        }
}
static void EndList(FILE *trace, const char *name, u32 indent, Bool XMTDump)
{
        char ind_buf[GF_IPMPX_MAX_TREE];
        GF_IPMPX_FORMAT_INDENT(ind_buf, indent);
        if (XMTDump) {
                fprintf(trace, "%s</%s>\n", ind_buf, name);
        } else {
                fprintf(trace, "%s]\n", ind_buf);
        }
}
static void StartElement(FILE *trace, const char *descName, u32 indent, Bool XMTDump)
{
        char ind_buf[GF_IPMPX_MAX_TREE];
        GF_IPMPX_FORMAT_INDENT(ind_buf, indent);
        fprintf(trace, "%s", ind_buf);
        if (!XMTDump) {
                fprintf(trace, "%s {\n", descName);
        } else {
                fprintf(trace, "<%s ", descName);
        }
}
static void EndAttributes(FILE *trace, Bool XMTDump, Bool has_children)
{
        if (XMTDump) {
                if (has_children) {
                        fprintf(trace, ">\n");
                } else {
                        fprintf(trace, "/>\n");
                }
        }
}
static void EndElement(FILE *trace, const char *descName, u32 indent, Bool XMTDump)
{
        char ind_buf[GF_IPMPX_MAX_TREE];
        GF_IPMPX_FORMAT_INDENT(ind_buf, indent);
        fprintf(trace, "%s", ind_buf);
        if (!XMTDump) {
                fprintf(trace, "}\n");
        } else {
                fprintf(trace, "</%s>\n", descName);
        }
}
static void StartAttribute(FILE *trace, const char *attName, u32 indent, Bool XMTDump)
{
        char ind_buf[GF_IPMPX_MAX_TREE];
        GF_IPMPX_FORMAT_INDENT(ind_buf, indent);
        if (!XMTDump) {
                fprintf(trace, "%s%s ", ind_buf, attName);
        } else {
                fprintf(trace, "%s=\"", attName);
        }
}
static void EndAttribute(FILE *trace, u32 indent, Bool XMTDump)
{
        if (!XMTDump) {
                fprintf(trace, "\n");
        } else {
                fprintf(trace, "\" ");
        }
}
static void DumpInt(FILE *trace, char *attName, u32  val, u32 indent, Bool XMTDump)
{
        if (!val) return;
        StartAttribute(trace, attName, indent, XMTDump);
        fprintf(trace, "%d", val);
        EndAttribute(trace, indent, XMTDump);
}
static void DumpLargeInt(FILE *trace, char *attName, u64  val, u32 indent, Bool XMTDump)
{
        if (!val) return;
        StartAttribute(trace, attName, indent, XMTDump);
        fprintf(trace, LLU, val);
        EndAttribute(trace, indent, XMTDump);
}
static void DumpBool(FILE *trace, char *attName, u32  val, u32 indent, Bool XMTDump)
{
        if (!val) return;
        StartAttribute(trace, attName, indent, XMTDump);
        fprintf(trace, "%s", val ? "true" : "false");
        EndAttribute(trace, indent, XMTDump);
}
static void DumpData(FILE *trace, const char *name, char *data, u32 dataLength, u32 indent, Bool XMTDump)
{
        u32 i;
        Bool ASCII_Dump;
        if (!name && !data) return;
        if (name) StartAttribute(trace, name, indent, XMTDump);
        if (!XMTDump) fprintf(trace, "\"");
        ASCII_Dump = GF_TRUE;
        for (i=0; i<dataLength; i++) {
                if ((data[i]<32) || (data[i]>126)) {
                        ASCII_Dump = GF_FALSE;
                        break;
                }
        }
        if (!ASCII_Dump && XMTDump) fprintf(trace, "data:application/octet-string,");
        for (i=0; i<dataLength; i++) {
                if (ASCII_Dump) {
                        fprintf(trace, "%c", (unsigned char) data[i]);
                } else {
                        fprintf(trace, "%%");
                        fprintf(trace, "%02X", (unsigned char) data[i]);
                }
        }
        if (!XMTDump) fprintf(trace, "\"");
        if (name) EndAttribute(trace, indent, XMTDump);
}
static void DumpData_16(FILE *trace, char *name, u16 *data, u16 dataLength, u32 indent, Bool XMTDump)
{
        u32 i;
        if (!name && !data) return;
        if (name) StartAttribute(trace, name, indent, XMTDump);
        if (!XMTDump) fprintf(trace, "\"");
        for (i=0; i<dataLength; i++) {
                if (XMTDump) {
                        fprintf(trace, "\'%d\'", data[i]);
                        if (i+1<dataLength) fprintf(trace, " ");
                } else {
                        fprintf(trace, "%d", data[i]);
                        if (i+1<dataLength) fprintf(trace, ", ");
                }
        }
        if (!XMTDump) fprintf(trace, "\"");
        if (name) EndAttribute(trace, indent, XMTDump);
}
static void DumpBin128(FILE *trace, char *name, char *data, u32 indent, Bool XMTDump)
{
        u32 i;
        if (!name ||!data) return;
        StartAttribute(trace, name, indent, XMTDump);
        fprintf(trace, "0x");
        i=0;
        while (!data[i] && (i<16)) i++;
        if (i==16) {
                fprintf(trace, "00");
        } else {
                for (; i<16; i++) fprintf(trace, "%02X", (unsigned char) data[i]);
        }
        EndAttribute(trace, indent, XMTDump);
}
static void DumpDate(FILE *trace, char *name, char *data, u32 indent, Bool XMTDump)
{
        u32 i;
        if (!name ||!data) return;
        StartAttribute(trace, name, indent, XMTDump);
        fprintf(trace, "0x");
        for (i=0; i<5; i++) fprintf(trace, "%02X", (unsigned char) data[i]);
        EndAttribute(trace, indent, XMTDump);
}
void gf_ipmpx_dump_ByteArray(GF_IPMPX_ByteArray *_p, const char *attName, FILE *trace, u32 indent, Bool XMTDump)
{
        if (_p && _p->data) {
                if (XMTDump) {
                        StartElement(trace, attName ? attName : (char*)"ByteArray", indent, XMTDump);
                        indent++;
                        DumpData(trace, "array", _p->data, _p->length, indent, XMTDump);
                        indent--;
                        EndAttributes(trace, GF_TRUE, GF_FALSE);
                } else {
                        DumpData(trace, attName ? attName : "ByteArray", _p->data, _p->length, indent, GF_FALSE);
                }
        }
}
void gf_ipmpx_dump_AUTH(GF_IPMPX_Authentication *ipa, FILE *trace, u32 indent, Bool XMTDump)
{
        switch (ipa->tag) {
        case GF_IPMPX_AUTH_KeyDescr_Tag:
        {
                GF_IPMPX_AUTH_KeyDescriptor *p = (GF_IPMPX_AUTH_KeyDescriptor *)ipa;
                StartElement(trace, "IPMP_KeyDescriptor", indent, XMTDump);
                DumpData(trace, "keyBody", p->keyBody, p->keyBodyLength, indent+1, XMTDump);
                if (XMTDump) EndAttributes(trace, GF_TRUE, GF_FALSE);
                else EndElement(trace, "", indent, GF_FALSE);
        }
        break;
        case GF_IPMPX_AUTH_AlgorithmDescr_Tag:
        {
                GF_IPMPX_AUTH_AlgorithmDescriptor *p = (GF_IPMPX_AUTH_AlgorithmDescriptor *)ipa;
                StartElement(trace, "IPMP_AlgorithmDescriptor", indent, XMTDump);
                if (p->regAlgoID) {
                        DumpInt(trace, "regAlgoID", p->regAlgoID, indent+1, XMTDump);
                } else {
                        gf_ipmpx_dump_ByteArray(p->specAlgoID, "specAlgoID", trace, indent+1, XMTDump);
                }
                EndAttributes(trace, XMTDump, GF_TRUE);
                if (p->OpaqueData) gf_ipmpx_dump_ByteArray(p->OpaqueData, "OpaqueData", trace, indent+1, XMTDump);
                EndElement(trace, "IPMP_AlgorithmDescriptor", indent, XMTDump);
        }
        break;
        }
}
void gf_ipmpx_dump_BaseData(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
#if 0
        if (XMTDump) {
                StartElement(trace, "IPMP_BaseData", indent, XMTDump);
                DumpInt(trace, "dataID", _p->dataID, indent, 1);
                DumpInt(trace, "Version", _p->Version, indent, 1);
                EndLeafAttribute(trace, indent, XMTDump);
        } else {
                DumpInt(trace, "dataID", _p->dataID, indent, 0);
                DumpInt(trace, "Version", _p->Version, indent, 0);
        }
#endif
}
GF_Err gf_ipmpx_dump_OpaqueData(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_OpaqueData *p = (GF_IPMPX_OpaqueData *)_p;
        StartElement(trace, (p->tag==GF_IPMPX_RIGHTS_DATA_TAG) ? "IPMP_RightsData" : "IPMP_OpaqueData", indent, XMTDump);
        indent++;
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        gf_ipmpx_dump_ByteArray(p->opaqueData, (p->tag==GF_IPMPX_RIGHTS_DATA_TAG) ? "rightsInfo" : "opaqueData", trace, indent, XMTDump);
        indent--;
        EndElement(trace, (p->tag==GF_IPMPX_RIGHTS_DATA_TAG) ? "IPMP_RightsData" : "IPMP_OpaqueData", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_KeyData(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_KeyData*p = (GF_IPMPX_KeyData*)_p;
        StartElement(trace, "IPMP_KeyData", indent, XMTDump);
        indent++;
        DumpBool(trace, "hasStartDTS", (p->flags & 1) ? 1 : 0, indent, XMTDump);
        DumpBool(trace, "hasStartPacketID", (p->flags & 2) ? 1 : 0, indent, XMTDump);
        DumpBool(trace, "hasEndDTS", (p->flags & 4) ? 1 : 0, indent, XMTDump);
        DumpBool(trace, "hasEndPacketID", (p->flags & 8) ? 1 : 0, indent, XMTDump);
        if (p->flags & 1) DumpLargeInt(trace, "startDTS", p->startDTS, indent, XMTDump);
        if (p->flags & 2) DumpInt(trace, "startPacketID", p->startPacketID, indent, XMTDump);
        if (p->flags & 4) DumpLargeInt(trace, "expireDTS", p->expireDTS, indent, XMTDump);
        if (p->flags & 8) DumpInt(trace, "expirePacketID", p->expirePacketID, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        gf_ipmpx_dump_ByteArray(p->keyBody, "keyBody", trace, indent, XMTDump);
        gf_ipmpx_dump_ByteArray(p->OpaqueData, "OpaqueData", trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_KeyData", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_SecureContainer(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_SecureContainer*p = (GF_IPMPX_SecureContainer*)_p;
        StartElement(trace, "IPMP_SecureContainer", indent, XMTDump);
        indent++;
        DumpBool(trace, "isMACEncrypted", p->isMACEncrypted, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        if (p->encryptedData) gf_ipmpx_dump_ByteArray(p->encryptedData, "encryptedData", trace, indent, XMTDump);
        if (p->protectedMsg) gf_ipmpx_dump_data(p->protectedMsg, trace, indent, XMTDump);
        if (p->MAC) gf_ipmpx_dump_ByteArray(p->MAC, "MAC", trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_SecureContainer", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_InitAuthentication(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_InitAuthentication*p = (GF_IPMPX_InitAuthentication*)_p;
        StartElement(trace, "IPMP_InitAuthentication", indent, XMTDump);
        indent++;
        DumpInt(trace, "Context", p->Context, indent, XMTDump);
        DumpInt(trace, "AuthType", p->AuthType, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_InitAuthentication", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_TrustSecurityMetadata(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        u32 i, j;
        GF_IPMPX_TrustSecurityMetadata*p = (GF_IPMPX_TrustSecurityMetadata*)_p;
        StartElement(trace, "IPMP_TrustSecurityMetadata", indent, XMTDump);
        indent++;
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        StartList(trace, "trustedTools", indent, XMTDump);
        indent++;
        for (i=0; i<gf_list_count(p->TrustedTools); i++) {
                GF_IPMPX_TrustedTool *tt = (GF_IPMPX_TrustedTool *)gf_list_get(p->TrustedTools, i);
                StartElement(trace, "IPMP_TrustedTool", indent, XMTDump);
                indent++;
                DumpBin128(trace, "toolID", (char *)tt->toolID, indent, XMTDump);
                DumpDate(trace, "AuditDate", tt->AuditDate, indent, XMTDump);
                EndAttributes(trace, XMTDump, GF_TRUE);
                StartList(trace, "trustSpecifications", indent, XMTDump);
                indent++;
                for (j=0; j<gf_list_count(tt->trustSpecifications); j++) {
                        GF_IPMPX_TrustSpecification *ts = (GF_IPMPX_TrustSpecification *)gf_list_get(tt->trustSpecifications, j);
                        StartElement(trace, "IPMP_TrustSpecification", indent, XMTDump);
                        indent++;
                        DumpDate(trace, "startDate", ts->startDate, indent, XMTDump);
                        DumpInt(trace, "attackerProfile", ts->attackerProfile, indent, XMTDump);
                        DumpInt(trace, "trustedDuration", ts->trustedDuration, indent, XMTDump);
                        EndAttributes(trace, XMTDump, GF_TRUE);
                        if (ts->CCTrustMetadata) gf_ipmpx_dump_ByteArray(ts->CCTrustMetadata, "CCTrustMetadata", trace, indent, XMTDump);
                        indent--;
                        EndElement(trace, "IPMP_TrustSpecification", indent, XMTDump);
                }
                indent--;
                EndList(trace, "trustSpecifications", indent, XMTDump);
                indent--;
                EndElement(trace, "IPMP_TrustedTool", indent, XMTDump);
        }
        indent--;
        EndList(trace, "trustedTools", indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_TrustSecurityMetadata", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_MutualAuthentication(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        u32 i, count;
        GF_IPMPX_MutualAuthentication *p = (GF_IPMPX_MutualAuthentication*)_p;
        StartElement(trace, "IPMP_MutualAuthentication", indent, XMTDump);
        indent++;
        DumpBool(trace, "failedNegotiation", p->failedNegotiation, indent, XMTDump);
        if (gf_list_count(p->certificates)) DumpInt(trace, "certType", p->certType, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        StartList(trace, "candidateAlgorithms", indent, XMTDump);
        count = gf_list_count(p->candidateAlgorithms);
        indent++;
        for (i=0; i<count; i++) {
                GF_IPMPX_Authentication *ip_auth = (GF_IPMPX_Authentication *)gf_list_get(p->candidateAlgorithms, i);
                gf_ipmpx_dump_AUTH(ip_auth, trace, indent, XMTDump);
        }
        indent--;
        EndList(trace, "candidateAlgorithms", indent, XMTDump);
        StartList(trace, "agreedAlgorithms", indent, XMTDump);
        count = gf_list_count(p->agreedAlgorithms);
        indent++;
        for (i=0; i<count; i++) {
                GF_IPMPX_Authentication *ip_auth = (GF_IPMPX_Authentication *)gf_list_get(p->agreedAlgorithms, i);
                gf_ipmpx_dump_AUTH(ip_auth, trace, indent, XMTDump);
        }
        indent--;
        EndList(trace, "agreedAlgorithms", indent, XMTDump);
        if (p->AuthenticationData) gf_ipmpx_dump_ByteArray(p->AuthenticationData, "AuthenticationData", trace, indent, XMTDump);
        count = gf_list_count(p->certificates);
        if (count || p->opaque || p->publicKey) {
                
                if (count) {
                        StartList(trace, "certificates", indent, XMTDump);
                        for (i=0; i<count; i++) {
                                GF_IPMPX_ByteArray *ipd = (GF_IPMPX_ByteArray *)gf_list_get(p->certificates, i);
                                if (XMTDump) {
                                        gf_ipmpx_dump_ByteArray(ipd, NULL, trace, indent, XMTDump);
                                } else {
                                        StartAttribute(trace, "", indent, GF_FALSE);
                                        DumpData(trace, NULL, ipd->data, ipd->length, indent, GF_FALSE);
                                        if (i+1<count) fprintf(trace, ",");
                                        fprintf(trace, "\n");
                                }
                        }
                        EndList(trace, "certificates", indent, XMTDump);
                }
                
                else if (p->publicKey) {
                        gf_ipmpx_dump_AUTH((GF_IPMPX_Authentication *) p->publicKey, trace, indent, XMTDump);
                }
                
                else if (p->opaque) {
                        gf_ipmpx_dump_ByteArray(p->opaque, "opaque", trace, indent, XMTDump);
                }
                if (!XMTDump) StartAttribute(trace, "trustData", indent, GF_FALSE);
                else {
                        StartElement(trace, "trustData", indent, XMTDump);
                        EndAttributes(trace, XMTDump, GF_TRUE);
                }
                gf_ipmpx_dump_data((GF_IPMPX_Data *)p->trustData, trace, indent, XMTDump);
                if (XMTDump) EndElement(trace, "trustData", indent, XMTDump);
                gf_ipmpx_dump_ByteArray(p->authCodes, "authCodes", trace, indent, XMTDump);
        }
        indent--;
        EndElement(trace, "IPMP_MutualAuthentication", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_GetToolsResponse(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_GetToolsResponse*p = (GF_IPMPX_GetToolsResponse*)_p;
        StartElement(trace, "IPMP_GetToolsResponse", indent, XMTDump);
        indent++;
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        DumpDescList(p->ipmp_tools, trace, indent, "IPMP_Tools", XMTDump, GF_FALSE);
        indent--;
        EndElement(trace, "IPMP_GetToolsResponse", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_ParametricDescription(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        u32 i;
        GF_IPMPX_ParametricDescription*p = (GF_IPMPX_ParametricDescription*)_p;
        StartElement(trace, "IPMP_ParametricDescription", indent, XMTDump);
        indent++;
        DumpInt(trace, "majorVersion", p->majorVersion, indent, XMTDump);
        DumpInt(trace, "minorVersion", p->minorVersion, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        gf_ipmpx_dump_ByteArray(p->descriptionComment, "descriptionComment", trace, indent, XMTDump);
        StartList(trace, "descriptions", indent, XMTDump);
        indent++;
        for (i=0; i<gf_list_count(p->descriptions); i++) {
                GF_IPMPX_ParametricDescriptionItem *it = (GF_IPMPX_ParametricDescriptionItem *)gf_list_get(p->descriptions, i);
                StartElement(trace, "IPMP_ParametricDescriptionItem", indent, XMTDump);
                indent++;
                EndAttributes(trace, XMTDump, GF_TRUE);
                gf_ipmpx_dump_ByteArray(it->main_class, "class", trace, indent, XMTDump);
                gf_ipmpx_dump_ByteArray(it->subClass, "subClass", trace, indent, XMTDump);
                gf_ipmpx_dump_ByteArray(it->typeData, "typeData", trace, indent, XMTDump);
                gf_ipmpx_dump_ByteArray(it->type, "type", trace, indent, XMTDump);
                gf_ipmpx_dump_ByteArray(it->addedData, "addedData", trace, indent, XMTDump);
                indent--;
                EndElement(trace, "IPMP_ParametricDescriptionItem", indent, XMTDump);
        }
        indent--;
        EndList(trace, "descriptions", indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_ParametricDescription", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_ToolParamCapabilitiesQuery(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_ToolParamCapabilitiesQuery*p = (GF_IPMPX_ToolParamCapabilitiesQuery*)_p;
        StartElement(trace, "IPMP_ToolParamCapabilitiesQuery", indent, XMTDump);
        indent++;
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        if (!XMTDump) StartAttribute(trace, "description", indent, GF_FALSE);
        else {
                StartElement(trace, "description", indent, XMTDump);
                EndAttributes(trace, XMTDump, GF_TRUE);
        }
        gf_ipmpx_dump_data((GF_IPMPX_Data *) p->description, trace, indent, XMTDump);
        if (XMTDump) EndElement(trace, "description", indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_ToolParamCapabilitiesQuery", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_ToolParamCapabilitiesResponse(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_ToolParamCapabilitiesResponse*p = (GF_IPMPX_ToolParamCapabilitiesResponse*)_p;
        StartElement(trace, "IPMP_ToolParamCapabilitiesResponse", indent, XMTDump);
        indent++;
        DumpBool(trace, "capabilitiesSupported", p->capabilitiesSupported, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_ToolParamCapabilitiesResponse", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_ConnectTool(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_ConnectTool*p = (GF_IPMPX_ConnectTool*)_p;
        StartElement(trace, "IPMP_ConnectTool", indent, XMTDump);
        indent++;
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        if (!XMTDump) StartAttribute(trace, "toolDescriptor", indent, GF_FALSE);
        else {
                StartElement(trace, "toolDescriptor", indent, XMTDump);
                EndAttributes(trace, XMTDump, GF_TRUE);
        }
        gf_odf_dump_desc((GF_Descriptor *)p->toolDescriptor, trace, indent, XMTDump);
        if (XMTDump) EndElement(trace, "toolDescriptor", indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_ConnectTool", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_DisconnectTool(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_DisconnectTool*p = (GF_IPMPX_DisconnectTool*)_p;
        StartElement(trace, "IPMP_DisconnectTool", indent, XMTDump);
        indent++;
        DumpInt(trace, "IPMP_ToolContextID", p->IPMP_ToolContextID, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_DisconnectTool", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_GetToolContext(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_GetToolContext*p = (GF_IPMPX_GetToolContext*)_p;
        StartElement(trace, "IPMP_GetToolContext", indent, XMTDump);
        indent++;
        DumpInt(trace, "scope", p->scope, indent, XMTDump);
        DumpInt(trace, "IPMP_DescriptorIDEx", p->IPMP_DescriptorIDEx, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_GetToolContext", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_GetToolContextResponse(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_GetToolContextResponse*p = (GF_IPMPX_GetToolContextResponse*)_p;
        StartElement(trace, "IPMP_GetToolContextResponse", indent, XMTDump);
        indent++;
        DumpInt(trace, "OD_ID", p->OD_ID, indent, XMTDump);
        DumpInt(trace, "ESD_ID", p->ESD_ID, indent, XMTDump);
        DumpInt(trace, "IPMP_ToolContextID", p->IPMP_ToolContextID, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_GetToolContextResponse", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_AddToolNotificationListener(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        u32 i;
        GF_IPMPX_AddToolNotificationListener*p = (GF_IPMPX_AddToolNotificationListener*)_p;
        StartElement(trace, "IPMP_AddToolNotificationListener", indent, XMTDump);
        indent++;
        DumpInt(trace, "scope", p->scope, indent, XMTDump);
        StartAttribute(trace, "eventType", indent, XMTDump);
        if (!XMTDump) fprintf(trace, "\"");
        for (i=0; i<p->eventTypeCount; i++) {
                if (XMTDump) {
                        fprintf(trace, "\'%d\'", p->eventType[i]);
                        if (i+1<p->eventTypeCount) fprintf(trace, " ");
                } else {
                        fprintf(trace, "%d", p->eventType[i]);
                        if (i+1<p->eventTypeCount) fprintf(trace, ",");
                }
        }
        if (!XMTDump) fprintf(trace, "\"");
        EndAttribute(trace, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_AddToolNotificationListener", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_RemoveToolNotificationListener(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        u32 i;
        GF_IPMPX_RemoveToolNotificationListener*p = (GF_IPMPX_RemoveToolNotificationListener*)_p;
        StartElement(trace, "IPMP_RemoveToolNotificationListener", indent, XMTDump);
        indent++;
        StartAttribute(trace, "eventType", indent, XMTDump);
        if (!XMTDump) fprintf(trace, "\"");
        for (i=0; i<p->eventTypeCount; i++) {
                if (XMTDump) {
                        fprintf(trace, "\'%d\'", p->eventType[i]);
                        if (i+1<p->eventTypeCount) fprintf(trace, " ");
                } else {
                        fprintf(trace, "%d", p->eventType[i]);
                        if (i+1<p->eventTypeCount) fprintf(trace, ",");
                }
        }
        if (!XMTDump) fprintf(trace, "\"");
        EndAttribute(trace, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_RemoveToolNotificationListener", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_NotifyToolEvent(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_NotifyToolEvent*p = (GF_IPMPX_NotifyToolEvent*)_p;
        StartElement(trace, "IPMP_NotifyToolEvent", indent, XMTDump);
        indent++;
        DumpInt(trace, "OD_ID", p->OD_ID, indent, XMTDump);
        DumpInt(trace, "ESD_ID", p->ESD_ID, indent, XMTDump);
        DumpInt(trace, "IPMP_ToolContextID", p->IPMP_ToolContextID, indent, XMTDump);
        DumpInt(trace, "eventType", p->eventType, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_NotifyToolEvent", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_CanProcess(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_CanProcess*p = (GF_IPMPX_CanProcess*)_p;
        StartElement(trace, "IPMP_CanProcess", indent, XMTDump);
        indent++;
        DumpBool(trace, "canProcess", p->canProcess, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_CanProcess", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_ToolAPI_Config(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_ToolAPI_Config*p = (GF_IPMPX_ToolAPI_Config*)_p;
        StartElement(trace, "IPMP_ToolAPI_Config", indent, XMTDump);
        indent++;
        DumpInt(trace, "Instantiation_API_ID", p->Instantiation_API_ID, indent, XMTDump);
        DumpInt(trace, "Messaging_API_ID", p->Messaging_API_ID, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        gf_ipmpx_dump_ByteArray(p->opaqueData, "opaqueData", trace, indent, XMTDump);
        indent--;
        EndElement(trace, "IPMP_ToolAPI_Config", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_WatermarkingInit(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_WatermarkingInit*p = (GF_IPMPX_WatermarkingInit*)_p;
        StartElement(trace, (char*)  ( (_p->tag==GF_IPMPX_AUDIO_WM_INIT_TAG) ? "IPMP_AudioWatermarkingInit" : "IPMP_VideoWatermarkingInit"), indent, XMTDump);
        indent++;
        DumpInt(trace, "inputFormat", p->inputFormat, indent, XMTDump);
        DumpInt(trace, "requiredOp", p->requiredOp, indent, XMTDump);
        if (p->inputFormat==0x01) {
                if (_p->tag==GF_IPMPX_AUDIO_WM_INIT_TAG) {
                        DumpInt(trace, "nChannels", p->nChannels, indent, XMTDump);
                        DumpInt(trace, "bitPerSample", p->bitPerSample, indent, XMTDump);
                        DumpInt(trace, "frequency", p->frequency, indent, XMTDump);
                } else {
                        DumpInt(trace, "frame_horizontal_size", p->frame_horizontal_size, indent, XMTDump);
                        DumpInt(trace, "frame_vertical_size", p->frame_vertical_size, indent, XMTDump);
                        DumpInt(trace, "chroma_format", p->chroma_format, indent, XMTDump);
                }
        }
        switch (p->requiredOp) {
        case GF_IPMPX_WM_INSERT:
        case GF_IPMPX_WM_REMARK:
                DumpData(trace, "wmPayload", p->wmPayload, p->wmPayloadLen, indent, XMTDump);
                break;
        case GF_IPMPX_WM_EXTRACT:
        case GF_IPMPX_WM_DETECT_COMPRESSION:
                DumpInt(trace, "wmRecipientId", p->wmRecipientId, indent, XMTDump);
                break;
        }
        if (p->opaqueData) DumpData(trace, "opaqueData", p->opaqueData, p->opaqueDataSize, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, (char*) ( (_p->tag==GF_IPMPX_AUDIO_WM_INIT_TAG) ? "IPMP_AudioWatermarkingInit" : "IPMP_VideoWatermarkingInit"), indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_SendWatermark(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_SendWatermark*p = (GF_IPMPX_SendWatermark*)_p;
        StartElement(trace, (char*) ((_p->tag==GF_IPMPX_AUDIO_WM_SEND_TAG) ? "IPMP_SendAudioWatermark" : "IPMP_SendVideoWatermark"), indent, XMTDump);
        indent++;
        DumpInt(trace, "wmStatus", p->wm_status, indent, XMTDump);
        DumpInt(trace, "compression_status", p->compression_status, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        if (p->wm_status==GF_IPMPX_WM_PAYLOAD) gf_ipmpx_dump_ByteArray(p->payload, "payload", trace, indent, XMTDump);
        if (p->opaqueData) gf_ipmpx_dump_ByteArray(p->opaqueData, "opaqueData", trace, indent, XMTDump);
        indent--;
        EndElement(trace, (char*) ( (_p->tag==GF_IPMPX_AUDIO_WM_SEND_TAG) ? "IPMP_SendAudioWatermark" : "IPMP_SendVideoWatermark"), indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_SelectiveDecryptionInit(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        u32 i, count;
        GF_IPMPX_SelectiveDecryptionInit*p = (GF_IPMPX_SelectiveDecryptionInit*)_p;
        StartElement(trace, "IPMP_SelectiveDecryptionInit", indent, XMTDump);
        indent++;
        DumpInt(trace, "mediaTypeExtension", p->mediaTypeExtension, indent, XMTDump);
        DumpInt(trace, "mediaTypeIndication", p->mediaTypeIndication, indent, XMTDump);
        DumpInt(trace, "profileLevelIndication", p->profileLevelIndication, indent, XMTDump);
        DumpInt(trace, "compliance", p->compliance, indent, XMTDump);
        if (p->RLE_Data) DumpData_16(trace, "RLE_Data", p->RLE_Data, p->RLE_DataLength, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        count = gf_list_count(p->SelEncBuffer);
        if (count) {
                StartList(trace, "SelectiveBuffers", indent, XMTDump);
                indent++;
                for (i=0; i<count; i++) {
                        GF_IPMPX_SelEncBuffer *sb = (GF_IPMPX_SelEncBuffer *)gf_list_get(p->SelEncBuffer, i);
                        StartElement(trace, "IPMP_SelectiveBuffer", indent, XMTDump);
                        indent++;
                        DumpBin128(trace, "cipher_Id", (char*)sb->cipher_Id, indent, XMTDump);
                        DumpInt(trace, "syncBoundary", sb->syncBoundary, indent, XMTDump);
                        if (!sb->Stream_Cipher_Specific_Init_Info) {
                                DumpInt(trace, "mode", sb->mode, indent, XMTDump);
                                DumpInt(trace, "blockSize", sb->blockSize, indent, XMTDump);
                                DumpInt(trace, "keySize", sb->keySize, indent, XMTDump);
                        }
                        EndAttributes(trace, XMTDump, GF_TRUE);
                        if (sb->Stream_Cipher_Specific_Init_Info)
                                gf_ipmpx_dump_ByteArray(sb->Stream_Cipher_Specific_Init_Info, "StreamCipher", trace, indent, XMTDump);
                        indent--;
                        EndElement(trace, "IPMP_SelectiveBuffer", indent, XMTDump);
                }
                indent--;
                EndList(trace, "SelectiveBuffers", indent, XMTDump);
        }
        count = gf_list_count(p->SelEncFields);
        if (!p->RLE_Data && count) {
                StartList(trace, "SelectiveFields", indent, XMTDump);
                indent++;
                for (i=0; i<count; i++) {
                        GF_IPMPX_SelEncField *sf = (GF_IPMPX_SelEncField *)gf_list_get(p->SelEncFields, i);
                        StartElement(trace, "IPMP_SelectiveField", indent, XMTDump);
                        indent++;
                        DumpInt(trace, "field_Id", sf->field_Id, indent, XMTDump);
                        DumpInt(trace, "field_Scope", sf->field_Scope, indent, XMTDump);
                        DumpInt(trace, "buf", sf->buf, indent, XMTDump);
                        if (sf->mappingTable) DumpData_16(trace, "mappingTable", sf->mappingTable, sf->mappingTableSize, indent, XMTDump);
                        EndAttributes(trace, XMTDump, GF_TRUE);
                        if (sf->shuffleSpecificInfo)
                                gf_ipmpx_dump_ByteArray(sf->shuffleSpecificInfo, "shuffleSpecificInfo", trace, indent, XMTDump);
                        indent--;
                        EndElement(trace, "IPMP_SelectiveField", indent, XMTDump);
                }
                indent--;
                EndList(trace, "SelectiveFields", indent, XMTDump);
        }
        indent--;
        EndElement(trace, "IPMP_SelectiveDecryptionInit", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_ISMACryp(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        GF_IPMPX_ISMACryp*p = (GF_IPMPX_ISMACryp*)_p;
        StartElement(trace, "ISMACryp_Data", indent, XMTDump);
        indent++;
        DumpInt(trace, "crypto_suite", p->cryptoSuite, indent, XMTDump);
        DumpInt(trace, "IV_length", p->IV_length, indent, XMTDump);
        DumpBool(trace, "selective_encryption", p->use_selective_encryption, indent, XMTDump);
        DumpInt(trace, "key_indicator_length", p->key_indicator_length, indent, XMTDump);
        EndAttributes(trace, XMTDump, GF_TRUE);
        gf_ipmpx_dump_BaseData(_p, trace, indent, XMTDump);
        indent--;
        EndElement(trace, "ISMACryp_Data", indent, XMTDump);
        return GF_OK;
}
GF_Err gf_ipmpx_dump_data(GF_IPMPX_Data *_p, FILE *trace, u32 indent, Bool XMTDump)
{
        switch (_p->tag) {
        case GF_IPMPX_RIGHTS_DATA_TAG:
        case GF_IPMPX_OPAQUE_DATA_TAG:
                return gf_ipmpx_dump_OpaqueData(_p, trace, indent, XMTDump);
        case GF_IPMPX_KEY_DATA_TAG:
                return gf_ipmpx_dump_KeyData(_p, trace, indent, XMTDump);
        case GF_IPMPX_SECURE_CONTAINER_TAG:
                return gf_ipmpx_dump_SecureContainer(_p, trace, indent, XMTDump);
        case GF_IPMPX_INIT_AUTHENTICATION_TAG:
                return gf_ipmpx_dump_InitAuthentication(_p, trace, indent, XMTDump);
        case GF_IPMPX_TRUST_SECURITY_METADATA_TAG:
                return gf_ipmpx_dump_TrustSecurityMetadata(_p, trace, indent, XMTDump);
        case GF_IPMPX_MUTUAL_AUTHENTICATION_TAG:
                return gf_ipmpx_dump_MutualAuthentication(_p, trace, indent, XMTDump);
        case GF_IPMPX_GET_TOOLS_RESPONSE_TAG:
                return gf_ipmpx_dump_GetToolsResponse(_p, trace, indent, XMTDump);
        case GF_IPMPX_PARAMETRIC_DESCRIPTION_TAG:
                return gf_ipmpx_dump_ParametricDescription(_p, trace, indent, XMTDump);
        case GF_IPMPX_PARAMETRIC_CAPS_QUERY_TAG:
                return gf_ipmpx_dump_ToolParamCapabilitiesQuery(_p, trace, indent, XMTDump);
        case GF_IPMPX_PARAMETRIC_CAPS_RESPONSE_TAG:
                return gf_ipmpx_dump_ToolParamCapabilitiesResponse(_p, trace, indent, XMTDump);
        case GF_IPMPX_GET_TOOL_CONTEXT_TAG:
                return gf_ipmpx_dump_GetToolContext(_p, trace, indent, XMTDump);
        case GF_IPMPX_GET_TOOL_CONTEXT_RESPONSE_TAG:
                return gf_ipmpx_dump_GetToolContextResponse(_p, trace, indent, XMTDump);
        case GF_IPMPX_CONNECT_TOOL_TAG:
                return gf_ipmpx_dump_ConnectTool(_p, trace, indent, XMTDump);
        case GF_IPMPX_DISCONNECT_TOOL_TAG:
                return gf_ipmpx_dump_DisconnectTool(_p, trace, indent, XMTDump);
        case GF_IPMPX_ADD_TOOL_LISTENER_TAG:
                return gf_ipmpx_dump_AddToolNotificationListener(_p, trace, indent, XMTDump);
        case GF_IPMPX_REMOVE_TOOL_LISTENER_TAG:
                return gf_ipmpx_dump_RemoveToolNotificationListener(_p, trace, indent, XMTDump);
        case GF_IPMPX_NOTIFY_TOOL_EVENT_TAG:
                return gf_ipmpx_dump_NotifyToolEvent(_p, trace, indent, XMTDump);
        case GF_IPMPX_CAN_PROCESS_TAG:
                return gf_ipmpx_dump_CanProcess(_p, trace, indent, XMTDump);
        case GF_IPMPX_ISMACRYP_TAG:
                return gf_ipmpx_dump_ISMACryp(_p, trace, indent, XMTDump);
        case GF_IPMPX_TOOL_API_CONFIG_TAG:
                return gf_ipmpx_dump_ToolAPI_Config(_p, trace, indent, XMTDump);
        case GF_IPMPX_AUDIO_WM_INIT_TAG:
        case GF_IPMPX_VIDEO_WM_INIT_TAG:
                return gf_ipmpx_dump_WatermarkingInit(_p, trace, indent, XMTDump);
        case GF_IPMPX_AUDIO_WM_SEND_TAG:
        case GF_IPMPX_VIDEO_WM_SEND_TAG:
                return gf_ipmpx_dump_SendWatermark(_p, trace, indent, XMTDump);
        case GF_IPMPX_SEL_DEC_INIT_TAG:
                return gf_ipmpx_dump_SelectiveDecryptionInit(_p, trace, indent, XMTDump);
        
        case GF_IPMPX_GET_TOOLS_TAG:
                return GF_BAD_PARAM;
        default:
                return GF_BAD_PARAM;
        }
}
#endif