diff options
author | Teddy Wing | 2018-11-10 15:00:45 +0100 |
---|---|---|
committer | Teddy Wing | 2018-11-10 15:00:45 +0100 |
commit | 8edf2808e1b2f11ecb5e395452886e98ce8acb18 (patch) | |
tree | e3c7729cfa655d32fa2ae12496480aeda450a8cc /license-generator/src/request.rs | |
parent | d87ed40cd99f6c7dae019cc13b0a16db65d847e5 (diff) | |
download | dome-key-web-8edf2808e1b2f11ecb5e395452886e98ce8acb18.tar.bz2 |
Add a helper function to verify webhook requests
The new `request::verified()` takes POST params as a string as does all
the work needed to call `paddle::verify_signature()`.
This involves extracting the `p_signature` POST parameter to get the
signature, and getting the public key PEM.
Change `params::parse()` to return a
`BTreeMap<Cow<'a, str>, Cow<'a, str>>` instead of `String` keys &
values. This is because `paddle::verify_signature()` needs a `(<&str,
&str)` iterator. Actually, it still doesn't solve the problem because
the types don't match. We need to modify the input type of
`verify_signature()`, but at least this change gives us references.
Make `params` private to the crate because we no longer need to use it
in `main()`.
Diffstat (limited to 'license-generator/src/request.rs')
-rw-r--r-- | license-generator/src/request.rs | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/license-generator/src/request.rs b/license-generator/src/request.rs new file mode 100644 index 0000000..103656c --- /dev/null +++ b/license-generator/src/request.rs @@ -0,0 +1,14 @@ +use paddle; + +use params; + +pub fn verified(req_params: &str) -> bool { + let mut p = params::parse(&req_params); + let signature = p.remove("p_signature"); + let pem = include_bytes!("../private/paddle.pubkey.asc"); + + match signature { + Some(signature) => paddle::verify_signature(pem, &signature, p), + None => false, + } +} |