#include #include #include #include #include #include #include #include #include #include #include "lightningd/sphinx.h" secp256k1_context *secp256k1_ctx; int main(int argc, char **argv) { bool generate = false, decode = false; const tal_t *ctx = talz(NULL, tal_t); u8 assocdata[32]; memset(assocdata, 'B', sizeof(assocdata)); secp256k1_ctx = secp256k1_context_create( SECP256K1_CONTEXT_VERIFY | SECP256K1_CONTEXT_SIGN); opt_register_noarg("--help|-h", opt_usage_and_exit, "--generate ... OR\n" "--decode \n" "Either create an onion message, or decode one step", "Print this message."); opt_register_noarg("--generate", opt_set_bool, &generate, "Generate onion through the given hex pubkeys"); opt_register_noarg("--decode", opt_set_bool, &decode, "Decode onion from stdin given the private key"); opt_parse(&argc, argv, opt_log_stderr_exit); if (generate) { int num_hops = argc - 1; struct pubkey *path = tal_arr(ctx, struct pubkey, num_hops); u8 privkeys[argc - 1][32]; u8 sessionkey[32]; memset(&sessionkey, 'A', sizeof(sessionkey)); int i; for (i = 0; i < num_hops; i++) { hex_decode(argv[1 + i], 66, privkeys[i], 33); if (secp256k1_ec_pubkey_create(secp256k1_ctx, &path[i].pubkey, privkeys[i]) != 1) return 1; } struct hoppayload *hoppayloads = tal_arr(ctx, struct hoppayload, num_hops); for (i=0; inext) errx(1, "Error processing message."); u8 *ser = serialize_onionpacket(ctx, step->next); if (!ser) errx(1, "Error serializing message."); hex_encode(ser, tal_count(ser), hextemp, sizeof(hextemp)); printf("%s\n", hextemp); } secp256k1_context_destroy(secp256k1_ctx); tal_free(ctx); return 0; }