Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add blsct api #168

Merged
merged 44 commits into from
Oct 20, 2024
Merged
Changes from 1 commit
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
08523e4
add ext api working up to range proof prove
gogoex Jul 13, 2024
a4ecb44
fix token id problems
gogoex Jul 14, 2024
0ab0b6f
add missing dispose functions
gogoex Jul 14, 2024
74a5702
fix range proof memory allocation issue
gogoex Jul 20, 2024
42814ee
add range proof amount recovery apis
gogoex Jul 28, 2024
5d8d90c
handle memory allocation failures
gogoex Jul 28, 2024
9424fe5
let dispose_ret_val not to dispose its value. use void* for dispose_d…
gogoex Jul 30, 2024
97292db
replace most of dispose_* with free_obj
gogoex Jul 31, 2024
0770794
wip
gogoex Aug 2, 2024
f0012ae
fix missing symbol issue
gogoex Aug 17, 2024
9798a28
build libunivalue_blsct.a
gogoex Aug 17, 2024
1caba62
wip
gogoex Aug 17, 2024
476c651
rebase to up-to-date master
gogoex Aug 18, 2024
2f41d78
fully uncomment build_tx
gogoex Aug 18, 2024
34dd006
remove unused function header
gogoex Aug 22, 2024
fe1df72
deserialize tx up to txIns and txOuts level
gogoex Aug 25, 2024
9b01529
return objects with size
gogoex Aug 25, 2024
927fbc5
wip
gogoex Aug 26, 2024
a5bcdb5
add blsct data functions
gogoex Aug 27, 2024
2e631de
support scriptPubKey and rangeProof
gogoex Aug 27, 2024
6f364af
add txin serialization
gogoex Sep 8, 2024
01f363d
add msg signing and verification
gogoex Sep 19, 2024
b4519c9
add key derivation apis
gogoex Sep 22, 2024
6f84e1d
add rest of api functions w/ missing symbol issue
gogoex Sep 22, 2024
317fd6f
fix hash_id issue
gogoex Sep 27, 2024
3ab0054
fix build issues
gogoex Oct 16, 2024
b6788c4
avoid using a function in the locale-dependent funciton list
gogoex Oct 16, 2024
1b1656a
add blsct/key_io.h to BLSCT_H
gogoex Oct 16, 2024
a22bc8e
wip
gogoex Oct 16, 2024
5482653
use const reference for rp
gogoex Oct 16, 2024
80f88cd
apply wallet test fix patch
gogoex Oct 17, 2024
1cd8e56
add swap to fuzzer ci test
gogoex Oct 18, 2024
26f2725
replace VOID macro w/ TO_VOID
gogoex Oct 18, 2024
da7a22b
use 7 arguments for UPNP_GetValidIGD if MINIUPNPC_API_VERSION > 17
gogoex Oct 19, 2024
48b4cbe
use medium type for fuzzer task
gogoex Oct 19, 2024
7f718b4
test fuzzer ci check only
gogoex Oct 19, 2024
c6baeea
wip
gogoex Oct 19, 2024
e65fbd8
wip
gogoex Oct 19, 2024
e6841e1
wip
gogoex Oct 19, 2024
ba62a15
wip
gogoex Oct 19, 2024
64ac555
wip
gogoex Oct 19, 2024
d2b7995
wip
gogoex Oct 19, 2024
4783908
kick off ci
gogoex Oct 20, 2024
339df7c
uncomment all ci tasks. use small persistent_worker for lint
gogoex Oct 20, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
return objects with size
  • Loading branch information
gogoex committed Oct 15, 2024

Verified

This commit was signed with the committer’s verified signature.
suchapalaver Joseph Livesey
commit 9b0152966bda5a6d31ced26b4e8cc07c1191b1e0
75 changes: 40 additions & 35 deletions src/blsct/external_api/blsct.cpp
Original file line number Diff line number Diff line change
@@ -85,13 +85,15 @@ bool set_chain(enum Chain chain)
}

BlsctRetVal* succ(
void* value
void* value,
size_t value_size
) {
MALLOC(BlsctRetVal, p);
RETURN_IF_MEM_ALLOC_FAILED(p);

p->result = BLSCT_SUCCESS;
p->value = value;
p->value_size = value_size;
return p;
}

@@ -142,32 +144,35 @@ void free_amounts_ret_val(BlsctAmountsRetVal* rv) {
free(rv);
}

BlsctPoint* gen_random_point() {
BlsctRetVal* gen_random_point() {
MALLOC(BlsctPoint, blsct_point);
RETURN_IF_MEM_ALLOC_FAILED(blsct_point);

auto x = Point::Rand();
SERIALIZE_AND_COPY(x, blsct_point);
return blsct_point;

return succ(blsct_point, POINT_SIZE);
}

BlsctScalar* gen_random_scalar() {
BlsctRetVal* gen_random_scalar() {
MALLOC(BlsctScalar, blsct_scalar);
RETURN_IF_MEM_ALLOC_FAILED(blsct_scalar);

auto x = Scalar::Rand(true);
SERIALIZE_AND_COPY(x, blsct_scalar);
return blsct_scalar;

return succ(blsct_scalar, SCALAR_SIZE);
}

BlsctScalar* gen_scalar(
BlsctRetVal* gen_scalar(
const uint64_t n
) {
Scalar scalar_n(n);
Scalar scalar(n);
MALLOC(BlsctScalar, blsct_scalar);
RETURN_IF_MEM_ALLOC_FAILED(blsct_scalar);
SERIALIZE_AND_COPY(scalar_n, blsct_scalar);
return blsct_scalar;
SERIALIZE_AND_COPY(scalar, blsct_scalar);

return succ(blsct_scalar, SCALAR_SIZE);
}

uint64_t scalar_to_uint64(const BlsctScalar* blsct_scalar)
@@ -177,15 +182,15 @@ uint64_t scalar_to_uint64(const BlsctScalar* blsct_scalar)
return scalar.GetUint64();
}

BlsctPubKey* gen_random_public_key() {
BlsctRetVal* gen_random_public_key() {
auto vec = Point::Rand().GetVch();
blsct::PublicKey pub_key(vec);

MALLOC(BlsctPubKey, blsct_pub_key);
RETURN_IF_MEM_ALLOC_FAILED(blsct_pub_key);
SERIALIZE_AND_COPY(pub_key, blsct_pub_key);

return blsct_pub_key;
return succ(blsct_pub_key, PUBLIC_KEY_SIZE);
}

BlsctRetVal* decode_address(
@@ -205,7 +210,7 @@ BlsctRetVal* decode_address(
RETURN_ERR_IF_MEM_ALLOC_FAILED(dec_addr);
std::memcpy(dec_addr, &buf[0], DOUBLE_PUBLIC_KEY_SIZE);

return succ(dec_addr);
return succ(dec_addr, DOUBLE_PUBLIC_KEY_SIZE);
}
}
} catch(...) {}
@@ -235,7 +240,7 @@ BlsctRetVal* encode_address(
RETURN_ERR_IF_MEM_ALLOC_FAILED(enc_addr);
std::memcpy(enc_addr, enc_dpk_str.c_str(), BUF_SIZE);

return succ(enc_addr);
return succ(enc_addr, BUF_SIZE);

} catch(...) {}

@@ -266,10 +271,10 @@ BlsctRetVal* gen_double_pub_key(
blsct::DoublePublicKey dpk(pk1, pk2);
SERIALIZE_AND_COPY(dpk, blsct_dpk);

return succ(blsct_dpk);
return succ(blsct_dpk, sizeof(BlsctDoublePubKey));
}

BlsctTokenId* gen_token_id_with_subid(
BlsctRetVal* gen_token_id_with_subid(
const uint64_t token,
const uint64_t subid
) {
@@ -285,10 +290,10 @@ BlsctTokenId* gen_token_id_with_subid(
RETURN_IF_MEM_ALLOC_FAILED(blsct_token_id);
SERIALIZE_AND_COPY_WITH_STREAM(token_id, blsct_token_id);

return blsct_token_id;
return succ(blsct_token_id, TOKEN_ID_SIZE);
}

BlsctTokenId* gen_token_id(
BlsctRetVal* gen_token_id(
const uint64_t token
) {
return gen_token_id_with_subid(
@@ -297,13 +302,13 @@ BlsctTokenId* gen_token_id(
);
}

BlsctTokenId* gen_default_token_id() {
BlsctRetVal* gen_default_token_id() {
TokenId token_id;
MALLOC(BlsctTokenId, blsct_token_id);
RETURN_IF_MEM_ALLOC_FAILED(blsct_token_id);
SERIALIZE_AND_COPY_WITH_STREAM(token_id, blsct_token_id);

return blsct_token_id;
return succ(blsct_token_id, TOKEN_ID_SIZE);
}

BlsctRetVal* build_range_proof(
@@ -351,7 +356,7 @@ BlsctRetVal* build_range_proof(
MALLOC(BlsctRangeProof, blsct_range_proof);
RETURN_ERR_IF_MEM_ALLOC_FAILED(blsct_range_proof);
SERIALIZE_AND_COPY_WITH_STREAM(range_proof, blsct_range_proof);
return succ(blsct_range_proof);
return succ(blsct_range_proof, RANGE_PROOF_SIZE);

} catch(...) {}

@@ -472,7 +477,7 @@ BlsctAmountsRetVal* recover_amount(
return rv;
}

BlsctOutPoint* gen_out_point(
BlsctRetVal* gen_out_point(
const char* tx_id_c_str,
const uint32_t out_index
) {
@@ -488,10 +493,10 @@ BlsctOutPoint* gen_out_point(
out_point,
blsct_out_point
);
return blsct_out_point;
return succ(blsct_out_point, OUT_POINT_SIZE);
}

BlsctTxIn* build_tx_in(
BlsctRetVal* build_tx_in(
const uint64_t amount,
const uint64_t gamma,
const BlsctScalar* spending_key,
@@ -509,10 +514,10 @@ BlsctTxIn* build_tx_in(
BLSCT_COPY(out_point, tx_in->out_point);
tx_in->rbf = rbf;

return tx_in;
return succ(tx_in, sizeof(BlsctTxIn));
}

BlsctSubAddr* dpk_to_sub_addr(
BlsctRetVal* dpk_to_sub_addr(
const void* blsct_dpk
) {
// unserialize double public key
@@ -531,7 +536,7 @@ BlsctSubAddr* dpk_to_sub_addr(
// serialize sub address
SERIALIZE_AND_COPY_WITH_STREAM(sub_addr, blsct_sub_addr);

return blsct_sub_addr;
return succ(blsct_sub_addr, sizeof(blsct::SubAddress));
}

BlsctRetVal* build_tx_out(
@@ -559,7 +564,7 @@ BlsctRetVal* build_tx_out(
tx_out->output_type = output_type;
tx_out->min_stake = min_stake;

return succ(tx_out);
return succ(tx_out, sizeof(BlsctTxOut));
}

static blsct::PrivateKey blsct_scalar_to_priv_key(
@@ -728,12 +733,12 @@ const size_t get_tx_ins_size(const std::vector<CTxIn>* tx_ins) {
return tx_ins->size();
}

const CTxIn* get_tx_in(const std::vector<CTxIn>* tx_ins, const size_t i) {
const BlsctRetVal* get_tx_in(const std::vector<CTxIn>* tx_ins, const size_t i) {
auto tx_in = &tx_ins->at(i);
auto tx_in_size = sizeof(*tx_in);
auto buf = static_cast<CTxIn*>(malloc(tx_in_size));
std::memcpy(buf, tx_in, tx_in_size);
return buf;
auto tx_in_copy = static_cast<CTxIn*>(malloc(tx_in_size));
std::memcpy(tx_in_copy, tx_in, tx_in_size);
return succ(tx_in_copy, tx_in_size);
}

const std::vector<CTxOut>* get_tx_outs(const CMutableTransaction* tx) {
@@ -744,12 +749,12 @@ const size_t get_tx_outs_size(const std::vector<CTxOut>* tx_outs) {
return tx_outs->size();
}

const CTxOut* get_tx_out(const std::vector<CTxOut>* tx_outs, const size_t i) {
const BlsctRetVal* get_tx_out(const std::vector<CTxOut>* tx_outs, const size_t i) {
auto tx_out = &tx_outs->at(i);
auto tx_out_size = sizeof(*tx_out);
auto buf = static_cast<CTxOut*>(malloc(tx_out_size));
std::memcpy(buf, tx_out, tx_out_size);
return buf;
auto tx_out_copy = static_cast<CTxOut*>(malloc(tx_out_size));
std::memcpy(tx_out_copy, tx_out, tx_out_size);
return succ(tx_out_copy, tx_out_size);
}

/*
40 changes: 26 additions & 14 deletions src/blsct/external_api/blsct.h
Original file line number Diff line number Diff line change
@@ -245,6 +245,7 @@ typedef struct {
typedef struct {
BLSCT_RESULT result;
void* value;
size_t value_size;
} BlsctRetVal;

typedef struct {
@@ -267,7 +268,8 @@ typedef struct {
} BlsctTxRetVal;

BlsctRetVal* succ(
void* value
void* value,
size_t value_size
);

BlsctRetVal* err(
@@ -319,18 +321,20 @@ void free_amounts_ret_val(BlsctAmountsRetVal* rv); // free attrs as well
void init();
bool set_chain(enum Chain chain);

// point/scalar generation/disposition
BlsctPoint* gen_random_point();
BlsctScalar* gen_random_scalar();
// point
BlsctRetVal* gen_random_point();

BlsctScalar* gen_scalar(const uint64_t n);
// scalar
BlsctRetVal* gen_random_scalar();
BlsctRetVal* gen_scalar(const uint64_t n);

// type convertion
uint64_t scalar_to_uint64(const BlsctScalar* blsct_scalar);

// public key generation
BlsctPubKey* gen_random_public_key();
BlsctRetVal* gen_random_public_key();

// address
BlsctRetVal* decode_address(
const char* blsct_enc_addr
);
@@ -340,22 +344,25 @@ BlsctRetVal* encode_address(
const enum AddressEncoding encoding
);

// double public key
BlsctRetVal* gen_double_pub_key(
const BlsctPubKey* blsct_pk1,
const BlsctPubKey* blsct_pk2
);

BlsctTokenId* gen_token_id_with_subid(
// token id
BlsctRetVal* gen_token_id_with_subid(
const uint64_t token,
const uint64_t subid
);

BlsctTokenId* gen_token_id(
BlsctRetVal* gen_token_id(
const uint64_t token
);

BlsctTokenId* gen_default_token_id();
BlsctRetVal* gen_default_token_id();

// range proof
BlsctRetVal* build_range_proof(
const void* vp_uint64_vec,
const BlsctPoint* blsct_nonce,
@@ -367,6 +374,7 @@ BlsctBoolRetVal* verify_range_proofs(
const void* vp_range_proofs
);

// amount recovery
BlsctAmountRecoveryReq* gen_recover_amount_req(
const void* vp_blsct_range_proof,
const void* vp_blsct_nonce
@@ -378,13 +386,14 @@ BlsctAmountsRetVal* recover_amount(
void* vp_amt_recovery_req_vec
);

// out point
// txid is 32 bytes and represented as 64-char hex str
BlsctOutPoint* gen_out_point(
BlsctRetVal* gen_out_point(
const char* tx_id_c_str,
const uint32_t n
);

BlsctTxIn* build_tx_in(
BlsctRetVal* build_tx_in(
const uint64_t amount,
const uint64_t gamma,
const BlsctScalar* spending_key,
@@ -393,7 +402,7 @@ BlsctTxIn* build_tx_in(
const bool rbf
);

BlsctSubAddr* dpk_to_sub_addr(
BlsctRetVal* dpk_to_sub_addr(
const void* blsct_dpk
);

@@ -421,13 +430,16 @@ const std::vector<CTxIn>* get_tx_ins(const CMutableTransaction* tx);

const size_t get_tx_ins_size(const std::vector<CTxIn>* tx_ins);

const CTxIn* get_tx_in(const std::vector<CTxIn>* tx_ins, const size_t i);
const BlsctRetVal* get_tx_in(const std::vector<CTxIn>* tx_ins, const size_t i);

const std::vector<CTxOut>* get_tx_outs(const CMutableTransaction* tx);

const size_t get_tx_outs_size(const std::vector<CTxOut>* tx_ins);

const CTxOut* get_tx_out(const std::vector<CTxOut>* tx_ins, const size_t i);
const BlsctRetVal* get_tx_out(const std::vector<CTxOut>* tx_ins, const size_t i);


//const Scalar* get_tx_in_amount(const CTxIn* tx_in);

///// END new pointer-based API