2 unstable releases
0.1.0 | Aug 14, 2022 |
---|---|
0.0.1 | Apr 15, 2022 |
#2 in #luno
20KB
462 lines
Luno-API-Client-Rust (async)
V.0.0.1 beta
https://www.luno.com/en/developers/api
The Luno API provides developers with a wealth of financial information provided through the Luno platform. Through this secure system developers can:
Create accounts for trading in cryptocurrencies
Access current and historic cryptocurrency market data
Submit trade orders and view order status
Buy and sell Bitcoin and Ethereum
Send and receive Bitcoin and Ethereum
Generate Bitcoin and Ethereum wallet addresses
The Async Rust Luno API client brings the world of Bitcoin and Ethereum to your doorstep.
Authentication
Some API calls require your application to authenticate itself. This is done using an API key associated with your account. You can create an API key by visiting the API Keys section on the settings page.
An API key consists of a key id and a key secret. For example, cnz2yjswbv3jd (key id) and 0hydMZDb9HRR3Qq-iqALwZtXLkbLR4fWxtDZvkB9h4I (key secret).
API requests are authenticated using HTTP basic authentication with the key id as the username and the key secret as the password. A missing, incorrect or revoked key causes error 401 to be returned.
Each API key is granted a set of permissions when it is created. The key can only be used to call the permitted API functions.
USAGE
Dependencies
- reqwest
- serde
- serde_json
- tokio
Configuration
- Get your api key and secret from luno.com
- Create .env file in your project route and configure with:
API_KEY=myapikey
API_SECRET=myapisecret
- import Luno client to your project and initialize
use luno_rust_api::Luno;
#[tokio::test] // any other async runtime can be used, not limited to tokio
async fn test_luno_async() {
dotenv::dotenv().ok();
let key = env::var("API_KEY").expect("Api Key doesn't exist yet, please add");
let secret = env::var("API_SECRET").expect("Api Key Secret doesn't exist yet, please add");
let luno = Luno::init(key, secret).await;
let tickers = luno.get_all_balance().await;
println!("{:#?}", json!(tickers.as_ref().unwrap())); // data can be serialized to json)
assert_eq!(true, tickers.is_ok());
}
Available METHODS regularly (more will be added until completion)
- create_account()
- get_all_balance()
- get_ticker(pair:
"XBTNGN"
) - get_all_tickers()
- get_full_order_book(pair:
"XBTNGN"
) - get_top_order_book(pair:
"XBTNGN"
)
CONTRIBUTING
make us better :)
Dependencies
~7–19MB
~256K SLoC