Note: The information on this page is for reference only, it might not work with your particular CasparCG Flash-template.
In the old days, CasparCG supported Flash-based templates that used a XML-based schema for data interchange.
For backwards-compatiblity, the option client.gddPlayoutOptions.dataformat: "json" | "caspar-xml"
is provided as a way for playout clients to support the old Flash-based templates.
Here is an example of the normal JSON-data and its XML equivalent:
JSON data:
{
"f0": "This is the first line",
"f1": "second line"
}
CasparCG XML data:
<templateData>
<componentData id="f0"><data id="text" value="This is the first line" /></componentData>
<componentData id="f1"><data id="text" value="second line" /></componentData>
</templateData>
Here is a bare-bones example implementation for the XML conversion, in javascript.
function parametersToCasparXML(json, basePath) {
basePath = basePath || ''
let xml = ''
for (const [key, value] of Object.entries(json)) {
const path = (basePath ? basePath + '.' : '') + key
if (typeof value === 'object') {
xml += parametersToCasparXML(value, path)
} else {
xml += `<componentData id="${path}"><data id="text" value="${escapeStringForXML(value)}" /></componentData>\n`
}
}
if (!basePath) {
return `<templateData>\n${xml}</templateData>`
} else {
return xml
}
}
function escapeStringForXML(unsafe) {
if (!unsafe) return ''
return `${unsafe}`
.replace(/&/g, '&')
.replace(/</g, '<')
.replace(/>/g, '>')
.replace(/"/g, '"')
.replace(/'/g, ''')
}