aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--examples/fetch-abconfig.rs42
-rw-r--r--src/abconfig.rs34
-rw-r--r--src/client.rs6
-rw-r--r--src/lib.rs1
-rw-r--r--tests/zotapi.rs14
5 files changed, 97 insertions, 0 deletions
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 <haraldei@anduin.net>
+//
+// 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 <https://www.gnu.org/licenses/>.
+
+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 <haraldei@anduin.net>
+//
+// 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 <https://www.gnu.org/licenses/>.
+
+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<String, Error> {
+ 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();
+}