Difference between revisions of "Cloud JSON Protocol"
(Created) |
m (→Change) |
||
Line 3: | Line 3: | ||
The protocol is based on JSON only. | The protocol is based on JSON only. | ||
− | === Commands and answers === | + | ===Commands and answers=== |
All exchanges are in the form : <code>{ "command" : ''data...'' }</code>. | All exchanges are in the form : <code>{ "command" : ''data...'' }</code>. | ||
Line 10: | Line 10: | ||
Answers will start with either : | Answers will start with either : | ||
− | * When the command is requesting some value (<code>get</code> or <code>change</code> for instance), the answer will start with the command containing the requested object. | + | *When the command is requesting some value (<code>get</code> or <code>change</code> for instance), the answer will start with the command containing the requested object. |
− | * <code>"OK"</code> when the command is doing an action, with a string property containing the command. For instance: <code>{"OK":"set"}</code> | + | *<code>"OK"</code> when the command is doing an action, with a string property containing the command. For instance: <code>{"OK":"set"}</code> |
− | * <code>"ERROR"</code> if the command failed, with a string property containing the command. For instance: <code>{"ERROR":"load"}</code> | + | *<code>"ERROR"</code> if the command failed, with a string property containing the command. For instance: <code>{"ERROR":"load"}</code> |
− | ==== Basic commands ==== | + | ====Basic commands==== |
− | ===== Get ===== | + | =====Get===== |
<code>{ "get" : `object` }</code> | <code>{ "get" : `object` }</code> | ||
Line 25: | Line 25: | ||
For instance, <code><nowiki>{"get":{"status":null}}</nowiki></code> returns <code><nowiki>{"get":{"status":{"preset_changed":false,"license_valid":true,"version":"1.1.19"}}}</nowiki></code> | For instance, <code><nowiki>{"get":{"status":null}}</nowiki></code> returns <code><nowiki>{"get":{"status":{"preset_changed":false,"license_valid":true,"version":"1.1.19"}}}</nowiki></code> | ||
− | ===== Change ===== | + | =====Change===== |
<code>{ "change" : null }</code> | <code>{ "change" : null }</code> | ||
Line 32: | Line 32: | ||
For instance : <code>{"change":null}</code> returns <code><nowiki>{"change":{"vu":{"in":{"vu":{"pk":[-9.467268943786621,-10.68277359008789],"vu":[-20.523719787597656,-21.058277130126953]}}}}}</nowiki></code> | For instance : <code>{"change":null}</code> returns <code><nowiki>{"change":{"vu":{"in":{"vu":{"pk":[-9.467268943786621,-10.68277359008789],"vu":[-20.523719787597656,-21.058277130126953]}}}}}</nowiki></code> | ||
− | ===== Set ===== | + | '''''Note''': For X1.CL≤1.3.7, IMPACT.CL≤1.1.7,BIGVOICE.CL≤0.9.7, the state is reset also for filtered out objects. So avoid alternating objects filter between calls, or you will miss some changes'' |
+ | |||
+ | =====Set===== | ||
<code>{ "set" : `object` }</code> | <code>{ "set" : `object` }</code> | ||
Line 39: | Line 41: | ||
For instance: <code><nowiki>{"set":{"settings":{"general":{"operate":false}}}}</nowiki></code> returns <code>{"OK":"set"}</code> | For instance: <code><nowiki>{"set":{"settings":{"general":{"operate":false}}}}</nowiki></code> returns <code>{"OK":"set"}</code> | ||
− | ==== Commands for undo/redo ==== | + | ====Commands for undo/redo==== |
If the process has undo/redo, you can use those. | If the process has undo/redo, you can use those. | ||
− | ===== Undo ===== | + | =====Undo===== |
<code>{ "undo" : `count` }</code> | <code>{ "undo" : `count` }</code> | ||
Undo last(s) <code>count</code> preset change | Undo last(s) <code>count</code> preset change | ||
− | ===== Redo ===== | + | =====Redo===== |
<code>{ "redo" : `count` }</code> | <code>{ "redo" : `count` }</code> | ||
Redo last(s) <code>count</code> preset change | Redo last(s) <code>count</code> preset change | ||
− | ==== Commands for presets ==== | + | ====Commands for presets==== |
If the process has presets, you can use those. | If the process has presets, you can use those. | ||
− | ===== Getting information ===== | + | =====Getting information===== |
The <code>"status"</code> object has an extra <code>"preset_changed"</code> boolean value. | The <code>"status"</code> object has an extra <code>"preset_changed"</code> boolean value. | ||
There are also : | There are also : | ||
− | * <code>"presetinfo"</code> object : contains the name, factory name, and dates of the onair preset. | + | *<code>"presetinfo"</code> object : contains the name, factory name, and dates of the onair preset. |
− | * <code>"saved"</code> object : contains the on air preset's saved content (without current changes) | + | *<code>"saved"</code> object : contains the on air preset's saved content (without current changes) |
− | * <code>"factory"</code> object: contains the on air preset's factory preset | + | *<code>"factory"</code> object: contains the on air preset's factory preset |
− | * <code>"presetlist"</code> array of <code>presetinfo</code> object for all presets | + | *<code>"presetlist"</code> array of <code>presetinfo</code> object for all presets |
− | * <code>"factorylist"</code> array of string with factory preset names | + | *<code>"factorylist"</code> array of string with factory preset names |
− | ===== Load ===== | + | =====Load===== |
<code>{ "load" : "`presetname`" }</code> | <code>{ "load" : "`presetname`" }</code> | ||
Loads the preset with this name | Loads the preset with this name | ||
− | ===== Save ===== | + | =====Save===== |
<code>{ "save" : "`presetname`" }</code> | <code>{ "save" : "`presetname`" }</code> | ||
Saves the preset. If NULL is given, save on air preset. | Saves the preset. If NULL is given, save on air preset. | ||
− | ===== Delete ===== | + | =====Delete===== |
<code>{ "delete" : "`presetname`" }</code> | <code>{ "delete" : "`presetname`" }</code> | ||
Deletes the preset. Can also be an array of preset names. | Deletes the preset. Can also be an array of preset names. | ||
− | ===== Factoryload ===== | + | =====Factoryload===== |
<code>{ "factoryload" : "`presetname`" }</code> | <code>{ "factoryload" : "`presetname`" }</code> | ||
Creates a preset from factory and loads it. | Creates a preset from factory and loads it. | ||
− | ===== Rename ===== | + | =====Rename===== |
<code>{ "rename" : { "preset" : "`presetname`", "name": "`newname`" } }</code> | <code>{ "rename" : { "preset" : "`presetname`", "name": "`newname`" } }</code> | ||
Renames a preset. | Renames a preset. | ||
− | ===== Import ===== | + | =====Import===== |
<code>{ "import" : { "preset" : "`presetname`", "content": `presetcontent` } }</code> | <code>{ "import" : { "preset" : "`presetname`", "content": `presetcontent` } }</code> | ||
Imports a preset. | Imports a preset. | ||
− | ===== Export ===== | + | =====Export===== |
<code>{ "export" : "`presetname`" }</code> | <code>{ "export" : "`presetname`" }</code> | ||
Exports a preset : get preset's content, so it can be imported later. | Exports a preset : get preset's content, so it can be imported later. | ||
− | ===== New ===== | + | =====New===== |
<code>{ "new" : { "name": "`presetname`", "factory": "`presetname`" } }</code> | <code>{ "new" : { "name": "`presetname`", "factory": "`presetname`" } }</code> | ||
Creates a new preset from a factory. Can use array for multiple. | Creates a new preset from a factory. Can use array for multiple. | ||
− | ==== Commands for extensions ==== | + | ====Commands for extensions==== |
Some process may have some extensions. | Some process may have some extensions. | ||
Line 113: | Line 115: | ||
NOTE: currently, undo/redo and presets does not work on extensions, you can only use basic commands (set,get,change). | NOTE: currently, undo/redo and presets does not work on extensions, you can only use basic commands (set,get,change). | ||
− | === Accessing JSON from HTTP server === | + | ===Accessing JSON from HTTP server=== |
When there is an HTTP server, you can access the JSON protocol in <code>/json</code>. | When there is an HTTP server, you can access the JSON protocol in <code>/json</code>. | ||
There are multiple ways to access a command and an object : | There are multiple ways to access a command and an object : | ||
− | * Using the parameters in get/post/put, where the parameter name is the command <code>wget -O- --post-data 'load="Jazz"' <nowiki>http://localhost:8080/json</nowiki></code> | + | *Using the parameters in get/post/put, where the parameter name is the command <code>wget -O- --post-data 'load="Jazz"' <nowiki>http://localhost:8080/json</nowiki></code> |
− | * Using the body as direct JSON request <code><nowiki>echo '{"get":{"presetlist":null}}' | http POST localhost:8080/json</nowiki></code> | + | *Using the body as direct JSON request <code><nowiki>echo '{"get":{"presetlist":null}}' | http POST localhost:8080/json</nowiki></code> |
− | * Using the path to construct a JSON request <code>http localhost:8080/json/get/presetlist</code> | + | *Using the path to construct a JSON request <code>http localhost:8080/json/get/presetlist</code> |
− | * To get all JSON get/set possibilities <code>http localhost:8080/json/get</code> | + | *To get all JSON get/set possibilities <code>http localhost:8080/json/get</code> |
The possible commands are: | The possible commands are: | ||
− | * <code>get</code> or <code>set</code> with a full path, and value for set or <code>null</code> for get | + | *<code>get</code> or <code>set</code> with a full path, and value for set or <code>null</code> for get |
− | * <code>load</code>, <code>factoryload</code> or save with the preset name | + | *<code>load</code>, <code>factoryload</code> or save with the preset name |
− | * <code>delete</code> with the preset name to delete <code>.../json/delete/presetname</code> | + | *<code>delete</code> with the preset name to delete <code>.../json/delete/presetname</code> |
− | * <code>new</code> with the factory preset name to create a new preset <code>.../json/new/factoryname</code> | + | *<code>new</code> with the factory preset name to create a new preset <code>.../json/new/factoryname</code> |
− | * <code>rename</code> with from preset name then to preset name <code>.../json/rename/from/to</code> | + | *<code>rename</code> with from preset name then to preset name <code>.../json/rename/from/to</code> |
− | * <code>export</code> with from preset name <code>.../json/export/presetname</code> | + | *<code>export</code> with from preset name <code>.../json/export/presetname</code> |
− | * <code>undo</code>/<code>redo</code> with optional count <code>.../json/undo/2</code> | + | *<code>undo</code>/<code>redo</code> with optional count <code>.../json/undo/2</code> |
Here are some examples : | Here are some examples : | ||
− | * Set <code><nowiki>http://localhost:8080/json/set/preset/agc/attack/15</nowiki></code> or <code><nowiki>http://localhost:8080/json?set={</nowiki>"preset":{"agc":{"attack":15}}}</code> | + | *Set <code><nowiki>http://localhost:8080/json/set/preset/agc/attack/15</nowiki></code> or <code><nowiki>http://localhost:8080/json?set={</nowiki><nowiki>"preset":{"agc":{"attack":15}}}</nowiki></code> |
− | * Get <code><nowiki>http://localhost:8080/json/get/preset/agc</nowiki></code> or <code><nowiki>http://localhost:8080/json?get={</nowiki>"preset":{"agc":null}}</code> | + | *Get <code><nowiki>http://localhost:8080/json/get/preset/agc</nowiki></code> or <code><nowiki>http://localhost:8080/json?get={</nowiki><nowiki>"preset":{"agc":null}}</nowiki></code> |
<br /> | <br /> |
Revision as of 10:38, 3 November 2023
This is the communication protocol used in all .CL libraries, and in some standalone products.
The protocol is based on JSON only.
Commands and answers
All exchanges are in the form : { "command" : data... }
.
The process/library is passive : it only answers when something is asked.
Answers will start with either :
- When the command is requesting some value (
get
orchange
for instance), the answer will start with the command containing the requested object. "OK"
when the command is doing an action, with a string property containing the command. For instance:{"OK":"set"}
"ERROR"
if the command failed, with a string property containing the command. For instance:{"ERROR":"load"}
Basic commands
Get
{ "get" : `object` }
Get values. If object
is NULL, get all parameters, and so show the possibilities.
Otherwise, return the requested object.
For instance, {"get":{"status":null}}
returns {"get":{"status":{"preset_changed":false,"license_valid":true,"version":"1.1.19"}}}
Change
{ "change" : null }
Get all changes since last request from this port. This behaves like "get", but only providing changes. Each call reset the state for this connection to current.
For instance : {"change":null}
returns {"change":{"vu":{"in":{"vu":{"pk":[-9.467268943786621,-10.68277359008789],"vu":[-20.523719787597656,-21.058277130126953]}}}}}
Note: For X1.CL≤1.3.7, IMPACT.CL≤1.1.7,BIGVOICE.CL≤0.9.7, the state is reset also for filtered out objects. So avoid alternating objects filter between calls, or you will miss some changes
Set
{ "set" : `object` }
Set values. object
can be any subpart, only those will be changed.
For instance: {"set":{"settings":{"general":{"operate":false}}}}
returns {"OK":"set"}
Commands for undo/redo
If the process has undo/redo, you can use those.
Undo
{ "undo" : `count` }
Undo last(s) count
preset change
Redo
{ "redo" : `count` }
Redo last(s) count
preset change
Commands for presets
If the process has presets, you can use those.
Getting information
The "status"
object has an extra "preset_changed"
boolean value.
There are also :
"presetinfo"
object : contains the name, factory name, and dates of the onair preset."saved"
object : contains the on air preset's saved content (without current changes)"factory"
object: contains the on air preset's factory preset"presetlist"
array ofpresetinfo
object for all presets"factorylist"
array of string with factory preset names
Load
{ "load" : "`presetname`" }
Loads the preset with this name
Save
{ "save" : "`presetname`" }
Saves the preset. If NULL is given, save on air preset.
Delete
{ "delete" : "`presetname`" }
Deletes the preset. Can also be an array of preset names.
Factoryload
{ "factoryload" : "`presetname`" }
Creates a preset from factory and loads it.
Rename
{ "rename" : { "preset" : "`presetname`", "name": "`newname`" } }
Renames a preset.
Import
{ "import" : { "preset" : "`presetname`", "content": `presetcontent` } }
Imports a preset.
Export
{ "export" : "`presetname`" }
Exports a preset : get preset's content, so it can be imported later.
New
{ "new" : { "name": "`presetname`", "factory": "`presetname`" } }
Creates a new preset from a factory. Can use array for multiple.
Commands for extensions
Some process may have some extensions.
In this case, each extension provides a root object with its name, and then follow the same protocol.
NOTE: currently, undo/redo and presets does not work on extensions, you can only use basic commands (set,get,change).
Accessing JSON from HTTP server
When there is an HTTP server, you can access the JSON protocol in /json
.
There are multiple ways to access a command and an object :
- Using the parameters in get/post/put, where the parameter name is the command
wget -O- --post-data 'load="Jazz"' http://localhost:8080/json
- Using the body as direct JSON request
echo '{"get":{"presetlist":null}}' | http POST localhost:8080/json
- Using the path to construct a JSON request
http localhost:8080/json/get/presetlist
- To get all JSON get/set possibilities
http localhost:8080/json/get
The possible commands are:
get
orset
with a full path, and value for set ornull
for getload
,factoryload
or save with the preset namedelete
with the preset name to delete.../json/delete/presetname
new
with the factory preset name to create a new preset.../json/new/factoryname
rename
with from preset name then to preset name.../json/rename/from/to
export
with from preset name.../json/export/presetname
undo
/redo
with optional count.../json/undo/2
Here are some examples :
- Set
http://localhost:8080/json/set/preset/agc/attack/15
orhttp://localhost:8080/json?set={"preset":{"agc":{"attack":15}}}
- Get
http://localhost:8080/json/get/preset/agc
orhttp://localhost:8080/json?get={"preset":{"agc":null}}