Skip to content

Commit

Permalink
Flex support + NBGL api update + tests update
Browse files Browse the repository at this point in the history
  • Loading branch information
agrojean-ledger committed Jun 7, 2024
1 parent ae7aaf4 commit c766801
Show file tree
Hide file tree
Showing 318 changed files with 348 additions and 462 deletions.
202 changes: 66 additions & 136 deletions Makefile
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#*******************************************************************************
# Ledger App Hedera
# (c) 2019 Hedera Hashgraph
# (c) 2024 Hedera Hashgraph
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
Expand All @@ -18,54 +18,75 @@
ifeq ($(BOLOS_SDK),)
$(error Environment variable BOLOS_SDK is not set)
endif
include $(BOLOS_SDK)/Makefile.defines

#########
# App #
#########

APP_LOAD_PARAMS = --curve ed25519
APP_LOAD_PARAMS += --appFlags 0x200 # APPLICATION_FLAG_BOLOS_SETTINGS
APP_LOAD_PARAMS += --path "44'/3030'"
APP_LOAD_PARAMS += $(COMMON_LOAD_PARAMS)
include $(BOLOS_SDK)/Makefile.defines

APPVERSION_M = 1
APPVERSION_N = 4
APPVERSION_P = 2
APPVERSION = $(APPVERSION_M).$(APPVERSION_N).$(APPVERSION_P)
########################################
# Mandatory configuration #
########################################
# Application name
APPNAME = Hedera

COIN = HBAR

DEFINES += $(DEFINES_LIB)
# Application version
APPVERSION_M = 1
APPVERSION_N = 5
APPVERSION_P = 0
APPVERSION = "$(APPVERSION_M).$(APPVERSION_N).$(APPVERSION_P)"

# Application source files
APP_SOURCE_PATH += src proto
SDK_SOURCE_PATH += lib_u2f

# Application icons
ICON_NANOS = icons/nanos_app_hedera.gif
ICON_NANOX = icons/nanox_app_hedera.gif
ICON_NANOSP = icons/nanox_app_hedera.gif
ICON_STAX = icons/stax_app_hedera.gif
ICON_FLEX = icons/flex_app_hedera.gif

# Application allowed derivation curves.
CURVE_APP_LOAD_PARAMS = ed25519

# Application allowed derivation paths.
PATH_APP_LOAD_PARAMS = "44'/3030'" # purpose=coin(44) / coin_type=Hedera HBAR(3030)

VARIANT_PARAM = COIN
VARIANT_VALUES = hedera

# Enabling DEBUG flag will enable PRINTF and disable optimizations
#DEBUG = 1

########################################
# Application custom permissions #
########################################
HAVE_APPLICATION_FLAG_BOLOS_SETTINGS = 1

########################################
# Application communication interfaces #
########################################
ENABLE_BLUETOOTH = 1

########################################
# NBGL custom features #
########################################
ENABLE_NBGL_QRCODE = 1

########################################
# Features disablers #
########################################
# These advanced settings allow to disable some feature that are by
# default enabled in the SDK `Makefile.standard_app`.
DISABLE_STANDARD_APP_FILES = 1

########################################
# App specific configuration #
########################################
ifeq ($(TARGET_NAME),TARGET_NANOS)
ICONNAME=icons/nanos_app_hedera.gif
else ifeq ($(TARGET_NAME),TARGET_STAX)
ICONNAME=icons/stax_app_hedera.gif
else
ICONNAME=icons/nanox_app_hedera.gif
DISABLE_STANDARD_BAGL_UX_FLOW = 1
endif


################
# Default rule #
################

all: default

############
# Platform #
############

DEFINES += OS_IO_SEPROXYHAL
DEFINES += HAVE_SPRINTF

DEFINES += HAVE_IO_USB HAVE_L4_USBLIB IO_USB_MAX_ENDPOINTS=6 IO_HID_EP_LENGTH=64 HAVE_USB_APDU
DEFINES += APPVERSION_M=$(APPVERSION_M) APPVERSION_N=$(APPVERSION_N) APPVERSION_P=$(APPVERSION_P)

# vendor/ledger-nanopb
DFEFINES += PB_FIELD_32BIT=1
DEFINES += PB_FIELD_32BIT=1

# vendor/printf
DEFINES += PRINTF_DISABLE_SUPPORT_FLOAT PRINTF_DISABLE_SUPPORT_EXPONENTIAL PRINTF_DISABLE_SUPPORT_PTRDIFF_T
Expand All @@ -75,97 +96,17 @@ DEFINES += PRINTF_FTOA_BUFFER_SIZE=0
# U2F
DEFINES += HAVE_U2F HAVE_IO_U2F
DEFINES += U2F_PROXY_MAGIC=\"BOIL\"
DEFINES += USB_SEGMENT_SIZE=64
DEFINES += BLE_SEGMENT_SIZE=32 #max MTU, min 20

#WEBUSB_URL = www.ledgerwallet.com
#DEFINES += HAVE_WEBUSB WEBUSB_URL_SIZE_B=$(shell echo -n $(WEBUSB_URL) | wc -c) WEBUSB_URL=$(shell echo -n $(WEBUSB_URL) | sed -e "s/./\\\'\0\\\',/g")

DEFINES += HAVE_WEBUSB WEBUSB_URL_SIZE_B=0 WEBUSB_URL=""

DEFINES += APPVERSION=\"$(APPVERSION)\"


ifeq ($(TARGET_NAME),$(filter $(TARGET_NAME),TARGET_NANOX TARGET_STAX))
DEFINES += HAVE_BLE BLE_COMMAND_TIMEOUT_MS=2000 HAVE_BLE_APDU
endif

ifeq ($(TARGET_NAME),TARGET_NANOS)
DEFINES += IO_SEPROXYHAL_BUFFER_SIZE_B=128
else
DEFINES += IO_SEPROXYHAL_BUFFER_SIZE_B=300
endif

ifeq ($(TARGET_NAME),TARGET_STAX)
DEFINES += NBGL_QRCODE
SDK_SOURCE_PATH += qrcode
else
DEFINES += HAVE_BAGL
ifneq ($(TARGET_NAME),TARGET_NANOS)
DEFINES += HAVE_UX_FLOW
DEFINES += HAVE_GLO096
DEFINES += BAGL_WIDTH=128 BAGL_HEIGHT=64
DEFINES += HAVE_BAGL_ELLIPSIS # long label truncation feature
DEFINES += HAVE_BAGL_FONT_OPEN_SANS_REGULAR_11PX
DEFINES += HAVE_BAGL_FONT_OPEN_SANS_EXTRABOLD_11PX
DEFINES += HAVE_BAGL_FONT_OPEN_SANS_LIGHT_16PX
endif
endif

# Enabling debug PRINTF
DEBUG ?= 0
ifneq ($(DEBUG),0)
ifeq ($(TARGET_NAME),TARGET_NANOS)
DEFINES += HAVE_PRINTF PRINTF=screen_printf
else
DEFINES += HAVE_PRINTF PRINTF=mcu_usb_printf
endif
else
DEFINES += PRINTF\(...\)=
endif

##############
# Compiler #
##############
ifneq ($(BOLOS_ENV),)
CLANGPATH := $(BOLOS_ENV)/clang-arm-fropi/bin/
GCCPATH := $(BOLOS_ENV)/gcc-arm-none-eabi-5_3-2016q1/bin/
endif

CC := $(CLANGPATH)clang

CFLAGS += -Og -Iproto

# nanopb
CFLAGS += -Og -Iproto
CFLAGS += -I.

# printf
# CFLAGS += -Ivendor/printf/

# enable color from inside a script
CFLAGS += -fcolor-diagnostics

AS := $(GCCPATH)arm-none-eabi-gcc

LD := $(GCCPATH)arm-none-eabi-gcc

LDFLAGS += -Og -flto=thin
LDLIBS += -lm -lgcc -lc

# import rules to compile glyphs(/pone)
include $(BOLOS_SDK)/Makefile.glyphs

### variables processed by the common makefile.rules of the SDK to grab source files and include dirs
APP_SOURCE_PATH += src proto
SDK_SOURCE_PATH += lib_stusb lib_stusb_impl lib_u2f

ifneq ($(TARGET_NAME),TARGET_STAX)
SDK_SOURCE_PATH += lib_ux
endif

ifeq ($(TARGET_NAME),$(filter $(TARGET_NAME),TARGET_NANOX TARGET_STAX))
SDK_SOURCE_PATH += lib_blewbxx lib_blewbxx_impl
endif

# Allow usage of function from lib_standard_app/crypto_helpers.c
APP_SOURCE_FILES += ${BOLOS_SDK}/lib_standard_app/crypto_helpers.c
Expand All @@ -189,6 +130,8 @@ $(C_PB_FILES): %.pb.c: $(PB_FILES)
$(PYTHON_PB_FILES): %_pb2.py: $(PB_FILES)
$(PROTOC) $(PROTOC_OPTS) --python_out=. $*.proto



.PHONY: c_pb python_pb clean_python_pb
c_pb: $(C_PB_FILES)
python_pb: $(PYTHON_PB_FILES)
Expand All @@ -200,27 +143,14 @@ clean_python_pb:
cleanall : clean
-@rm -rf proto/*.pb.c proto/*.pb.h

load: all
python -m ledgerblue.loadApp $(APP_LOAD_PARAMS)

load-offline: all
python -m ledgerblue.loadApp $(APP_LOAD_PARAMS) --offline

delete:
python -m ledgerblue.deleteApp $(COMMON_DELETE_PARAMS)

# import generic rules from the sdk
include $(BOLOS_SDK)/Makefile.rules

#add dependency on custom makefile filename
dep/%.d: %.c Makefile

listvariants:
@echo VARIANTS COIN hedera

check:
@ clang-tidy \
$(foreach path, $(APP_SOURCE_PATH), $(shell find $(path) -name "*.c" -and -not -name "pb*" -and -not -name "glyphs*")) -- \
$(CFLAGS) \
$(addprefix -D, $(DEFINES)) \
$(addprefix -I, $(INCLUDES_PATH))

include $(BOLOS_SDK)/Makefile.standard_app
Binary file added icons/flex_app_hedera.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 1 addition & 1 deletion ledger_app.toml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
[app]
build_directory = "./"
sdk = "C"
devices = ["nanos", "nanox", "nanos+", "stax"]
devices = ["nanos", "nanox", "nanos+", "stax", "flex"]

[tests]
unit_directory = "./unit-tests/"
Expand Down
6 changes: 3 additions & 3 deletions src/get_app_configuration.c
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,9 @@ void handle_get_app_configuration(
G_io_apdu_buffer[ 0 ] = 0;

// version
G_io_apdu_buffer[ 1 ] = APPVERSION_M;
G_io_apdu_buffer[ 2 ] = APPVERSION_N;
G_io_apdu_buffer[ 3 ] = APPVERSION_P;
G_io_apdu_buffer[ 1 ] = MAJOR_VERSION;
G_io_apdu_buffer[ 2 ] = MINOR_VERSION;
G_io_apdu_buffer[ 3 ] = PATCH_VERSION;

io_exchange_with_code(EXCEPTION_OK, 4);
}
5 changes: 2 additions & 3 deletions src/get_public_key.c
Original file line number Diff line number Diff line change
Expand Up @@ -41,11 +41,10 @@ void handle_get_public_key(uint8_t p1, uint8_t p2, uint8_t* buffer,
// key frequently Only do UI actions for p1 == 0
if (p1 == 0) {
// Complete "Export Public | Key #x?"
hedera_snprintf(gpk_ctx.ui_approve_l2,
DISPLAY_SIZE,
hedera_snprintf(gpk_ctx.ui_approve_l2, DISPLAY_SIZE,
#if defined(TARGET_NANOX) || defined(TARGET_NANOS2) || defined(TARGET_NANOS)
"Key #%u?",
#elif defined(TARGET_STAX)
#elif defined(TARGET_STAX) || defined(TARGET_FLEX)
"#%u",
#endif
gpk_ctx.key_index);
Expand Down
2 changes: 1 addition & 1 deletion src/get_public_key.h
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ typedef struct get_public_key_context_s {
// Lines on the UI Screen
char ui_approve_l2[ DISPLAY_SIZE + 1 ];

uint8_t raw_pubkey[65];
uint8_t raw_pubkey[ 65 ];

// Public Key Compare
uint8_t display_index;
Expand Down
38 changes: 12 additions & 26 deletions src/hedera.c
Original file line number Diff line number Diff line change
Expand Up @@ -4,33 +4,26 @@
#include <os.h>
#include <string.h>

#include "lib_standard_app/crypto_helpers.h"

#include "globals.h"
#include "lib_standard_app/crypto_helpers.h"
#include "utils.h"

static void hedera_set_path(uint32_t index, uint32_t path[static 5]) {
static void hedera_set_path(uint32_t index, uint32_t path[ static 5 ]) {
path[ 0 ] = PATH_ZERO;
path[ 1 ] = PATH_ONE;
path[ 2 ] = PATH_TWO;
path[ 3 ] = PATH_THREE;
path[ 4 ] = PATH_FOUR;
}

bool hedera_get_pubkey(uint32_t index, uint8_t raw_pubkey[static 65]) {
bool hedera_get_pubkey(uint32_t index, uint8_t raw_pubkey[ static 65 ]) {
static uint32_t path[ 5 ];

hedera_set_path(index, path);

if (CX_OK != bip32_derive_with_seed_get_pubkey_256(HDW_ED25519_SLIP10,
CX_CURVE_Ed25519,
path,
5,
raw_pubkey,
NULL,
CX_SHA512,
NULL,
0)) {
if (CX_OK != bip32_derive_with_seed_get_pubkey_256(
HDW_ED25519_SLIP10, CX_CURVE_Ed25519, path, 5, raw_pubkey,
NULL, CX_SHA512, NULL, 0)) {
return false;
}

Expand All @@ -39,24 +32,17 @@ bool hedera_get_pubkey(uint32_t index, uint8_t raw_pubkey[static 65]) {

bool hedera_sign(uint32_t index, const uint8_t* tx, uint8_t tx_len,
/* out */ uint8_t* result) {

static uint32_t path[ 5 ];
size_t sig_len = 64;

hedera_set_path(index, path);


if (CX_OK != bip32_derive_with_seed_eddsa_sign_hash_256(HDW_ED25519_SLIP10,
CX_CURVE_Ed25519,
path,
5,
CX_SHA512,
tx, // hash (really message)
tx_len, // hash length (really message length)
result, // signature
&sig_len,
NULL,
0)) {
if (CX_OK != bip32_derive_with_seed_eddsa_sign_hash_256(
HDW_ED25519_SLIP10, CX_CURVE_Ed25519, path, 5, CX_SHA512,
tx, // hash (really message)
tx_len, // hash length (really message length)
result, // signature
&sig_len, NULL, 0)) {
return false;
}

Expand Down
2 changes: 1 addition & 1 deletion src/hedera.h
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
#include <stdbool.h>
#include <stdint.h>

bool hedera_get_pubkey(uint32_t index, uint8_t raw_pubkey[static 65]);
bool hedera_get_pubkey(uint32_t index, uint8_t raw_pubkey[ static 65 ]);

bool hedera_sign(uint32_t index, const uint8_t* tx, uint8_t tx_len,
/* out */ uint8_t* result);
Loading

0 comments on commit c766801

Please sign in to comment.