Difference between revisions of "Component: Hydro Encryption (Comms: Networking)"
From Flowcode Help
Jump to navigationJump to search| (2 intermediate revisions by the same user not shown) | |||
| Line 57: | Line 57: | ||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | === | + | |
| + | |||
| + | |||
| + | ==Macro reference== | ||
| + | |||
| + | ===hash_keygen=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | ||
| − | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | ''' | + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''hash_keygen''' | 
| |- | |- | ||
| − | | colspan="2" | Creates a secret key suitable for use with the  | + | | colspan="2" | Creates a secret key suitable for use with the hash_hash function. You must provide a 32 byte array for the key.  | 
| |- | |- | ||
| |- | |- | ||
| Line 146: | Line 118: | ||
| − | === | + | ===hash_without_key=== | 
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | ||
| − | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | ''' | + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''hash_without_key''' | 
| |- | |- | ||
| − | | colspan="2" |  | + | | 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="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| − | | width="90%" |  | + | | width="90%" | hash | 
| |- | |- | ||
| − | | colspan="2" | Buffer to  | + | | 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="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| − | | width="90%" |  | + | | width="90%" | data | 
| |- | |- | ||
| − | | colspan="2" |  | + | | colspan="2" | Data buffer to be processed  | 
| |- | |- | ||
| | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| − | | width="90%" |  | + | | width="90%" | size | 
| |- | |- | ||
| − | | colspan="2" | Byte count of  | + | | 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="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT | ||
| Line 194: | Line 161: | ||
| − | === | + | ===secretbox_decrypt=== | 
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | ||
| − | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | ''' | + | | 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="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| − | | width="90%" |  | + | | width="90%" | key | 
| |- | |- | ||
| − | | colspan="2" |  | + | | colspan="2" | The secret key  | 
| |- | |- | ||
| | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| − | | width="90%" |  | + | | width="90%" | ciphertext | 
| |- | |- | ||
| − | | colspan="2" | Buffer to  | + | | 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="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT | ||
| Line 257: | Line 239: | ||
| − | === | + | ===secretbox_keygen=== | 
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | ||
| − | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | ''' | + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''secretbox_keygen''' | 
| |- | |- | ||
| − | | colspan="2" | Creates a secret key suitable for use with the  | + | | colspan="2" | Creates a secret key suitable for use with the secretbox functions. You must provide a 32 byte array for the key.  | 
| |- | |- | ||
| |- | |- | ||
| Line 276: | Line 258: | ||
| − | === | + | ===sign_create=== | 
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | ||
| − | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | ''' | + | | 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="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| | width="90%" | message | | width="90%" | message | ||
| |- | |- | ||
| − | | colspan="2" | Buffer  | + | | colspan="2" | Buffer containing the data to sign  | 
| |- | |- | ||
| | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| − | | width="90%" |  | + | | 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'' | ||
| + | |} | ||
| + | |||
| + | |||
| + | ===sign_keygen=== | ||
| + | {| 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="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| − | | width="90%" |  | + | | width="90%" | Secret | 
| |- | |- | ||
| − | | colspan="2" |  | + | | 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="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| − | | width="90%" |  | + | | width="90%" | Public | 
| |- | |- | ||
| − | | colspan="2" | Buffer  | + | | 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="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT | ||
| Line 315: | Line 316: | ||
| − | === | + | ===sign_verify=== | 
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | | width="10%" align="center" style="background-color:#D8C9D8;" align="center" | [[File:Fc9-comp-macro.png]] | ||
| − | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | ''' | + | | width="90%" style="background-color:#D8C9D8; color:#4B008D;" | '''sign_verify''' | 
| |- | |- | ||
| − | | colspan="2" |  | + | | 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="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| − | | width="90%" |  | + | | width="90%" | signature | 
| |- | |- | ||
| − | | colspan="2" | Buffer  | + | | colspan="2" | Buffer to receive the signature. Must be 64 bytes.  | 
| |- | |- | ||
| | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | | width="10%" align="center" | [[File:Fc9-u8-icon.png]] - BYTE | ||
| − | | width="90%" |  | + | | width="90%" | message | 
| |- | |- | ||
| − | | colspan="2" |  | + | | colspan="2" | Buffer containing the data to sign  | 
| |- | |- | ||
| | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | | width="10%" align="center" | [[File:Fc9-u16-icon.png]] - UINT | ||
| − | | width="90%" |  | + | | 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" |  | + | | 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="10%" align="center" style="border-top: 2px solid #000;" | [[File:Fc9-s16-icon.png]] - INT | ||
| | width="90%" style="border-top: 2px solid #000;" | ''Return'' | | width="90%" style="border-top: 2px solid #000;" | ''Return'' | ||
| |} | |} | ||
| − | |||
| − | |||
Latest revision as of 13:13, 7 February 2023
| Author | |
| Version | 1.0 | 
| Category | Comms: Networking | 
Contents
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
hash_keygen
|   | hash_keygen | 
| Creates a secret key suitable for use with the hash_hash function. You must provide a 32 byte array for the key. | |
|  - BYTE | key | 
|  - VOID | Return | 
hash_with_key
hash_without_key
init
|   | init | 
| Initialisation function. To be called at the very start of your program. | |
|  - INT | Return | 
secretbox_decrypt
secretbox_encrypt
secretbox_keygen
|   | secretbox_keygen | 
| Creates a secret key suitable for use with the secretbox functions. You must provide a 32 byte array for the key. | |
|  - BYTE | key | 
|  - VOID | Return | 
sign_create
sign_keygen
sign_verify
Property reference
|   | Properties | 

