2017-01-10 06:08:33 +01:00
|
|
|
#include "hsm_control.h"
|
|
|
|
#include "lightningd.h"
|
2017-03-10 11:49:43 +01:00
|
|
|
#include "subd.h"
|
2017-01-10 06:08:33 +01:00
|
|
|
#include <ccan/err/err.h>
|
|
|
|
#include <ccan/io/io.h>
|
|
|
|
#include <ccan/take/take.h>
|
2017-08-28 18:05:01 +02:00
|
|
|
#include <common/status.h>
|
2017-08-28 18:02:01 +02:00
|
|
|
#include <common/utils.h>
|
2017-06-24 08:50:23 +02:00
|
|
|
#include <errno.h>
|
2017-11-30 17:07:38 +01:00
|
|
|
#include <hsmd/gen_hsm_client_wire.h>
|
2017-01-10 06:08:33 +01:00
|
|
|
#include <inttypes.h>
|
2017-11-22 01:25:39 +01:00
|
|
|
#include <lightningd/hsm_control.h>
|
2017-08-28 18:04:01 +02:00
|
|
|
#include <lightningd/log.h>
|
2018-02-05 05:09:27 +01:00
|
|
|
#include <lightningd/log_status.h>
|
2017-06-24 08:50:23 +02:00
|
|
|
#include <string.h>
|
2017-02-21 05:45:29 +01:00
|
|
|
#include <wally_bip32.h>
|
2017-06-24 08:50:23 +02:00
|
|
|
#include <wire/wire_sync.h>
|
2017-01-10 06:08:33 +01:00
|
|
|
|
2017-06-24 08:50:23 +02:00
|
|
|
u8 *hsm_sync_read(const tal_t *ctx, struct lightningd *ld)
|
2017-01-10 06:08:33 +01:00
|
|
|
{
|
2017-06-24 08:50:23 +02:00
|
|
|
for (;;) {
|
|
|
|
u8 *msg = wire_sync_read(ctx, ld->hsm_fd);
|
2018-02-05 05:09:27 +01:00
|
|
|
|
2017-06-24 08:50:23 +02:00
|
|
|
if (!msg)
|
2017-10-25 11:17:08 +02:00
|
|
|
fatal("Could not read from HSM: %s", strerror(errno));
|
2018-02-05 05:09:27 +01:00
|
|
|
if (log_status_msg(ld->log, msg))
|
|
|
|
tal_free(msg);
|
|
|
|
else
|
2017-06-24 08:50:23 +02:00
|
|
|
return msg;
|
2017-01-10 06:08:33 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-10 06:08:33 +01:00
|
|
|
void hsm_init(struct lightningd *ld, bool newdir)
|
|
|
|
{
|
2017-06-24 08:50:23 +02:00
|
|
|
const tal_t *tmpctx = tal_tmpctx(ld);
|
2017-08-18 06:43:52 +02:00
|
|
|
u8 *msg;
|
2017-01-10 06:08:33 +01:00
|
|
|
bool create;
|
|
|
|
|
2017-08-29 06:12:04 +02:00
|
|
|
ld->hsm_fd = subd_raw(ld, "lightning_hsmd");
|
2017-06-24 08:50:23 +02:00
|
|
|
if (ld->hsm_fd < 0)
|
2017-03-10 11:49:43 +01:00
|
|
|
err(1, "Could not subd hsm");
|
2017-01-10 06:08:33 +01:00
|
|
|
|
2018-02-05 05:09:27 +01:00
|
|
|
ld->hsm_log = new_log(ld, ld->log_book, "hsmd:");
|
2017-01-10 06:08:33 +01:00
|
|
|
if (newdir)
|
|
|
|
create = true;
|
|
|
|
else
|
|
|
|
create = (access("hsm_secret", F_OK) != 0);
|
|
|
|
|
2017-11-30 17:07:38 +01:00
|
|
|
if (!wire_sync_write(ld->hsm_fd, towire_hsm_init(tmpctx, create)))
|
2017-06-24 08:50:23 +02:00
|
|
|
err(1, "Writing init msg to hsm");
|
2017-01-10 06:08:33 +01:00
|
|
|
|
2017-08-28 18:09:01 +02:00
|
|
|
ld->wallet->bip32_base = tal(ld->wallet, struct ext_key);
|
2017-06-24 08:50:23 +02:00
|
|
|
msg = hsm_sync_read(tmpctx, ld);
|
2018-02-20 21:59:09 +01:00
|
|
|
if (!fromwire_hsm_init_reply(msg,
|
2017-08-28 18:09:01 +02:00
|
|
|
&ld->id,
|
2017-06-24 08:50:23 +02:00
|
|
|
&ld->peer_seed,
|
2017-08-28 18:09:01 +02:00
|
|
|
ld->wallet->bip32_base))
|
2017-06-24 08:50:23 +02:00
|
|
|
errx(1, "HSM did not give init reply");
|
2017-01-10 06:08:33 +01:00
|
|
|
|
2017-08-18 06:43:52 +02:00
|
|
|
tal_free(tmpctx);
|
2017-06-24 08:50:23 +02:00
|
|
|
}
|