Difference between revisions of "Component: Hydro Encryption (Comms: Networking)"

From Flowcode Help
Jump to navigationJump to search
Line 17: Line 17:
 
==Component Source Code==
 
==Component Source Code==
  
Please click here to download the component source project: [https://www.flowcode.co.uk/wikicopy/componentsource/FC_Comp_Source_libhydrogen.fcfx FC_Comp_Source_libhydrogen.fcfx]
+
Please click here to download the component source project: [https://www.flowcode.co.uk/wiki/componentsource/FC_Comp_Source_libhydrogen.fcfx FC_Comp_Source_libhydrogen.fcfx]
  
 
Please click here to view the component source code (Beta): [https://www.flowcode.co.uk/FlowchartView/?wfile=componentsource/FC_Comp_Source_libhydrogen.fcfx FC_Comp_Source_libhydrogen.fcfx]
 
Please click here to view the component source code (Beta): [https://www.flowcode.co.uk/FlowchartView/?wfile=componentsource/FC_Comp_Source_libhydrogen.fcfx FC_Comp_Source_libhydrogen.fcfx]
  
 
==Detailed description==
 
==Detailed description==
 +
 +
  
  
Line 34: Line 36:
  
 
==Examples==
 
==Examples==
 +
 +
  
  
Line 46: Line 50:
  
 
==Macro reference==
 
==Macro reference==
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''sign_create'''
 +
|-
 +
| colspan="2" | Computes a signature for a message using the secret key. Returns 0 if successful. 
 +
|-
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | signature
 +
|-
 +
| colspan="2" | Buffer to receive the signature. Must be 64 bytes. 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | message
 +
|-
 +
| colspan="2" | Buffer containing the data to sign 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT
 +
| width="90%" | message_size
 +
|-
 +
| colspan="2" | Byte count of the message 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | secret_key
 +
|-
 +
| colspan="2" | Secret/Private key to be used.Size is 64 bytes. 
 +
|-
 +
| width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT
 +
| width="90%" style="border-top: 2px solid #000;" | ''Return''
 +
|}
 +
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''secretbox_keygen'''
 +
|-
 +
| colspan="2" | Creates a secret key suitable for use with the secretbox functions. You must provide a 32 byte array for the key. 
 +
|-
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | key
 +
|-
 +
| colspan="2" |  
 +
|-
 +
| width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-void-icon.png]] - VOID
 +
| width="90%" style="border-top: 2px solid #000;" | ''Return''
 +
|}
 +
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''hash_with_key'''
 +
|-
 +
| colspan="2" | Creates a hash fingerprint of the data, using the given key. Returns 0 if successful. 
 +
|-
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | hash
 +
|-
 +
| colspan="2" | Buffer for the hash. Size >=32 makes it practically impossible for two messages to produce the same fingerprint. 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | data
 +
|-
 +
| colspan="2" | The data buffer to be processed 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT
 +
| width="90%" | size
 +
|-
 +
| colspan="2" | Byte count of the data to be processed 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | key
 +
|-
 +
| colspan="2" | Key to be used 
 +
|-
 +
| width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT
 +
| width="90%" style="border-top: 2px solid #000;" | ''Return''
 +
|}
 +
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''sign_verify'''
 +
|-
 +
| colspan="2" | Verify the signature of a mesasge using the public key. Returns 0 if successful. 
 +
|-
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | signature
 +
|-
 +
| colspan="2" | Buffer to receive the signature. Must be 64 bytes. 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | message
 +
|-
 +
| colspan="2" | Buffer containing the data to sign 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT
 +
| width="90%" | message_size
 +
|-
 +
| colspan="2" | Byte count of the message 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | public_key
 +
|-
 +
| colspan="2" | Public key to be used.Size is 32 bytes. 
 +
|-
 +
| width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT
 +
| width="90%" style="border-top: 2px solid #000;" | ''Return''
 +
|}
 +
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''init'''
 +
|-
 +
| colspan="2" | Initialisation function. To be called at the very start of your program. 
 +
|-
 +
|-
 +
| width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT
 +
| width="90%" style="border-top: 2px solid #000;" | ''Return''
 +
|}
 +
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''sign_keygen'''
 +
|-
 +
| colspan="2" | Creates Private and Public key pair to sign and verify messages. Returns 0 if successful. 
 +
|-
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | Secret
 +
|-
 +
| colspan="2" | Buffer to receive the Private/Secret Key. Buffer size must be 64 bytes 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | Public
 +
|-
 +
| colspan="2" | Buffer to receive the Public key. Buffer size must be 32 bytes 
 +
|-
 +
| width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT
 +
| width="90%" style="border-top: 2px solid #000;" | ''Return''
 +
|}
 +
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''secretbox_encrypt'''
 +
|-
 +
| colspan="2" | Encrypts a message with a secret key. A single key is used both to encrypt/sign and verify/decrypt messages. For this reason, it is critical to keep the key confidential. Returns 0 on success. 
 +
|-
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | message
 +
|-
 +
| colspan="2" | Buffer containing the message to be encrypted. 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT
 +
| width="90%" | length
 +
|-
 +
| colspan="2" | The length (byte count) of the message 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT
 +
| width="90%" | ID
 +
|-
 +
| colspan="2" | Message ID. Can be 0 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | key
 +
|-
 +
| colspan="2" | The secret key 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | ciphertext
 +
|-
 +
| colspan="2" | Buffer for ciphertext output. Buffer size must be at least length + 36 
 +
|-
 +
| width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT
 +
| width="90%" style="border-top: 2px solid #000;" | ''Return''
 +
|}
 +
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''hash_keygen'''
 +
|-
 +
| colspan="2" | Creates a secret key suitable for use with the hash_hash function. You must provide a 32 byte array for the key. 
 +
|-
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | key
 +
|-
 +
| colspan="2" |  
 +
|-
 +
| width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-void-icon.png]] - VOID
 +
| width="90%" style="border-top: 2px solid #000;" | ''Return''
 +
|}
 +
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''secretbox_decrypt'''
 +
|-
 +
| colspan="2" | Decrypts a message with a secret key. A single key is used both to encrypt/sign and verify/decrypt messages. For this reason, it is critical to keep the key confidential. Returns 0 on success. 
 +
|-
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | message
 +
|-
 +
| colspan="2" | Buffer for the decrypted message. Size must be at least length - 36 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT
 +
| width="90%" | length
 +
|-
 +
| colspan="2" | The length (byte count) of the ciphertext 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT
 +
| width="90%" | ID
 +
|-
 +
| colspan="2" | Message ID. Must match with the original message ID. Can be 0 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | key
 +
|-
 +
| colspan="2" | The secret key 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | ciphertext
 +
|-
 +
| colspan="2" | Buffer containing the ciphertext to be decrypted. 
 +
|-
 +
| width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT
 +
| width="90%" style="border-top: 2px solid #000;" | ''Return''
 +
|}
 +
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''hash_without_key'''
 +
|-
 +
| colspan="2" | Creates a hash fingerprint of the data, which will always have the same fingerprint, similar to the MD5 or SHA-1 Returns 0 if successful. 
 +
|-
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | hash
 +
|-
 +
| colspan="2" | Buffer for the hash. Size >=32 makes it practically impossible for two messages to produce the same fingerprint. 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE
 +
| width="90%" | data
 +
|-
 +
| colspan="2" | Data buffer to be processed 
 +
|-
 +
| width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT
 +
| width="90%" | size
 +
|-
 +
| colspan="2" | Byte count of data to be processed 
 +
|-
 +
| width="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT
 +
| width="90%" style="border-top: 2px solid #000;" | ''Return''
 +
|}
 +
 +
 +
 +
 +
==Property reference==
 +
 +
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 +
|-
 +
| width="10%" align="center" style="background-color:#D8C9D8;" | [[File:Fc9-prop-icon.png]]
 +
| width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''Properties'''
 +
|-
 +
|}==Macro reference==
  
 
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"
 
{| class="wikitable" style="width:60%; background-color:#FFFFFF;"

Revision as of 10:01, 27 January 2023

Author
Version 1.0
Category Comms: Networking


Hydro Encryption component

A cipher suite to enable encryption and decryption of data messages, based on libhydrogen.

Component Source Code

Please click here to download the component source project: FC_Comp_Source_libhydrogen.fcfx

Please click here to view the component source code (Beta): FC_Comp_Source_libhydrogen.fcfx

Detailed description

No detailed description exists yet for this component

Examples

No additional examples

Macro reference

Fc9-comp-macro.png sign_create
Computes a signature for a message using the secret key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE signature
Buffer to receive the signature. Must be 64 bytes. 
Fc9-u8-icon.png - BYTE message
Buffer containing the data to sign 
Fc9-u16-icon.png - UINT message_size
Byte count of the message 
Fc9-u8-icon.png - BYTE secret_key
Secret/Private key to be used.Size is 64 bytes. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png secretbox_keygen
Creates a secret key suitable for use with the secretbox functions. You must provide a 32 byte array for the key. 
Fc9-u8-icon.png - BYTE key
 
Fc9-void-icon.png - VOID Return


Fc9-comp-macro.png hash_with_key
Creates a hash fingerprint of the data, using the given key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE hash
Buffer for the hash. Size >=32 makes it practically impossible for two messages to produce the same fingerprint. 
Fc9-u8-icon.png - BYTE data
The data buffer to be processed 
Fc9-u16-icon.png - UINT size
Byte count of the data to be processed 
Fc9-u8-icon.png - BYTE key
Key to be used 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png sign_verify
Verify the signature of a mesasge using the public key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE signature
Buffer to receive the signature. Must be 64 bytes. 
Fc9-u8-icon.png - BYTE message
Buffer containing the data to sign 
Fc9-u16-icon.png - UINT message_size
Byte count of the message 
Fc9-u8-icon.png - BYTE public_key
Public key to be used.Size is 32 bytes. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png init
Initialisation function. To be called at the very start of your program. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png sign_keygen
Creates Private and Public key pair to sign and verify messages. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE Secret
Buffer to receive the Private/Secret Key. Buffer size must be 64 bytes 
Fc9-u8-icon.png - BYTE Public
Buffer to receive the Public key. Buffer size must be 32 bytes 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png secretbox_encrypt
Encrypts a message with a secret key. A single key is used both to encrypt/sign and verify/decrypt messages. For this reason, it is critical to keep the key confidential. Returns 0 on success. 
Fc9-u8-icon.png - BYTE message
Buffer containing the message to be encrypted. 
Fc9-u16-icon.png - UINT length
The length (byte count) of the message 
Fc9-u16-icon.png - UINT ID
Message ID. Can be 0 
Fc9-u8-icon.png - BYTE key
The secret key 
Fc9-u8-icon.png - BYTE ciphertext
Buffer for ciphertext output. Buffer size must be at least length + 36 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png hash_keygen
Creates a secret key suitable for use with the hash_hash function. You must provide a 32 byte array for the key. 
Fc9-u8-icon.png - BYTE key
 
Fc9-void-icon.png - VOID Return


Fc9-comp-macro.png secretbox_decrypt
Decrypts a message with a secret key. A single key is used both to encrypt/sign and verify/decrypt messages. For this reason, it is critical to keep the key confidential. Returns 0 on success. 
Fc9-u8-icon.png - BYTE message
Buffer for the decrypted message. Size must be at least length - 36 
Fc9-u16-icon.png - UINT length
The length (byte count) of the ciphertext 
Fc9-u16-icon.png - UINT ID
Message ID. Must match with the original message ID. Can be 0 
Fc9-u8-icon.png - BYTE key
The secret key 
Fc9-u8-icon.png - BYTE ciphertext
Buffer containing the ciphertext to be decrypted. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png hash_without_key
Creates a hash fingerprint of the data, which will always have the same fingerprint, similar to the MD5 or SHA-1 Returns 0 if successful. 
Fc9-u8-icon.png - BYTE hash
Buffer for the hash. Size >=32 makes it practically impossible for two messages to produce the same fingerprint. 
Fc9-u8-icon.png - BYTE data
Data buffer to be processed 
Fc9-u16-icon.png - UINT size
Byte count of data to be processed 
Fc9-s16-icon.png - INT Return



Property reference

Fc9-prop-icon.png Properties

==Macro reference==

Fc9-comp-macro.png sign_create
Computes a signature for a message using the secret key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE signature
Buffer to receive the signature. Must be 64 bytes. 
Fc9-u8-icon.png - BYTE message
Buffer containing the data to sign 
Fc9-u16-icon.png - UINT message_size
Byte count of the message 
Fc9-u8-icon.png - BYTE secret_key
Secret/Private key to be used.Size is 64 bytes. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png secretbox_keygen
Creates a secret key suitable for use with the secretbox functions. You must provide a 32 byte array for the key. 
Fc9-u8-icon.png - BYTE key
 
Fc9-void-icon.png - VOID Return


Fc9-comp-macro.png hash_with_key
Creates a hash fingerprint of the data, using the given key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE hash
Buffer for the hash. Size >=32 makes it practically impossible for two messages to produce the same fingerprint. 
Fc9-u8-icon.png - BYTE data
The data buffer to be processed 
Fc9-u16-icon.png - UINT size
Byte count of the data to be processed 
Fc9-u8-icon.png - BYTE key
Key to be used 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png sign_verify
Verify the signature of a mesasge using the public key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE signature
Buffer to receive the signature. Must be 64 bytes. 
Fc9-u8-icon.png - BYTE message
Buffer containing the data to sign 
Fc9-u16-icon.png - UINT message_size
Byte count of the message 
Fc9-u8-icon.png - BYTE public_key
Public key to be used.Size is 32 bytes. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png init
Initialisation function. To be called at the very start of your program. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png sign_keygen
Creates Private and Public key pair to sign and verify messages. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE Secret
Buffer to receive the Private/Secret Key. Buffer size must be 64 bytes 
Fc9-u8-icon.png - BYTE Public
Buffer to receive the Public key. Buffer size must be 32 bytes 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png secretbox_encrypt
Encrypts a message with a secret key. A single key is used both to encrypt/sign and verify/decrypt messages. For this reason, it is critical to keep the key confidential. Returns 0 on success. 
Fc9-u8-icon.png - BYTE message
Buffer containing the message to be encrypted. 
Fc9-u16-icon.png - UINT length
The length (byte count) of the message 
Fc9-u16-icon.png - UINT ID
Message ID. Can be 0 
Fc9-u8-icon.png - BYTE key
The secret key 
Fc9-u8-icon.png - BYTE ciphertext
Buffer for ciphertext output. Buffer size must be at least length + 36 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png hash_keygen
Creates a secret key suitable for use with the hash_hash function. You must provide a 32 byte array for the key. 
Fc9-u8-icon.png - BYTE key
 
Fc9-void-icon.png - VOID Return


Fc9-comp-macro.png secretbox_decrypt
Decrypts a message with a secret key. A single key is used both to encrypt/sign and verify/decrypt messages. For this reason, it is critical to keep the key confidential. Returns 0 on success. 
Fc9-u8-icon.png - BYTE message
Buffer for the decrypted message. Size must be at least length - 36 
Fc9-u16-icon.png - UINT length
The length (byte count) of the ciphertext 
Fc9-u16-icon.png - UINT ID
Message ID. Must match with the original message ID. Can be 0 
Fc9-u8-icon.png - BYTE key
The secret key 
Fc9-u8-icon.png - BYTE ciphertext
Buffer containing the ciphertext to be decrypted. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png hash_without_key
Creates a hash fingerprint of the data, which will always have the same fingerprint, similar to the MD5 or SHA-1 Returns 0 if successful. 
Fc9-u8-icon.png - BYTE hash
Buffer for the hash. Size >=32 makes it practically impossible for two messages to produce the same fingerprint. 
Fc9-u8-icon.png - BYTE data
Data buffer to be processed 
Fc9-u16-icon.png - UINT size
Byte count of data to be processed 
Fc9-s16-icon.png - INT Return



Property reference

Fc9-prop-icon.png Properties

==Macro reference==

Fc9-comp-macro.png sign_create
Computes a signature for a message using the secret key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE signature
Buffer to receive the signature. Must be 64 bytes. 
Fc9-u8-icon.png - BYTE message
Buffer containing the data to sign 
Fc9-u16-icon.png - UINT message_size
Byte count of the message 
Fc9-u8-icon.png - BYTE secret_key
Secret/Private key to be used.Size is 64 bytes. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png secretbox_keygen
Creates a secret key suitable for use with the secretbox functions. You must provide a 32 byte array for the key. 
Fc9-u8-icon.png - BYTE key
 
Fc9-void-icon.png - VOID Return


Fc9-comp-macro.png hash_with_key
Creates a hash fingerprint of the data, using the given key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE hash
Buffer for the hash. Size >=32 makes it practically impossible for two messages to produce the same fingerprint. 
Fc9-u8-icon.png - BYTE data
The data buffer to be processed 
Fc9-u16-icon.png - UINT size
Byte count of the data to be processed 
Fc9-u8-icon.png - BYTE key
Key to be used 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png sign_verify
Verify the signature of a mesasge using the public key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE signature
Buffer to receive the signature. Must be 64 bytes. 
Fc9-u8-icon.png - BYTE message
Buffer containing the data to sign 
Fc9-u16-icon.png - UINT message_size
Byte count of the message 
Fc9-u8-icon.png - BYTE public_key
Public key to be used.Size is 32 bytes. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png init
Initialisation function. To be called at the very start of your program. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png sign_keygen
Creates Private and Public key pair to sign and verify messages. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE Secret
Buffer to receive the Private/Secret Key. Buffer size must be 64 bytes 
Fc9-u8-icon.png - BYTE Public
Buffer to receive the Public key. Buffer size must be 32 bytes 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png secretbox_encrypt
Encrypts a message with a secret key. A single key is used both to encrypt/sign and verify/decrypt messages. For this reason, it is critical to keep the key confidential. Returns 0 on success. 
Fc9-u8-icon.png - BYTE message
Buffer containing the message to be encrypted. 
Fc9-u16-icon.png - UINT length
The length (byte count) of the message 
Fc9-u16-icon.png - UINT ID
Message ID. Can be 0 
Fc9-u8-icon.png - BYTE key
The secret key 
Fc9-u8-icon.png - BYTE ciphertext
Buffer for ciphertext output. Buffer size must be at least length + 36 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png hash_keygen
Creates a secret key suitable for use with the hash_hash function. You must provide a 32 byte array for the key. 
Fc9-u8-icon.png - BYTE key
 
Fc9-void-icon.png - VOID Return


Fc9-comp-macro.png secretbox_decrypt
Decrypts a message with a secret key. A single key is used both to encrypt/sign and verify/decrypt messages. For this reason, it is critical to keep the key confidential. Returns 0 on success. 
Fc9-u8-icon.png - BYTE message
Buffer for the decrypted message. Size must be at least length - 36 
Fc9-u16-icon.png - UINT length
The length (byte count) of the ciphertext 
Fc9-u16-icon.png - UINT ID
Message ID. Must match with the original message ID. Can be 0 
Fc9-u8-icon.png - BYTE key
The secret key 
Fc9-u8-icon.png - BYTE ciphertext
Buffer containing the ciphertext to be decrypted. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png hash_without_key
Creates a hash fingerprint of the data, which will always have the same fingerprint, similar to the MD5 or SHA-1 Returns 0 if successful. 
Fc9-u8-icon.png - BYTE hash
Buffer for the hash. Size >=32 makes it practically impossible for two messages to produce the same fingerprint. 
Fc9-u8-icon.png - BYTE data
Data buffer to be processed 
Fc9-u16-icon.png - UINT size
Byte count of data to be processed 
Fc9-s16-icon.png - INT Return



Property reference

Fc9-prop-icon.png Properties

==Macro reference==

Fc9-comp-macro.png sign_create
Computes a signature for a message using the secret key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE signature
Buffer to receive the signature. Must be 64 bytes. 
Fc9-u8-icon.png - BYTE message
Buffer containing the data to sign 
Fc9-u16-icon.png - UINT message_size
Byte count of the message 
Fc9-u8-icon.png - BYTE secret_key
Secret/Private key to be used.Size is 64 bytes. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png secretbox_keygen
Creates a secret key suitable for use with the secretbox functions. You must provide a 32 byte array for the key. 
Fc9-u8-icon.png - BYTE key
 
Fc9-void-icon.png - VOID Return


Fc9-comp-macro.png hash_with_key
Creates a hash fingerprint of the data, using the given key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE hash
Buffer for the hash. Size >=32 makes it practically impossible for two messages to produce the same fingerprint. 
Fc9-u8-icon.png - BYTE data
The data buffer to be processed 
Fc9-u16-icon.png - UINT size
Byte count of the data to be processed 
Fc9-u8-icon.png - BYTE key
Key to be used 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png sign_verify
Verify the signature of a mesasge using the public key. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE signature
Buffer to receive the signature. Must be 64 bytes. 
Fc9-u8-icon.png - BYTE message
Buffer containing the data to sign 
Fc9-u16-icon.png - UINT message_size
Byte count of the message 
Fc9-u8-icon.png - BYTE public_key
Public key to be used.Size is 32 bytes. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png init
Initialisation function. To be called at the very start of your program. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png sign_keygen
Creates Private and Public key pair to sign and verify messages. Returns 0 if successful. 
Fc9-u8-icon.png - BYTE Secret
Buffer to receive the Private/Secret Key. Buffer size must be 64 bytes 
Fc9-u8-icon.png - BYTE Public
Buffer to receive the Public key. Buffer size must be 32 bytes 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png secretbox_encrypt
Encrypts a message with a secret key. A single key is used both to encrypt/sign and verify/decrypt messages. For this reason, it is critical to keep the key confidential. Returns 0 on success. 
Fc9-u8-icon.png - BYTE message
Buffer containing the message to be encrypted. 
Fc9-u16-icon.png - UINT length
The length (byte count) of the message 
Fc9-u16-icon.png - UINT ID
Message ID. Can be 0 
Fc9-u8-icon.png - BYTE key
The secret key 
Fc9-u8-icon.png - BYTE ciphertext
Buffer for ciphertext output. Buffer size must be at least length + 36 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png hash_keygen
Creates a secret key suitable for use with the hash_hash function. You must provide a 32 byte array for the key. 
Fc9-u8-icon.png - BYTE key
 
Fc9-void-icon.png - VOID Return


Fc9-comp-macro.png secretbox_decrypt
Decrypts a message with a secret key. A single key is used both to encrypt/sign and verify/decrypt messages. For this reason, it is critical to keep the key confidential. Returns 0 on success. 
Fc9-u8-icon.png - BYTE message
Buffer for the decrypted message. Size must be at least length - 36 
Fc9-u16-icon.png - UINT length
The length (byte count) of the ciphertext 
Fc9-u16-icon.png - UINT ID
Message ID. Must match with the original message ID. Can be 0 
Fc9-u8-icon.png - BYTE key
The secret key 
Fc9-u8-icon.png - BYTE ciphertext
Buffer containing the ciphertext to be decrypted. 
Fc9-s16-icon.png - INT Return


Fc9-comp-macro.png hash_without_key
Creates a hash fingerprint of the data, which will always have the same fingerprint, similar to the MD5 or SHA-1 Returns 0 if successful. 
Fc9-u8-icon.png - BYTE hash
Buffer for the hash. Size >=32 makes it practically impossible for two messages to produce the same fingerprint. 
Fc9-u8-icon.png - BYTE data
Data buffer to be processed 
Fc9-u16-icon.png - UINT size
Byte count of data to be processed 
Fc9-s16-icon.png - INT Return



Property reference

Fc9-prop-icon.png Properties