Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
86 commits
Select commit Hold shift + click to select a range
d92fc2b
build(deps): bump reviewdog/action-actionlint from 1.63.0 to 1.64.1 (…
dependabot[bot] Jan 24, 2025
2a7f8ae
build(deps): bump codecov/codecov-action from 5.1.2 to 5.2.0 (#848)
dependabot[bot] Jan 24, 2025
1f8e0e9
Update dependabot.yml (#856)
mpguerra Jan 28, 2025
121a116
fix errors (#858)
sky-coderay Jan 30, 2025
7035593
build(deps): bump codecov/codecov-action from 5.2.0 to 5.3.1 (#851)
dependabot[bot] Jan 30, 2025
1d41c21
Fixing a small typo (#863)
AntoineRondelet Feb 4, 2025
602157a
docs: correction comments (#860)
reject-i Feb 4, 2025
464cc05
book: add FROST Server section (#811)
conradoplg Feb 4, 2025
4d3d882
Fix typo (#866)
azuchi Feb 7, 2025
543e6f4
all: use OsRng instead of thread_rng() (#861)
conradoplg Feb 11, 2025
f862ef1
update release checklist; misc cleanups (#843)
conradoplg Feb 11, 2025
64a4be6
chore(ci): update some github action dependencies (#873)
StackOverflowExcept1on Feb 17, 2025
fc87f59
chore(deps): improve organization of workspace (root Cargo.toml) (#874)
StackOverflowExcept1on Feb 17, 2025
aed1ea8
feat(frost-core): add (de)serialization for `VerifiableSecretSharingS…
StackOverflowExcept1on Feb 24, 2025
2a6673f
docs: Add network topologies section with diagrams (#883)
crStiv Apr 10, 2025
ca1c98c
Add tests for all test vectors in DKG (#875)
azuchi Apr 11, 2025
d7cd2a2
docs: add warning about encrypted channel for DKG (#888)
conradoplg Apr 14, 2025
a8c8b6d
clippy fixes (#889)
conradoplg Apr 24, 2025
78c70b4
chore(frost-core): import `String` from `alloc` (#899)
StackOverflowExcept1on Jun 5, 2025
412f049
feat: bump MSRV to Rust 1.73 (#900)
StackOverflowExcept1on Jun 6, 2025
4378727
feat: bump MSRV to Rust 1.81 (#901)
StackOverflowExcept1on Jun 6, 2025
81a091d
Add post_generate to Ciphersuite trait (#884)
VolodymyrBg Jun 6, 2025
6ff59d1
Add CONTRIBUTING.md (#902)
mpguerra Jun 12, 2025
9956559
Remove reference to private repo (#905)
mpguerra Jun 20, 2025
f62ee73
core: remove unused error (#909)
conradoplg Aug 25, 2025
379ef68
refresh: validate min_signers (#908)
conradoplg Aug 27, 2025
3ffc19d
bump to 2.2.0 (#914)
conradoplg Aug 27, 2025
6034316
core: add aggregate_custom (#911)
conradoplg Sep 29, 2025
29fa065
build(deps): bump reviewdog/action-actionlint from 1.64.1 to 1.65.2 (…
dependabot[bot] Sep 29, 2025
e0d2176
feat(frost-core): simplify trait bounds, don't use the allocator in s…
StackOverflowExcept1on Oct 2, 2025
80fd87e
ci: install clippy (#923)
conradoplg Oct 6, 2025
76dc3a2
build(deps): bump reviewdog/action-actionlint from 1.65.2 to 1.68.0 (…
dependabot[bot] Nov 20, 2025
dbaa190
build(deps): bump clechasseur/rs-clippy-check from 4 to 5 (#928)
dependabot[bot] Nov 20, 2025
aad8b8a
build(deps): bump codecov/codecov-action from 5.3.1 to 5.5.1 (#924)
dependabot[bot] Nov 20, 2025
72c4847
build(deps): bump actions/checkout from 4.2.2 to 5.0.0 (#925)
dependabot[bot] Nov 20, 2025
40edb6e
ci: commit Cargo.lock, update crypto-common to avoid generic-array de…
conradoplg Nov 27, 2025
1882937
build(deps): bump reviewdog/action-actionlint from 1.68.0 to 1.69.0 (…
dependabot[bot] Dec 2, 2025
4431ca1
ci(mergify): upgrade configuration to current format (#934)
mergify[bot] Dec 8, 2025
43c8827
all: remove cheater-detection feature (#958)
conradoplg Dec 9, 2025
18d4ed1
dependabot: update lockfile only (#959)
conradoplg Dec 9, 2025
ca1df5f
ci: test with latest versions of dependencies (#961)
conradoplg Dec 9, 2025
ee450bd
book: add devtool demo section (#968)
conradoplg Dec 18, 2025
705acde
core: fix unused warning due to compiler bug (#971)
conradoplg Dec 22, 2025
a454d02
docs: explain origin of identifiers in aggregate() (#956)
conradoplg Dec 22, 2025
4827fd2
core: fix `dkg::round2::SecretPackage` serialization (#937)
conradoplg Dec 22, 2025
85c16bc
core: expose NonceCommitment getter/new under internals (#947)
conradoplg Dec 22, 2025
0f21162
core: add pre-commitment computation hooks (#950)
conradoplg Dec 22, 2025
2bc191f
core: improve zeroization (#945)
conradoplg Dec 22, 2025
99aca96
docs: add warning about secp256k1; clean up READMEs (#954)
conradoplg Dec 22, 2025
a473fc8
book: make it clear that auth channel is not needed for signing (#953)
conradoplg Dec 22, 2025
94cef54
core: bind traits to Send + Sync (#946)
conradoplg Dec 22, 2025
5a27016
fix function name and ciphersuite refresh modules (#922)
conradoplg Dec 22, 2025
8f60e6d
core: add more serialization roundtrips to tests (#952)
conradoplg Dec 22, 2025
59b4dbd
update debugless-unwrap (#962)
conradoplg Dec 22, 2025
504ef20
Implement ZeroizeOnDrop for SigningNonces (#987)
kwsantiago Jan 6, 2026
78066bf
all: cleanup repairable module (#957)
conradoplg Jan 23, 2026
5cac0f4
build(deps): bump reviewdog/action-actionlint from 1.69.0 to 1.69.1 (…
dependabot[bot] Jan 23, 2026
9637346
build(deps): bump codecov/codecov-action from 5.5.1 to 5.5.2 (#982)
dependabot[bot] Jan 23, 2026
e6a57b3
build(deps): bump actions/checkout from 6.0.0 to 6.0.1 (#966)
dependabot[bot] Jan 23, 2026
bac3297
frost-rerandomized: change Randomizer generation (#762)
conradoplg Jan 23, 2026
3ed40ad
core: simplify compute_refreshing_shares() (#940)
conradoplg Jan 23, 2026
8f97498
use partX() for repair share functions (#1001)
conradoplg Jan 27, 2026
68b1f57
reexport rerandomized API in ciphersuite crates (#998)
conradoplg Jan 27, 2026
ee89da3
change PublicKeyPackage::new() to take min_signers as an Option (#1000)
conradoplg Jan 27, 2026
893afc7
Release 3.0.0 (#995)
conradoplg Jan 27, 2026
1792427
book, docs: mention channel requirements for DKG; remove redundancy; …
conradoplg Jan 27, 2026
3fa76ef
Clippy fixes (#1006)
natalieesk Jan 28, 2026
8315231
fix issues from specific feature combinations (#1008)
conradoplg Jan 28, 2026
6e2ed05
actually remove the std feature (#1010)
conradoplg Jan 28, 2026
1399dc0
feat(frost-core): add pre_commitment_aggregate hook to `verify_signat…
scaraven Feb 6, 2026
f7954c3
ci: migrate book to GitHub pages (#1020)
conradoplg Feb 20, 2026
ff5ec8d
core: misc fixes (#1042)
conradoplg Apr 1, 2026
3c2f25f
build(deps): bump keccak from 0.1.5 to 0.1.6 (#1023)
dependabot[bot] Apr 1, 2026
75d14b0
build(deps): bump actions/upload-pages-artifact from 3 to 4 (#1026)
dependabot[bot] Apr 1, 2026
7967016
build(deps): bump regex from 1.12.2 to 1.12.3 (#1028)
dependabot[bot] Apr 1, 2026
5c0deb3
build(deps): bump codecov/codecov-action from 5.5.2 to 6.0.0 (#1043)
dependabot[bot] Apr 1, 2026
d94090a
build(deps): bump reviewdog/action-actionlint from 1.69.1 to 1.72.0 (…
dependabot[bot] Apr 1, 2026
c484499
build(deps): bump release-drafter/release-drafter from 6 to 7 (#1045)
dependabot[bot] Apr 1, 2026
4ea9c86
build(deps): bump insta from 1.46.1 to 1.47.2 (#1046)
dependabot[bot] Apr 1, 2026
fb36ac9
build(deps): bump actions/deploy-pages from 4 to 5 (#1047)
dependabot[bot] Apr 1, 2026
7bc107e
build(deps): bump proptest from 1.9.0 to 1.11.0 (#1048)
dependabot[bot] Apr 1, 2026
28a9b27
build(deps): bump tokio from 1.49.0 to 1.50.0 (#1049)
dependabot[bot] Apr 1, 2026
7dcfd30
core: add ZeroizeOnDrop for dkg::round2::Package (#1040)
conradoplg Apr 16, 2026
4705e79
book: update to mdbook 0.5 (#1022)
conradoplg Apr 16, 2026
1aef3fb
Release 3.0.0 (#1041)
conradoplg Apr 23, 2026
2016e44
Add explicit release-drafter permissions (#1061)
natalieesk Apr 23, 2026
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: 5 additions & 2 deletions .github/dependabot.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,15 @@ updates:
- package-ecosystem: github-actions
directory: "/"
schedule:
interval: daily
interval: monthly
timezone: America/New_York
open-pull-requests-limit: 10
- package-ecosystem: cargo
directory: "/"
# Update only the lockfile. We shouldn't update Cargo.toml unless it's for
# a security issue, or if we need a new feature of the dependency.
versioning-strategy: lockfile-only
schedule:
interval: daily
interval: monthly
timezone: America/New_York
open-pull-requests-limit: 10
11 changes: 4 additions & 7 deletions .github/workflows/coverage.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
branches:
- main
pull_request:
path:

Check failure on line 9 in .github/workflows/coverage.yaml

View workflow job for this annotation

GitHub Actions / actionlint

[actionlint] reported by reviewdog 🐶 unexpected key "path" for "pull_request" section. expected one of "branches", "branches-ignore", "paths", "paths-ignore", "tags", "tags-ignore", "types", "workflows" [syntax-check] Raw Output: e:.github/workflows/coverage.yaml:9:5: unexpected key "path" for "pull_request" section. expected one of "branches", "branches-ignore", "paths", "paths-ignore", "tags", "tags-ignore", "types", "workflows" [syntax-check]

Check failure on line 9 in .github/workflows/coverage.yaml

View workflow job for this annotation

GitHub Actions / actionlint

[actionlint] reported by reviewdog 🐶 unexpected key "path" for "pull_request" section. expected one of "branches", "branches-ignore", "paths", "paths-ignore", "tags", "tags-ignore", "types", "workflows" [syntax-check] Raw Output: e:.github/workflows/coverage.yaml:9:5: unexpected key "path" for "pull_request" section. expected one of "branches", "branches-ignore", "paths", "paths-ignore", "tags", "tags-ignore", "types", "workflows" [syntax-check]
- '**/*.rs'
- '**/*.txt'
- '**/Cargo.toml'
Expand All @@ -23,16 +23,13 @@
RUST_BACKTRACE: full

steps:
- uses: actions/checkout@v4.2.2
- uses: actions/checkout@v6.0.2
with:
persist-credentials: false

- uses: actions-rs/toolchain@v1.0.7
- uses: dtolnay/rust-toolchain@stable
with:
toolchain: stable
override: true
profile: minimal
components: llvm-tools-preview
components: llvm-tools

- name: Install cargo-llvm-cov cargo command
run: cargo install cargo-llvm-cov
Expand All @@ -44,4 +41,4 @@
run: cargo llvm-cov report --lcov --ignore-filename-regex '.*(tests).*|benches.rs|gencode|helpers.rs|interoperability_tests.rs' --output-path lcov.info

- name: Upload coverage report to Codecov
uses: codecov/codecov-action@v5.1.2
uses: codecov/codecov-action@v6.0.0
57 changes: 29 additions & 28 deletions .github/workflows/docs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,14 +15,20 @@ on:
paths:
# doc source files
- 'book/**'
- '**/firebase.json'
- 'katex-header.html'
# source files; some md files include code snippets that we want to keep up to date
- 'frost-*/**'
# workflow definitions
- '.github/workflows/docs.yml'
push:
branches:
- main

# Sets permissions for GitHub Pages deployment
permissions:
contents: read
pages: write
id-token: write

env:
RUST_LOG: info
RUST_BACKTRACE: full
Expand All @@ -31,56 +37,51 @@ env:

jobs:
build:
name: Build and Deploy Docs (+beta)
name: Build Docs (+beta)
timeout-minutes: 45
runs-on: ubuntu-latest
steps:
- name: Checkout the source code
uses: actions/checkout@v4.2.2
uses: actions/checkout@v6.0.2
with:
persist-credentials: false

- name: Install latest beta
uses: actions-rs/toolchain@v1
with:
toolchain: beta
components: rust-docs
override: true
uses: dtolnay/rust-toolchain@beta

- uses: Swatinem/rust-cache@v2

- name: Setup mdBook
uses: peaceiris/actions-mdbook@v2.0.0
with:
mdbook-version: '0.4.18'
mdbook-version: '0.5.2'

# TODO: actions-mdbook does not yet have an option to install mdbook-mermaid https://github.com/peaceiris/actions-mdbook/issues/426
- name: Install plugins
run: |
cargo install mdbook-mermaid
cargo install mdbook-admonish

- name: Build FROST book
run: |
mdbook build book/

- name: Deploy FROST book to Firebase preview channel
uses: FirebaseExtended/action-hosting-deploy@v0
if: ${{ github.event_name == 'pull_request' && github.actor != 'dependabot[bot]' }}
with:
entrypoint: "book/"
expires: 14d
firebaseServiceAccount: ${{ secrets.GCP_SA_KEY }}
repoToken: ${{ secrets.GITHUB_TOKEN }}
projectId: ${{ vars.FIREBASE_PROJECT_ID }}

- name: Deploy FROST book to Firebase live channel
uses: FirebaseExtended/action-hosting-deploy@v0
- name: Upload artifact
uses: actions/upload-pages-artifact@v4
if: ${{ github.event_name == 'push' && github.ref_name == 'main' }}
with:
channelId: live
entrypoint: "book/"
firebaseServiceAccount: ${{ secrets.GCP_SA_KEY }}
repoToken: ${{ secrets.GITHUB_TOKEN }}
projectId: ${{ vars.FIREBASE_PROJECT_ID }}
path: 'book/book'

deploy:
name: Deploy to GitHub Pages
if: ${{ github.event_name == 'push' && github.ref_name == 'main' }}
needs: build
timeout-minutes: 10
runs-on: ubuntu-latest
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v5

96 changes: 36 additions & 60 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,27 +9,30 @@ on:
- main

jobs:

build_default:
name: build with default features
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4.2.2
- uses: actions-rs/toolchain@v1.0.7
with:
toolchain: beta
override: true
- uses: actions-rs/cargo@v1.0.3
with:
command: build
- uses: actions/checkout@v6.0.2
- uses: dtolnay/rust-toolchain@beta
- run: cargo build

build_latest:
name: build with latest versions of dependencies
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v6.0.2
- uses: dtolnay/rust-toolchain@stable
- run: cargo update && cargo build --all-features

build_msrv:
name: build with MSRV (1.66.1)
name: build with MSRV (1.81)
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4.2.2
- uses: actions/checkout@v6.0.2
# Re-resolve Cargo.lock with minimal versions.
# This only works with nightly. We pin to a specific version because
# newer versions use lock file version 4, but the MSRV cargo does not
Expand All @@ -40,7 +43,7 @@ jobs:
- run: cargo update -Z minimal-versions
# Now check that `cargo build` works with respect to the oldest possible
# deps and the stated MSRV
- uses: dtolnay/rust-toolchain@1.66.1
- uses: dtolnay/rust-toolchain@1.81
- run: cargo build --all-features

# TODO: this is filling up the disk space in CI. See if there is a way to
Expand All @@ -51,7 +54,7 @@ jobs:
# runs-on: ubuntu-latest

# steps:
# - uses: actions/checkout@v4.2.2
# - uses: actions/checkout@v6.0.2
# - uses: dtolnay/rust-toolchain@stable
# - run: cargo install cargo-all-features
# # We check and then test because some test dependencies could help
Expand All @@ -71,7 +74,7 @@ jobs:
matrix:
crate: [ristretto255, ed25519, p256, secp256k1, secp256k1-tr, rerandomized]
steps:
- uses: actions/checkout@v4.2.2
- uses: actions/checkout@v6.0.2
- uses: dtolnay/rust-toolchain@master
with:
toolchain: stable
Expand All @@ -84,29 +87,22 @@ jobs:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4.2.2
- uses: actions-rs/toolchain@v1.0.7
with:
toolchain: beta
override: true
- uses: actions-rs/cargo@v1.0.3
with:
command: test
args: --release --all-features
- uses: actions/checkout@v6.0.2
- uses: dtolnay/rust-toolchain@beta
- run: cargo test --release --all-features

clippy:
name: Clippy
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4.2.2
- uses: actions/checkout@v6.0.2
with:
persist-credentials: false

- uses: actions-rs/toolchain@v1.0.7
- uses: dtolnay/rust-toolchain@stable
with:
toolchain: stable
override: true
components: clippy

- name: Check workflow permissions
id: check_permissions
Expand All @@ -117,12 +113,9 @@ jobs:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

- name: Run clippy action to produce annotations
uses: actions-rs/clippy-check@v1.0.7
uses: clechasseur/rs-clippy-check@v5
if: ${{ steps.check_permissions.outputs.has-permission }}
with:
# GitHub displays the clippy job and its results as separate entries
name: Clippy (stable) Results
token: ${{ secrets.GITHUB_TOKEN }}
args: --all-features --all-targets -- -D warnings

- name: Run clippy manually without annotations
Expand All @@ -134,44 +127,34 @@ jobs:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4.2.2
- uses: actions/checkout@v6.0.2
with:
persist-credentials: false

- uses: actions-rs/toolchain@v1.0.7
- uses: dtolnay/rust-toolchain@stable
with:
toolchain: stable
components: rustfmt
override: true

- uses: Swatinem/rust-cache@v2

- uses: actions-rs/cargo@v1.0.3
with:
command: fmt
args: --all -- --check
- run: cargo fmt --all -- --check

gencode:
name: Check if automatically generated code is up to date
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4.2.2
- uses: actions/checkout@v6.0.2
with:
persist-credentials: false

- uses: actions-rs/toolchain@v1.0.7
- uses: dtolnay/rust-toolchain@stable
with:
toolchain: stable
components: rustfmt
override: true

- uses: Swatinem/rust-cache@v2

- uses: actions-rs/cargo@v1.0.3
with:
command: run
args: --bin gencode -- --check
- run: cargo run --bin gencode -- --check

docs:
name: Check Rust doc
Expand All @@ -180,27 +163,20 @@ jobs:
RUSTDOCFLAGS: -D warnings

steps:
- uses: actions/checkout@v4.2.2
- uses: actions/checkout@v6.0.2
with:
persist-credentials: false

- uses: actions-rs/toolchain@v1.0.7
with:
toolchain: stable
profile: minimal
override: true
- uses: dtolnay/rust-toolchain@stable

- uses: actions-rs/cargo@v1.0.3
with:
command: doc
args: --no-deps --document-private-items --all-features
- run: cargo doc --no-deps --document-private-items --all-features

actionlint:
runs-on: ubuntu-latest
continue-on-error: true
steps:
- uses: actions/checkout@v4.2.2
- uses: reviewdog/action-actionlint@v1.63.0
- uses: actions/checkout@v6.0.2
- uses: reviewdog/action-actionlint@v1.72.0
with:
level: warning
fail_on_error: false
fail_level: none
5 changes: 4 additions & 1 deletion .github/workflows/release-drafter.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,12 @@ on:
jobs:
update_release_draft:
runs-on: ubuntu-latest
permissions:
contents: write
pull-requests: read
steps:
# Drafts your next Release notes as Pull Requests are merged into main
- uses: release-drafter/release-drafter@v6
- uses: release-drafter/release-drafter@v7
with:
# (Optional) specify config name to use, relative to .github/. Default: release-drafter.yml
config-name: release-drafter.yml
Expand Down
1 change: 0 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
/target
**/*.rs.bk
Cargo.lock
*~
**/.DS_Store
.vscode/*
1 change: 0 additions & 1 deletion .mergify.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ queue_rules:
# which are the same as the GitHub main branch protection rules
# https://docs.mergify.com/conditions/#about-branch-protection
- base=main
allow_inplace_checks: true
batch_size: 2
# Wait for a few minutes to embark 2 tickets together in a merge train
batch_max_wait_time: "3 minutes"
Expand Down
Loading
Loading