Monero
Toggle main menu visibility
Loading...
Searching...
No Matches
src
multisig
multisig_kex_msg_serialization.h
Go to the documentation of this file.
1
// Copyright (c) 2021-2022, The Monero Project
2
//
3
// All rights reserved.
4
//
5
// Redistribution and use in source and binary forms, with or without modification, are
6
// permitted provided that the following conditions are met:
7
//
8
// 1. Redistributions of source code must retain the above copyright notice, this list of
9
// conditions and the following disclaimer.
10
//
11
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
12
// of conditions and the following disclaimer in the documentation and/or other
13
// materials provided with the distribution.
14
//
15
// 3. Neither the name of the copyright holder nor the names of its contributors may be
16
// used to endorse or promote products derived from this software without specific
17
// prior written permission.
18
//
19
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
20
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
22
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
24
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
26
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
27
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
29
#pragma once
30
31
#include "
crypto/crypto.h
"
32
#include "
serialization/containers.h
"
33
#include "
serialization/crypto.h
"
34
#include "
serialization/serialization.h
"
35
36
#include <cstdint>
37
#include <vector>
38
39
40
namespace
multisig
41
{
43
struct
multisig_kex_msg_serializable_round1
44
{
45
// privkey stored in msg
46
crypto::secret_key
msg_privkey
;
47
// pubkey used to sign this msg
48
crypto::public_key
signing_pubkey
;
49
// message signature
50
crypto::signature
signature
;
51
52
BEGIN_SERIALIZE
()
53
FIELD
(
msg_privkey
)
54
FIELD
(
signing_pubkey
)
55
FIELD
(
signature
)
56
END_SERIALIZE
()
57
};
58
60
struct
multisig_kex_msg_serializable_general
61
{
62
// key exchange round this msg was produced for
63
std::uint32_t
kex_round
;
64
// pubkeys stored in msg
65
std::vector<crypto::public_key>
msg_pubkeys
;
66
// pubkey used to sign this msg
67
crypto::public_key
signing_pubkey
;
68
// message signature
69
crypto::signature
signature
;
70
71
BEGIN_SERIALIZE
()
72
VARINT_FIELD
(
kex_round
)
73
FIELD
(
msg_pubkeys
)
74
FIELD
(
signing_pubkey
)
75
FIELD
(
signature
)
76
END_SERIALIZE
()
77
};
78
}
//namespace multisig
containers.h
crypto.h
BEGIN_SERIALIZE
#define BEGIN_SERIALIZE()
FIELD
#define FIELD(f)
END_SERIALIZE
#define END_SERIALIZE()
VARINT_FIELD
#define VARINT_FIELD(f)
crypto::signature
POD_CLASS signature
Definition
crypto.h:98
crypto::secret_key
epee::mlocked< tools::scrubbed< ec_scalar > > secret_key
Definition
crypto.h:72
crypto::public_key
POD_CLASS public_key
Definition
crypto.h:64
multisig
Definition
multisig.cpp:46
crypto.h
serialization.h
Simple DSL AAPI based on.
multisig::multisig_kex_msg_serializable_general
general kex message (if round > 1)
Definition
multisig_kex_msg_serialization.h:61
multisig::multisig_kex_msg_serializable_general::signing_pubkey
crypto::public_key signing_pubkey
Definition
multisig_kex_msg_serialization.h:67
multisig::multisig_kex_msg_serializable_general::kex_round
std::uint32_t kex_round
Definition
multisig_kex_msg_serialization.h:63
multisig::multisig_kex_msg_serializable_general::msg_pubkeys
std::vector< crypto::public_key > msg_pubkeys
Definition
multisig_kex_msg_serialization.h:65
multisig::multisig_kex_msg_serializable_general::signature
crypto::signature signature
Definition
multisig_kex_msg_serialization.h:69
multisig::multisig_kex_msg_serializable_round1
round 1 kex message
Definition
multisig_kex_msg_serialization.h:44
multisig::multisig_kex_msg_serializable_round1::signature
crypto::signature signature
Definition
multisig_kex_msg_serialization.h:50
multisig::multisig_kex_msg_serializable_round1::signing_pubkey
crypto::public_key signing_pubkey
Definition
multisig_kex_msg_serialization.h:48
multisig::multisig_kex_msg_serializable_round1::msg_privkey
crypto::secret_key msg_privkey
Definition
multisig_kex_msg_serialization.h:46
Generated on
for Monero by
1.17.0