2017-01-14 23:46:31 +08:00
|
|
|
/*
|
2016-12-10 19:21:22 +08:00
|
|
|
* Batch encryption functions.
|
2017-01-14 23:46:31 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2018-08-26 07:36:42 +08:00
|
|
|
* Copyright © 2016-2018 The TokTok team.
|
2017-01-14 23:46:31 +08:00
|
|
|
* Copyright © 2013-2016 Tox Developers.
|
2014-09-10 01:23:09 +08:00
|
|
|
*
|
2017-01-14 23:46:31 +08:00
|
|
|
* This file is part of Tox, the free peer to peer instant messenger.
|
2014-09-10 01:23:09 +08:00
|
|
|
*
|
2017-01-14 23:46:31 +08:00
|
|
|
* Tox is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
2014-09-10 01:23:09 +08:00
|
|
|
*
|
2017-01-14 23:46:31 +08:00
|
|
|
* Tox is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
2014-09-10 01:23:09 +08:00
|
|
|
*
|
2017-01-14 23:46:31 +08:00
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with Tox. If not, see <http://www.gnu.org/licenses/>.
|
2014-09-10 01:23:09 +08:00
|
|
|
*/
|
2018-09-10 03:54:05 +08:00
|
|
|
#ifndef C_TOXCORE_TOXENCRYPTSAVE_TOXENCRYPTSAVE_H
|
|
|
|
#define C_TOXCORE_TOXENCRYPTSAVE_TOXENCRYPTSAVE_H
|
2014-09-10 01:23:09 +08:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-04-01 07:15:59 +08:00
|
|
|
#include <stdbool.h>
|
2016-09-01 07:33:20 +08:00
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdint.h>
|
2014-09-15 01:08:01 +08:00
|
|
|
|
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/*******************************************************************************
|
|
|
|
*
|
|
|
|
* This module is organized into two parts.
|
|
|
|
*
|
|
|
|
* 1. A simple API operating on plain text/cipher text data and a password to
|
|
|
|
* encrypt or decrypt it.
|
|
|
|
* 2. A more advanced API that splits key derivation and encryption into two
|
|
|
|
* separate function calls.
|
|
|
|
*
|
|
|
|
* The first part is implemented in terms of the second part and simply calls
|
|
|
|
* the separate functions in sequence. Since key derivation is very expensive
|
|
|
|
* compared to the actual encryption, clients that do a lot of crypto should
|
|
|
|
* prefer the advanced API and reuse pass-key objects.
|
|
|
|
*
|
|
|
|
* To use the second part, first derive an encryption key from a password with
|
2016-12-14 17:17:19 +08:00
|
|
|
* tox_pass_key_derive, then use the derived key to encrypt the data.
|
2016-12-10 19:21:22 +08:00
|
|
|
*
|
|
|
|
* The encrypted data is prepended with a magic number, to aid validity
|
|
|
|
* checking (no guarantees are made of course). Any data to be decrypted must
|
|
|
|
* start with the magic number.
|
|
|
|
*
|
|
|
|
* Clients should consider alerting their users that, unlike plain data, if
|
|
|
|
* even one bit becomes corrupted, the data will be entirely unrecoverable.
|
|
|
|
* Ditto if they forget their password, there is no way to recover the data.
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
|
2014-09-15 01:08:01 +08:00
|
|
|
|
2016-02-14 12:50:16 +08:00
|
|
|
/**
|
2016-12-10 19:21:22 +08:00
|
|
|
* The size of the salt part of a pass-key.
|
2016-02-14 12:50:16 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
#define TOX_PASS_SALT_LENGTH 32
|
|
|
|
|
|
|
|
uint32_t tox_pass_salt_length(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The size of the key part of a pass-key.
|
2014-10-23 17:19:18 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
#define TOX_PASS_KEY_LENGTH 32
|
|
|
|
|
|
|
|
uint32_t tox_pass_key_length(void);
|
2014-10-23 17:19:18 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/**
|
|
|
|
* The amount of additional data required to store any encrypted byte array.
|
|
|
|
* Encrypting an array of N bytes requires N + TOX_PASS_ENCRYPTION_EXTRA_LENGTH
|
|
|
|
* bytes in the encrypted byte array.
|
2015-04-02 04:26:09 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
#define TOX_PASS_ENCRYPTION_EXTRA_LENGTH 80
|
|
|
|
|
|
|
|
uint32_t tox_pass_encryption_extra_length(void);
|
2015-04-02 04:26:09 +08:00
|
|
|
|
2015-04-01 07:15:59 +08:00
|
|
|
typedef enum TOX_ERR_KEY_DERIVATION {
|
2016-12-10 19:21:22 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The function returned successfully.
|
|
|
|
*/
|
2015-04-01 07:15:59 +08:00
|
|
|
TOX_ERR_KEY_DERIVATION_OK,
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-03-27 00:39:09 +08:00
|
|
|
/**
|
2016-12-10 19:21:22 +08:00
|
|
|
* One of the arguments to the function was NULL when it was not expected.
|
2015-03-27 00:39:09 +08:00
|
|
|
*/
|
2015-04-01 07:15:59 +08:00
|
|
|
TOX_ERR_KEY_DERIVATION_NULL,
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-03-27 00:39:09 +08:00
|
|
|
/**
|
2015-04-01 07:15:59 +08:00
|
|
|
* The crypto lib was unable to derive a key from the given passphrase,
|
2016-12-16 11:00:55 +08:00
|
|
|
* which is usually a lack of memory issue.
|
2015-03-27 00:39:09 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
TOX_ERR_KEY_DERIVATION_FAILED,
|
|
|
|
|
2015-04-01 07:15:59 +08:00
|
|
|
} TOX_ERR_KEY_DERIVATION;
|
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-04-01 07:15:59 +08:00
|
|
|
typedef enum TOX_ERR_ENCRYPTION {
|
2016-12-10 19:21:22 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The function returned successfully.
|
|
|
|
*/
|
2015-04-01 07:15:59 +08:00
|
|
|
TOX_ERR_ENCRYPTION_OK,
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-03-27 00:39:09 +08:00
|
|
|
/**
|
2016-12-10 19:21:22 +08:00
|
|
|
* One of the arguments to the function was NULL when it was not expected.
|
2015-03-27 00:39:09 +08:00
|
|
|
*/
|
2015-04-01 07:15:59 +08:00
|
|
|
TOX_ERR_ENCRYPTION_NULL,
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-03-27 00:39:09 +08:00
|
|
|
/**
|
2015-04-01 07:15:59 +08:00
|
|
|
* The crypto lib was unable to derive a key from the given passphrase,
|
|
|
|
* which is usually a lack of memory issue. The functions accepting keys
|
|
|
|
* do not produce this error.
|
2015-03-27 00:39:09 +08:00
|
|
|
*/
|
2015-04-01 07:15:59 +08:00
|
|
|
TOX_ERR_ENCRYPTION_KEY_DERIVATION_FAILED,
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-03-27 00:39:09 +08:00
|
|
|
/**
|
2015-04-01 07:15:59 +08:00
|
|
|
* The encryption itself failed.
|
2015-03-27 00:39:09 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
TOX_ERR_ENCRYPTION_FAILED,
|
|
|
|
|
2015-04-01 07:15:59 +08:00
|
|
|
} TOX_ERR_ENCRYPTION;
|
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-04-01 07:15:59 +08:00
|
|
|
typedef enum TOX_ERR_DECRYPTION {
|
2016-12-10 19:21:22 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The function returned successfully.
|
|
|
|
*/
|
2015-04-01 07:15:59 +08:00
|
|
|
TOX_ERR_DECRYPTION_OK,
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-04-01 07:15:59 +08:00
|
|
|
/**
|
2016-12-10 19:21:22 +08:00
|
|
|
* One of the arguments to the function was NULL when it was not expected.
|
2015-04-01 07:15:59 +08:00
|
|
|
*/
|
|
|
|
TOX_ERR_DECRYPTION_NULL,
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-03-27 00:39:09 +08:00
|
|
|
/**
|
2015-04-01 07:15:59 +08:00
|
|
|
* The input data was shorter than TOX_PASS_ENCRYPTION_EXTRA_LENGTH bytes
|
2015-03-27 00:39:09 +08:00
|
|
|
*/
|
2015-04-01 07:15:59 +08:00
|
|
|
TOX_ERR_DECRYPTION_INVALID_LENGTH,
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-03-27 00:39:09 +08:00
|
|
|
/**
|
2015-04-01 07:15:59 +08:00
|
|
|
* The input data is missing the magic number (i.e. wasn't created by this
|
2016-12-10 19:21:22 +08:00
|
|
|
* module, or is corrupted).
|
2015-03-27 00:39:09 +08:00
|
|
|
*/
|
2015-04-01 07:15:59 +08:00
|
|
|
TOX_ERR_DECRYPTION_BAD_FORMAT,
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-03-27 00:39:09 +08:00
|
|
|
/**
|
2015-04-01 07:15:59 +08:00
|
|
|
* The crypto lib was unable to derive a key from the given passphrase,
|
|
|
|
* which is usually a lack of memory issue. The functions accepting keys
|
|
|
|
* do not produce this error.
|
2015-03-27 00:39:09 +08:00
|
|
|
*/
|
2015-04-01 07:15:59 +08:00
|
|
|
TOX_ERR_DECRYPTION_KEY_DERIVATION_FAILED,
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2015-03-27 00:39:09 +08:00
|
|
|
/**
|
|
|
|
* The encrypted byte array could not be decrypted. Either the data was
|
2016-12-10 19:21:22 +08:00
|
|
|
* corrupted or the password/key was incorrect.
|
2015-03-27 00:39:09 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
TOX_ERR_DECRYPTION_FAILED,
|
|
|
|
|
2015-04-01 07:15:59 +08:00
|
|
|
} TOX_ERR_DECRYPTION;
|
|
|
|
|
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
*
|
|
|
|
* BEGIN PART 1
|
|
|
|
*
|
|
|
|
* The simple API is presented first. If your code spends too much time using
|
|
|
|
* these functions, consider using the advanced functions instead and caching
|
|
|
|
* the generated pass-key.
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Encrypts the given data with the given passphrase.
|
|
|
|
*
|
|
|
|
* The output array must be at least `plaintext_len + TOX_PASS_ENCRYPTION_EXTRA_LENGTH`
|
|
|
|
* bytes long. This delegates to tox_pass_key_derive and
|
|
|
|
* tox_pass_key_encrypt.
|
|
|
|
*
|
|
|
|
* @param plaintext A byte array of length `plaintext_len`.
|
2016-12-16 19:32:09 +08:00
|
|
|
* @param plaintext_len The length of the plain text array. Bigger than 0.
|
2017-01-08 23:18:36 +08:00
|
|
|
* @param passphrase The user-provided password. Can be empty.
|
2016-12-10 19:21:22 +08:00
|
|
|
* @param passphrase_len The length of the password.
|
|
|
|
* @param ciphertext The cipher text array to write the encrypted data to.
|
|
|
|
*
|
|
|
|
* @return true on success.
|
2015-04-01 07:15:59 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
bool tox_pass_encrypt(const uint8_t *plaintext, size_t plaintext_len, const uint8_t *passphrase, size_t passphrase_len,
|
|
|
|
uint8_t *ciphertext, TOX_ERR_ENCRYPTION *error);
|
2015-04-01 07:15:59 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/**
|
|
|
|
* Decrypts the given data with the given passphrase.
|
2015-04-01 07:15:59 +08:00
|
|
|
*
|
2016-12-10 19:21:22 +08:00
|
|
|
* The output array must be at least `ciphertext_len - TOX_PASS_ENCRYPTION_EXTRA_LENGTH`
|
|
|
|
* bytes long. This delegates to tox_pass_key_decrypt.
|
|
|
|
*
|
|
|
|
* @param ciphertext A byte array of length `ciphertext_len`.
|
2016-12-16 19:32:09 +08:00
|
|
|
* @param ciphertext_len The length of the cipher text array. At least TOX_PASS_ENCRYPTION_EXTRA_LENGTH.
|
2017-01-08 23:18:36 +08:00
|
|
|
* @param passphrase The user-provided password. Can be empty.
|
2016-12-10 19:21:22 +08:00
|
|
|
* @param passphrase_len The length of the password.
|
|
|
|
* @param plaintext The plain text array to write the decrypted data to.
|
|
|
|
*
|
|
|
|
* @return true on success.
|
2015-04-01 07:15:59 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
bool tox_pass_decrypt(const uint8_t *ciphertext, size_t ciphertext_len, const uint8_t *passphrase,
|
|
|
|
size_t passphrase_len, uint8_t *plaintext, TOX_ERR_DECRYPTION *error);
|
2015-03-27 00:39:09 +08:00
|
|
|
|
2015-04-01 07:15:59 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/*******************************************************************************
|
2015-04-01 07:15:59 +08:00
|
|
|
*
|
2016-12-10 19:21:22 +08:00
|
|
|
* BEGIN PART 2
|
2014-10-17 19:02:15 +08:00
|
|
|
*
|
2016-12-10 19:21:22 +08:00
|
|
|
* And now part 2, which does the actual encryption, and can be used to write
|
|
|
|
* less CPU intensive client code than part one.
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
2014-10-17 19:02:15 +08:00
|
|
|
|
2014-10-23 17:19:18 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/**
|
|
|
|
* This type represents a pass-key.
|
|
|
|
*
|
|
|
|
* A pass-key and a password are two different concepts: a password is given
|
|
|
|
* by the user in plain text. A pass-key is the generated symmetric key used
|
|
|
|
* for encryption and decryption. It is derived from a salt and the user-
|
|
|
|
* provided password.
|
|
|
|
*
|
2016-12-16 11:00:55 +08:00
|
|
|
* The Tox_Pass_Key structure is hidden in the implementation. It can be created
|
|
|
|
* using tox_pass_key_derive or tox_pass_key_derive_with_salt and must be deallocated using tox_pass_key_free.
|
2014-10-23 17:19:18 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
#ifndef TOX_PASS_KEY_DEFINED
|
|
|
|
#define TOX_PASS_KEY_DEFINED
|
|
|
|
typedef struct Tox_Pass_Key Tox_Pass_Key;
|
|
|
|
#endif /* TOX_PASS_KEY_DEFINED */
|
2014-10-23 17:19:18 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/**
|
|
|
|
* Deallocate a Tox_Pass_Key. This function behaves like free(), so NULL is an
|
|
|
|
* acceptable argument value.
|
2014-10-12 15:28:18 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
void tox_pass_key_free(struct Tox_Pass_Key *_key);
|
2014-10-12 15:28:18 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/**
|
|
|
|
* Generates a secret symmetric key from the given passphrase.
|
|
|
|
*
|
|
|
|
* Be sure to not compromise the key! Only keep it in memory, do not write
|
|
|
|
* it to disk.
|
|
|
|
*
|
|
|
|
* Note that this function is not deterministic; to derive the same key from
|
|
|
|
* a password, you also must know the random salt that was used. A
|
|
|
|
* deterministic version of this function is tox_pass_key_derive_with_salt.
|
|
|
|
*
|
2017-01-08 23:18:36 +08:00
|
|
|
* @param passphrase The user-provided password. Can be empty.
|
2016-12-10 19:21:22 +08:00
|
|
|
* @param passphrase_len The length of the password.
|
|
|
|
*
|
|
|
|
* @return true on success.
|
2014-10-23 17:19:18 +08:00
|
|
|
*/
|
2016-12-16 11:00:55 +08:00
|
|
|
struct Tox_Pass_Key *tox_pass_key_derive(const uint8_t *passphrase, size_t passphrase_len,
|
|
|
|
TOX_ERR_KEY_DERIVATION *error);
|
2014-10-23 17:19:18 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/**
|
|
|
|
* Same as above, except use the given salt for deterministic key derivation.
|
2014-10-09 07:14:23 +08:00
|
|
|
*
|
2017-01-08 23:18:36 +08:00
|
|
|
* @param passphrase The user-provided password. Can be empty.
|
2016-12-10 19:21:22 +08:00
|
|
|
* @param passphrase_len The length of the password.
|
|
|
|
* @param salt An array of at least TOX_PASS_SALT_LENGTH bytes.
|
2016-12-09 16:01:36 +08:00
|
|
|
*
|
2016-12-10 19:21:22 +08:00
|
|
|
* @return true on success.
|
2014-10-23 17:19:18 +08:00
|
|
|
*/
|
2016-12-16 11:00:55 +08:00
|
|
|
struct Tox_Pass_Key *tox_pass_key_derive_with_salt(const uint8_t *passphrase, size_t passphrase_len,
|
|
|
|
const uint8_t *salt, TOX_ERR_KEY_DERIVATION *error);
|
2014-10-23 17:19:18 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/**
|
|
|
|
* Encrypt a plain text with a key produced by tox_pass_key_derive or tox_pass_key_derive_with_salt.
|
|
|
|
*
|
|
|
|
* The output array must be at least `plaintext_len + TOX_PASS_ENCRYPTION_EXTRA_LENGTH`
|
|
|
|
* bytes long.
|
|
|
|
*
|
|
|
|
* @param plaintext A byte array of length `plaintext_len`.
|
2016-12-16 19:32:09 +08:00
|
|
|
* @param plaintext_len The length of the plain text array. Bigger than 0.
|
2016-12-10 19:21:22 +08:00
|
|
|
* @param ciphertext The cipher text array to write the encrypted data to.
|
|
|
|
*
|
|
|
|
* @return true on success.
|
|
|
|
*/
|
|
|
|
bool tox_pass_key_encrypt(const struct Tox_Pass_Key *_key, const uint8_t *plaintext, size_t plaintext_len,
|
|
|
|
uint8_t *ciphertext, TOX_ERR_ENCRYPTION *error);
|
2014-10-23 17:19:18 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/**
|
|
|
|
* This is the inverse of tox_pass_key_encrypt, also using only keys produced by
|
|
|
|
* tox_pass_key_derive or tox_pass_key_derive_with_salt.
|
2014-10-09 07:14:23 +08:00
|
|
|
*
|
2016-12-10 19:21:22 +08:00
|
|
|
* @param ciphertext A byte array of length `ciphertext_len`.
|
2016-12-16 19:32:09 +08:00
|
|
|
* @param ciphertext_len The length of the cipher text array. At least TOX_PASS_ENCRYPTION_EXTRA_LENGTH.
|
2016-12-10 19:21:22 +08:00
|
|
|
* @param plaintext The plain text array to write the decrypted data to.
|
|
|
|
*
|
|
|
|
* @return true on success.
|
2014-09-10 01:23:09 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
bool tox_pass_key_decrypt(const struct Tox_Pass_Key *_key, const uint8_t *ciphertext, size_t ciphertext_len,
|
|
|
|
uint8_t *plaintext, TOX_ERR_DECRYPTION *error);
|
|
|
|
|
|
|
|
typedef enum TOX_ERR_GET_SALT {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The function returned successfully.
|
|
|
|
*/
|
|
|
|
TOX_ERR_GET_SALT_OK,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* One of the arguments to the function was NULL when it was not expected.
|
|
|
|
*/
|
|
|
|
TOX_ERR_GET_SALT_NULL,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The input data is missing the magic number (i.e. wasn't created by this
|
|
|
|
* module, or is corrupted).
|
|
|
|
*/
|
|
|
|
TOX_ERR_GET_SALT_BAD_FORMAT,
|
|
|
|
|
|
|
|
} TOX_ERR_GET_SALT;
|
2014-10-23 17:19:18 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves the salt used to encrypt the given data.
|
2014-10-23 17:19:18 +08:00
|
|
|
*
|
2016-12-10 19:21:22 +08:00
|
|
|
* The retrieved salt can then be passed to tox_pass_key_derive_with_salt to
|
|
|
|
* produce the same key as was previously used. Any data encrypted with this
|
|
|
|
* module can be used as input.
|
2014-10-17 19:02:15 +08:00
|
|
|
*
|
2016-12-10 19:21:22 +08:00
|
|
|
* The cipher text must be at least TOX_PASS_ENCRYPTION_EXTRA_LENGTH bytes in length.
|
|
|
|
* The salt must be TOX_PASS_SALT_LENGTH bytes in length.
|
|
|
|
* If the passed byte arrays are smaller than required, the behaviour is
|
|
|
|
* undefined.
|
|
|
|
*
|
2017-09-02 17:08:15 +08:00
|
|
|
* If the cipher text pointer or the salt is NULL, this function returns false.
|
|
|
|
*
|
2016-12-10 19:21:22 +08:00
|
|
|
* Success does not say anything about the validity of the data, only that
|
|
|
|
* data of the appropriate size was copied.
|
|
|
|
*
|
|
|
|
* @return true on success.
|
2014-10-17 19:02:15 +08:00
|
|
|
*/
|
2016-12-10 19:21:22 +08:00
|
|
|
bool tox_get_salt(const uint8_t *ciphertext, uint8_t *salt, TOX_ERR_GET_SALT *error);
|
2014-10-17 19:02:15 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
/**
|
|
|
|
* Determines whether or not the given data is encrypted by this module.
|
|
|
|
*
|
|
|
|
* It does this check by verifying that the magic number is the one put in
|
|
|
|
* place by the encryption functions.
|
2016-12-09 16:01:36 +08:00
|
|
|
*
|
|
|
|
* The data must be at least TOX_PASS_ENCRYPTION_EXTRA_LENGTH bytes in length.
|
2016-12-10 19:21:22 +08:00
|
|
|
* If the passed byte array is smaller than required, the behaviour is
|
|
|
|
* undefined.
|
|
|
|
*
|
2017-09-02 17:08:15 +08:00
|
|
|
* If the data pointer is NULL, the behaviour is undefined
|
2016-12-09 16:01:36 +08:00
|
|
|
*
|
2016-12-10 19:21:22 +08:00
|
|
|
* @return true if the data is encrypted by this module.
|
2014-09-12 08:29:18 +08:00
|
|
|
*/
|
2015-04-01 07:15:59 +08:00
|
|
|
bool tox_is_data_encrypted(const uint8_t *data);
|
2014-09-12 08:29:18 +08:00
|
|
|
|
2016-12-10 19:21:22 +08:00
|
|
|
|
2014-09-10 01:23:09 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2018-09-10 03:54:05 +08:00
|
|
|
#endif // C_TOXCORE_TOXENCRYPTSAVE_TOXENCRYPTSAVE_H
|