<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wk.sound4.biz/index.php?action=history&amp;feed=atom&amp;title=Cloud_JSON_Protocol</id>
	<title>Cloud JSON Protocol - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wk.sound4.biz/index.php?action=history&amp;feed=atom&amp;title=Cloud_JSON_Protocol"/>
	<link rel="alternate" type="text/html" href="https://wk.sound4.biz/index.php?title=Cloud_JSON_Protocol&amp;action=history"/>
	<updated>2026-05-05T15:06:53Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.33.1</generator>
	<entry>
		<id>https://wk.sound4.biz/index.php?title=Cloud_JSON_Protocol&amp;diff=1038&amp;oldid=prev</id>
		<title>Camille at 10:43, 14 February 2024</title>
		<link rel="alternate" type="text/html" href="https://wk.sound4.biz/index.php?title=Cloud_JSON_Protocol&amp;diff=1038&amp;oldid=prev"/>
		<updated>2024-02-14T10:43:11Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 10:43, 14 February 2024&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l141&quot; &gt;Line 141:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 141:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;br /&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;br /&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt; &lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[Category:Cloud]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Camille</name></author>
		
	</entry>
	<entry>
		<id>https://wk.sound4.biz/index.php?title=Cloud_JSON_Protocol&amp;diff=924&amp;oldid=prev</id>
		<title>Camille: /* Change */</title>
		<link rel="alternate" type="text/html" href="https://wk.sound4.biz/index.php?title=Cloud_JSON_Protocol&amp;diff=924&amp;oldid=prev"/>
		<updated>2023-11-03T10:38:55Z</updated>

		<summary type="html">&lt;p&gt;&lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;Change&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;a href=&quot;https://wk.sound4.biz/index.php?title=Cloud_JSON_Protocol&amp;amp;diff=924&amp;amp;oldid=893&quot;&gt;Show changes&lt;/a&gt;</summary>
		<author><name>Camille</name></author>
		
	</entry>
	<entry>
		<id>https://wk.sound4.biz/index.php?title=Cloud_JSON_Protocol&amp;diff=893&amp;oldid=prev</id>
		<title>Camille: Created</title>
		<link rel="alternate" type="text/html" href="https://wk.sound4.biz/index.php?title=Cloud_JSON_Protocol&amp;diff=893&amp;oldid=prev"/>
		<updated>2023-09-29T09:04:02Z</updated>

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