...
The error code is a 32-bit unsigned integer formatted as a hexadecimal string. Synchronous error replies always will have a request ID returned. Asynchronous error replies only will return a request ID if the reply is associated with an asynchronous request. Optionally, all commands immediately return an acknowledgment reply. If the Acks option is turned on, the client receives an immediate reply "@ReqID;OK;" followed by the command that was recognized.
The API Sets
There are four are three API sets available in the Fairmount SSH Server: the Fairmount Network Data Access (FANDA) APIs, the Design Pad APIs, the Configuration APIs, and the internal use APIs.
Access to API sets may be limited based on authentication credentials. The GetCaps command provides a mechanism to determine the capabilities of the current connection.
...
The FANDA APIs
GetNDL
Panel |
---|
|
This command requests a bit field indicating the capabilities of the current connection. The contents may depend on the device type, software version, and rights of the current FANDA user. Additional bits may be defined as new commands and capabilities are added in the future without requiring a change to the protocol version. Clients should simply ignore unsupported bits.
The response is:
Panel |
---|
|
HexByteList is a comma-separated list of capability bytes, starting with Byte 0. The client should ignore unknown bytes in the response, and should treat any missing bytes as zero. The currently defined capability flags are (Mask is in the format used by GetCaps and SetCaps):
Panel | ||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| ||||||||||||||||||||||||||||||||||||||||||||
|
The current max-capability response is
Panel |
---|
|
SetCaps
Panel |
---|
|
This command is intended for internal use. The response is the same as the GetCaps command.
The bytes in HexByteList have the same format as a GetCaps response. The connection's current capabilities are masked with the capabilities given in this command. After this command completes, the connection's capabilities are reduced to the intersection of the two sets.
The FANDA APIs
GetNDL
Panel |
---|
|
This command requests a download of the NDL string. Returns “@ReqID;
NDL
=
xml string
” or “@ReqID;
Error
=
code;error message
”. The format of xml string is documented elsewhere.
GetMulticastKey
Panel |
---|
|
This command requests a download of the multicast encryption key(s). If a particular Multicast ID is not specified, all multicast keys are reported. Returns “@ReqID;MulticastKey=MulticastID,KeyGen,Base64KeyData,Base64NextKeyData
” or “@ReqID;Error=code;error message
”. If all multicast keys are requested, each key will be reported with a MulticastKey= response. KeyGen specifies the current key generation number in use, Base64KeyData is the current encryption key in use, and Base64NextKeyData is the next encryption key to be used after rekeying. The format of Base64KeyData and Base64NextKeyData is little-endian binary encryption key encoded as a Base64 string. The key cipher and length are described in the NDL.
GetVar
Panel |
---|
|
Get the value of the variable VariableName and return it in the format specified by the SetDataFormat option. If VariableName contains embedded whitespace or periods, it must be enclosed in double quotes. At this point, VariableName must be defined in Design Pad as a global variable with network access enabled. The second form of the command may be used for structure type variables. In that case, the requested structure member is returned. If the SetDataFormat option is Base64 (the default) or String, the format of the returned data is:
Panel |
---|
|
The format of Base64Value is a little-endian binary value encoded as a Base64 string. The format of StringValue is a human-readable decimal value (i.e. formatted using the C-language sprintf function). If the SetDataFormat option is XML, the format of the returned data is:
Panel |
---|
|
where XMLString is an XML representation of the data. See Design Pad Structures for details on the XML format returned for structure data and underlying simple type data.
SetVar
Panel |
---|
|
Sets the value of the variable VariableName to Base64Value. Base64Value is a little-endian binary value encoded as a Base64 string. At this point, VariableName must be defined in Design Pad as a global variable with network access enabled. The second form of the command may be used for structure type variables. In that case, the requested structure member value is set. Returns "@ReqID;SetVar=Success
” or “@ReqID;Error=code;error message
”.
The Design Pad APIs
FairNET
Panel |
---|
|
Sends the bytes specified by Base64Value to the device's FANDA FairNET channel. The data is interpreted per the FairNET specification, as if the data had been received over the IR interface. The FANDA client acts as the FairNET master.
There is no reply to this command. Returned FairNET data arrives via asynchronous FairNET messages.
A single FairNET packet may be split into multiple FANDA FairNET commands, and a single FANDA FairNET command may contain data from multiple FairNET packets.
Update
Panel |
---|
|
The UpdateSubcommand command set allows uploading and executing a self-extracting update program, which may include a control code update or a kernel update. There are several sub-commands, which are typically issued in the order shown below.
UpdateStart
Panel |
---|
|
Start an update. The server will ensure that sufficient space is available to store an image of the specified size before proceeding. If sufficient space is available, the server will respond with:
Panel |
---|
|
otherwise, the server will return an error and cancel the update:
Panel |
---|
|
UpdateData
Panel |
---|
|
Transfers a chunk of the update program. CurrentOffset indicates the offset within the updater program at which Base64Data should be written. If the data is written out successfully the response is:
Panel |
---|
|
otherwise, an error response is returned and the client may retry the failed chunk:
Panel |
---|
|
UpdateApply
Panel |
---|
|
Verify the message digest of the transferred data and apply the update. If no digest is provided or the provided digest is not supported, the total amount of data transferred in successful UpdateData commands is compared to the size given in the UpdateStart command. If a digest or length mismatch is detected, an error response is returned and the update is canceled:
Panel |
---|
|
If validation succeeds, the UpdateApply=Success message is returned, followed by an EOF:
Panel |
---|
|
at which point no more FANDA data is passed over the connection. The SSH connection is connected to the update program's stdin, stdout, and stderr. Messages from the update program should be displayed to the user to confirm progress. When the update completes (successfully or otherwise) the SSH connection will be closed.
Each UpdateArg is passed as as a command-line argument to the update program. If no UpdateArg parameters are passed, the default is -- -n (preserve node configuration) to maintain network parameters. To run the updater with no arguments, pass Arg= (empty string).
If the update process proceeds to stop or restart the control code, any other connected clients will receive:
Panel |
---|
|
Currently supported DigestType values are MD5 and SHA1. The DigestValue is Base64 encoded. Multiple digests types may be included in a single command, in any order.
The SC1 supports all digest types. The NIM2 does not support message digests and performs length validation only. Any digest provided is ignored.
UpdateCancel
Panel |
---|
|
Cancel an in-progress update, typically in response to a user action. Any data already transferred is discarded. The response is:
Panel |
---|
|
Lock
Panel |
---|
|
Acquire the lock(s) specified by the LockID parameters. Return an error if the lock can not be acquired after AcquireTimeout seconds (may be zero or omitted, in which case the command returns a result immediately). If the locked capability is not used for HoldTimeout seconds the lock is automatically released. All held locks are released when a FANDA session ends. If HoldTimeout is zero or omitted, the lock is held until the session ends.
If more than one lock is specified, they are all acquired atomically or, if one or more cannot be acquired, then none are acquired.
Repeated Lock commands may be used to verify that the caller is still holding the lock. This will also reset the HoldTimeout to the value specified in the most recent Lock command. This is not a nested lock, only one Unlock call is needed to release the lock, regardless of the number of Lock commands that were executed.
The currently defined locks are:
Panel | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
|
The response is either
Panel |
---|
|
for success or
Panel |
---|
|
if an error occurs.
LockIDs are C-style numeric values (parsed with scanf "%d" modifier or strtol with base 0).
Unlock
Panel |
---|
|
Unlock the lock(s) with the IDs specified in the LockID parameters. If no error occurs, the response is:
Panel |
---|
|
with a comma-separated list of all locks that were released (locks that were abandoned due to timeout will not appear in the list). If an error occurs the response is
Panel |
---|
|
If LockID is the string "all", all locks currently held by the caller are released, and the response is:
Panel |
---|
|
with a comma-separated list of all locks that were released. If no locks were held the ID list is empty.
LockIDs are C-style numeric values (parsed with scanf "%d" modifier or strtol with base 0), or the string "all"download of the NDL string. Returns “@ReqID;
NDL
=
xml string
” or “@ReqID;
Error
=
code;error message
”. The format of xml string is documented elsewhere.
GetMulticastKey
Panel |
---|
|
This command requests a download of the multicast encryption key(s). If a particular Multicast ID is not specified, all multicast keys are reported. Returns “@ReqID;MulticastKey=MulticastID,KeyGen,Base64KeyData,Base64NextKeyData
” or “@ReqID;Error=code;error message
”. If all multicast keys are requested, each key will be reported with a MulticastKey= response. KeyGen specifies the current key generation number in use, Base64KeyData is the current encryption key in use, and Base64NextKeyData is the next encryption key to be used after rekeying. The format of Base64KeyData and Base64NextKeyData is little-endian binary encryption key encoded as a Base64 string. The key cipher and length are described in the NDL. If multicasts are not encrypted, KeyGen will be 0 and no key data follows.
GetVar
Panel |
---|
|
Get the value of the variable VariableName and return it in the format specified by the SetDataFormat option. If VariableName contains embedded whitespace or periods, it must be enclosed in double quotes. At this point, VariableName must be defined in Design Pad as a global variable with network access enabled. The second form of the command may be used for structure type variables. In that case, the requested structure member is returned. If the SetDataFormat option is Base64 (the default) or String, the format of the returned data is:
Panel |
---|
|
The format of Base64Value is a little-endian binary value encoded as a Base64 string. The format of StringValue is a human-readable decimal value (i.e. formatted using the C-language sprintf function). If the SetDataFormat option is XML, the format of the returned data is:
Panel |
---|
|
where XMLString is an XML representation of the data. See Design Pad Structures for details on the XML format returned for structure data and underlying simple type data.
SetVar
Panel |
---|
|
Sets the value of the variable VariableName to Base64Value. Base64Value is a little-endian binary value encoded as a Base64 string. At this point, VariableName must be defined in Design Pad as a global variable with network access enabled. The second form of the command may be used for structure type variables. In that case, the requested structure member value is set. Returns "@ReqID;SetVar=Success
” or “@ReqID;Error=code;error message
”.
Configuration APIs
These meta-commands affect the FANDA connection itself.
...
Specifies whether acknowledgements are returned. If the client wishes to operate asynchronously, this option may be turned on. This will cause the server to immediately respond to all commands with an “<tt>@ReqID;OK;Command</tt>” string where Command is the recognized command (which may differ in case from the transmitted command). No reply is given to this command.
EOF
Panel |
---|
|
The EOF command signifies that the client is about to disconnect. (Future version: If the client does not send the EOF command before disconnecting, the server will maintain workspace information about the session until the session times out. This feature allows the client to reconnect after an unintended disconnect using the same logon credentials as the previous connection.) No reply is given to this command.
...
Specifies the reply format of data returned by the GetVar command.
GetCaps
Panel |
---|
|
This command requests a bit field indicating the capabilities of the current connection. The contents may depend on the device type, software version, and rights of the current FANDA user. Additional bits may be defined as new commands and capabilities are added in the future without requiring a change to the protocol version. Clients should simply ignore unsupported bits.
...
Panel | ||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| ||||||||||||||||||||||||||||||||||||||||||||
|
The current max-capability response is
Panel |
---|
|
SetCaps
Panel |
---|
|
This command is intended for internal use. The response is the same as the GetCaps command.
...
|
The current max-capability response is
Panel |
---|
|
Asynchronous Messages
The following messages may be sent from the server to the client at any time.
...
This message will be sent whenever there is a program change causing the NDL format to change. When the schema program is erased, an empty NDL is sent (xml string is blank). When a new schema program is loaded, the new NDL string is sent.
FairNET
Panel |
---|
|
Returns the bytes specified by Base64Value from the device's FANDA FairNET channel. The data is interpreted per the FairNET specification, as if the data had been received by the client from the IR interface. The FANDA client is the FairNET master, so this message will only occur in response to an earlier FairNET message sent from the client.
A single FairNET packet may be split into multiple FANDA FairNET commands, and a single FANDA FairNET command may contain data from multiple FairNET packets.
Internal Use APIs
GetCapsAsync
Panel |
---|
|
It has no synchronous response, and causes the current caps to be sent as an asynchronous messageprogram is loaded, the new NDL string is sent.
Internal Use APIs
These APIs are for internal use only, and are not intended to be called by client software.
GetCapsAsync
Panel |
---|
|
It has no synchronous response, and causes the current caps to be sent as an asynchronous message.
SetCaps
Panel |
---|
|
The response is the same as the GetCaps command.
The bytes in HexByteList have the same format as a GetCaps response. The connection's current capabilities are masked with the capabilities given in this command. After this command completes, the connection's capabilities are reduced to the intersection of the two sets.
SetCapsAsync
Panel |
---|
|
...