Since we included the spec for it, this is a good time to implement it. I also asked chatgpt to write some unit tests. I had to mangle them a bit, but it probably saved me a few minutes. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
32 lines
1.2 KiB
C
32 lines
1.2 KiB
C
#ifndef LIGHTNING_COMMON_SHUTDOWN_SCRIPTPUBKEY_H
|
|
#define LIGHTNING_COMMON_SHUTDOWN_SCRIPTPUBKEY_H
|
|
#include "config.h"
|
|
#include <ccan/short_types/short_types.h>
|
|
|
|
/* BOLT #2:
|
|
*
|
|
* 1. `OP_0` `20` 20-bytes (version 0 pay to witness pubkey hash), OR
|
|
* 2. `OP_0` `32` 32-bytes (version 0 pay to witness script hash), OR
|
|
* 3. if (and only if) `option_shutdown_anysegwit` is negotiated:
|
|
* * `OP_1` through `OP_16` inclusive, followed by a single push of 2 to 40 bytes
|
|
* (witness program versions 1 through 16)
|
|
* 4. if (and only if) `option_simple_close` is negotiated:
|
|
* * `OP_RETURN` followed by one of:
|
|
* * `6` to `75` inclusive followed by exactly that many bytes
|
|
* * `76` followed by `76` to `80` followed by exactly that many bytes
|
|
*
|
|
* A receiving node:
|
|
*...
|
|
* - if the `scriptpubkey` is not in one of the above forms:
|
|
* - SHOULD send a `warning`
|
|
*/
|
|
|
|
/* We still allow them to specify an old-style P2PKH or P2SH (though we
|
|
* never will send such a thing!) if they're not using anchors. */
|
|
bool valid_shutdown_scriptpubkey(const u8 *scriptpubkey,
|
|
bool anysegwit,
|
|
bool allow_oldstyle,
|
|
bool option_simple_close);
|
|
|
|
#endif /* LIGHTNING_COMMON_SHUTDOWN_SCRIPTPUBKEY_H */
|