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-03-22 16:09:01 +01:00
|
|
|
/**
|
|
|
|
* Value of the coin being minted (matching the denomination key)
|
|
|
|
* plus the transaction fee. We include this in what is being
|
|
|
|
* signed so that we can verify a reserve's remaining total balance
|
|
|
|
* without needing to access the respective denomination key
|
|
|
|
* information each time.
|
|
|
|
*/
|
|
|
|
struct TALER_AmountNBO amount_with_fee;
|
|
|
|
|
2015-01-09 18:18:59 +01:00
|
|
|
/**
|
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;
|
|
|
|
|
|
|
|
/**
|
2015-03-22 16:09:01 +01:00
|
|
|
* Amount to be deposited, including fee.
|
2015-01-28 14:55:25 +01:00
|
|
|
*/
|
2015-03-22 16:09:01 +01:00
|
|
|
struct TALER_AmountNBO amount_with_fee;
|
|
|
|
/* FIXME: we should probably also include the value of
|
|
|
|
the depositing fee here as well! */
|
2015-01-28 14:55:25 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
|
|
|
|
/**
|
2015-03-22 16:09:01 +01:00
|
|
|
* Amount to be deposited, including fee.
|
2015-01-28 19:48:41 +01:00
|
|
|
*/
|
2015-03-22 16:09:01 +01:00
|
|
|
struct TALER_AmountNBO amount_with_fee;
|
|
|
|
|
|
|
|
/* FIXME: we should probably also include the value of
|
|
|
|
the depositing fee here as well! */
|
2015-01-28 19:48:41 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
|
|
/**
|
2015-03-22 16:09:01 +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. We include the
|
|
|
|
* fee in what is being signed so that we can verify a reserve's
|
|
|
|
* remaining total balance without needing to access the respective
|
|
|
|
* denomination key information each time.
|
2015-03-09 12:29:41 +01:00
|
|
|
*/
|
2015-03-22 16:09:01 +01:00
|
|
|
struct TALER_AmountNBO amount_with_fee;
|
|
|
|
|
|
|
|
/* FIXME: we should probably also include the value of
|
|
|
|
the melting fee here as well! */
|
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
|
2015-03-22 16:09:01 +01:00
|
|
|
* refresh, including melting fee!
|
2015-03-10 17:00:12 +01:00
|
|
|
*/
|
2015-03-22 16:09:01 +01:00
|
|
|
struct TALER_AmountNBO amount_with_fee;
|
|
|
|
|
|
|
|
/* FIXME: we should probably also include the value of
|
|
|
|
the melting fee here as well! */
|
|
|
|
|
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
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2015-03-15 18:18:14 +01:00
|
|
|
* Information about a signing key of the mint. Signing keys are used
|
|
|
|
* to sign mint messages other than coins, i.e. to confirm that a
|
|
|
|
* deposit was successful or that a refresh was accepted.
|
2015-01-09 18:18:59 +01:00
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct TALER_MINT_SignKeyIssue
|
2015-01-09 18:18:59 +01:00
|
|
|
{
|
2015-03-15 18:18:14 +01:00
|
|
|
/**
|
|
|
|
* Signature over the signing key (by the master key of the mint).
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_CRYPTO_EddsaSignature signature;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Purpose is #TALER_SIGNATURE_MASTER_SIGNKEY.
|
|
|
|
*/
|
2015-01-09 18:18:59 +01:00
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Master public key of the mint corresponding to @e signature.
|
|
|
|
* This is the long-term offline master key of the mint.
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_CRYPTO_EddsaPublicKey master_pub;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* When does this signing key begin to be valid?
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_TIME_AbsoluteNBO start;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* When does this signing key expire? Note: This is
|
|
|
|
* currently when the Mint will definitively stop using it.
|
|
|
|
* This does not mean that all signatures with tkey key are
|
|
|
|
* afterwards invalid.
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_TIME_AbsoluteNBO expire;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The public online signing key that the mint will use
|
|
|
|
* between @e start and @e expire.
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_CRYPTO_EddsaPublicKey signkey_pub;
|
2015-01-09 18:18:59 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2015-03-15 18:18:14 +01:00
|
|
|
* Information about a denomination key. Denomination keys
|
|
|
|
* are used to sign coins of a certain value into existence.
|
2015-01-09 18:18:59 +01:00
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct TALER_MINT_DenomKeyIssue
|
2015-01-09 18:18:59 +01:00
|
|
|
{
|
2015-03-15 18:18:14 +01:00
|
|
|
/**
|
|
|
|
* Signature over this struct to affirm the validity
|
|
|
|
* of the key.
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_CRYPTO_EddsaSignature signature;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Purpose ist #TALER_SIGNATURE_MASTER_DENOM.
|
|
|
|
*/
|
2015-01-09 18:18:59 +01:00
|
|
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The long-term offline master key of the mint that was
|
|
|
|
* used to create @e signature.
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_CRYPTO_EddsaPublicKey master;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Start time of the validity period for this key.
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_TIME_AbsoluteNBO start;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The mint will sign fresh coins between @e start and
|
|
|
|
* this time.
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_TIME_AbsoluteNBO expire_withdraw;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Coins signed with the denomination key must be spent or refreshed
|
|
|
|
* between @e start and this expiration time. After this time, the
|
|
|
|
* mint will refuse transactions involving this key as it will
|
|
|
|
* "drop" the table with double-spending information (shortly after)
|
|
|
|
* this time. Note that wallets should refresh coins significantly
|
|
|
|
* before this time to be on the safe side.
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct GNUNET_TIME_AbsoluteNBO expire_spend;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The value of the coins signed with this denomination key.
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct TALER_AmountNBO value;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The fee the mint charges when a coin of this type is withdrawn.
|
|
|
|
* (can be zero).
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct TALER_AmountNBO fee_withdraw;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The fee the mint charges when a coin of this type is deposited.
|
|
|
|
* (can be zero).
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct TALER_AmountNBO fee_deposit;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The fee the mint charges when a coin of this type is refreshed.
|
|
|
|
* (can be zero).
|
|
|
|
*/
|
2015-03-09 12:29:41 +01:00
|
|
|
struct TALER_AmountNBO fee_refresh;
|
2015-03-15 18:18:14 +01:00
|
|
|
|
2015-03-15 18:27:32 +01:00
|
|
|
/**
|
|
|
|
* Hash code of the denomination public key.
|
|
|
|
*/
|
|
|
|
struct GNUNET_HashCode denom_hash;
|
|
|
|
|
2015-01-09 18:18:59 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
GNUNET_NETWORK_STRUCT_END
|
|
|
|
|
2015-01-08 18:37:20 +01:00
|
|
|
#endif
|