Skip to content

Releases: aws/s2n-tls

Release: v1.6.0

30 Oct 18:51
6aefe74

Choose a tag to compare

Weekly release for October 30 2025

Release Summary:

  • Multiple changes to the s2n-tls default policy:
    1. Added TLS13 support
    2. Added Post-Quantum key exchange
    3. Removed CBC ciphersuites
  • Changes to the RFC9151 policy: Removes RSA key exchange and DHE cipher suites. Use the numbered version of this policy instead (20250429) to maintain the current preferences.
  • Adds support for PQ only policies, which should not include classical ECC curves. This feature only works on libcryptos that support TLS 1.3 and PQ kem groups.
  • Fixed a validation issue in s2n_connection_deserialize() where malformed protocol version bytes could result in invalid connection state and inconsistent TLS behavior.
  • Add a synchronous rust binding API for s2n_cert_validation_callback
  • Upgrades MSRV for extended crates (s2n-tls-sys, s2n-tls, s2n-tls-tokio) from 1.63 to 1.72

What's Changed

  • docs: Small doc changes for KTLS by @maddeleine in #5521
  • ci: install missing rust component for gitthub action workflows by @jouho in #5528
  • refactor(aws-kms-tls-auth): add hmac based psk derivation by @jmayclin in #5519
  • chore: bindings release 0.3.27 by @jouho in #5526
  • fix(usage-guide): Update book.toml for mdbook 0.5 release by @goatgoose in #5535
  • bindings(rust): bump extended crates MSRV to 1.72.0 by @jouho in #5534
  • feat(bindings): expose cert validation callback by @CarolYeh910 in #5357
  • chore: bindings release 0.3.28 by @goatgoose in #5540
  • chore: add new team member by @kaukabrizvi in #5542
  • fix: validate protocol version during connection deserialization by @jouho in #5523
  • chore(bindings): revert dependency pins by @jmayclin in #5544
  • refactor(aws-kms-tls-auth): psk provider using HMAC psks by @jmayclin in #5530
  • chore: update bindgen version to v0.69.0 by @boquan-fang in #5396
  • refactor 1/2: Fix security policy version in tests to numbered string by @maddeleine in #5549
  • refactor: add psk receiver by @jmayclin in #5552
  • build(deps): update rtshark requirement from 3.1.0 to 4.0.0 in /tests/pcap in the all-cargo-updates group across 1 directory by @dependabot[bot] in #5555
  • fix(aws-kms-tls-auth): supress logging & version bump by @jmayclin in #5554
  • refactor 2/2: Fix security policy version in tests to numbered string by @maddeleine in #5553
  • fix(test): Reduce s2n_security_policies_test duration by @goatgoose in #5558
  • docs: update nix integration test instructions for uvinteg function by @kaukabrizvi in #5550
  • build(deps): bump the all-gha-updates group across 1 directory with 4 updates by @dependabot[bot] in #5548
  • build(deps): update zeroize requirement from =1.7.0 to =1.8.2 in /bindings/rust/extended by @dependabot[bot] in #5537
  • build(deps): update regex requirement from =1.9.6 to =1.12.1 in /bindings/rust/extended by @dependabot[bot] in #5556
  • feat: Improve supported cipher suites in RFC9151 policy by @goatgoose in #5559
  • ci: pin to older kissat version to unblock CBMC by @lrstewart in #5581
  • fix: update test broken by Openssl dhe generation change by @lrstewart in #5580
  • feat: output utility for security policy by @jouho in #5502
  • feat: add PQ only policy support by @CarolYeh910 in #5545
  • fix: update test_pq_only policy snapshot by @CarolYeh910 in #5583
  • refactor: Adds tls13 ciphersuites to default/default_fips policy by @maddeleine in #5560
  • build(deps): bump the all-gha-updates group in /.github/workflows with 2 updates by @dependabot[bot] in #5585
  • ci: scope down GitHub Token permissions by @AdnaneKhan in #5570

New Contributors

Full Changelog: v1.5.27...v1.6.0

Release: v1.5.27

25 Sep 17:12
30f40f2

Choose a tag to compare

Weekly release for September 25 2025

Release Summary:

  • Our kTLS feature can now perform key updates, meaning that kTLS is now safe to turn on in TLS1.3 when using the newest version of the linux kernel (6.14+).

What's Changed

Full Changelog: v1.5.26...v1.5.27

v1.5.26

15 Sep 16:27
792d366

Choose a tag to compare

Release Summary

  • Adds async public key support: s2n_pkey_verify() can be performed asynchronously through the async offloading callback.
  • Add new s2n_connection_get_signature_scheme method to retrieve the IANA description of the server signature scheme

What's Changed

New Contributors

Full Changelog: v1.5.25...v1.5.26

Release: v1.5.25

25 Aug 21:55
a786223

Choose a tag to compare

Weekly release for August 25 2025

Release Summary

  • Add a copy of the rfc9151 policy (20250429) which pins all of the policy parts to the current version.
  • Adds new TLSv1.3-enabled security policies for CloudFront's outbound ("upstream") connections to origin servers. We also add similar policies with PQ enabled.

What's Changed

New Contributors

Full Changelog: v1.5.24...v1.5.25

Release: v1.5.24

04 Aug 23:56
418313c

Choose a tag to compare

Weekly release for August 04 2025

Release Summary

  • Adds new PQ security policies with ML-KEM for the CRT.

What's Changed

Full Changelog: v1.5.23...v1.5.24

Release: v1.5.23

24 Jul 20:23
30f6248

Choose a tag to compare

Weekly release for July 24 2025

Release Summary

  • The aws-kms-tls-auth crate is now available, which provides utilities to do TLS-PSK based authentication using IAM and KMS.
  • Created a new hybrid KEM group s2n_secp384r1_mlkem_1024.
  • Updated the default_pq security policy to include the secp384r1_mlkem_1024 hybrid KEM group.

What's Changed

  • fix(ci): adding set -e to prevent nix develop to hide failing tests by @boquan-fang in #5393
  • chore: release 0.3.22 by @boquan-fang in #5397
  • docs: note that s2n_shutdown may keep reading by @lrstewart in #5370
  • feat(aws-kms-tls-auth): add codec and parsing by @jmayclin in #5398
  • ci: start codebuild jobs from github actions by @lrstewart in #5383
  • ci: Migrate Duvet GitHub Action to duvet-action repo by @johubertj in #5400
  • feat(aws-kms-tls-auth): add psk identity by @jmayclin in #5402
  • feat: add ML-KEM-1024 kem definition by @johubertj in #5367
  • Flip Nix integration tests to use uv/pytest by @dougch in #5352
  • feat(aws-kms-tls-auth): add provider & receiver structs by @jmayclin in #5408
  • ci: require repo write permissions for codebuild by @lrstewart in #5421
  • docs(aws-kms-tls-auth): add readme by @jmayclin in #5409
  • docs(aws-kms-tls-auth): clarify security impact of failure modes by @jmayclin in #5424
  • ci: run rustfmt/clippy on standard crates by @jmayclin in #5333
  • feat: add secp384r1_mlkem_1024 kem group by @johubertj in #5395
  • feat(bench): add generic shutdown functionality by @jmayclin in #5426
  • chore: Nix Corretto version bump/upstream by @dougch in #5427
  • feature: update default_pq to support secp384r1_mlkem_1024 by @johubertj in #5433
  • build(deps): bump cross-platform-actions/action from 0.28.0 to 0.29.0 in /.github/workflows in the all-gha-updates group by @dependabot[bot] in #5435

Full Changelog: v1.5.22...v1.5.23

Release: v1.5.22

07 Jul 21:27
e33d7ef

Choose a tag to compare

Weekly release for July 07 2025

Release Summary

  • Add a new security policy for CRT that supports FIPS and TLS1.2.
  • The fmt::Debug message for application errors in the Rust bindings now use the application error's fmt::Debug implementation, rather than a generic message.

What's Changed

  • chore(ci): add a cargo timing buildspec by @dougch in #5176
  • build(deps): update pprof requirement from 0.14 to 0.15 in /bindings/rust/standard by @dependabot in #5334
  • refactor(examples): remove connection pool by @jmayclin in #5353
  • ci: Fix the sslyze test for nix by @dougch in #5283
  • Include application message in Debug impl by @Mark-Simulacrum in #5359
  • build: prevent needless rebuild with S2N_INTERN_LIBCRYPTO=ON and Ninja by @kou in #5356
  • build(deps): bump baptiste0928/cargo-install from 3.3.0 to 3.3.1 in /.github/workflows in the all-gha-updates group by @dependabot in #5361
  • tests(integv2): fix flaky session resumption test by @lrstewart in #5362
  • tests(integ): add more debug logging by @lrstewart in #5363
  • build(deps): bump nixbuild/nix-quick-install-action from 30 to 31 in /.github/workflows in the all-gha-updates group by @dependabot in #5366
  • build(deps): bump nixbuild/nix-quick-install-action from 31 to 32 in /.github/workflows in the all-gha-updates group by @dependabot in #5371
  • fix: policy util should ignore deprecated TLS1.2 kems if missing by @lrstewart in #5372
  • chore: apply clippy and fmt fixes by @boquan-fang in #5386
  • feature: new TLS1.2 + FIPS CRT security policy by @lrstewart in #5375

Full Changelog: v1.5.21...v1.5.22

Release: v1.5.21

04 Jun 21:05
a772605

Choose a tag to compare

Weekly release for Jun 04 2025

Release Summary

  • Fixed bug preventing use of ML-DSA with mainline AWSLC built in FIPS mode

What's Changed

Full Changelog: v1.5.20...v1.5.21

Release: v1.5.20

30 May 20:52
e12a1fe

Choose a tag to compare

Weekly release for May 30 2025

Release Summary:

  • Add a new CertificateRequest callback to allow clients to select a certificate chain during the handshake.
  • Add support for custom critical certificate extensions. Users MUST validate their custom extensions in the cert validation callback or after the handshake.

What's Changed

Full Changelog: v1.5.19...v1.5.20

Release: v1.5.19

22 May 20:31
92f7827

Choose a tag to compare

Release Summary:

  • Adds support for post-quantum ML-DSA certificates

What's Changed

  • ci: handle 429 from yahoo.com network integ test by @lrstewart in #5280
  • ci: fix expectations when using system default libcrypto by @lrstewart in #5279
  • chore: bindings release 0.3.18 by @johubertj in #5284
  • build(deps): bump astral-sh/setup-uv from 5 to 6 in /.github/workflows in the all-gha-updates group by @dependabot in #5273
  • tests: improve coverage for s2n_stream_cipher_null by @wafuwafu13 in #5268
  • chore: Add comments to track dependency requirements by @johubertj in #5287
  • chore: bump standard MSRV to 1.82.0 by @johubertj in #5295
  • tests: fix flaky test_serialization by @lrstewart in #5288
  • build(deps): bump aws-actions/configure-aws-credentials from 4.1.0 to 4.2.0 in /.github/workflows in the all-gha-updates group by @dependabot in #5297
  • build(deps): update env_logger requirement from 0.10 to 0.11 in /bindings/rust/standard by @dependabot in #5296
  • tests: reduce integ test flakiness + improve debugability by @lrstewart in #5282
  • feat: Add as_ptr() API for Config by @goatgoose in #5274
  • build(deps): update test-log-macros requirement from =0.2.14 to =0.2.17 in /bindings/rust/standard by @dependabot in #5290
  • build(deps): update strum requirement from 0.25 to 0.27 in /bindings/rust/standard by @dependabot in #5292
  • chore: bindings release 0.3.19 by @goatgoose in #5298
  • build: add pull requests limit for dependabot by @boquan-fang in #5299
  • build(deps): unpin test-log because of MSRV updates by @boquan-fang in #5300
  • refactor: remove conn->client_hello_version by @lrstewart in #5278
  • feature: add crypto support for mldsa signing by @lrstewart in #5272
  • chore: Update Apache test certificates from RSA1024 to RSA2048 by @dougch in #5285
  • Revert "build: add pull requests limit for dependabot" by @boquan-fang in #5302
  • tests: turn verbose mode off by default in integ tests by @lrstewart in #5286
  • feature: support for ML-DSA handshake signatures by @lrstewart in #5303
  • feature: release ML-DSA support by @lrstewart in #5307
  • fix(benches): use session ticket for resumption by @jmayclin in #5305
  • tests: policy snapshot test by @lrstewart in #5309
  • chore: Bump nixpkgs version to 24.11 by @dougch in #5294
  • Remove unused negotiate_kem function causing build failure by @Mark-Simulacrum in #5316

New Contributors

Full Changelog: v1.5.18...v1.5.19