From ce5a59c81ba15b6222fb675a4fb9fc2799e91608 Mon Sep 17 00:00:00 2001 From: Harald Eilertsen Date: Sun, 23 Sep 2018 20:20:34 +0200 Subject: Begin implement undocumented abconfig API. --- examples/fetch-abconfig.rs | 42 ++++++++++++++++++++++++++++++++++++++++++ src/abconfig.rs | 34 ++++++++++++++++++++++++++++++++++ src/client.rs | 6 ++++++ src/lib.rs | 1 + tests/zotapi.rs | 14 ++++++++++++++ 5 files changed, 97 insertions(+) create mode 100644 examples/fetch-abconfig.rs create mode 100644 src/abconfig.rs diff --git a/examples/fetch-abconfig.rs b/examples/fetch-abconfig.rs new file mode 100644 index 0000000..289097e --- /dev/null +++ b/examples/fetch-abconfig.rs @@ -0,0 +1,42 @@ +// zotapi - Rust wrapper for the Zot API as implemented by Hubzilla +// Copyright (C) 2018 Harald Eilertsen +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see . + +extern crate zotapi; +extern crate dotenv; +extern crate serde_json; + +use dotenv::dotenv; +use std::env; + +fn main() { + dotenv().ok(); + let site = env::var("HUB").expect("HUB variable expected"); + let user = env::var("HZ_USER").expect("HZ_USER variable expected"); + let password = env::var("HZ_PASSWORD").expect("HZ_PASSWORD variable expected"); + + let mut a = env::args(); + let program = a.next().unwrap(); + let client = zotapi::client(&site, &user, &password); + + match client.abconfig().fetch() { + Ok(payload) => { + println!("{}", payload); + }, + Err(e) => { + println!("{:?}", e); + } + } +} diff --git a/src/abconfig.rs b/src/abconfig.rs new file mode 100644 index 0000000..92b8161 --- /dev/null +++ b/src/abconfig.rs @@ -0,0 +1,34 @@ +// zotapi - Rust wrapper for the Zot API as implemented by Hubzilla +// Copyright (C) 2018 Harald Eilertsen +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see . + +use client::{self, Client}; +use error::Error; + +pub struct ABConfigFetcher<'a> { + client: &'a Client, +} + +impl<'a> ABConfigFetcher<'a> { + pub fn new(client: &'a Client) -> ABConfigFetcher<'a> { + ABConfigFetcher { + client, + } + } + + pub fn fetch(&self) -> Result { + self.client.fetch_stream(client::ZOTAPI_ABCONFIG_PATH, &()) + } +} diff --git a/src/client.rs b/src/client.rs index f181e65..bce4d08 100644 --- a/src/client.rs +++ b/src/client.rs @@ -25,9 +25,11 @@ use serde::Serialize; use serde_urlencoded; use std::io::Read; use abook::AbookFetcher; +use abconfig::ABConfigFetcher; use xchan::XChanFetcher; pub const ZOTAPI_ABOOK_PATH : &str = "/api/z/1.0/abook"; +pub const ZOTAPI_ABCONFIG_PATH : &str = "/api/z/1.0/abconfig"; pub const ZOTAPI_CHANNEL_STREAM_PATH : &str = "/api/z/1.0/channel/stream"; pub const ZOTAPI_NETWORK_STREAM_PATH : &str = "/api/z/1.0/network/stream"; pub const ZOTAPI_ITEM_UPDATE_PATH : &str = "/api/z/1.0/item/update"; @@ -50,6 +52,10 @@ impl Client { } } + pub fn abconfig(&self) -> ABConfigFetcher { + ABConfigFetcher::new(self) + } + pub fn abook(&self) -> AbookFetcher { AbookFetcher::new(self) } diff --git a/src/lib.rs b/src/lib.rs index 176f780..a7dc24c 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -18,6 +18,7 @@ extern crate reqwest; extern crate serde; extern crate serde_urlencoded; +mod abconfig; mod abook; mod client; mod error; diff --git a/tests/zotapi.rs b/tests/zotapi.rs index 269e8d7..3f889c5 100644 --- a/tests/zotapi.rs +++ b/tests/zotapi.rs @@ -156,3 +156,17 @@ fn fetch_connections() { let _res = z.abook().fetch().unwrap(); m.assert(); } + +#[test] +fn fetch_abconfig() { + let m = mock("GET", "/api/z/1.0/abconfig") + .match_header("Authorization", Matcher::Regex(r"Basic \w+".into())) + .with_status(200) + .with_header("content-type", "application/json") + .with_body("{}") + .create(); + + let z = zotapi::client(&format!("http://{}", mockito::SERVER_ADDRESS), "testuser", "test1234"); + let _res = z.abconfig().fetch().unwrap(); + m.assert(); +} -- cgit v1.2.3