From a8041ed7e324a2d70abae9dac96a7fa07d1422d4 Mon Sep 17 00:00:00 2001 From: DangerousFreedom1984 <98208928+DangerousFreedom1984@users.noreply.github.com> Date: Mon, 23 Oct 2023 20:50:35 +0200 Subject: [PATCH] make JamtisPaymentProposal serializable (#21) * make JamtisPaymentProposal serializable --------- Co-authored-by: DangerousFreedom --- src/seraphis_impl/serialization_demo_types.h | 48 +++++++++++++++++++ .../serialization_demo_utils.cpp | 37 ++++++++++++++ src/seraphis_impl/serialization_demo_utils.h | 4 ++ 3 files changed, 89 insertions(+) diff --git a/src/seraphis_impl/serialization_demo_types.h b/src/seraphis_impl/serialization_demo_types.h index 50dd0db586a..1cd507d476f 100644 --- a/src/seraphis_impl/serialization_demo_types.h +++ b/src/seraphis_impl/serialization_demo_types.h @@ -56,6 +56,11 @@ namespace sp { namespace serialization { +/// serializable jamtis::address_index_t +struct ser_address_index_t final +{ + unsigned char bytes[sizeof(jamtis::address_index_t)]; +}; /// serializable jamtis::address_tag_t struct ser_address_tag_t final @@ -433,10 +438,53 @@ struct ser_JamtisDestinationV1 final END_SERIALIZE() }; +/// serializable JamtisPaymentProposalV1 +struct ser_JamtisPaymentProposalV1 final +{ + /// destination address + ser_JamtisDestinationV1 destination; + /// amount + rct::xmr_amount amount; + /// enote ephemeral private key + crypto::x25519_scalar enote_ephemeral_privkey; + /// memo elements + std::vector partial_memo; + + BEGIN_SERIALIZE() + FIELD(destination) + FIELD(amount) + FIELD(enote_ephemeral_privkey) + FIELD(partial_memo) + END_SERIALIZE() +}; + +/// serializable JamtisPaymentProposalV1 +struct ser_JamtisPaymentProposalSelfSendV1 final +{ + /// destination address + ser_JamtisDestinationV1 destination; + /// amount + rct::xmr_amount amount; + /// selfspend type + unsigned char type; + /// enote ephemeral private key + crypto::x25519_scalar enote_ephemeral_privkey; + /// memo elements + std::vector partial_memo; + + BEGIN_SERIALIZE() + FIELD(destination) + FIELD(amount) + FIELD(type) + FIELD(enote_ephemeral_privkey) + FIELD(partial_memo) + END_SERIALIZE() +}; } //namespace serialization } //namespace sp +BLOB_SERIALIZER(sp::serialization::ser_address_index_t); BLOB_SERIALIZER(sp::serialization::ser_address_tag_t); BLOB_SERIALIZER(sp::serialization::ser_encrypted_address_tag_t); BLOB_SERIALIZER(sp::serialization::ser_encoded_amount_t); diff --git a/src/seraphis_impl/serialization_demo_utils.cpp b/src/seraphis_impl/serialization_demo_utils.cpp index 0e2949ee96b..14c0bee96db 100644 --- a/src/seraphis_impl/serialization_demo_utils.cpp +++ b/src/seraphis_impl/serialization_demo_utils.cpp @@ -37,6 +37,8 @@ #include "seraphis_core/binned_reference_set.h" #include "seraphis_core/discretized_fee.h" #include "seraphis_core/jamtis_destination.h" +#include "seraphis_core/jamtis_payment_proposal.h" +#include "seraphis_core/jamtis_support_types.h" #include "seraphis_crypto/bulletproofs_plus2.h" #include "seraphis_crypto/grootle.h" #include "seraphis_crypto/sp_composition_proof.h" @@ -223,6 +225,23 @@ void make_serializable_grootle_proof(const GrootleProof &grootle, ser_GrootlePro serializable_grootle_out.z = grootle.z; } //------------------------------------------------------------------------------------------------------------------- +void make_serializable_jamtis_payment_proposal_v1(const jamtis::JamtisPaymentProposalV1 &payment, ser_JamtisPaymentProposalV1 &serializable_payment_out) +{ + make_serializable_sp_destination_v1(payment.destination, serializable_payment_out.destination); + serializable_payment_out.amount = payment.amount; + serializable_payment_out.enote_ephemeral_privkey = payment.enote_ephemeral_privkey; + serializable_payment_out.partial_memo = payment.partial_memo; +} +//------------------------------------------------------------------------------------------------------------------- +void make_serializable_jamtis_payment_proposal_selfsend_v1(const jamtis::JamtisPaymentProposalSelfSendV1 &payment, ser_JamtisPaymentProposalSelfSendV1 &serializable_payment_out) +{ + make_serializable_sp_destination_v1(payment.destination, serializable_payment_out.destination); + serializable_payment_out.amount = payment.amount; + serializable_payment_out.type = static_cast(payment.type); + serializable_payment_out.enote_ephemeral_privkey = payment.enote_ephemeral_privkey; + serializable_payment_out.partial_memo = payment.partial_memo; +} +//------------------------------------------------------------------------------------------------------------------- void make_serializable_sp_composition_proof(const SpCompositionProof &proof, ser_SpCompositionProof &serializable_proof_out) { @@ -435,6 +454,23 @@ void recover_grootle_proof(ser_GrootleProof &serializable_grootle_in, GrootlePro grootle_out.z = serializable_grootle_in.z; } //------------------------------------------------------------------------------------------------------------------- +void recover_jamtis_payment_proposal_v1(const ser_JamtisPaymentProposalV1 &serializable_payment, jamtis::JamtisPaymentProposalV1 &payment_out) +{ + recover_sp_destination_v1(serializable_payment.destination, payment_out.destination); + payment_out.amount = serializable_payment.amount; + payment_out.enote_ephemeral_privkey = serializable_payment.enote_ephemeral_privkey; + payment_out.partial_memo = serializable_payment.partial_memo; +} +//------------------------------------------------------------------------------------------------------------------- +void recover_jamtis_payment_proposal_selfsend_v1(const ser_JamtisPaymentProposalSelfSendV1 &serializable_payment, jamtis::JamtisPaymentProposalSelfSendV1 &payment_out) +{ + recover_sp_destination_v1(serializable_payment.destination, payment_out.destination); + payment_out.amount = serializable_payment.amount; + payment_out.type = static_cast(serializable_payment.type); + payment_out.enote_ephemeral_privkey = serializable_payment.enote_ephemeral_privkey; + payment_out.partial_memo = serializable_payment.partial_memo; +} +//------------------------------------------------------------------------------------------------------------------- void recover_sp_composition_proof(const ser_SpCompositionProof &serializable_proof, SpCompositionProof &proof_out) { proof_out.c = serializable_proof.c; @@ -701,5 +737,6 @@ void recover_sp_destination_v1(const ser_JamtisDestinationV1 &serializable_desti sizeof(serializable_destination.addr_tag)); } //------------------------------------------------------------------------------------------------------------------- + } //namespace serialization } //namespace sp diff --git a/src/seraphis_impl/serialization_demo_utils.h b/src/seraphis_impl/serialization_demo_utils.h index 62bb13d5b96..77964ccbc61 100644 --- a/src/seraphis_impl/serialization_demo_utils.h +++ b/src/seraphis_impl/serialization_demo_utils.h @@ -110,6 +110,8 @@ bool try_get_serializable(epee::span serialized, Serializabl void make_serializable_bpp2(const BulletproofPlus2 &bpp2, ser_BulletproofPlus2_PARTIAL &serializable_bpp2_out); void make_serializable_clsag(const rct::clsag &clsag, ser_clsag_PARTIAL &serializable_clsag_out); void make_serializable_grootle_proof(const GrootleProof &grootle, ser_GrootleProof &serializable_grootle_out); +void make_serializable_jamtis_payment_proposal_v1(const jamtis::JamtisPaymentProposalV1 &payment, ser_JamtisPaymentProposalV1 &serializable_payment_out); +void make_serializable_jamtis_payment_proposal_selfsend_v1(const jamtis::JamtisPaymentProposalSelfSendV1 &payment, ser_JamtisPaymentProposalSelfSendV1 &serializable_payment_out); void make_serializable_sp_composition_proof(const SpCompositionProof &proof, ser_SpCompositionProof &serializable_proof_out); void make_serializable_sp_coinbase_enote_core(const SpCoinbaseEnoteCore &enote, @@ -148,6 +150,8 @@ void recover_bpp2(ser_BulletproofPlus2_PARTIAL &serializable_bpp2_in, BulletproofPlus2 &bpp2_out); void recover_clsag(ser_clsag_PARTIAL &serializable_clsag_in, const crypto::key_image &key_image, rct::clsag &clsag_out); void recover_grootle_proof(ser_GrootleProof &serializable_grootle_in, GrootleProof &grootle_out); +void recover_jamtis_payment_proposal_v1(const ser_JamtisPaymentProposalV1 &serializable_payment, jamtis::JamtisPaymentProposalV1 &payment_out); +void recover_jamtis_payment_proposal_selfsend_v1(const ser_JamtisPaymentProposalSelfSendV1 &serializable_payment, jamtis::JamtisPaymentProposalSelfSendV1 &payment_out); void recover_sp_composition_proof(const ser_SpCompositionProof &serializable_proof, SpCompositionProof &proof_out); void recover_sp_coinbase_enote_core(const ser_SpCoinbaseEnoteCore &serializable_enote, SpCoinbaseEnoteCore &enote_out); void recover_sp_enote_core(const ser_SpEnoteCore &serializable_enote, SpEnoteCore &enote_out);