Describe Properties in config Hardware command body forming rules
Is Netty based Java server responsible for message forwarding between mobile application and any hardware (e.g. Arduino, Raspberry Pi for now). Please read more detailed description here.
Every message consists of 2 parts.
-
Header :
- Protocol command (1 byte);
- MessageId (2 bytes);
- Body message length (2 bytes);
-
Body : string (could be up to 2^15 bytes).
Scheme:
BEFORE DECODE (8 bytes)
+------------------+------------+---------+------------------------+
| 1 byte | 2 bytes | 2 bytes | Variable length |
+------------------+------------+---------+------------------------+
| Protocol Command | MessageId | Length | Message body (String) |
| 0x01 | 0x000A | 0x0003 | "1 2" |
+------------------+------------+---------+------------------------+
| 3 bytes |
+------------------------+
So, message is always "1 byte + 2 bytes + 2 bytes + messageBody.length".
Unsigned byte. This is 1 byte field responsible for storing command code from client, like login, ping, etc...
Unsigned short. Message Id field is a 2 bytes field for defining unique message identifier. It’s used in order to distinguish how to manage responses from hardware on mobile client. Message ID field should be generated on client’s side. Any ‘read’ protocol command should always have same messageId for the same widget. Let's say, you have a Graph_1 widget which is configured to read data from the analog pin. After you reconfigured Graph_1 to read another pin, load command will still look the same, and messageID will be an ID of the widget to display results at.
Unsigned short. Length field is a 2 bytes field for defining body length. Could be 0 if body is empty or missing.
0 - response; After every message client sends to server it retrieves response message back (exception commands are: LoadProfile, GetToken, Ping commands).
1 - register; Must have 2 space-separated params as a content field (username and password) : “[email protected] UserPassword”
2 - login:
a) Mobile client must send send 2 space-separated parameters as a content field (username and password) : "[email protected] UserPassword"
b) Hardware client must send 1 parameter, which is user Authentication Token : "6a7a3151cb044cd893a92033dd65f655"
3 - save profile; Must have 1 parameter as content string : "{...}"
4 - load profile; Doesn’t have any parameters
5 - getToken; Must have 1 signed int (4 bytes) parameter, Dashboard ID : "1". NOTE : number of dashboards is limited per user by 10 and token request should request token for id of existing dashboard, that saved via saveProfile
6 - ping; Sends request from client to server, then from server to hardware, than back to server and back to the client.
7 - activate dashboard. "activate DASH_ID";
8 - deactivate dashboard. "deactivate";
9 - refresh token. Generates new token for dashboard; "refreshToken DASH_ID".
12 - tweet; Sends tweet request from hardware to server. 140 chars max.
20 - hardware; Command for hardware. Every Widget forms it's own body message for hardware command.
//todo
Client sends commands to the server and gets response for every command sent. For commands (register, login, saveProfile, hardware) that doesn't request any data back - 'response' (command field 0x00) message is returned. For commands (loadProfile, getToken, ping) that request data back - message will be returned with same command code. In case you sent 'loadProfile' you will receive 'loadProfile' command back with filled body.
Here is the class with all of the codes. Response message structure:
BEFORE DECODE
+------------------+------------+----------------+
| 1 byte | 2 bytes | 2 bytes |
+------------------+------------+----------------+
| Protocol Command | MessageId | Response code |
| 0x00 | 0x000A | 0x0001 |
+------------------+------------+----------------+
| always 5 bytes |
+------------------------------------------------+
200 - message was successfully processed/passed to the server
1 - too many requests.
2 - command is badly formed, check syntax and passed params
3 - user is not registered
4 - user with this name has been registered already
5 - user hasn’t made login command
6 - user is not allowed to perform this operation (most probably is not logged or socket has been closed)
7 - hardware is offline
8 - no active dashboard. User has to activated dashboard.
9 - token is invalid
11 - user is already logged in. Happens in cases when same user tries to login for more than one time.
12 - tweet exception, exception occurred during posting request to Twitter could be in case messages are the same in a row;
13 - tweet body invalid exception; body is empty or larger than 140 chars;
14 - user has no twitter access token provided.
500 - server error. something went wrong on server
{ "dashBoards" :
[
{
"id":1, "name":"My Dashboard", "isActive":true, "timestamp":333333,
"widgets" : [...],
"boardType":"UNO"
}
],
"twitter" : {
"token" : "USER_TOKEN",
"tokenSecret" : "USER_SECRET"
}
}
//output
BUTTON,
TOGGLE_BUTTON,
SLIDER,
SLIDER_LARGE,
KNOB,
ROTARY_KNOB,
RGB,
TWO_WAY_ARROW,
FOUR_WAY_ARROW,
ONE_AXIS_JOYSTICK,
TWO_AXIS_JOYSTICK,
GAMEPAD,
KEYPAD,
//input
LED,
DIGIT4_DISPLAY, //same as NUMERICAL_DISPLAY
GAUGE,
LCD_DISPLAY,
GRAPH,
LEVEL_DISPLAY,
//sensors
MICROPHONE,
GYROSCOPE,
ACCELEROMETER,
GPS,
//other
TERMINAL,
TWITTER,
EMAIL,
NOTIFICATION,
SD_CARD,
EVENTOR,
RCT,
TIMER
Button : {"id":1, "x":1, "y":1, "dashBoardId":1, "label":"Some Text", "type":"BUTTON", "pinType":"NONE", "pin":13, "value":"1" } -- sends HIGH on digital pin 13. Possible values 1|0.
Slider : {"id":1, "x":1, "y":1, "dashBoardId":1, "label":"Some Text", "type":"SLIDER", "pinType":"ANALOG", "pin":18, "value":"244" } -- sends 244 on analog pin 18. Possible values -9999 to 9999
Timer : {"id":1, "x":1, "y":1, "dashBoardId":1, "label":"Some Text", "type":"TIMER", "pinType":"DIGITAL", "pin":13, "startTime" : 1111111111, "stopInterval" : 111111111} -- startTime is time in UTC when to start timer (milliseconds are ignored), stopInterval interval in milliseconds after which stop timer.
//pin reading widgets
LED : {"id":1, "x":1, "y":1, "dashBoardId":1, "label":"Some Text", "type":"LED", "pinType":"DIGITAL", "pin":10} - sends READ pin to server
Digit Display : {"id":1, "x":1, "y":1, "dashBoardId":1, "label":"Some Text", "type":"DIGIT4_DISPLAY", "pinType":"DIGITAL", "pin":10} - sends READ pin to server
Graph : {"id":1, "x":1, "y":1, "dashBoardId":1, "label":"Some Text", "type":"GRAPH", "pinType":"DIGITAL", "pin":10, "readingFrequency":1000} - sends READ pin to server. Frequency in microseconds
Server guarantees that commands will be processed in same order in which they were send.