2018-03-22 11:36:25 +01:00
|
|
|
#ifndef LIGHTNING_WALLET_DB_H
|
|
|
|
#define LIGHTNING_WALLET_DB_H
|
2017-05-12 20:24:18 +02:00
|
|
|
#include "config.h"
|
2018-03-07 01:06:07 +01:00
|
|
|
|
2017-10-30 19:21:41 +01:00
|
|
|
#include <bitcoin/preimage.h>
|
2018-03-07 01:06:07 +01:00
|
|
|
#include <bitcoin/pubkey.h>
|
2017-10-30 19:21:41 +01:00
|
|
|
#include <bitcoin/short_channel_id.h>
|
|
|
|
#include <bitcoin/tx.h>
|
2017-08-28 18:04:01 +02:00
|
|
|
#include <ccan/short_types/short_types.h>
|
|
|
|
#include <ccan/tal/tal.h>
|
2019-02-20 12:31:48 +01:00
|
|
|
#include <common/amount.h>
|
2017-10-30 19:21:41 +01:00
|
|
|
#include <secp256k1_ecdh.h>
|
2017-05-12 20:24:18 +02:00
|
|
|
#include <sqlite3.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
2019-02-24 06:12:09 +01:00
|
|
|
struct lightningd;
|
2018-01-02 05:03:42 +01:00
|
|
|
struct log;
|
|
|
|
|
2017-05-12 20:24:18 +02:00
|
|
|
struct db {
|
|
|
|
char *filename;
|
2017-11-01 02:21:56 +01:00
|
|
|
const char *in_transaction;
|
2017-05-12 20:24:18 +02:00
|
|
|
sqlite3 *sql;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* db_setup - Open a the lightningd database and update the schema
|
|
|
|
*
|
|
|
|
* Opens the database, creating it if necessary, and applying
|
|
|
|
* migrations until the schema is updated to the current state.
|
2017-11-01 02:21:56 +01:00
|
|
|
* Calls fatal() on error.
|
2017-05-12 20:24:18 +02:00
|
|
|
*
|
|
|
|
* Params:
|
|
|
|
* @ctx: the tal_t context to allocate from
|
2019-03-01 23:18:40 +01:00
|
|
|
* @ld: the lightningd context to hand to upgrade functions.
|
2017-05-12 20:24:18 +02:00
|
|
|
* @log: where to log messages to
|
|
|
|
*/
|
2019-02-24 06:12:09 +01:00
|
|
|
struct db *db_setup(const tal_t *ctx, struct lightningd *ld, struct log *log);
|
2017-05-12 20:24:18 +02:00
|
|
|
|
|
|
|
/**
|
2017-11-01 02:21:56 +01:00
|
|
|
* db_query - Prepare and execute a query, and return the result (or NULL)
|
2017-05-12 20:24:18 +02:00
|
|
|
*/
|
|
|
|
sqlite3_stmt *PRINTF_FMT(3, 4)
|
2018-04-27 03:39:56 +02:00
|
|
|
db_query_(const char *location, struct db *db, const char *fmt, ...);
|
|
|
|
#define db_query(db, ...) \
|
|
|
|
db_query_(__FILE__ ":" stringify(__LINE__), db, __VA_ARGS__)
|
2017-05-12 20:24:18 +02:00
|
|
|
|
2017-05-31 15:50:36 +02:00
|
|
|
/**
|
|
|
|
* db_begin_transaction - Begin a transaction
|
|
|
|
*
|
2017-11-01 02:21:56 +01:00
|
|
|
* Begin a new DB transaction. fatal() on database error.
|
2017-05-31 15:50:36 +02:00
|
|
|
*/
|
2017-11-01 02:21:56 +01:00
|
|
|
#define db_begin_transaction(db) \
|
|
|
|
db_begin_transaction_((db), __FILE__ ":" stringify(__LINE__))
|
|
|
|
void db_begin_transaction_(struct db *db, const char *location);
|
2017-05-31 15:50:36 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* db_commit_transaction - Commit a running transaction
|
|
|
|
*
|
2017-11-01 02:21:56 +01:00
|
|
|
* Requires that we are currently in a transaction. fatal() if we
|
|
|
|
* fail to commit.
|
2017-05-31 15:50:36 +02:00
|
|
|
*/
|
2017-11-01 02:21:56 +01:00
|
|
|
void db_commit_transaction(struct db *db);
|
2017-05-31 15:50:36 +02:00
|
|
|
|
2017-06-01 16:10:40 +02:00
|
|
|
/**
|
|
|
|
* db_set_intvar - Set an integer variable in the database
|
|
|
|
*
|
|
|
|
* Utility function to store generic integer values in the
|
|
|
|
* database.
|
|
|
|
*/
|
2017-11-01 02:21:56 +01:00
|
|
|
void db_set_intvar(struct db *db, char *varname, s64 val);
|
2017-06-01 16:10:40 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* db_get_intvar - Retrieve an integer variable from the database
|
|
|
|
*
|
|
|
|
* Either returns the value in the database, or @defval if
|
|
|
|
* the query failed or no such variable exists.
|
|
|
|
*/
|
|
|
|
s64 db_get_intvar(struct db *db, char *varname, s64 defval);
|
|
|
|
|
2017-10-04 14:24:12 +02:00
|
|
|
/**
|
|
|
|
* db_prepare -- Prepare a DB query/command
|
|
|
|
*
|
|
|
|
* Tiny wrapper around `sqlite3_prepare_v2` that checks and sets
|
|
|
|
* errors like `db_query` and `db_exec` do. It returns a statement
|
|
|
|
* `stmt` if the given query/command was successfully compiled into a
|
|
|
|
* statement, `NULL` otherwise. On failure `db->err` will be set with
|
|
|
|
* the human readable error.
|
|
|
|
*
|
|
|
|
* @db: Database to query/exec
|
|
|
|
* @query: The SQL statement to compile
|
|
|
|
*/
|
2018-04-27 03:39:56 +02:00
|
|
|
#define db_prepare(db,query) \
|
|
|
|
db_prepare_(__FILE__ ":" stringify(__LINE__), db, query)
|
|
|
|
sqlite3_stmt *db_prepare_(const char *location, struct db *db, const char *query);
|
2017-10-04 14:24:12 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* db_exec_prepared -- Execute a prepared statement
|
|
|
|
*
|
|
|
|
* After preparing a statement using `db_prepare`, and after binding
|
|
|
|
* all non-null variables using the `sqlite3_bind_*` functions, it can
|
|
|
|
* be executed with this function. It is a small, transaction-aware,
|
2017-11-01 02:21:56 +01:00
|
|
|
* wrapper around `sqlite3_step`, that calls fatal() if the execution
|
|
|
|
* fails. This will take ownership of `stmt` and will free
|
2017-10-30 16:05:00 +01:00
|
|
|
* it before returning.
|
2017-10-04 14:24:12 +02:00
|
|
|
*
|
|
|
|
* @db: The database to execute on
|
|
|
|
* @stmt: The prepared statement to execute
|
|
|
|
*/
|
|
|
|
#define db_exec_prepared(db,stmt) db_exec_prepared_(__func__,db,stmt)
|
2017-11-01 02:21:56 +01:00
|
|
|
void db_exec_prepared_(const char *caller, struct db *db, sqlite3_stmt *stmt);
|
2017-11-01 02:10:48 +01:00
|
|
|
|
2018-04-27 03:39:33 +02:00
|
|
|
/* Wrapper around sqlite3_finalize(), for tracking statements. */
|
|
|
|
void db_stmt_done(sqlite3_stmt *stmt);
|
|
|
|
|
|
|
|
/* Call when you know there should be no outstanding db statements. */
|
|
|
|
void db_assert_no_outstanding_statements(void);
|
|
|
|
|
2018-02-26 20:29:58 +01:00
|
|
|
/* Do not keep db open across a fork: needed for --daemon */
|
|
|
|
void db_close_for_fork(struct db *db);
|
|
|
|
void db_reopen_after_fork(struct db *db);
|
|
|
|
|
2018-02-19 02:06:14 +01:00
|
|
|
#define sqlite3_column_arr(ctx, stmt, col, type) \
|
|
|
|
((type *)sqlite3_column_arr_((ctx), (stmt), (col), \
|
|
|
|
sizeof(type), TAL_LABEL(type, "[]"), \
|
|
|
|
__func__))
|
|
|
|
void *sqlite3_column_arr_(const tal_t *ctx, sqlite3_stmt *stmt, int col,
|
|
|
|
size_t bytes, const char *label, const char *caller);
|
|
|
|
|
2017-10-30 19:21:41 +01:00
|
|
|
bool sqlite3_bind_short_channel_id(sqlite3_stmt *stmt, int col,
|
|
|
|
const struct short_channel_id *id);
|
2019-01-20 06:43:35 +01:00
|
|
|
WARN_UNUSED_RESULT bool sqlite3_column_short_channel_id(sqlite3_stmt *stmt, int col,
|
|
|
|
struct short_channel_id *dest);
|
2018-01-20 15:00:35 +01:00
|
|
|
bool sqlite3_bind_short_channel_id_array(sqlite3_stmt *stmt, int col,
|
|
|
|
const struct short_channel_id *id);
|
|
|
|
struct short_channel_id *
|
|
|
|
sqlite3_column_short_channel_id_array(const tal_t *ctx,
|
|
|
|
sqlite3_stmt *stmt, int col);
|
2017-10-30 19:21:41 +01:00
|
|
|
bool sqlite3_bind_tx(sqlite3_stmt *stmt, int col, const struct bitcoin_tx *tx);
|
|
|
|
struct bitcoin_tx *sqlite3_column_tx(const tal_t *ctx, sqlite3_stmt *stmt,
|
|
|
|
int col);
|
|
|
|
bool sqlite3_bind_signature(sqlite3_stmt *stmt, int col, const secp256k1_ecdsa_signature *sig);
|
|
|
|
bool sqlite3_column_signature(sqlite3_stmt *stmt, int col, secp256k1_ecdsa_signature *sig);
|
|
|
|
|
|
|
|
bool sqlite3_column_pubkey(sqlite3_stmt *stmt, int col, struct pubkey *dest);
|
|
|
|
bool sqlite3_bind_pubkey(sqlite3_stmt *stmt, int col, const struct pubkey *pk);
|
|
|
|
|
2018-01-20 15:00:35 +01:00
|
|
|
bool sqlite3_bind_pubkey_array(sqlite3_stmt *stmt, int col,
|
|
|
|
const struct pubkey *pks);
|
|
|
|
struct pubkey *sqlite3_column_pubkey_array(const tal_t *ctx,
|
|
|
|
sqlite3_stmt *stmt, int col);
|
|
|
|
|
2017-10-30 19:21:41 +01:00
|
|
|
bool sqlite3_column_preimage(sqlite3_stmt *stmt, int col, struct preimage *dest);
|
|
|
|
bool sqlite3_bind_preimage(sqlite3_stmt *stmt, int col, const struct preimage *p);
|
|
|
|
|
|
|
|
bool sqlite3_column_sha256(sqlite3_stmt *stmt, int col, struct sha256 *dest);
|
|
|
|
bool sqlite3_bind_sha256(sqlite3_stmt *stmt, int col, const struct sha256 *p);
|
|
|
|
|
2017-12-20 12:44:00 +01:00
|
|
|
bool sqlite3_column_sha256_double(sqlite3_stmt *stmt, int col, struct sha256_double *dest);
|
|
|
|
bool sqlite3_bind_sha256_double(sqlite3_stmt *stmt, int col, const struct sha256_double *p);
|
2018-01-17 21:29:49 +01:00
|
|
|
struct secret *sqlite3_column_secrets(const tal_t *ctx,
|
|
|
|
sqlite3_stmt *stmt, int col);
|
2018-03-26 02:08:16 +02:00
|
|
|
|
|
|
|
struct json_escaped *sqlite3_column_json_escaped(const tal_t *ctx,
|
|
|
|
sqlite3_stmt *stmt, int col);
|
|
|
|
bool sqlite3_bind_json_escaped(sqlite3_stmt *stmt, int col,
|
|
|
|
const struct json_escaped *esc);
|
2019-02-20 12:31:48 +01:00
|
|
|
|
|
|
|
struct amount_msat sqlite3_column_amount_msat(sqlite3_stmt *stmt, int col);
|
|
|
|
struct amount_sat sqlite3_column_amount_sat(sqlite3_stmt *stmt, int col);
|
|
|
|
void sqlite3_bind_amount_msat(sqlite3_stmt *stmt, int col,
|
|
|
|
struct amount_msat msat);
|
|
|
|
void sqlite3_bind_amount_sat(sqlite3_stmt *stmt, int col,
|
|
|
|
struct amount_sat sat);
|
2018-03-22 11:36:25 +01:00
|
|
|
#endif /* LIGHTNING_WALLET_DB_H */
|