2个不稳定版本
使用旧的Rust 2015
0.2.0 | 2016年8月23日 |
---|---|
0.1.0 | 2016年8月15日 |
#14 in #request-builder
17KB
407 行
api_kit
Rust库,用于构建类型安全的Web API客户端。
示例用法
extern crate api_kit;
extern crate hyper;
extern crate serde_json;
use hyper::client::response::Response;
use api_kit::api_request::{ApiRequest, ApiRequestBuilder};
use api_kit::api_request::HttpMethod;
use api_kit::api_client::ApiClient;
use api_kit::error::ApiError;
use hyper::header::{Headers, Accept, qitem};
use hyper::mime::{Mime, TopLevel, SubLevel, Attr, Value};
use hyper::client::request::Request;
use hyper::net::Fresh;
use std::io::{Read};
use std::rc::Rc;
use std::cell::RefCell;
use api_kit::interceptor::log::LogInterceptor;
struct CircleCi {
}
impl ApiClient for CircleCi {
fn base_url(&self) -> String {
return String::from("https://circleci.com/api/v1.1");
}
}
struct CircleCiMeRequest<'a> {
api_token: &'a str
}
impl<'a> CircleCiMeRequest<'a> {
fn new(token: &'a str) -> CircleCiMeRequest {
CircleCiMeRequest {
api_token: token
}
}
}
impl<'a> ApiRequestBuilder<serde_json::Value> for CircleCiMeRequest<'a> {
fn method(&self) -> HttpMethod {
return HttpMethod::Get;
}
fn path(&self) -> String {
return String::from("/me");
}
fn queryParameters(&self) -> Vec<(String, String)> {
return vec![
(String::from("circle-token"), String::from(self.api_token))
];
}
fn interceptRequest(&self, mut request: Request<Fresh>) -> Result<Request<Fresh>, ApiError> {
request.headers_mut().set(
Accept(vec![
qitem(Mime(TopLevel::Application, SubLevel::Json,
vec![(Attr::Charset, Value::Utf8)])),
])
);
return Ok(request);
}
fn responseFromObject(&self, response: Rc<RefCell<Response>>) -> Result<serde_json::Value, ApiError> {
let mut raw_response = (*response).borrow_mut();
let mut buffer = String::new();
raw_response.read_to_string(&mut buffer).unwrap();
return Ok(serde_json::from_str(&buffer).unwrap());
}
}
fn main() {
let ci = CircleCi {} ;
let me = ci.call(Rc::new(CircleCiMeRequest::new("Your-CircleCi-Token")))
.addInterceptor(Box::new(LogInterceptor {}))
.send();
println!("{}", me.unwrap());
}
待办事项
- 支持多部分/表单
- 支持拦截器(重试自动认证等)
依赖项
~6MB
~142K SLoC