activitystreams/activitystreams-traits/README.md

61 lines
2.2 KiB
Markdown
Raw Normal View History

2018-05-14 04:22:34 +00:00
# ActivityStreams Traits
__Traits for Activity Streams__
2019-07-30 22:02:05 +00:00
- [Read the documentation on docs.rs](https://docs.rs/activitystreams-traits)
- [Find the crate on crates.io](https://crates.io/crates/activitystreams-traits)
2020-03-10 16:48:54 +00:00
- [Hit me up on Mastodon](https://asonix.dog/@asonix)
2019-07-30 22:02:05 +00:00
2018-05-14 04:22:34 +00:00
These traits don't provide any functionality other than anotations for types created in other
projects. See the `activitystreams-types` crate for examples of how these traits could be used.
## Examples
2020-03-10 16:48:54 +00:00
Add it to your `Cargo.toml`
```toml
2020-03-11 13:39:57 +00:00
activitystreams-traits = "0.4.0-alpha.0"
2020-03-10 16:48:54 +00:00
serde = { version = "1.0", features = ["derive"] }
typetag = "0.1.4"
```
Use it in your project
2018-05-14 04:22:34 +00:00
```rust
use activitystreams_traits::{Object, Actor};
2020-03-10 16:48:54 +00:00
#[derive(Clone, Debug, Default, serde::Deserialize, serde::Serialize)]
2018-05-14 04:22:34 +00:00
#[serde(rename_all = "camelCase")]
pub struct Persona {
#[serde(rename = "type")]
kind: String,
}
2020-03-10 16:48:54 +00:00
// TypeTag exists so user-defined types can be deserialized generically in activitystreams-types
#[typetag::serde]
impl Object for Persona {
fn as_any(&self) -> &(dyn Any + 'static) {
self
}
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static) {
self
}
fn duplicate(&self) -> Box<dyn Object + 'static> {
Box::new(self.clone())
}
}
2018-05-14 04:22:34 +00:00
impl Actor for Persona {}
```
## Contributing
Feel free to open issues for anything you find an issue with. Please note that any contributed code will be licensed under the GPLv3.
## License
2020-03-10 16:48:54 +00:00
Copyright © 2020 Riley Trautman
2018-05-14 04:22:34 +00:00
ActivityStreams Traits 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.
ActivityStreams Traits 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. This file is part of ActivityStreams Traits.
You should have received a copy of the GNU General Public License along with ActivityStreams Traits. If not, see [http://www.gnu.org/licenses/](http://www.gnu.org/licenses/).