ligo/vendors/ocaml-secp256k1/src/external.mli
2018-05-03 15:36:02 +02:00

207 lines
7.3 KiB
OCaml

module Context : sig
type t
(** Opaque data structure that holds context information
(precomputed tables etc.).
Do not create a new context object for each operation, as
construction is far slower than all other API calls (~100 times
slower than an ECDSA verification).
A constructed context can safely be used from multiple threads
simultaneously, but API call that take a non-const pointer to a
context need exclusive access to it. In particular this is the
case for secp256k1_context_destroy and
secp256k1_context_randomize.
Regarding randomization, either do it once at creation time (in
which case you do not need any locking for the other calls), or
use a read-write lock. *)
val create : ?sign:bool -> ?verify:bool -> unit -> t
(** [create ?sign ?bool ()] is a freshly allocated [t]. *)
val clone : t -> t
(** [clone t] is a copy of [t]. *)
val randomize : t -> Bigstring.t -> bool
(** While secp256k1 code is written to be constant-time no matter
what secret values are, it's possible that a future compiler may
output code which isn't, and also that the CPU may not emit the
same radio frequencies or draw the same amount power for all
values.
This function provides a seed which is combined into the
blinding value: that blinding value is added before each
multiplication (and removed afterwards) so that it does not
affect function results, but shields against attacks which rely
on any input-dependent behaviour.
You should call this after secp256k1_context_create or
secp256k1_context_clone, and may call this repeatedly
afterwards. *)
end
module Key : sig
type secret
type public
type _ t
val buffer : _ t -> Bigstring.t
(** [buffer k] is the underlying buffer of [k]. DO NOT MODIFY. *)
val secret_bytes : int
(** Length of a secret key in memory: 32 bytes *)
val public_bytes : int
(** Length of a public key in memory: 64 bytes *)
val compressed_pk_bytes : int
(** Length of the compressed serialization of a public key: 33 bytes *)
val uncompressed_pk_bytes : int
(** Length of the uncompressed serialization of a public key: 65 bytes *)
val bytes : _ t -> int
(** [bytes k] is the length of [k] in memory (the length of the
underlying [Bigstring.t]). *)
val serialized_bytes : ?compressed:bool -> _ t -> int
(** [serialized_bytes ?compressed k] is the length of the
serialization (compressed) of [k].*)
val equal : 'a t -> 'a t -> bool
val copy : 'a t -> 'a t
(** {2 Aritmetic operations } *)
val negate : Context.t -> 'a t -> 'a t
val add_tweak : Context.t -> 'a t -> Bigstring.t -> 'a t
val mul_tweak : Context.t -> 'a t -> Bigstring.t -> 'a t
val neuterize : Context.t -> _ t -> public t option
val neuterize_exn : Context.t -> _ t -> public t
val combine : Context.t -> _ t list -> public t option
val combine_exn : Context.t -> _ t list -> public t
(** {2 Input/Output} *)
val read_sk : Context.t -> Bigstring.t -> (secret t, string) result
val read_sk_exn : Context.t -> Bigstring.t -> secret t
val read_pk : Context.t -> Bigstring.t -> (public t, string) result
val read_pk_exn : Context.t -> Bigstring.t -> public t
val write : ?compress:bool -> Context.t -> ?pos:int -> Bigstring.t -> _ t -> int
val to_bytes : ?compress:bool -> Context.t -> _ t -> Bigstring.t
end
module Sign : sig
(** {2 Signature} *)
type plain
type recoverable
type _ t
val buffer : _ t -> Bigstring.t
(** [buffer signature] is the underlying buffer of [signature]. DO
NOT MODIFY. *)
val plain_bytes : int
(** 64 bytes *)
val recoverable_bytes : int
(** 65 bytes *)
val msg_bytes : int
(** 32 bytes *)
val equal : 'a t -> 'a t -> bool
val to_plain : Context.t -> _ t -> plain t
(** {3 Input/Output} *)
val read : Context.t -> Bigstring.t -> (plain t, string) result
val read_exn : Context.t -> Bigstring.t -> plain t
val read_der : Context.t -> Bigstring.t -> (plain t, string) result
val read_der_exn : Context.t -> Bigstring.t -> plain t
val read_recoverable :
Context.t -> Bigstring.t -> (recoverable t, string) result
(** [read_recoverable_exn ctx buf] reads a recoverable signature in
[buf] if everything goes well or return an error otherwise. *)
val read_recoverable_exn : Context.t -> Bigstring.t -> recoverable t
(** [read_recoverable_exn ctx buf] reads a recoverable signature in
[buf].
@raises [Invalid_argument] if [buf] is less than 65 bytes long
or [buf] does not contain a valid recoverable signature. *)
val write_exn : ?der:bool -> Context.t -> Bigstring.t -> _ t -> int
val write : ?der:bool -> Context.t -> Bigstring.t -> _ t -> (int, string) result
val to_bytes : ?der:bool -> Context.t -> _ t -> Bigstring.t
(** [to_bytes ?der ctx signature] writes the serialization of
[signature] in a freshly allocated [Bigstring.t], which is then
returned. *)
(** {3 Sign} *)
val normalize :
Context.t -> plain t -> plain t option
(** [normalize ctx sig] is the normalized lower-S form of [Some
normalized_sig] if [sig] was not already in this form, or [None]
otherwise. *)
(** {4 Creation} *)
val sign : Context.t -> sk:Key.secret Key.t -> Bigstring.t -> (plain
t, string) result
val sign_exn : Context.t -> sk:Key.secret Key.t -> Bigstring.t ->
plain t
val sign_recoverable : Context.t -> sk:Key.secret Key.t ->
Bigstring.t -> (recoverable t, string) result
val sign_recoverable_exn : Context.t -> sk:Key.secret Key.t ->
Bigstring.t -> recoverable t
(** {4 Direct write} *)
val write_sign : Context.t -> Bigstring.t -> sk:Key.secret Key.t ->
msg:Bigstring.t -> (int, string) result (** [write_sign ctx buf ~sk
~msg] writes signs [msg] with [sk] and writes the signature to
[buf] at [?pos]. It returns the number of bytes written (64) on
success, or ar error message otherwise. *)
val write_sign_exn : Context.t -> Bigstring.t -> sk:Key.secret Key.t
-> msg:Bigstring.t -> int (** [write_sign_exn ctx buf ~sk ~msg]
writes signs [msg] with [sk] and writes the signature to [buf] at
[?pos]. It returns the number of bytes written (64).
@raise [Invalid_argument] if [buf] is not long enough to contain
a signature or signing has failed. *)
val write_sign_recoverable : Context.t -> sk:Key.secret Key.t ->
msg:Bigstring.t -> Bigstring.t -> (int, string) result
val write_sign_recoverable_exn : Context.t -> sk:Key.secret Key.t ->
msg:Bigstring.t -> Bigstring.t -> int
(** {4 Verification} *)
val verify_exn : Context.t -> pk:Key.public Key.t -> msg:Bigstring.t
-> signature:_ t -> bool
val verify : Context.t -> pk:Key.public Key.t -> msg:Bigstring.t ->
signature:_ t -> (bool, string) result
(** {4 Recovery} *)
val recover_exn : Context.t -> signature:recoverable t ->
Bigstring.t -> Key.public Key.t
val recover : Context.t -> signature:recoverable t -> Bigstring.t ->
(Key.public Key.t, string) result end