2018-12-08 01:39:28 +01:00
|
|
|
/* Helpers for use with param parsing. */
|
|
|
|
#ifndef LIGHTNING_COMMON_JSON_TOK_H
|
|
|
|
#define LIGHTNING_COMMON_JSON_TOK_H
|
|
|
|
#include "config.h"
|
2019-01-15 04:54:27 +01:00
|
|
|
#include <ccan/short_types/short_types.h>
|
2018-12-08 01:39:28 +01:00
|
|
|
#include <common/json.h>
|
|
|
|
|
|
|
|
struct command;
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result;
|
2019-01-15 04:54:27 +01:00
|
|
|
struct json_escaped;
|
|
|
|
struct sha256;
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract json array token */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_array(struct command *cmd, const char *name,
|
|
|
|
const char *buffer, const jsmntok_t *tok,
|
|
|
|
const jsmntok_t **arr);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract boolean this (must be a true or false) */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_bool(struct command *cmd, const char *name,
|
|
|
|
const char *buffer, const jsmntok_t *tok,
|
|
|
|
bool **b);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract double from this (must be a number literal) */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_double(struct command *cmd, const char *name,
|
|
|
|
const char *buffer, const jsmntok_t *tok,
|
|
|
|
double **num);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract an escaped string (and unescape it) */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_escaped_string(struct command *cmd,
|
|
|
|
const char *name,
|
|
|
|
const char *buffer,
|
|
|
|
const jsmntok_t *tok,
|
|
|
|
const char **str);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract a string */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_string(struct command *cmd, const char *name,
|
|
|
|
const char * buffer, const jsmntok_t *tok,
|
|
|
|
const char **str);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract a label. It is either an escaped string or a number. */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_label(struct command *cmd, const char *name,
|
|
|
|
const char * buffer, const jsmntok_t *tok,
|
|
|
|
struct json_escaped **label);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract number from this (may be a string, or a number literal) */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_number(struct command *cmd, const char *name,
|
|
|
|
const char *buffer, const jsmntok_t *tok,
|
|
|
|
unsigned int **num);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract sha256 hash */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_sha256(struct command *cmd, const char *name,
|
|
|
|
const char *buffer, const jsmntok_t *tok,
|
|
|
|
struct sha256 **hash);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract positive integer, or NULL if tok is 'any'. */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_msat(struct command *cmd, const char *name,
|
|
|
|
const char *buffer, const jsmntok_t * tok,
|
|
|
|
u64 **msatoshi_val);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract double in range [0.0, 100.0] */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_percent(struct command *cmd, const char *name,
|
|
|
|
const char *buffer, const jsmntok_t *tok,
|
|
|
|
double **num);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/* Extract number from this (may be a string, or a number literal) */
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_u64(struct command *cmd, const char *name,
|
|
|
|
const char *buffer, const jsmntok_t *tok,
|
|
|
|
uint64_t **num);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Set the address of @out to @tok. Used as a callback by handlers that
|
|
|
|
* want to unmarshal @tok themselves.
|
2018-12-10 19:59:04 +01:00
|
|
|
*
|
|
|
|
* Usage of this is discouraged. Writing a local static bespoke handler is
|
|
|
|
* preferred.
|
2018-12-08 01:39:28 +01:00
|
|
|
*/
|
2018-12-16 05:50:06 +01:00
|
|
|
struct command_result *param_tok(struct command *cmd, const char *name,
|
|
|
|
const char *buffer, const jsmntok_t * tok,
|
|
|
|
const jsmntok_t **out);
|
2018-12-08 01:39:28 +01:00
|
|
|
|
|
|
|
#endif /* LIGHTNING_COMMON_JSON_TOK_H */
|