Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 7 additions & 0 deletions .github/workflows/rust.yml
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ jobs:
- uses: actions/checkout@v5
- uses: actions-rust-lang/setup-rust-toolchain@v1
with:
toolchain: 'stable'
rustflags: '-D warnings -W unreachable-pub'
- run: RUSTDOCFLAGS="-D warnings" cargo doc --all --no-deps

Expand Down Expand Up @@ -61,6 +62,7 @@ jobs:
- uses: actions-rust-lang/setup-rust-toolchain@v1
with:
rustflags: ''
toolchain: 'stable'
- run: cargo build --locked

test:
Expand All @@ -70,6 +72,7 @@ jobs:
- uses: actions-rust-lang/setup-rust-toolchain@v1
with:
rustflags: ''
toolchain: 'stable'
- uses: taiki-e/install-action@nextest
- name: "Test rusty-jwt-tools"
run: sh run-tests.sh
Expand All @@ -89,6 +92,7 @@ jobs:
- uses: actions-rust-lang/setup-rust-toolchain@v1
with:
rustflags: ''
toolchain: 'stable'
- uses: davidB/rust-cargo-make@v1
- name: "Run Haskell test"
run: cd ffi && cargo make hs-test
Expand All @@ -103,6 +107,7 @@ jobs:
- uses: actions-rust-lang/setup-rust-toolchain@v1
with:
rustflags: ''
toolchain: 'stable'
- name: Install wasm-pack
run: curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh
- name: WASM build
Expand All @@ -118,6 +123,7 @@ jobs:
- uses: actions-rust-lang/setup-rust-toolchain@v1
with:
rustflags: ''
toolchain: 'stable'
- name: Install wasm-pack
run: curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh
- name: Run tests (wasm)
Expand All @@ -130,6 +136,7 @@ jobs:
- uses: actions-rust-lang/setup-rust-toolchain@v1
with:
rustflags: ''
toolchain: 'stable'
- uses: taiki-e/install-action@cargo-hack
- name: cargo/hack (verify features compile in isolation)
run: cargo hack check --each-feature --no-dev-deps
7 changes: 3 additions & 4 deletions .rustfmt.toml
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@
# version = "Two"
use_try_shorthand = true
use_field_init_shorthand = true
max_width = 120
newline_style = "Unix"
merge_derives = true
# condense_wildcard_suffixes = true
edition = "2021"
# imports_granularity = "Crate"
condense_wildcard_suffixes = true
imports_granularity = "Crate"
group_imports = "StdExternalCrate"
1 change: 1 addition & 0 deletions acme/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ edition = "2024"
repository = "https://github.com/wireapp/rusty-jwt-tools"
license = "MPL-2.0"
publish = false
rust-version = "1.90"

[lib]
crate-type = ["cdylib", "rlib"]
Expand Down
6 changes: 4 additions & 2 deletions acme/src/account.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
use crate::prelude::*;
use rusty_jwt_tools::prelude::*;

use crate::prelude::*;

impl RustyAcme {
/// 5. Create a new acme account
/// see [RFC 8555 Section 7.3](https://www.rfc-editor.org/rfc/rfc8555.html#section-7.3)
Expand Down Expand Up @@ -143,10 +144,11 @@ pub enum AcmeAccountStatus {

#[cfg(test)]
pub mod tests {
use super::*;
use serde_json::json;
use wasm_bindgen_test::*;

use super::*;

wasm_bindgen_test_configure!(run_in_browser);

mod json {
Expand Down
4 changes: 1 addition & 3 deletions acme/src/authz.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,7 @@
use base64::Engine;

use rusty_jwt_tools::prelude::*;

use crate::chall::AcmeChallengeType;
use crate::prelude::*;
use crate::{chall::AcmeChallengeType, prelude::*};

impl RustyAcme {
/// create authorizations
Expand Down
6 changes: 3 additions & 3 deletions acme/src/certificate.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
use crate::{error::CertificateError, identifier::CanonicalIdentifier, prelude::*};
use rusty_jwt_tools::prelude::*;
use rusty_x509_check::revocation::{PkiEnvironment, PkiEnvironmentParams};
use x509_cert::Certificate;
use x509_cert::anchor::TrustAnchorChoice;
use x509_cert::{Certificate, anchor::TrustAnchorChoice};

use crate::{error::CertificateError, identifier::CanonicalIdentifier, prelude::*};

impl RustyAcme {
/// For fetching the generated certificate
Expand Down
3 changes: 2 additions & 1 deletion acme/src/directory.rs
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,10 @@ pub struct AcmeDirectory {

#[cfg(test)]
pub mod tests {
use super::*;
use wasm_bindgen_test::*;

use super::*;

wasm_bindgen_test_configure!(run_in_browser);

#[test]
Expand Down
5 changes: 2 additions & 3 deletions acme/src/finalize.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
use base64::Engine;
use jwt_simple::prelude::*;
use x509_cert::der::Encode;

use rusty_jwt_tools::prelude::*;
use x509_cert::der::Encode;

use crate::identifier::CanonicalIdentifier;
use crate::{
identifier::CanonicalIdentifier,
order::{AcmeOrderError, AcmeOrderStatus},
prelude::*,
};
Expand Down
3 changes: 2 additions & 1 deletion acme/src/identifier.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
use crate::prelude::*;
use rusty_jwt_tools::prelude::*;

use crate::prelude::*;

/// Represent an identifier in an ACME Order
#[derive(Debug, Clone, Eq, PartialEq, Hash, serde::Serialize, serde::Deserialize)]
#[serde(tag = "type", content = "value", rename_all = "kebab-case")]
Expand Down
9 changes: 3 additions & 6 deletions acme/src/identity/mod.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,8 @@
use x509_cert::der::Decode as _;

use rusty_jwt_tools::prelude::*;
use rusty_x509_check::IdentityStatus;
use rusty_x509_check::revocation::PkiEnvironment;
use rusty_x509_check::{IdentityStatus, revocation::PkiEnvironment};
use x509_cert::der::Decode as _;

use crate::error::CertificateError;
use crate::prelude::*;
use crate::{error::CertificateError, prelude::*};

pub(crate) mod thumbprint;

Expand Down
11 changes: 5 additions & 6 deletions acme/src/identity/thumbprint.rs
Original file line number Diff line number Diff line change
@@ -1,16 +1,15 @@
use crate::{
error::CertificateError,
prelude::{RustyAcmeError, RustyAcmeResult},
};

use jwt_simple::prelude::*;
use rusty_jwt_tools::{
jwk::TryIntoJwk,
prelude::{HashAlgorithm, JwkThumbprint, JwsAlgorithm},
};

use x509_cert::spki::SubjectPublicKeyInfoOwned;

use crate::{
error::CertificateError,
prelude::{RustyAcmeError, RustyAcmeResult},
};

/// Used to compute the MLS thumbprint of a Basic Credential
pub fn compute_raw_key_thumbprint(
sign_alg: JwsAlgorithm,
Expand Down
3 changes: 2 additions & 1 deletion acme/src/jws.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
use crate::prelude::*;
use jwt_simple::prelude::*;
use rusty_jwt_tools::prelude::*;

use crate::prelude::*;

#[derive(Debug, serde::Serialize, serde::Deserialize)]
#[cfg_attr(test, derive(Clone))]
#[serde(rename_all = "camelCase")]
Expand Down
10 changes: 4 additions & 6 deletions acme/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,22 +12,20 @@ mod order;

/// Prelude
pub mod prelude {
pub use super::RustyAcme;
use super::*;
pub use account::AcmeAccount;
pub use authz::AcmeAuthz;
pub use chall::{AcmeChallError, AcmeChallenge, AcmeChallengeType};
pub use directory::AcmeDirectory;
pub use error::{RustyAcmeError, RustyAcmeResult};
pub use finalize::AcmeFinalize;
pub use identifier::{AcmeIdentifier, WireIdentifier};
pub use identity::{WireIdentity, WireIdentityReader};
pub use identity::{WireIdentity, WireIdentityReader, thumbprint::compute_raw_key_thumbprint};
pub use jws::AcmeJws;
pub use order::AcmeOrder;
pub use rusty_x509_check as x509;

pub use identity::thumbprint::compute_raw_key_thumbprint;

pub use directory::AcmeDirectory;
pub use super::RustyAcme;
use super::*;
}

pub struct RustyAcme;
6 changes: 3 additions & 3 deletions acme/src/order.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
use crate::identifier::CanonicalIdentifier;
use rusty_jwt_tools::prelude::*;
use std::collections::HashSet;

use crate::prelude::*;
use rusty_jwt_tools::prelude::*;

use crate::{identifier::CanonicalIdentifier, prelude::*};

// Order creation
impl RustyAcme {
Expand Down
1 change: 1 addition & 0 deletions e2e-identity/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ edition = "2024"
repository = "https://github.com/wireapp/rusty-jwt-tools"
license = "MPL-2.0"
publish = false
rust-version = "1.90"

[lib]
crate-type = ["cdylib", "rlib"]
Expand Down
27 changes: 14 additions & 13 deletions e2e-identity/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,36 +1,37 @@
use jwt_simple::prelude::{ES256KeyPair, ES384KeyPair, ES512KeyPair, Ed25519KeyPair, Jwk};
use zeroize::Zeroize;

use crate::prelude::x509::revocation::PkiEnvironment;
use error::*;
use jwt_simple::prelude::{ES256KeyPair, ES384KeyPair, ES512KeyPair, Ed25519KeyPair, Jwk};
use prelude::*;
use rusty_acme::prelude::{AcmeChallenge, AcmeIdentifier};
use rusty_jwt_tools::{
jwk::TryIntoJwk,
jwk_thumbprint::JwkThumbprint,
prelude::{ClientId, Dpop, Handle, Htm, Pem, RustyJwtTools},
};
use zeroize::Zeroize;

use crate::prelude::x509::revocation::PkiEnvironment;

mod error;
mod types;

pub mod prelude {
pub use rusty_acme::prelude::x509;
pub use rusty_acme::prelude::{
AcmeDirectory, RustyAcme, RustyAcmeError, WireIdentity, WireIdentityReader, compute_raw_key_thumbprint,
AcmeDirectory, RustyAcme, RustyAcmeError, WireIdentity, WireIdentityReader, compute_raw_key_thumbprint, x509,
x509::IdentityStatus,
};
#[cfg(feature = "builder")]
pub use rusty_jwt_tools::prelude::generate_jwk;
pub use rusty_jwt_tools::prelude::{
ClientId as E2eiClientId, Handle, HashAlgorithm, JwsAlgorithm, RustyJwtError, parse_json_jwk,
};

#[cfg(feature = "builder")]
pub use rusty_jwt_tools::prelude::generate_jwk;

pub use super::RustyE2eIdentity;
pub use super::error::{E2eIdentityError, E2eIdentityResult};
pub use super::types::{
E2eiAcmeAccount, E2eiAcmeAuthorization, E2eiAcmeChallenge, E2eiAcmeFinalize, E2eiAcmeOrder, E2eiNewAcmeOrder,
pub use super::{
RustyE2eIdentity,
error::{E2eIdentityError, E2eIdentityResult},
types::{
E2eiAcmeAccount, E2eiAcmeAuthorization, E2eiAcmeChallenge, E2eiAcmeFinalize, E2eiAcmeOrder,
E2eiNewAcmeOrder,
},
};
}

Expand Down
3 changes: 1 addition & 2 deletions e2e-identity/src/types.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
use rusty_acme::prelude::AcmeChallenge;

use crate::prelude::{E2eIdentityError, E2eIdentityResult};

use super::Json;
use crate::prelude::{E2eIdentityError, E2eIdentityResult};

#[derive(
Debug, Clone, derive_more::From, derive_more::Into, derive_more::Deref, serde::Serialize, serde::Deserialize,
Expand Down
5 changes: 2 additions & 3 deletions e2e-identity/tests/api.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@
use jwt_simple::prelude::*;
use serde_json::json;
use wasm_bindgen_test::*;

use rusty_jwt_tools::prelude::*;
use serde_json::json;
use utils::keys::enrollments;
use wasm_bindgen_test::*;
use wire_e2e_identity::prelude::E2eiAcmeAuthorization;

wasm_bindgen_test_configure!(run_in_browser);
Expand Down
13 changes: 7 additions & 6 deletions e2e-identity/tests/e2e.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@

use jwt_simple::prelude::*;
use rstest::rstest;

use rusty_acme::prelude::*;
use rusty_jwt_tools::prelude::*;
use utils::{
Expand Down Expand Up @@ -174,13 +173,15 @@ mod alg {

/// Since the acme server is a fork, verify its invariants are respected
mod acme_server {
use super::*;
use rusty_acme::prelude::x509::RustyX509CheckError;
use rusty_acme::prelude::x509::reexports::certval;
use rusty_acme::prelude::x509::reexports::certval::PathValidationStatus;
use rusty_acme::prelude::x509::revocation::{PkiEnvironment, PkiEnvironmentParams};
use rusty_acme::prelude::x509::{
RustyX509CheckError,
reexports::{certval, certval::PathValidationStatus},
revocation::{PkiEnvironment, PkiEnvironmentParams},
};
use x509_cert::der::Decode;

use super::*;

#[rstest]
#[tokio::test]
/// Acme server has been man-in-middle:ed and returns untrusted certificates
Expand Down
3 changes: 1 addition & 2 deletions e2e-identity/tests/utils/cfg.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,9 @@ use std::{collections::HashMap, net::SocketAddr};
use jwt_simple::prelude::*;
use oauth2::RefreshToken;
use rand::random;
use scraper::Html;

use rusty_acme::prelude::{AcmeAccount, AcmeAuthz, AcmeChallenge, AcmeDirectory, AcmeFinalize, AcmeOrder};
use rusty_jwt_tools::{jwk::TryIntoJwk, prelude::*};
use scraper::Html;

use crate::utils::{
TestResult,
Expand Down
2 changes: 1 addition & 1 deletion e2e-identity/tests/utils/ctx.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
//! Test helper for sharing data between the resource server (wire-server) and the client which
//! is responsible for displaying them.

use std::net::SocketAddr;
use std::{
collections::{HashMap, hash_map::RandomState},
net::SocketAddr,
str::FromStr,
};

Expand Down
1 change: 0 additions & 1 deletion e2e-identity/tests/utils/display.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ use std::{path::PathBuf, process::Command};
use base64::Engine;
use itertools::Itertools;
use jwt_simple::prelude::*;

use rusty_jwt_tools::prelude::*;

use crate::utils::rand_base64_str;
Expand Down
Loading