mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-18 05:12:45 +01:00
jsonrpc: Implement command_fail_detailed.
This commit is contained in:
parent
551dfedc4a
commit
e1d17e92e0
@ -323,24 +323,38 @@ static void connection_result(struct json_connection *jcon,
|
|||||||
const char *id,
|
const char *id,
|
||||||
const char *res,
|
const char *res,
|
||||||
const char *err,
|
const char *err,
|
||||||
int code)
|
int code,
|
||||||
|
const struct json_result *data)
|
||||||
{
|
{
|
||||||
struct json_output *out = tal(jcon, struct json_output);
|
struct json_output *out = tal(jcon, struct json_output);
|
||||||
|
const tal_t *tmpctx;
|
||||||
|
const char* data_str;
|
||||||
|
|
||||||
if (err == NULL)
|
if (err == NULL)
|
||||||
out->json = tal_fmt(out,
|
out->json = tal_fmt(out,
|
||||||
"{ \"jsonrpc\": \"2.0\", "
|
"{ \"jsonrpc\": \"2.0\", "
|
||||||
"\"result\" : %s,"
|
"\"result\" : %s,"
|
||||||
" \"id\" : %s }\n",
|
" \"id\" : %s }\n",
|
||||||
res, id);
|
res, id);
|
||||||
else
|
else {
|
||||||
|
tmpctx = tal_tmpctx(out);
|
||||||
|
if (data)
|
||||||
|
data_str = tal_fmt(tmpctx,
|
||||||
|
", \"data\" : %s",
|
||||||
|
json_result_string(data));
|
||||||
|
else
|
||||||
|
data_str = "";
|
||||||
|
|
||||||
out->json = tal_fmt(out,
|
out->json = tal_fmt(out,
|
||||||
"{ \"jsonrpc\": \"2.0\", "
|
"{ \"jsonrpc\": \"2.0\", "
|
||||||
" \"error\" : "
|
" \"error\" : "
|
||||||
"{ \"code\" : %d,"
|
"{ \"code\" : %d,"
|
||||||
" \"message\" : %s},"
|
" \"message\" : %s%s },"
|
||||||
" \"id\" : %s }\n",
|
" \"id\" : %s }\n",
|
||||||
code,
|
code, err, data_str,
|
||||||
err, id);
|
id);
|
||||||
|
tal_free(tmpctx);
|
||||||
|
}
|
||||||
|
|
||||||
/* Queue for writing, and wake writer (and maybe reader). */
|
/* Queue for writing, and wake writer (and maybe reader). */
|
||||||
list_add_tail(&jcon->output, &out->list);
|
list_add_tail(&jcon->output, &out->list);
|
||||||
@ -435,16 +449,19 @@ void command_success(struct command *cmd, struct json_result *result)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
assert(jcon->current == cmd);
|
assert(jcon->current == cmd);
|
||||||
connection_result(jcon, cmd->id, json_result_string(result), NULL, 0);
|
connection_result(jcon, cmd->id, json_result_string(result),
|
||||||
|
NULL, 0, NULL);
|
||||||
log_debug(jcon->log, "Success");
|
log_debug(jcon->log, "Success");
|
||||||
jcon->current = tal_free(cmd);
|
jcon->current = tal_free(cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void command_fail(struct command *cmd, const char *fmt, ...)
|
static void command_fail_v(struct command *cmd,
|
||||||
|
int code,
|
||||||
|
const struct json_result *data,
|
||||||
|
const char *fmt, va_list ap)
|
||||||
{
|
{
|
||||||
char *quote, *error;
|
char *quote, *error;
|
||||||
struct json_connection *jcon = cmd->jcon;
|
struct json_connection *jcon = cmd->jcon;
|
||||||
va_list ap;
|
|
||||||
|
|
||||||
if (!jcon) {
|
if (!jcon) {
|
||||||
log_unusual(cmd->ld->log,
|
log_unusual(cmd->ld->log,
|
||||||
@ -453,9 +470,7 @@ void command_fail(struct command *cmd, const char *fmt, ...)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
va_start(ap, fmt);
|
|
||||||
error = tal_vfmt(cmd, fmt, ap);
|
error = tal_vfmt(cmd, fmt, ap);
|
||||||
va_end(ap);
|
|
||||||
|
|
||||||
log_debug(jcon->log, "Failing: %s", error);
|
log_debug(jcon->log, "Failing: %s", error);
|
||||||
|
|
||||||
@ -467,9 +482,25 @@ void command_fail(struct command *cmd, const char *fmt, ...)
|
|||||||
quote = tal_fmt(cmd, "\"%s\"", error);
|
quote = tal_fmt(cmd, "\"%s\"", error);
|
||||||
|
|
||||||
assert(jcon->current == cmd);
|
assert(jcon->current == cmd);
|
||||||
connection_result(jcon, cmd->id, NULL, quote, -1);
|
connection_result(jcon, cmd->id, NULL, quote, -1, data);
|
||||||
jcon->current = tal_free(cmd);
|
jcon->current = tal_free(cmd);
|
||||||
}
|
}
|
||||||
|
void command_fail(struct command *cmd, const char *fmt, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
va_start(ap, fmt);
|
||||||
|
command_fail_v(cmd, -1, NULL, fmt, ap);
|
||||||
|
va_end(ap);
|
||||||
|
}
|
||||||
|
void command_fail_detailed(struct command *cmd,
|
||||||
|
int code, const struct json_result *data,
|
||||||
|
const char *fmt, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
va_start(ap, fmt);
|
||||||
|
command_fail_v(cmd, code, data, fmt, ap);
|
||||||
|
va_end(ap);
|
||||||
|
}
|
||||||
|
|
||||||
void command_still_pending(struct command *cmd)
|
void command_still_pending(struct command *cmd)
|
||||||
{
|
{
|
||||||
@ -483,7 +514,8 @@ static void json_command_malformed(struct json_connection *jcon,
|
|||||||
const char *error)
|
const char *error)
|
||||||
{
|
{
|
||||||
return connection_result(jcon, id, NULL, error,
|
return connection_result(jcon, id, NULL, error,
|
||||||
JSONRPC2_INVALID_REQUEST);
|
JSONRPC2_INVALID_REQUEST,
|
||||||
|
NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void parse_request(struct json_connection *jcon, const jsmntok_t tok[])
|
static void parse_request(struct json_connection *jcon, const jsmntok_t tok[])
|
||||||
|
@ -58,6 +58,10 @@ struct json_command {
|
|||||||
struct json_result *null_response(const tal_t *ctx);
|
struct json_result *null_response(const tal_t *ctx);
|
||||||
void command_success(struct command *cmd, struct json_result *response);
|
void command_success(struct command *cmd, struct json_result *response);
|
||||||
void PRINTF_FMT(2, 3) command_fail(struct command *cmd, const char *fmt, ...);
|
void PRINTF_FMT(2, 3) command_fail(struct command *cmd, const char *fmt, ...);
|
||||||
|
void PRINTF_FMT(4, 5) command_fail_detailed(struct command *cmd,
|
||||||
|
int code,
|
||||||
|
const struct json_result *data,
|
||||||
|
const char *fmt, ...);
|
||||||
|
|
||||||
/* Mainly for documentation, that we plan to close this later. */
|
/* Mainly for documentation, that we plan to close this later. */
|
||||||
void command_still_pending(struct command *cmd);
|
void command_still_pending(struct command *cmd);
|
||||||
|
Loading…
Reference in New Issue
Block a user