mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-10 15:45:09 +01:00
2610799bda
This is less convenient to use, but makes far more sense for a real user (like a wallet). It can ask about the route, then decide whether to use it or not. This will make even more sense once we add a parameter to control how long we let the HTLC be delayed for, so a client can query for high, medium and low tolerances and compare results. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
81 lines
2.5 KiB
C
81 lines
2.5 KiB
C
#ifndef LIGHTNING_DAEMON_JSONRPC_H
|
|
#define LIGHTNING_DAEMON_JSONRPC_H
|
|
#include "config.h"
|
|
#include "json.h"
|
|
#include <ccan/list/list.h>
|
|
|
|
/* 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_state *dstate;
|
|
/* The 'id' which we need to include in the response. */
|
|
const char *id;
|
|
/* The connection, or NULL if it closed. */
|
|
struct json_connection *jcon;
|
|
};
|
|
|
|
struct json_connection {
|
|
/* The global state */
|
|
struct lightningd_state *dstate;
|
|
|
|
/* 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 *current;
|
|
|
|
struct list_head output;
|
|
const char *outbuf;
|
|
};
|
|
|
|
struct json_command {
|
|
const char *name;
|
|
void (*dispatch)(struct command *,
|
|
const char *buffer, const jsmntok_t *params);
|
|
const char *description;
|
|
const char *help;
|
|
};
|
|
|
|
struct json_result *null_response(const tal_t *ctx);
|
|
void command_success(struct command *cmd, struct json_result *response);
|
|
void PRINTF_FMT(2, 3) command_fail(struct command *cmd, const char *fmt, ...);
|
|
|
|
/* For initialization */
|
|
void setup_jsonrpc(struct lightningd_state *dstate, const char *rpc_filename);
|
|
|
|
/* Commands (from other files) */
|
|
extern const struct json_command connect_command;
|
|
extern const struct json_command getpeers_command;
|
|
extern const struct json_command gethtlcs_command;
|
|
extern const struct json_command newhtlc_command;
|
|
extern const struct json_command fulfillhtlc_command;
|
|
extern const struct json_command failhtlc_command;
|
|
extern const struct json_command commit_command;
|
|
extern const struct json_command mocktime_command;
|
|
extern const struct json_command close_command;
|
|
extern const struct json_command newaddr_command;
|
|
extern const struct json_command reconnect_command;
|
|
extern const struct json_command disconnect_command;
|
|
extern const struct json_command signcommit_command;
|
|
extern const struct json_command output_command;
|
|
extern const struct json_command accept_payment_command;
|
|
extern const struct json_command add_route_command;
|
|
extern const struct json_command routefail_command;
|
|
extern const struct json_command getroute_command;
|
|
extern const struct json_command sendpay_command;
|
|
extern const struct json_command feerate_command;
|
|
#endif /* LIGHTNING_DAEMON_JSONRPC_H */
|