1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
//! HTTP signature generation and verification for ActivityPub
//!
//! # Usage
//!
//! ## Generate a keypair
//!
//! ```
//! use sigh::Key;
//! use sigh::alg::{Algorithm, RsaSha256};
//!
//! let (private_key, public_key) = RsaSha256.generate_keys().unwrap();
//! publish(public_key.to_pem().unwrap());
//! save(private_key.to_pem().unwrap());
//!
//! fn publish(public_key: String) {
//! // include public_key in an ActivityPub actor's json
//! }
//! fn save(private_key: String) {
//! // stash private_key away securely
//! }
//! ```
//!
//! ## Sign a HTTP request
//!
//! ```
//! use http::Request;
//! use sigh::{Key, PrivateKey, SigningConfig};
//! use sigh::alg::RsaSha256;
//!
//! fn sign_request<B>(request: &mut Request<B>, private_key_pem: &[u8]) -> Result<(), sigh::Error> {
//! let private_key = PrivateKey::from_pem(private_key_pem)?;
//! SigningConfig::new(RsaSha256, &private_key, "my-key-id")
//! .sign(request)
//! }
//! ```
//!
//! ## Verify a HTTP request
//!
//! ```
//! use http::Request;
//! use sigh::{Key, PublicKey, Signature};
//!
//! fn lookup_public_key_pem(key_id: Option<&str>) -> Option<&[u8]> {
//! // retrieve the public_key in PEM format
//!
//! None
//! }
//!
//! fn verify_request<B>(request: &Request<B>) -> bool {
//! let signature = Signature::from(request);
//! let key_id = signature.key_id();
//! let public_key_pem = match lookup_public_key_pem(key_id) {
//! Some(public_key_pem) => public_key_pem,
//! None => return false,
//! };
//! let public_key = match PublicKey::from_pem(public_key_pem) {
//! Ok(public_key) => public_key,
//! Err(_) => return false,
//! };
//! signature.verify(&public_key)
//! .unwrap_or_else(|_| false)
//! }
//! ```
/// Signature algorithms
/// Key serialization/deserialization
pub use ;
pub use ;
/// General error type
pub use Error;