|
|
|
#ifndef LIGHTNING_LIGHTNINGD_JSONRPC_H
|
|
|
|
#define LIGHTNING_LIGHTNINGD_JSONRPC_H
|
|
|
|
#include "config.h"
|
|
|
|
#include <bitcoin/chainparams.h>
|
|
|
|
#include <ccan/autodata/autodata.h>
|
|
|
|
#include <ccan/list/list.h>
|
|
|
|
#include <ccan/membuf/membuf.h>
|
|
|
|
#include <common/io_lock.h>
|
|
|
|
#include <common/json.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
|
|
|
struct bitcoin_txid;
|
|
|
|
struct wireaddr;
|
|
|
|
struct wallet_tx;
|
|
|
|
|
|
|
|
/* The command mode tells param() how to process. */
|
|
|
|
enum command_mode {
|
|
|
|
/* Normal command processing */
|
|
|
|
CMD_NORMAL,
|
|
|
|
/* Create command usage string, nothing else. */
|
|
|
|
CMD_USAGE
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Context for a command (from JSON, but might outlive the connection!)
|
|
|
|
* You can allocate off this for temporary objects. */
|
|
|
|
struct command {
|
|
|
|
/* The global state */
|
|
|
|
struct lightningd *ld;
|
|
|
|
/* The 'id' which we need to include in the response. */
|
|
|
|
const char *id;
|
|
|
|
/* What command we're running (for logging) */
|
|
|
|
const struct json_command *json_cmd;
|
|
|
|
/* The connection, or NULL if it closed. */
|
|
|
|
struct json_connection *jcon;
|
|
|
|
/* Have we been marked by command_still_pending? For debugging... */
|
|
|
|
bool pending;
|
|
|
|
/* Tell param() how to process the command */
|
|
|
|
enum command_mode mode;
|
|
|
|
/* This is created if mode is CMD_USAGE */
|
|
|
|
const char *usage;
|
|
|
|
bool *ok;
|
|
|
|
/* Have we started a json stream already? For debugging. */
|
|
|
|
bool have_json_stream;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct json_connection {
|
|
|
|
/* The global state */
|
|
|
|
struct lightningd *ld;
|
|
|
|
|
|
|
|
/* This io_conn (and our owner!) */
|
|
|
|
struct io_conn *conn;
|
|
|
|
|
|
|
|
/* Logging for this json connection. */
|
|
|
|
struct log *log;
|
|
|
|
|
|
|
|
/* The buffer (required to interpret tokens). */
|
|
|
|
char *buffer;
|
|
|
|
|
|
|
|
/* Internal state: */
|
|
|
|
/* How much is already filled. */
|
|
|
|
size_t used;
|
|
|
|
/* How much has just been filled. */
|
|
|
|
size_t len_read;
|
|
|
|
|
|
|
|
/* We've been told to stop. */
|
|
|
|
bool stop;
|
|
|
|
|
|
|
|
/* Current command. */
|
|
|
|
struct command *command;
|
|
|
|
|
|
|
|
/* Current command's output. */
|
|
|
|
MEMBUF(char) outbuf;
|
|
|
|
|
|
|
|
/* How much we're writing right now. */
|
|
|
|
size_t out_amount;
|
|
|
|
struct io_lock *lock;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct json_command {
|
|
|
|
const char *name;
|
|
|
|
void (*dispatch)(struct command *,
|
|
|
|
const char *buffer, const jsmntok_t *params);
|
|
|
|
const char *description;
|
|
|
|
bool deprecated;
|
|
|
|
const char *verbose;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct json_stream *null_response(struct command *cmd);
|
|
|
|
void command_success(struct command *cmd, struct json_stream *response);
|
|
|
|
void command_failed(struct command *cmd, struct json_stream *result);
|
|
|
|
void PRINTF_FMT(3, 4) command_fail(struct command *cmd, int code,
|
|
|
|
const char *fmt, ...);
|
|
|
|
|
|
|
|
/* Mainly for documentation, that we plan to close this later. */
|
|
|
|
void command_still_pending(struct command *cmd);
|
|
|
|
|
|
|
|
/* Low level jcon routines. */
|
|
|
|
void jcon_append(struct json_connection *jcon, const char *str);
|
|
|
|
void jcon_append_vfmt(struct json_connection *jcon, const char *fmt, va_list ap);
|
|
|
|
|
|
|
|
/* For initialization */
|
|
|
|
void setup_jsonrpc(struct lightningd *ld, const char *rpc_filename);
|
|
|
|
|
|
|
|
enum address_parse_result {
|
|
|
|
/* Not recognized as an onchain address */
|
|
|
|
ADDRESS_PARSE_UNRECOGNIZED,
|
|
|
|
/* Recognized as an onchain address, but targets wrong network */
|
|
|
|
ADDRESS_PARSE_WRONG_NETWORK,
|
|
|
|
/* Recognized and succeeds */
|
|
|
|
ADDRESS_PARSE_SUCCESS,
|
|
|
|
};
|
|
|
|
/* Return result of address parsing and fills in *scriptpubkey
|
|
|
|
* allocated off ctx if ADDRESS_PARSE_SUCCESS
|
|
|
|
*/
|
json-invoice: add routeboost, warnings.
We split json_invoice(), as it now needs to round-trip to the gossipd,
and uniqueness checks need to happen *after* gossipd replies to avoid
a race.
For every candidate channel gossipd gives us, we check that it's in
state NORMAL (not shutting down, not still waiting for lockin), that
it's connected, and that it has capacity. We then choose one with
probability weighted by excess capacity, so larger channels are more
likely.
As a side effect of this, we can tell if an invoice is unpayble (no
channels have sufficient incoming capacity) or difficuly (no *online*
channels have sufficient capacity), so we add those warnings.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
6 years ago
|
|
|
enum address_parse_result json_tok_address_scriptpubkey(const tal_t *ctx,
|
|
|
|
const struct chainparams *chainparams,
|
|
|
|
const char *buffer,
|
|
|
|
const jsmntok_t *tok, const u8 **scriptpubkey);
|
|
|
|
|
|
|
|
/* Parse the satoshi token in wallet_tx. */
|
|
|
|
bool json_tok_wtx(struct wallet_tx * tx, const char * buffer,
|
|
|
|
const jsmntok_t * sattok, u64 max);
|
|
|
|
|
|
|
|
AUTODATA_TYPE(json_command, struct json_command);
|
|
|
|
#endif /* LIGHTNING_LIGHTNINGD_JSONRPC_H */
|