20 releases (6 stable)

2.1.0 May 13, 2024
2.0.0 Jul 27, 2023
1.1.0 May 3, 2023
1.0.5 Nov 16, 2022
0.1.0 Jul 29, 2020

#2 in #client-state

Download history 1614/week @ 2024-09-30 1768/week @ 2024-10-07 2528/week @ 2024-10-14 2055/week @ 2024-10-21 1598/week @ 2024-10-28 1454/week @ 2024-11-04 2251/week @ 2024-11-11 1744/week @ 2024-11-18 1127/week @ 2024-11-25 2206/week @ 2024-12-02 2641/week @ 2024-12-09 1815/week @ 2024-12-16 519/week @ 2024-12-23 1289/week @ 2024-12-30 3457/week @ 2025-01-06 1990/week @ 2025-01-13

7,283 downloads per month
Used in 8 crates (4 directly)

Apache-2.0

340KB
7K SLoC

Stronghold Client Interface

The client gives access to all Stronghold features and holds all state like secrets or insecure custom data. The interface is type based and separates between local Stronghold operations and remote Stronghold operations.

Accessing the Client

  • Load Clients
  • Create Clients
  • Writing Secrets
  • Reading / Writing from/into Store
  • Executing Procedures

Persisting State via Snapshots

  • Writing Client State into Snapshots

Working with Remote Strongholds

  • place a reference to the examples here

Procedures

Requests:

  • SLIP10Generate: Generate a raw SLIP10 seed of the specified size (in bytes, defaults to 64 bytes/512 bits) and store it in the Location.
  • SLIP10Derive: Derive a Slip10 child key from a seed or parent key. Store the output in a specified Location and return the corresponding ChainCode.
  • BIP39Recover: Use a BIP39 mnemonic sentence (optionally protected by a passphrase) to create or recover a BIP39 seed and store it in the output Location.
  • BIP39Generate: Generate a BIP39 seed and its corresponding mnemonic sentence (optionally protected by a passphrase) and store them in the output Location.
  • BIP39MnemonicSentence: Read a BIP39 seed and its corresponding mnemonic sentence (optionally protected by a passphrase) and store them in the output Location.
  • Ed25519PublicKey: Derive an Ed25519 public key from the corresponding private key stored at the specified Location.
  • Ed25519Sign: Use the specified Ed25519 compatible key to sign the given message. Compatible keys are any record that contain the desired key material in the first 32 bytes, in particular SLIP10 keys are compatible.

Responses:

  • SLIP10Generate: Returns a StatusMessage indicating the result of the request.
  • SLIP10Derive: Returns a ResultMessage with the ChainCode inside of it.
  • BIP39Recover: Returns a StatusMessage indicating the result of the request. .
  • BIP39Generate: Returns a StatusMessage indicating the result of the request.
  • BIP39MnemonicSentence: Returns the mnemonic sentence for the corresponding seed.
  • Ed25519PublicKey: Returns an Ed25519 public key inside of a ResultMessage.
  • Ed25519Sign: Returns an Ed25519 signature inside of a ResultMessage.

Dependencies

~11–36MB
~531K SLoC