diff --git a/README.md b/README.md index c17f73d305988c6be7cca54e2d8ac6a914f88648..bb5d6d15a82c21b635925def04432045db09eae4 100644 --- a/README.md +++ b/README.md @@ -1,12 +1,33 @@ # mquery (placeholder name) A Rust library for handling PROMQL (and possibly MetricsQL) queries. +# Usage Example +```rust +use mquery::{Auth, QueryManager}; +use tokio::runtime::Runtime; + +dotenv::dotenv().expect("No .env file found in working dir"); +let url = std::env::var("VM_URL").expect("VM URL not found in env"); +let token = std::env::var("VM_TOKEN").expect("VM URL not found in env"); +let rt = Runtime::new().unwrap(); +let query = "total_http_requests"; +let _response = rt + .block_on( + QueryManager::new(url.parse().unwrap()) + .auth(Auth::Bearer(token)) + .query(query), + ) + .expect("operation failed"); +} +``` + # Roadmap - [x] Basic raw queries (Instant and Ranged) - [ ] Query Builder - [ ] Basic queries - [ ] Operators - [ ] Functions +- [ ] Runtime syntax checking - [ ] Compile time syntax checking -- [ ] Deserialize to custom data types +- [ ] Deserialize to custom data types (with the help of proc-macros?) - [ ] Encapsulated raw queries with methods for constructing interpolated versions