Skip to content

Commit

Permalink
XS: Byron address derivation
Browse files Browse the repository at this point in the history
  • Loading branch information
janmazak committed Oct 6, 2023
1 parent 6662141 commit 5caa86a
Show file tree
Hide file tree
Showing 6 changed files with 77 additions and 53 deletions.
1 change: 1 addition & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ DEFINES += APP_FEATURE_NATIVE_SCRIPT_HASH
DEFINES += APP_FEATURE_TOKEN_MINTING
DEFINES += APP_FEATURE_POOL_REGISTRATION
DEFINES += APP_FEATURE_POOL_RETIREMENT
DEFINES += APP_FEATURE_BYRON_ADDRESS_DERIVATION
endif

##############
Expand Down
101 changes: 53 additions & 48 deletions src/addressUtilsByron.c
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,11 @@
#include "crc32.h"
#include "bufView.h"

static const size_t ADDRESS_ROOT_SIZE = 28;
static const size_t PROTOCOL_MAGIC_ADDRESS_ATTRIBUTE_KEY = 2;

#ifdef APP_FEATURE_BYRON_ADDRESS_DERIVATION

enum {
CARDANO_ADDRESS_TYPE_PUBKEY = 0,
/*
Expand All @@ -15,9 +20,6 @@ enum {
*/
};

static const size_t ADDRESS_ROOT_SIZE = 28;
static const size_t PROTOCOL_MAGIC_ADDRESS_ATTRIBUTE_KEY = 2;

void addressRootFromExtPubKey(
const extendedPublicKey_t* extPubKey,
uint8_t* outBuffer, size_t outSize
Expand Down Expand Up @@ -136,6 +138,54 @@ size_t cborPackRawAddressWithChecksum(
return view_processedSize(&output);
}

size_t deriveRawAddress(
const bip44_path_t* pathSpec, uint32_t protocolMagic,
uint8_t* outBuffer, size_t outSize
)
{
ASSERT(outSize < BUFFER_SIZE_PARANOIA);

uint8_t addressRoot[28] = {0};
{
extendedPublicKey_t extPubKey;

deriveExtendedPublicKey(pathSpec, &extPubKey);

addressRootFromExtPubKey(
&extPubKey,
addressRoot, SIZEOF(addressRoot)
);
}

return cborEncodePubkeyAddressInner(
addressRoot, SIZEOF(addressRoot),
protocolMagic,
outBuffer, outSize
);
}

size_t deriveAddress_byron(
const bip44_path_t* pathSpec, uint32_t protocolMagic,
uint8_t* outBuffer, size_t outSize
)
{
ASSERT(outSize < BUFFER_SIZE_PARANOIA);

uint8_t rawAddressBuffer[40] = {0};
size_t rawAddressSize = deriveRawAddress(
pathSpec, protocolMagic,
rawAddressBuffer, SIZEOF(rawAddressBuffer)
);

return cborPackRawAddressWithChecksum(
rawAddressBuffer, rawAddressSize,
outBuffer, outSize
);

}

#endif // APP_FEATURE_BYRON_ADDRESS_DERIVATION

static uint64_t parseToken(read_view_t* view, uint8_t type)
{
const cbor_token_t token = view_parseToken(view);
Expand Down Expand Up @@ -252,48 +302,3 @@ uint32_t extractProtocolMagic(
return protocolMagic;
}

size_t deriveRawAddress(
const bip44_path_t* pathSpec, uint32_t protocolMagic,
uint8_t* outBuffer, size_t outSize
)
{
ASSERT(outSize < BUFFER_SIZE_PARANOIA);

uint8_t addressRoot[28] = {0};
{
extendedPublicKey_t extPubKey;

deriveExtendedPublicKey(pathSpec, &extPubKey);

addressRootFromExtPubKey(
&extPubKey,
addressRoot, SIZEOF(addressRoot)
);
}

return cborEncodePubkeyAddressInner(
addressRoot, SIZEOF(addressRoot),
protocolMagic,
outBuffer, outSize
);
}

size_t deriveAddress_byron(
const bip44_path_t* pathSpec, uint32_t protocolMagic,
uint8_t* outBuffer, size_t outSize
)
{
ASSERT(outSize < BUFFER_SIZE_PARANOIA);

uint8_t rawAddressBuffer[40] = {0};
size_t rawAddressSize = deriveRawAddress(
pathSpec, protocolMagic,
rawAddressBuffer, SIZEOF(rawAddressBuffer)
);

return cborPackRawAddressWithChecksum(
rawAddressBuffer, rawAddressSize,
outBuffer, outSize
);

}
6 changes: 5 additions & 1 deletion src/addressUtilsByron.h
Original file line number Diff line number Diff line change
Expand Up @@ -4,19 +4,23 @@
#include "common.h"
#include "bip44.h"

#ifdef APP_FEATURE_BYRON_ADDRESS_DERIVATION

size_t deriveAddress_byron(
const bip44_path_t* pathSpec,
uint32_t protocolMagic,
uint8_t* outBuffer, size_t outSize
);

#endif // APP_FEATURE_BYRON_ADDRESS_DERIVATION

// Note: validates the overall address structure at the same time
uint32_t extractProtocolMagic(
const uint8_t* addressBuffer, size_t addressSize
);


#ifdef DEVEL
#if defined(DEVEL) && !defined(APP_XS)
void run_addressUtilsByron_test();
#endif // DEVEL

Expand Down
2 changes: 1 addition & 1 deletion src/addressUtilsByron_test.c
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#ifdef DEVEL
#if defined(DEVEL) && !defined(APP_XS)

#include "addressUtilsByron.h"
#include "cardano.h"
Expand Down
18 changes: 15 additions & 3 deletions src/addressUtilsShelley.c
Original file line number Diff line number Diff line change
Expand Up @@ -439,8 +439,6 @@ size_t deriveAddress(const addressParams_t* addressParams, uint8_t* outBuffer, s
ASSERT(outSize < BUFFER_SIZE_PARANOIA);
ASSERT(isValidAddressParams(addressParams));

const bip44_path_t* spendingPath = &addressParams->spendingKeyPath;

// shelley
switch (addressParams->type) {
case BASE_PAYMENT_KEY_STAKE_KEY:
Expand All @@ -458,8 +456,16 @@ size_t deriveAddress(const addressParams_t* addressParams, uint8_t* outBuffer, s
case REWARD_KEY:
case REWARD_SCRIPT:
return deriveAddress_reward(addressParams, outBuffer, outSize);

#ifdef APP_FEATURE_BYRON_ADDRESS_DERIVATION
case BYRON:
return deriveAddress_byron(spendingPath, addressParams->protocolMagic, outBuffer, outSize);
return deriveAddress_byron(
&addressParams->spendingKeyPath,
addressParams->protocolMagic,
outBuffer, outSize
);
#endif // APP_FEATURE_BYRON_ADDRESS_DERIVATION

default:
ASSERT(false);
}
Expand Down Expand Up @@ -698,6 +704,12 @@ bool isValidAddressParams(const addressParams_t* params)
#define CHECK(cond) if (!(cond)) return false
if (params->type != BYRON) {
CHECK(isValidNetworkId(params->networkId));
} else {
// code for Byron address derivation not available in XS app
// thus we cannot process address params
#ifndef APP_FEATURE_BYRON_ADDRESS_DERIVATION
return false;
#endif
}

CHECK(isValidStakingInfo(params));
Expand Down
2 changes: 2 additions & 0 deletions src/runTests.c
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,9 @@ void handleRunTests(
run_cbor_test();
run_bip44_test();
run_key_derivation_test();
#if !defined(APP_XS)
run_addressUtilsByron_test();
#endif
run_addressUtilsShelley_test();
#if !defined(APP_XS)
run_txHashBuilder_test();
Expand Down

0 comments on commit 5caa86a

Please sign in to comment.