|
- /**
- * @file decaf_crypto.h
- * @copyright
- * Copyright (c) 2015 Cryptography Research, Inc. \n
- * Released under the MIT License. See LICENSE.txt for license information.
- * @author Mike Hamburg
- * @brief Example Decaf cyrpto routines.
- * @warning These are merely examples, though they ought to be secure. But real
- * protocols will decide differently on magic numbers, formats, which items to
- * hash, etc.
- * @warning Experimental! The names, parameter orders etc are likely to change.
- */
-
- #ifndef __DECAF_CRYPTO_H__
- #define __DECAF_CRYPTO_H__ 1
-
- #include "decaf.h"
- #include "shake.h"
-
- /** Number of bytes for a symmetric key (expanded to full key) */
- #define DECAF_255_SYMMETRIC_KEY_BYTES 32
-
- /** @cond internal */
- #define API_VIS __attribute__((visibility("default"))) __attribute__((noinline)) // TODO: synergize with decaf.h
- #define WARN_UNUSED __attribute__((warn_unused_result))
- #define NONNULL1 __attribute__((nonnull(1)))
- #define NONNULL2 __attribute__((nonnull(1,2)))
- #define NONNULL3 __attribute__((nonnull(1,2,3)))
- #define NONNULL134 __attribute__((nonnull(1,3,4)))
- #define NONNULL5 __attribute__((nonnull(1,2,3,4,5)))
- /** @endcond */
-
- /** A symmetric key, the compressed point of a private key. */
- typedef unsigned char decaf_255_symmetric_key_t[DECAF_255_SYMMETRIC_KEY_BYTES];
-
- /** An encoded public key. */
- typedef unsigned char decaf_255_public_key_t[DECAF_255_SER_BYTES];
-
- /** A signature. */
- typedef unsigned char decaf_255_signature_t[DECAF_255_SER_BYTES + DECAF_255_SCALAR_BYTES];
-
- typedef struct {
- /** @cond intetrnal */
- /** The symmetric key from which everything is expanded */
- decaf_255_symmetric_key_t sym;
-
- /** The scalar x */
- decaf_255_scalar_t secret_scalar;
-
- /** x*Base */
- decaf_255_public_key_t pub;
- /** @endcond */
- } /** Private key structure for pointers. */
- decaf_255_private_key_s,
- /** A private key (gmp array[1] style). */
- decaf_255_private_key_t[1];
-
- #ifdef __cplusplus
- extern "C" {
- #endif
-
- /**
- * @brief Derive a key from its compressed form.
- * @param [out] priv The derived private key.
- * @param [in] proto The compressed or proto-key, which must be 32 random bytes.
- */
- void decaf_255_derive_private_key (
- decaf_255_private_key_t priv,
- const decaf_255_symmetric_key_t proto
- ) NONNULL2 API_VIS;
-
- /**
- * @brief Destroy a private key.
- */
- void decaf_255_destroy_private_key (
- decaf_255_private_key_t priv
- ) NONNULL1 API_VIS;
-
- /**
- * @brief Convert a private key to a public one.
- * @param [out] pub The extracted private key.
- * @param [in] priv The private key.
- */
- void decaf_255_private_to_public (
- decaf_255_public_key_t pub,
- const decaf_255_private_key_t priv
- ) NONNULL2 API_VIS;
-
- /**
- * @brief Compute a Diffie-Hellman shared secret.
- *
- * This is an example routine; real protocols would use something
- * protocol-specific.
- *
- * @param [out] shared A buffer to store the shared secret.
- * @param [in] shared_bytes The size of the buffer.
- * @param [in] my_privkey My private key.
- * @param [in] your_pubkey Your public key.
- *
- * @retval DECAF_SUCCESS Key exchange was successful.
- * @retval DECAF_FAILURE Key exchange failed.
- *
- * @warning This is a pretty silly shared secret computation
- * and will almost definitely change in the future.
- */
- decaf_bool_t
- decaf_255_shared_secret (
- uint8_t *shared,
- size_t shared_bytes,
- const decaf_255_private_key_t my_privkey,
- const decaf_255_public_key_t your_pubkey
- ) NONNULL134 WARN_UNUSED API_VIS;
-
- /**
- * @brief Sign a message from its SHAKE context.
- *
- * @param [out] sig The signature.
- * @param [in] priv Your private key.
- * @param [in] shake A SHAKE256 context with the message.
- */
- void
- decaf_255_sign_shake (
- decaf_255_signature_t sig,
- const decaf_255_private_key_t priv,
- const keccak_sponge_t shake
- ) NONNULL3 API_VIS;
-
- /**
- * @brief Sign a message from its SHAKE context.
- *
- * @param [out] sig The signature.
- * @param [in] priv Your private key.
- * @param [in] message The message.
- * @param [in] message_len The message's length.
- */
- void
- decaf_255_sign (
- decaf_255_signature_t sig,
- const decaf_255_private_key_t priv,
- const unsigned char *message,
- size_t message_len
- ) NONNULL3 API_VIS;
-
- /**
- * @brief Verify a signed message from its SHAKE context.
- *
- * @param [in] sig The signature.
- * @param [in] pub The public key.
- * @param [in] shake A SHAKE256 context with the message.
- */
- decaf_bool_t
- decaf_255_verify_shake (
- const decaf_255_signature_t sig,
- const decaf_255_public_key_t pub,
- const keccak_sponge_t shake
- ) NONNULL3 API_VIS WARN_UNUSED;
-
- /**
- * @brief Verify a signed message.
- *
- * @param [in] sig The signature.
- * @param [in] pub The public key.
- * @param [in] message The message.
- * @param [in] message_len The message's length.
- */
- decaf_bool_t
- decaf_255_verify (
- const decaf_255_signature_t sig,
- const decaf_255_public_key_t pub,
- const unsigned char *message,
- size_t message_len
- ) NONNULL3 API_VIS WARN_UNUSED;
-
- #undef API_VIS
- #undef WARN_UNUSED
- #undef NONNULL1
- #undef NONNULL2
- #undef NONNULL3
- #undef NONNULL134
- #undef NONNULL5
-
- #ifdef __cplusplus
- } /* extern "C" */
- #endif
-
- #endif /* __DECAF_CRYPTO_H__ */
-
|