4 releases
0.3.0-beta.4 | Jun 13, 2023 |
---|---|
0.3.0-beta.3 | Nov 17, 2022 |
0.3.0-beta.2 | Jul 29, 2022 |
0.3.0-beta.1 | May 23, 2022 |
#119 in #lightning
340 downloads per month
Used in 3 crates
(via clightningrpc-plugin)
14KB
188 lines
Common client in Rust for core lightning
This crate provides a generic interface to the core lightning daemon through RPC.
Project Homepage
This crate provides a generic interface to the core lightning daemon through RPC.
From the crate clightningrpc you can find this quote
Be aware that the API (of rust-clighting-rpc, but also that of c-lightning itself) is not finalized. This means that it is likely to change between versions and may break your compile, sorry!
This crate solve the versioning with core lightning by offering a strongly type library with a generic interface, an example can be:
extern crate clightningrpc_common;
use serde::{Deserialize, Serialize};
use std::env;
use clightningrpc_common::client;
use clightningrpc_common::types::Response;
/// Example of type definition
#[derive(Debug, Clone, Deserialize, Serialize)]
struct GetInfoResponse {
pub id: String,
}
/// Example of type definition
#[derive(Debug, Clone, Deserialize, Serialize)]
struct GetInfoRequest {}
fn main() {
let sock = env::home_dir().unwrap().join(".lightning/lightning-rpc");
println!("Using socket {}", sock.display());
let client = client::Client::new(&sock);
let method = "getinfo";
let params = GetInfoRequest {};
match client
.send_request(method, params)
.and_then(|res: Response<GetInfoResponse>| res.into_result())
{
Ok(d) => {
println!("Ok! {:?}", d);
}
Err(e) => {
println!("Error! {}", e);
}
}
}
Contributing guidelines
- Four spaces
- Call
make fmt
before committing - If you can, GPG-sign at least your top commit when filing a PR
Supports
If you want support this library consider to donate with the following methods
- Lightning address: vincenzopalazzo@lntxbot.com
- Github donation
Credits
This library is based on Andrew Poelstra's rust-jsonrpc.
Dependencies
~0.7–1.6MB
~35K SLoC