aboutsummaryrefslogtreecommitdiffstats
path: root/license-generator/src/main.rs
diff options
context:
space:
mode:
authorTeddy Wing2018-11-10 15:00:45 +0100
committerTeddy Wing2018-11-10 15:00:45 +0100
commit8edf2808e1b2f11ecb5e395452886e98ce8acb18 (patch)
treee3c7729cfa655d32fa2ae12496480aeda450a8cc /license-generator/src/main.rs
parentd87ed40cd99f6c7dae019cc13b0a16db65d847e5 (diff)
downloaddome-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/main.rs')
-rw-r--r--license-generator/src/main.rs6
1 files changed, 3 insertions, 3 deletions
diff --git a/license-generator/src/main.rs b/license-generator/src/main.rs
index 43a9d77..2211d6e 100644
--- a/license-generator/src/main.rs
+++ b/license-generator/src/main.rs
@@ -15,8 +15,8 @@ use simplelog::{Config, LevelFilter, WriteLogger};
use license_generator::database;
use license_generator::errors::*;
-use license_generator::params;
use license_generator::purchaser::Purchaser;
+use license_generator::request;
fn main() -> Result<()> {
let log_file_path = env::var("LOG_FILE")
@@ -63,8 +63,8 @@ fn main() -> Result<()> {
write!(&mut req.stdout(), "\n\nstdin: {}\n", stdin)
.unwrap_or(());
- let p = params::parse(&stdin);
- write!(&mut req.stdout(), "\n{:?}\n", p)
+ let is_verified = request::verified(&stdin);
+ write!(&mut req.stdout(), "\n{:?}\n", is_verified)
.unwrap_or(());
});