mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-10 07:37:05 +01:00
b99c5620ef
We alternated between using a sha256 and using a privkey, but there are numerous places where we have a random 32 bytes which are neither. This fixes many of them (plus, struct privkey is now defined in terms of struct secret). Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
32 lines
575 B
C
32 lines
575 B
C
#include <lightningd/hsm/client.h>
|
|
#include <lightningd/hsm/gen_hsm_client_wire.h>
|
|
#include <wire/wire_sync.h>
|
|
|
|
static int hsm_fd = -1;
|
|
|
|
void hsm_setup(int fd)
|
|
{
|
|
hsm_fd = fd;
|
|
}
|
|
|
|
bool hsm_do_ecdh(struct secret *ss, const struct pubkey *point)
|
|
{
|
|
u8 *req = towire_hsm_ecdh_req(NULL, point), *resp;
|
|
size_t len;
|
|
|
|
if (!wire_sync_write(hsm_fd, req))
|
|
goto fail;
|
|
resp = wire_sync_read(req, hsm_fd);
|
|
if (!resp)
|
|
goto fail;
|
|
len = tal_count(resp);
|
|
if (!fromwire_hsm_ecdh_resp(resp, &len, ss))
|
|
goto fail;
|
|
tal_free(req);
|
|
return true;
|
|
|
|
fail:
|
|
tal_free(req);
|
|
return false;
|
|
}
|