2015-01-08 18:37:20 +01:00
|
|
|
/*
|
|
|
|
This file is part of TALER
|
2015-02-08 00:16:22 +01:00
|
|
|
Copyright (C) 2014 Christian Grothoff (and other contributing authors)
|
2015-01-08 18:37:20 +01:00
|
|
|
|
|
|
|
TALER 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, or (at your option) any later version.
|
|
|
|
|
|
|
|
TALER 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.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License along with
|
|
|
|
TALER; see the file COPYING. If not, If not, see <http://www.gnu.org/licenses/>
|
|
|
|
*/
|
|
|
|
/**
|
2015-01-09 18:18:59 +01:00
|
|
|
* @file taler_signatures.h
|
|
|
|
* @brief message formats and signature constants used to define
|
|
|
|
* the binary formats of signatures in Taler
|
2015-01-08 18:37:20 +01:00
|
|
|
* @author Florian Dold
|
|
|
|
* @author Benedikt Mueller
|
2015-01-09 18:18:59 +01:00
|
|
|
*
|
|
|
|
* This file should define the constants and C structs that one
|
|
|
|
* needs to know to implement Taler clients (wallets or merchants)
|
|
|
|
* that need to produce or verify Taler signatures.
|
2015-01-08 18:37:20 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef TALER_SIGNATURES_H
|
|
|
|
#define TALER_SIGNATURES_H
|
|
|
|
|
2015-01-09 18:18:59 +01:00
|
|
|
#include <gnunet/gnunet_util_lib.h>
|
2015-01-28 14:55:25 +01:00
|
|
|
#include "taler_util.h"
|
2015-01-09 18:18:59 +01:00
|
|
|
|
2015-01-08 18:37:20 +01:00
|
|
|
/**
|
|
|
|
* Purpose for signing public keys signed
|
|
|
|
* by the mint master key.
|
|
|
|
*/
|
|
|
|
#define TALER_SIGNATURE_MASTER_SIGNKEY 1
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Purpose for denomination keys signed
|
|
|
|
* by the mint master key.
|
|
|
|
*/
|
|
|
|
#define TALER_SIGNATURE_MASTER_DENOM 2
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Purpose for the state of a reserve,
|
|
|
|
* signed by the mint's signing key.
|
|
|
|
*/
|
|
|
|
#define TALER_SIGNATURE_RESERVE_STATUS 3
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Signature where the reserve key
|
|
|
|
* confirms a withdraw request.
|
|
|
|
*/
|
|
|
|
#define TALER_SIGNATURE_WITHDRAW 4
|
|
|
|
|
|
|
|
/**
|
2015-03-10 16:15:14 +01:00
|
|
|
* Signature using a coin key confirming the melting of
|
|
|
|
* a coin.
|
2015-01-08 18:37:20 +01:00
|
|
|
*/
|
2015-03-10 16:15:14 +01:00
|
|
|
#define TALER_SIGNATURE_REFRESH_MELT_COIN 5
|
2015-01-08 18:37:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Signature where the refresh session confirms
|
|
|
|
* the commits.
|
|
|
|
*/
|
2015-03-10 17:00:12 +01:00
|
|
|
#define TALER_SIGNATURE_REFRESH_MELT_SESSION 6
|
2015-01-08 18:37:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Signature where the mint (current signing key)
|
2015-03-10 16:15:14 +01:00
|
|
|
* confirms the no-reveal index for cut-and-choose and
|
|
|
|
* the validity of the melted coins.
|
2015-01-08 18:37:20 +01:00
|
|
|
*/
|
|
|
|
#define TALER_SIGNATURE_REFRESH_MELT_RESPONSE 7
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Signature where coins confirm that they want
|
|
|
|
* to be melted into a certain session.
|
|
|
|
*/
|
|
|
|
#define TALER_SIGNATURE_REFRESH_MELT_CONFIRM 9
|
|
|
|
|
2015-01-28 19:48:41 +01:00
|
|
|
/**
|
|
|
|
* Signature where the Mint confirms a deposit request.
|
|
|
|
*/
|
|
|
|
#define TALER_SIGNATURE_MINT_DEPOSIT 10
|
|
|
|
|
|
|
|
|
2015-01-08 18:37:20 +01:00
|
|
|
/***********************/
|
|
|
|
/* Merchant signatures */
|
|
|
|
/***********************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Signature where the merchant confirms a contract
|
|
|
|
*/
|
|
|
|
#define TALER_SIGNATURE_MERCHANT_CONTRACT 101
|
|
|
|
|
|
|
|
/*********************/
|
|
|
|
/* Wallet signatures */
|
|
|
|
/*********************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Signature made by the wallet of a user to confirm a deposit permission
|
|
|
|
*/
|
2015-01-28 19:48:41 +01:00
|
|
|
#define TALER_SIGNATURE_WALLET_DEPOSIT 201
|
2015-01-08 18:37:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Signature made by the wallet of a user to confirm a incremental deposit permission
|
|
|
|
*/
|
2015-01-28 19:48:41 +01:00
|
|
|
#define TALER_SIGNATURE_INCREMENTAL_WALLET_DEPOSIT 202
|
2015-01-08 18:37:20 +01:00
|
|
|
|
2015-01-09 18:18:59 +01:00
|
|
|
|
|
|
|
|
|
|
|
GNUNET_NETWORK_STRUCT_BEGIN
|
|
|
|
|
|
|
|
/**
|
2015-01-26 12:22:26 +01:00
|
|
|
* Format used for to generate the signature on a request to withdraw
|
|
|
|
* coins from a reserve.
|
2015-01-09 18:18:59 +01:00
|
|
|
*/
|
|
|
|
struct TALER_WithdrawRequest
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Purpose must be #TALER_SIGNATURE_WITHDRAW.
|
|
|
|
*/
|
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
|
|
|
|
|
|
|
/**
|
2015-01-26 12:22:26 +01:00
|
|
|
* Reserve public key (which reserve to withdraw from). This is
|
|
|
|
* the public key which must match the signature.
|
2015-01-09 18:18:59 +01:00
|
|
|
*/
|
|
|
|
struct GNUNET_CRYPTO_EddsaPublicKey reserve_pub;
|
|
|
|
|
|
|
|
/**
|
2015-01-26 12:22:26 +01:00
|
|
|
* Hash of the denomination public key for the coin that is withdrawn.
|
2015-01-09 18:18:59 +01:00
|
|
|
*/
|
2015-01-26 12:22:26 +01:00
|
|
|
struct GNUNET_HashCode h_denomination_pub;
|
2015-01-09 18:18:59 +01:00
|
|
|
|
|
|
|
/**
|
2015-01-26 12:22:26 +01:00
|
|
|
* Hash of the (blinded) message to be signed by the Mint.
|
2015-01-09 18:18:59 +01:00
|
|
|
*/
|
2015-01-26 12:22:26 +01:00
|
|
|
struct GNUNET_HashCode h_coin_envelope;
|
2015-01-09 18:18:59 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2015-01-28 14:55:25 +01:00
|
|
|
/**
|
|
|
|
* Format used to generate the signature on a request to deposit
|
|
|
|
* a coin into the account of a merchant.
|
|
|
|
*/
|
|
|
|
struct TALER_DepositRequest
|
|
|
|
{
|
|
|
|
/**
|
2015-01-28 19:48:41 +01:00
|
|
|
* Purpose must be #TALER_SIGNATURE_WALLET_DEPOSIT
|
2015-01-28 14:55:25 +01:00
|
|
|
*/
|
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hash over the contract for which this deposit is made.
|
|
|
|
*/
|
|
|
|
struct GNUNET_HashCode h_contract;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hash over the wiring information of the merchant.
|
|
|
|
*/
|
|
|
|
struct GNUNET_HashCode h_wire;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Merchant-generated transaction ID to detect duplicate
|
|
|
|
* transactions.
|
|
|
|
*/
|
|
|
|
uint64_t transaction_id GNUNET_PACKED;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Amount to be deposited.
|
|
|
|
*/
|
|
|
|
struct TALER_AmountNBO amount;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The coin's public key.
|
|
|
|
*/
|
|
|
|
struct GNUNET_CRYPTO_EcdsaPublicKey coin_pub;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2015-01-09 18:18:59 +01:00
|
|
|
|
2015-01-28 19:48:41 +01:00
|
|
|
/**
|
|
|
|
* Format used to generate the signature on a confirmation
|
|
|
|
* from the mint that a deposit request succeeded.
|
|
|
|
*/
|
|
|
|
struct TALER_DepositConfirmation
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Purpose must be #TALER_SIGNATURE_MINT_DEPOSIT
|
|
|
|
*/
|
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hash over the contract for which this deposit is made.
|
|
|
|
*/
|
|
|
|
struct GNUNET_HashCode h_contract;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hash over the wiring information of the merchant.
|
|
|
|
*/
|
|
|
|
struct GNUNET_HashCode h_wire;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Merchant-generated transaction ID to detect duplicate
|
|
|
|
* transactions.
|
|
|
|
*/
|
|
|
|
uint64_t transaction_id GNUNET_PACKED;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Amount to be deposited.
|
|
|
|
*/
|
|
|
|
struct TALER_AmountNBO amount;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The coin's public key.
|
|
|
|
*/
|
|
|
|
struct GNUNET_CRYPTO_EcdsaPublicKey coin_pub;
|
|
|
|
|
|
|
|
/**
|
2015-03-10 17:00:12 +01:00
|
|
|
* The Merchant's public key.
|
2015-01-28 19:48:41 +01:00
|
|
|
*/
|
|
|
|
struct GNUNET_CRYPTO_EddsaPublicKey merchant;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2015-01-29 20:00:21 +01:00
|
|
|
/**
|
2015-03-10 16:15:14 +01:00
|
|
|
* Message signed by a coin to indicate that the coin should
|
|
|
|
* be melted.
|
2015-01-29 20:00:21 +01:00
|
|
|
*/
|
2015-03-10 17:00:12 +01:00
|
|
|
struct RefreshMeltCoinSignature
|
2015-01-29 20:00:21 +01:00
|
|
|
{
|
|
|
|
/**
|
2015-03-10 16:15:14 +01:00
|
|
|
* Purpose is #TALER_SIGNATURE_REFRESH_MELT_COIN.
|
2015-01-29 20:00:21 +01:00
|
|
|
*/
|
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
|
|
|
|
2015-03-10 16:15:14 +01:00
|
|
|
/**
|
|
|
|
* Which melting operation should the coin become a part of.
|
|
|
|
*/
|
|
|
|
struct GNUNET_HashCode melt_hash;
|
|
|
|
|
2015-03-09 12:29:41 +01:00
|
|
|
/**
|
|
|
|
* How much of the value of the coin should be melted?
|
|
|
|
* This amount includes the fees, so the final amount contributed
|
|
|
|
* to the melt is this value minus the fee for melting the coin.
|
|
|
|
*/
|
|
|
|
struct TALER_AmountNBO amount;
|
2015-03-10 17:00:12 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The coin's public key.
|
|
|
|
*/
|
|
|
|
struct GNUNET_CRYPTO_EcdsaPublicKey coin_pub;
|
2015-01-09 18:18:59 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2015-03-10 17:00:12 +01:00
|
|
|
* Message signed by a coin to indicate that the coin should
|
|
|
|
* be melted.
|
2015-01-09 18:18:59 +01:00
|
|
|
*/
|
2015-03-10 17:00:12 +01:00
|
|
|
struct RefreshMeltSessionSignature
|
2015-01-09 18:18:59 +01:00
|
|
|
{
|
2015-03-09 12:29:41 +01:00
|
|
|
/**
|
2015-03-10 17:00:12 +01:00
|
|
|
* Purpose is #TALER_SIGNATURE_REFRESH_MELT_SESSION
|
2015-03-09 12:29:41 +01:00
|
|
|
*/
|
2015-01-09 18:18:59 +01:00
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
2015-03-09 12:29:41 +01:00
|
|
|
|
|
|
|
/**
|
2015-03-10 17:00:12 +01:00
|
|
|
* Which melting operation should the coin become a part of.
|
|
|
|
*/
|
|
|
|
struct GNUNET_HashCode melt_hash;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Public key of the refresh session for which
|
|
|
|
* @e melt_client_signature must be a valid signature.
|
2015-03-09 12:29:41 +01:00
|
|
|
*/
|
2015-03-10 17:00:12 +01:00
|
|
|
struct GNUNET_CRYPTO_EddsaPublicKey session_key;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* What is the total value of the coins created during the
|
|
|
|
* refresh, excluding fees?
|
|
|
|
*/
|
|
|
|
struct TALER_AmountNBO amount;
|
2015-01-09 18:18:59 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2015-03-10 16:15:14 +01:00
|
|
|
* Format of the block signed by the Mint in response to a successful
|
|
|
|
* "/refresh/melt" request. Hereby the mint affirms that all of the
|
|
|
|
* coins were successfully melted. This also commits the mint to a
|
|
|
|
* particular index to not be revealed during the refresh.
|
2015-01-09 18:18:59 +01:00
|
|
|
*/
|
2015-03-10 16:15:14 +01:00
|
|
|
struct RefreshMeltResponseSignatureBody
|
2015-01-09 18:18:59 +01:00
|
|
|
{
|
2015-03-09 12:29:41 +01:00
|
|
|
/**
|
|
|
|
* Purpose is #TALER_SIGNATURE_REFRESH_MELT_RESPONSE.
|
|
|
|
*/
|
2015-01-09 18:18:59 +01:00
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
2015-03-09 12:29:41 +01:00
|
|
|
|
2015-03-09 13:21:55 +01:00
|
|
|
/**
|
|
|
|
* Hash of the refresh session.
|
|
|
|
*/
|
|
|
|
struct GNUNET_HashCode session_hash;
|
|
|
|
|
2015-03-09 12:29:41 +01:00
|
|
|
/**
|
|
|
|
* Index that the client will not have to reveal.
|
|
|
|
*/
|
|
|
|
uint16_t noreveal_index GNUNET_PACKED;
|
2015-01-09 18:18:59 +01:00
|
|
|
};
|
|
|
|
|
2015-03-09 12:29:41 +01:00
|
|
|
|
2015-01-09 18:18:59 +01:00
|
|
|
/**
|
2015-03-09 12:29:41 +01:00
|
|
|
* Message signed by the client requesting the final
|
|
|
|
* result of the melting operation.
|
2015-01-09 18:18:59 +01:00
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct RefreshMeltConfirmSignRequestBody
|
2015-01-09 18:18:59 +01:00
|
|
|
{
|
2015-03-09 12:29:41 +01:00
|
|
|
/**
|
|
|
|
* Purpose is #TALER_SIGNATURE_REFRESH_MELT_CONFIRM.
|
|
|
|
*/
|
2015-01-09 18:18:59 +01:00
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
2015-03-09 12:29:41 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* FIXME.
|
|
|
|
*/
|
|
|
|
struct GNUNET_CRYPTO_EddsaPublicKey session_pub;
|
2015-01-09 18:18:59 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* FIXME
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct TALER_MINT_SignKeyIssue
|
2015-01-09 18:18:59 +01:00
|
|
|
{
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_CRYPTO_EddsaSignature signature;
|
2015-01-09 18:18:59 +01:00
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_CRYPTO_EddsaPublicKey master_pub;
|
|
|
|
struct GNUNET_TIME_AbsoluteNBO start;
|
|
|
|
struct GNUNET_TIME_AbsoluteNBO expire;
|
|
|
|
struct GNUNET_CRYPTO_EddsaPublicKey signkey_pub;
|
2015-01-09 18:18:59 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* FIXME
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct TALER_MINT_DenomKeyIssue
|
2015-01-09 18:18:59 +01:00
|
|
|
{
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_CRYPTO_EddsaSignature signature;
|
2015-01-09 18:18:59 +01:00
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_CRYPTO_EddsaPublicKey master;
|
|
|
|
struct GNUNET_TIME_AbsoluteNBO start;
|
|
|
|
struct GNUNET_TIME_AbsoluteNBO expire_withdraw;
|
|
|
|
struct GNUNET_TIME_AbsoluteNBO expire_spend;
|
|
|
|
// FIXME: does not work like this:
|
|
|
|
struct GNUNET_CRYPTO_rsa_PublicKey * denom_pub;
|
|
|
|
struct TALER_AmountNBO value;
|
|
|
|
struct TALER_AmountNBO fee_withdraw;
|
|
|
|
struct TALER_AmountNBO fee_deposit;
|
|
|
|
struct TALER_AmountNBO fee_refresh;
|
2015-01-09 18:18:59 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2015-03-09 12:29:41 +01:00
|
|
|
|
2015-01-09 18:18:59 +01:00
|
|
|
GNUNET_NETWORK_STRUCT_END
|
|
|
|
|
2015-01-08 18:37:20 +01:00
|
|
|
#endif
|