75 lines
2.3 KiB
Markdown
75 lines
2.3 KiB
Markdown
# ruma-api-macros
|
|
|
|
[](https://travis-ci.org/ruma/ruma-api-macros)
|
|
|
|
**ruma-api-macros** provides a procedural macro for easily generating [ruma-api](https://github.com/ruma/ruma-api)-compatible API endpoints.
|
|
You define the endpoint's metadata, request fields, and response fields, and the macro generates all the necessary types and implements all the necessary traits.
|
|
|
|
## Usage
|
|
|
|
Here is an example that shows most of the macro's functionality.
|
|
|
|
``` rust
|
|
#![feature(associated_consts, proc_macro, try_from)]
|
|
|
|
extern crate futures;
|
|
extern crate hyper;
|
|
extern crate ruma_api;
|
|
extern crate ruma_api_macros;
|
|
extern crate serde;
|
|
#[macro_use] extern crate serde_derive;
|
|
extern crate serde_json;
|
|
extern crate serde_urlencoded;
|
|
extern crate url;
|
|
|
|
pub mod some_endpoint {
|
|
use ruma_api_macros::ruma_api;
|
|
|
|
ruma_api! {
|
|
metadata {
|
|
description: "Does something.",
|
|
method: Method::Get, // A `hyper::Method` value. No need to import the name.
|
|
name: "some_endpoint",
|
|
path: "/_matrix/some/endpoint/:baz",
|
|
rate_limited: false,
|
|
requires_authentication: false,
|
|
}
|
|
|
|
request {
|
|
// With no attribute on the field, it will be put into the body of the request.
|
|
pub foo: String,
|
|
|
|
// This value will be put into the "Content-Type" HTTP header.
|
|
#[ruma_api(header)]
|
|
pub content_type: ContentType,
|
|
|
|
// This value will be put into the query string of the request's URL.
|
|
#[ruma_api(query)]
|
|
pub bar: String,
|
|
|
|
// This value will be inserted into the request's URL in place of the
|
|
// ":baz" path component.
|
|
#[ruma_api(path)]
|
|
pub baz: String,
|
|
}
|
|
|
|
response {
|
|
// This value will be extracted from the "Content-Type" HTTP header.
|
|
#[ruma_api(header)]
|
|
pub content_type: ContentType,
|
|
|
|
// With no attribute on the field, it will be extracted from the body of the response.
|
|
pub value: String,
|
|
}
|
|
}
|
|
}
|
|
```
|
|
|
|
## Documentation
|
|
|
|
ruma-api-macros has [comprehensive documentation](https://docs.rs/ruma-api-macros) available on docs.rs.
|
|
|
|
## License
|
|
|
|
[MIT](http://opensource.org/licenses/MIT)
|