package octez-shell-libs

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Module Tezos_client_base.Client_keys_v1Source

Module to use keys over Tezos_crypto.Signature.V1

include module type of struct include Client_keys end

Cryptographic keys tables

Sourcetype pk_uri = private Uri.t
Sourcemodule Pk_uri_hashtbl = Client_keys.Pk_uri_hashtbl
Sourcetype sk_uri = private Uri.t
Sourcetype sapling_uri = private Uri.t
Sourcetype aggregate_pk_uri = private Uri.t
Sourcetype aggregate_sk_uri = private Uri.t
Sourceval pk_uri_parameter : unit -> (pk_uri, 'a) Tezos_clic.parameter
Sourceval pk_uri_param : ?name:string -> ?desc:string -> ('a, 'b) Tezos_clic.params -> (pk_uri -> 'a, 'b) Tezos_clic.params
Sourceval sk_uri_parameter : unit -> (sk_uri, 'a) Tezos_clic.parameter
Sourceval sk_uri_param : ?name:string -> ?desc:string -> ('a, 'b) Tezos_clic.params -> (sk_uri -> 'a, 'b) Tezos_clic.params
Sourceval aggregate_sk_uri_parameter : unit -> (aggregate_sk_uri, 'a) Tezos_clic.parameter
Sourceval aggregate_sk_uri_param : ?name:string -> ?desc:string -> ('a, 'b) Tezos_clic.params -> (aggregate_sk_uri -> 'a, 'b) Tezos_clic.params
Sourcetype Tezos_base.TzPervasives.error +=
  1. | Unregistered_key_scheme of string
Sourcetype sapling_key = Client_keys.sapling_key = {
  1. sk : sapling_uri;
  2. path : int32 list;
  3. address_index : Tezos_sapling.Core.Client.Viewing_key.index;
}
Sourcemodule Sapling_key = Client_keys.Sapling_key
Sourcemodule Aggregate_alias = Client_keys.Aggregate_alias

Aggregate_alias contains the implementation needed for the wallet to have the correspondence between aliases and keys. It has three sub-module Public_key Public_key_hash Secret_key. The reason of a sub-module inside a sub-module is not confuse them with the alias module for the standard signature (i.e. Public_key, Public_key_hash, and Secret_key).

Sourcemodule Aggregate_type = Client_keys.Aggregate_type
Sourcemodule Logging = Client_keys.Logging

Interface for external signing modules.

Sourcemodule type COMMON_SIGNER = Client_keys.COMMON_SIGNER
Sourcemodule type AGGREGATE_SIGNER = Client_keys.AGGREGATE_SIGNER
Sourcemodule type SIGNER = Client_keys.SIGNER
Sourcetype signer = Client_keys.signer =
  1. | Simple of (module SIGNER)
  2. | Aggregate of (module AGGREGATE_SIGNER)
Sourceval register_signer : (module SIGNER) -> unit

register_signer signer registers first-class module signer as signer for keys with scheme (val signer : SIGNER).scheme.

Sourceval registered_signers : unit -> (string * signer) list
Sourceval register_aggregate_signer : (module AGGREGATE_SIGNER) -> unit

register_aggregate_signer signer registers first-class module signer as signer for keys with scheme (val signer : AGGREGATE_SIGNER).scheme.

Sourceval register_aggregate_key : Client_context.wallet -> ?force:bool -> (Tezos_crypto.Aggregate_signature.Public_key_hash.t * aggregate_pk_uri * aggregate_sk_uri) -> ?public_key:Tezos_crypto.Aggregate_signature.Public_key.t -> string -> unit Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval list_aggregate_keys : Client_context.wallet -> (string * Tezos_crypto.Aggregate_signature.Public_key_hash.t * Tezos_crypto.Aggregate_signature.Public_key.t option * aggregate_sk_uri option) list Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval import_aggregate_secret_key : io:Client_context.io_wallet -> aggregate_pk_uri -> (Tezos_crypto.Aggregate_signature.Public_key_hash.t * Tezos_crypto.Aggregate_signature.Public_key.t option) Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval alias_aggregate_keys : Client_context.wallet -> string -> (Tezos_crypto.Aggregate_signature.Public_key_hash.t * Tezos_crypto.Aggregate_signature.Public_key.t option * aggregate_sk_uri option) option Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval aggregate_sign : Client_context.wallet -> aggregate_sk_uri -> Tezos_base.TzPervasives.Bytes.t -> Tezos_crypto.Aggregate_signature.t Tezos_base.TzPervasives.tzresult Lwt.t
Sourcemodule type S = Client_keys.S
Sourcemodule V_latest = Client_keys.V_latest
include module type of V_latest
include module type of struct include Client_keys.V1 end
Sourcemodule Signature_type = Client_keys.V1.Signature_type

Signature_type is a small module to be included in signer to conform to the module type SIGNER instead of rewriting all type.

Sourcemodule Public_key_hash = Client_keys.V1.Public_key_hash
Sourceval import_secret_key : io:Client_context.io_wallet -> Client_keys.pk_uri -> (Tezos_crypto.Signature.V1.Public_key_hash.t * Tezos_crypto.Signature.V1.Public_key.t option) Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval public_key : Client_keys.pk_uri -> Tezos_crypto.Signature.V1.Public_key.t Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval public_key_hash : Client_keys.pk_uri -> (Tezos_crypto.Signature.V1.Public_key_hash.t * Tezos_crypto.Signature.V1.Public_key.t option) Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval sign : Client_context.wallet -> ?watermark:Tezos_crypto.Signature.V1.watermark -> Client_keys.sk_uri -> Tezos_base.TzPervasives.Bytes.t -> Tezos_crypto.Signature.V1.t Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval check : ?watermark:Tezos_crypto.Signature.V1.watermark -> Client_keys.pk_uri -> Tezos_crypto.Signature.V1.t -> Tezos_base.TzPervasives.Bytes.t -> bool Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval supports_deterministic_nonces : Client_keys.sk_uri -> bool Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval register_key : Client_context.wallet -> ?force:bool -> (Tezos_crypto.Signature.V1.Public_key_hash.t * Client_keys.pk_uri * Client_keys.sk_uri) -> ?public_key:Tezos_crypto.Signature.V1.Public_key.t -> string -> unit Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval register_keys : Client_context.wallet -> (string * Tezos_crypto.Signature.V1.Public_key_hash.t * Tezos_crypto.Signature.V1.Public_key.t * Client_keys.pk_uri * Client_keys.sk_uri) list -> unit Tezos_base.TzPervasives.tzresult Lwt.t

Similar to repeated calls to register_key, but is more efficient. Always forces addition of new elements.

Sourceval list_keys : Client_context.wallet -> (string * Tezos_crypto.Signature.V1.Public_key_hash.t * Tezos_crypto.Signature.V1.Public_key.t option * Client_keys.sk_uri option) list Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval alias_keys : Client_context.wallet -> string -> (Tezos_crypto.Signature.V1.Public_key_hash.t * Tezos_crypto.Signature.V1.Public_key.t option * Client_keys.sk_uri option) option Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval get_key : Client_context.wallet -> Tezos_crypto.Signature.V1.Public_key_hash.t -> (string * Tezos_crypto.Signature.V1.Public_key.t * Client_keys.sk_uri) Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval get_public_key : Client_context.wallet -> Tezos_crypto.Signature.V1.Public_key_hash.t -> (string * Tezos_crypto.Signature.V1.Public_key.t) Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval get_keys : Client_context.wallet -> (string * Tezos_crypto.Signature.V1.Public_key_hash.t * Tezos_crypto.Signature.V1.Public_key.t * Client_keys.sk_uri) list Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval force_switch : unit -> (bool, 'ctx) Tezos_clic.arg
OCaml

Innovation. Community. Security.