Skip to content

Latest commit

 

History

History
281 lines (205 loc) · 12 KB

CHANGELOG.md

File metadata and controls

281 lines (205 loc) · 12 KB

Changelog

4.0.0

  • [#327]
    • Reuse the reqwest Client for all calls. This increases performance significantly if making multiple calls with the same IronOxide.
    • Change DeviceContext to BlockingDeviceContext for the blocking api. This allows the reuse of the runtime for all calls.

3.0.0

  • [#321]
    • Bump MSRV to 1.75.0.
    • Upgrade dependencies. This includes an update to itertools, which is part of the public API.
    • Re-export itertools::EitherOrBoth. Updates to itertools will not automatically be considered breaking changes going forward.

2.1.0

  • [#284] Remove dev as an option for IRONCORE_ENV.
  • [#300] Bump MSRV to 1.67.0.
  • [#308] Use policy caching in unmanaged encryption.
  • [#309] Bump MSRV to 1.70.0.

2.0.0

  • [#274] Bump MSRV to 1.60.0.
  • [#281] Make JwtClaims deserialization more lenient.

1.1.1

  • [#272] Fix regression that removed Hash from Jwt.

1.1.0

  • [#270] Add id to the UserCreateResult and UserUpdateResult.

1.0.0

  • [#267] Add user_change_password

0.27.0

  • [#246] Don't clone plaintext on AES encryption
    • Public APIs for document_encrypt, document_encrypt_unmanaged, and document_update_bytes now take owned bytes instead of byte slices to improve performance for common use cases.
    • AES encryption has improved memory usage in most cases.
  • [#249] Remove chrono types in public API and replace with equivalent time types
  • [#248]
    • Bump MSRV to 1.56.0
    • Update to recrypt 0.13
    • Update to rand 0.8
    • Update to rand_chacha 0.3
    • Update to ironcore-search-helpers 0.2
    • Update to jsonwebtoken 8

0.26.0

  • [#243] Add #[non_exhaustive] to IronOxideErr.
  • [#243] Increase throughput of document decrypt calls.

0.25.2

  • [#222] Loosen version requirements for dependencies.
  • [#225] Fix bug causing requests with empty policies to fail.
  • [#232] Remove dependency on publicsuffix.

0.25.1

  • [#216] Fix compatibility with serde 1.0.119

0.25.0

  • [#209] Update to itertools 0.10.0
  • [#211] Update to dashmap 4.0.1
  • [#213]
    • Update to tokio 1.0
    • Update to reqwest 0.11.0
    • Update to bytes 1.0
    • Require minimum protobuf of 2.20.0
  • [#215]
    • Update to recrypt 0.12.0
    • Bump MSRV to 1.41.1

0.24.1

  • Fix compatibility with serde 1.0.119
  • Locked to protobuf 2.17.0 (relaxed in later releases)

0.24.0

  • [#183]
    • Update to rust-protobuf 2.17
  • [#193]
    • Relax rust-protobuf dependency requirement. This should allow downstream consumers more freedom in what rust-protobuf version they are using.
  • [#196]
    • Add group encrypt benchmarks
  • Various non-breaking dependency updates

0.23.1

  • [#170]
    • Update JwtClaims struct to handle "http://ironcore/" namespace prefix on private claims
    • Add optional uid claim that is added by Auth0
    • Change type of pid and kid fields in claims from usize to u32
  • [#177]
    • Add explicit type_length_limit because as of Rust 1.46.0, the default wasn't sufficient
    • Update dependencies

0.23.0

  • [#164] [#168]
    • Add Jwt struct that validates JWT algorithm and payload form
    • Add JwtClaims struct to help form a valid Jwt payload
    • Change user_create, user_verify, and generate_new_device to use new Jwt struct

0.22.0

  • [#142]
    • Significant changes to organization of structs
      • Add ironoxide::common module to hold structs that span modules
      • Add all structs and traits to ironoxide::prelude
      • Move DeviceId, DeviceName, DeviceAddResult, and KeyPair to ironoxide::user module
      • Move DocumentId and DocumentName to ironoxide::document module
  • [#148]
    • Add serde support for EncryptedBlindSearchIndex
    • Expose transliterate_string function
  • [#155]
    • Upgrade dependencies
  • [#156]
    • proto module is no longer pub as it is only used internally
  • [#139] [#152] [#154] [#158]
    • Improve documentation throughout crate

0.21.1

  • [#138]
    • Remove publicsuffix default features (openssl-sys)
  • [#129]
    • Improve error message for SDK initialization failure
  • [#132]
    • Add feature flags to enable alternative TLS linking and implementations

0.21.0

  • [#126]
    • Upgrade dependencies (rand, rand_chacha, recrypt)
  • [#118]
    • Introduce search module with ability to create blind indexes. (behind beta flag)

0.20.0

  • [#119]
    • Add Clone, Debug, Eq, Hash, and PartialEq to almost all public structs.
    • Upgrade to itertools 0.9.0
  • [#123]
    • Add better error message for missing policy

0.19.1

  • [#120]
    • Add clear_policy_cache() to BlockingIronOxide.

0.19.0

  • [#114]
    • Adds timeouts to all public API methods. Most timeouts use a top-level config set in IronOxideConfig. Some special cases allow for passing an optional timeout directly (rotate_all, user_create, user_verify, generate_new_device). Timeouts apply to both IronOxide and BlockingIronOxide
    • Configs can now be set on BlockingIronOxide. Before, defaults were always used.
    • Trying out an "open" struct for all config objects to allow for easier construction and access
    • Adds dependency on tokio/rt-threaded feature flag

0.18.0

  • [#112]
    • Make the default API async
    • Add feature flag blocking to enable the sync API
  • [#111]
    • Adds simple policy caching
  • [#108]
    • Fix bug to allow decryption of 0 and 1 byte documents

0.17.0

  • [#107]
    • Change generate_new_device() to return a DeviceAddResult
  • [#101]
    • Dependency upgrades

0.16.0

  • [#98]
    • Removes device_id from RequestAuth and DeviceContext::new()

0.15.0

  • [#94]
    • Adds rotate_all() to PrivateKeyRotationCheckResult
    • Adds id() to GroupUpdatePrivateKeyResult
  • [#91]
    • Adds simple sharing of tokio runtime across device authenticated SDK calls
  • [#90]
    • Adds method GroupOps::group_rotate_private_key

0.14.0

  • [#81][#80][#77]
    • internal group api to async/await syntax
    • internal document api to async/await syntax
    • internal user api to async/await syntax
    • Tokio 0.2.0-alpha.2 upgrade
  • [#76]
    • Allows adding admins at group creation time.
    • Allows specifying an owner at group creation time.
  • [#72]
    • Allows adding members at group creation time.
  • [#69]
    • Allows changing of IronCore environment at runtime.
  • [#64]
    • Adds need_rotation to GroupCreateOpts, allowing a group to be created with its private key marked for rotation.

0.13.0

  • [#59]
    • Adds method UserOps::user_rotate_private_key
    • Adds a new initialization option: ironoxide::initialize_check_rotation to enable users to know if any of their private keys need rotation.
    • Renames user::UserVerifyResult -> user::UserResult

0.12.1

  • [#56]
    • Added needs_rotation as an Option<bool> to GroupMetaResult, GroupGetResult, GroupBasicApiResponse, and GroupGetApiResponse.

0.12.0

  • [#52]
    • Added device_id as a parameter to DeviceContext::new, renamed other parameters.
    • Changed Serialization/Deserialization of DeviceContext.

0.11.0

  • Added TryFrom<&[u8]> for PublicKey
  • UserCreateKeyPair has been renamed to UserCreateResult
  • [#35]
    • Clarified documentation for several struct parameters.
  • [#43]
    • Users can now be created with a needs_rotation flag set.
  • [#47]
    • UserVerifyResult now contains needs_rotation for the user.

0.10.1

  • [#32]
    • DocumentAdvancedOps::document_decrypt_unmanaged function added for advanced use cases. This decrypt operation is the inverse of DocumentAdvancedOps::document_encrypt_unmanaged

0.10.0

  • [#27]
    • DocumentAdvancedOps::document_encrypt_unmanaged function added for advanced use cases where the calling application wants to manage both the encrypted data and the associated edeks instead of using the IronCore service for EDEK management.

0.9.0

  • [#23]
    • IronOxide no longer has mutable references in its API, making it possible to share an IronOxide between threads.
    • The RNG used for AES now periodically reseeds itself.

0.8.0

  • Added the ability to encrypt via policy.

0.7.0

  • Added the ability to encrypt without granting to the author.

0.6.1

  • [#1]
    • added UserCreateKeyPair to public API
    • added IronOxideErr to the prelude
    • added From<IronOxideErr> for String to lib.rs

0.6.0

  • Initial Open Source Release