mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-02-22 14:42:40 +01:00
At the moment only lightingd needs it, and this avoids missing any places where we do bip32 derivation. This uses a hsm capability to mean we're backwards compatible with older hsmds. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> Changelog-Added: Protocol: we now always double-check bitcoin addresses are correct (no memory errors!) before issuing them.
28 lines
876 B
C
28 lines
876 B
C
#ifndef LIGHTNING_LIGHTNINGD_HSM_CONTROL_H
|
|
#define LIGHTNING_LIGHTNINGD_HSM_CONTROL_H
|
|
#include "config.h"
|
|
#include <ccan/short_types/short_types.h>
|
|
|
|
struct lightningd;
|
|
struct node_id;
|
|
struct ext_key;
|
|
|
|
/* Ask HSM for a new fd for a subdaemon to use. */
|
|
int hsm_get_client_fd(struct lightningd *ld,
|
|
const struct node_id *id,
|
|
u64 dbid,
|
|
int capabilities);
|
|
|
|
/* Ask HSM for an fd for a global subdaemon to use (gossipd, connectd) */
|
|
int hsm_get_global_fd(struct lightningd *ld, int capabilities);
|
|
|
|
/* Is this capability supported by the HSM? (So far, always a message
|
|
* number) */
|
|
bool hsm_capable(struct lightningd *ld, u32 msgtype);
|
|
|
|
struct ext_key *hsm_init(struct lightningd *ld);
|
|
|
|
/* Get (and check!) a bip32 derived pubkey */
|
|
void bip32_pubkey(struct lightningd *ld, struct pubkey *pubkey, u32 index);
|
|
|
|
#endif /* LIGHTNING_LIGHTNINGD_HSM_CONTROL_H */
|