jsonrpc: Implement command_fail_detailed.

This commit is contained in:
ZmnSCPxj 2018-01-27 02:05:49 +00:00 committed by Christian Decker
parent 551dfedc4a
commit e1d17e92e0
2 changed files with 48 additions and 12 deletions

View File

@ -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[])

View File

@ -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);