#cloud-front #aws #signed-url #signed-cookie

cloudfront_sign

Utility module for AWS CloudFront to generate signed URLs and cookies

5 unstable releases

0.3.0 Feb 25, 2024
0.2.1 Nov 13, 2022
0.2.0 Nov 13, 2022
0.1.2 Mar 27, 2021
0.1.1 Mar 17, 2021

#2225 in Network programming

Download history 273/week @ 2024-07-20 437/week @ 2024-07-27 266/week @ 2024-08-03 337/week @ 2024-08-10 443/week @ 2024-08-17 493/week @ 2024-08-24 566/week @ 2024-08-31 501/week @ 2024-09-07 319/week @ 2024-09-14 414/week @ 2024-09-21 368/week @ 2024-09-28 477/week @ 2024-10-05 633/week @ 2024-10-12 543/week @ 2024-10-19 483/week @ 2024-10-26 659/week @ 2024-11-02

2,416 downloads per month
Used in 2 crates (via cnctd_aws)

MIT license

15KB
204 lines

AWS CloudFront Sign Utility

Generating signed URLs for CloudFront links is a little more tricky than for S3. It's because signature generation for S3 URLs is handled a bit differently than CloudFront URLs. The Rusoto library is in maintenance mode and not accepting more features. Therefore we created this simple utility library to sign CloudFront URLs in Rust.

Examples

Getting signed cookies.

use std::fs;
use cloudfront_sign::*;
let private_key = fs::read_to_string("tests/data/private_key.pem").unwrap();
let options = SignedOptions {
    key_pair_id: String::from("SOMEKEYPAIRID"),
    private_key: private_key,
    ..Default::default()
};
let cookies = get_signed_cookie("https://example.com", &options).unwrap();

Getting signed URLS.

use std::fs;
use cloudfront_sign::*;
let private_key = fs::read_to_string("tests/data/private_key.pem").unwrap();
let options = SignedOptions {
    key_pair_id: String::from("SOMEKEYPAIRID"),
    private_key: private_key,
    ..Default::default()
};
let signed_url = get_signed_url("https://example.com", &options).unwrap();

Dependencies

~5MB
~97K SLoC