#signature #web #mehal #brog

messagesign

Library for signing requests to mehal services

7 stable releases (3 major)

new 5.0.0 Mar 3, 2025
4.0.2 Feb 22, 2025
3.0.1 Dec 9, 2024
2.0.1 Dec 7, 2024
1.0.0 Dec 7, 2024

#424 in Authentication

Download history 355/week @ 2024-12-06 22/week @ 2024-12-13 3/week @ 2024-12-27 19/week @ 2025-01-24 126/week @ 2025-01-31 3/week @ 2025-02-14 453/week @ 2025-02-21 287/week @ 2025-02-28

743 downloads per month

MIT license

19KB
297 lines

messagesign

A rust library to sign requests to mehal services based on the AWS S3V4 approach.

The implementation is based on the s3v4 library.

This crate provides a signature function that can be used to sign a request to an mehal services.

Both functions return an Error generated by the error_chain crate which can be converted to a String or accessed through the description method or display_chain and backtrace methods in case a full backtrace is needed.

Build

Examples

Signing a request

   let url = url::Url::parse("https://mehal.tech/endpoint").unwrap();
   let signature: messagesign::Signature = messagesign::signature(
       &url, // The endpoint of the mehel services
       "GET",   // The http Method  
       "ivegotthekey",  // the access key provided with your secret
       "ivegotthesecret", // The secret provided for your project
       "global", // A supported region See mehal.tech docs
       &"brog",
       "machineid", // The data in /etc/machine-id
       "UNSIGNED-PAYLOAD", //payload hash, or "UNSIGNED-PAYLOAD"
       "", // An empty string or a random u32
   ).map_err(|err| format!("Signature error: {}", err.display_chain()))?;

Using the signature data to make a request

Hyper

       let req = Request::builder()
       .method(Method::GET)
       .header("x-mhl-content-sha256", "UNSIGNED-PAYLOAD")
       .header("x-mhl-date", &signature.date_time)
       .header("x-mhl-mid", &machineid)
       .header("authorization", &signature.auth_header)

Ureq

   let agent = AgentBuilder::new().build();
   let response = agent
       .put(&uri)
       .set("x-mhl-content-sha256", "UNSIGNED-PAYLOAD")
       .set("x-mhl-date", &signature.date_time)
       .set("x-mhl-mid", &machineid)
       .set("authorization", &signature.auth_header)

Dependencies

~6–13MB
~160K SLoC