(**************************************************************************) (* *) (* Copyright (c) 2014 - 2018. *) (* Dynamic Ledger Solutions, Inc. *) (* *) (* All rights reserved. No warranty, explicit or implicit, provided. *) (* *) (**************************************************************************) type block = [ | `Genesis | `Head of int | `Test_head of int | `Hash of Block_hash.t * int ] val parse_block: string -> (block, string) result val to_string: block -> string type block_info = { hash: Block_hash.t ; chain_id: Chain_id.t ; level: Int32.t ; proto_level: int ; (* uint8 *) predecessor: Block_hash.t ; timestamp: Time.t ; validation_passes: int ; (* uint8 *) operations_hash: Operation_list_list_hash.t ; fitness: MBytes.t list ; context: Context_hash.t ; protocol_data: MBytes.t ; operations: (Operation_hash.t * Operation.t) list list option ; protocol: Protocol_hash.t ; test_chain: Test_chain_status.t ; } val pp_block_info: Format.formatter -> block_info -> unit type preapply_result = { shell_header: Block_header.shell_header ; operations: error Preapply_result.t list ; } open RPC_context val chain_id: #simple -> block -> Chain_id.t tzresult Lwt.t val level: #simple -> block -> Int32.t tzresult Lwt.t val predecessor: #simple -> block -> Block_hash.t tzresult Lwt.t val predecessors: #simple -> block -> int -> Block_hash.t list tzresult Lwt.t val hash: #simple -> block -> Block_hash.t tzresult Lwt.t val timestamp: #simple -> block -> Time.t tzresult Lwt.t val fitness: #simple -> block -> MBytes.t list tzresult Lwt.t val operations: #simple -> ?contents:bool -> block -> (Operation_hash.t * Operation.t option) list list tzresult Lwt.t val protocol: #simple -> block -> Protocol_hash.t tzresult Lwt.t val test_chain: #simple -> block -> Test_chain_status.t tzresult Lwt.t val info: #simple -> ?include_ops:bool -> block -> block_info tzresult Lwt.t val list: ?include_ops:bool -> ?length:int -> ?heads:Block_hash.t list -> ?delay:int -> ?min_date:Time.t -> ?min_heads:int -> #simple -> block_info list list tzresult Lwt.t val monitor: ?include_ops:bool -> ?length:int -> ?heads:Block_hash.t list -> ?delay:int -> ?min_date:Time.t -> ?min_heads:int -> #streamed -> (block_info list list Lwt_stream.t * stopper) tzresult Lwt.t val preapply: #simple -> block -> ?timestamp:Time.t -> ?sort:bool -> protocol_data:MBytes.t -> Operation.t list list -> preapply_result tzresult Lwt.t val complete: #simple -> block -> string -> string list tzresult Lwt.t (** Encodes a directory structure returned from a context query as a tree plus a special case [Cut] used when the query is limited by a [depth] value. [Cut] is encoded as [null] in json. *) type raw_context_result = | Key of MBytes.t | Dir of (string * raw_context_result) list | Cut (** Pretty-printer for raw_context_result *) val raw_context_result_pp : raw_context_result -> string val raw_context: #simple -> block -> string list -> int -> raw_context_result tzresult Lwt.t val unmark_invalid: #simple -> Block_hash.t -> unit Error_monad.tzresult Lwt.t val list_invalid: #simple -> (Block_hash.t * int32 * error list) list tzresult Lwt.t (** Signatures of all RPCs. This module is shared between the Client and the Node. *) module S : sig val blocks_arg : block RPC_arg.arg val info: ([ `POST ], unit, unit * block, unit, bool, block_info) RPC_service.t val chain_id: ([ `POST ], unit, unit * block, unit, unit, Chain_id.t) RPC_service.t val level: ([ `POST ], unit, unit * block, unit, unit, Int32.t) RPC_service.t val predecessor: ([ `POST ], unit, unit * block, unit, unit, Block_hash.t) RPC_service.t val predecessors: ([ `POST ], unit, unit * block , unit, int, Block_hash.t list) RPC_service.t val hash: ([ `POST ], unit, unit * block, unit, unit, Block_hash.t) RPC_service.t val timestamp: ([ `POST ], unit, unit * block, unit, unit, Time.t) RPC_service.t val fitness: ([ `POST ], unit, unit * block, unit, unit, MBytes.t list) RPC_service.t val context: ([ `POST ], unit, unit * block, unit, unit, Context_hash.t) RPC_service.t (** Accepts queries of the form /blocks//raw_context/?depth= returning the sub-tree corresponding to inside the context of block . The optional parameter controls the size of the tree, default is 1. Example: tezos-client rpc call /blocks/head/raw_context/v1?depth=2 *) val raw_context: ([ `POST ], unit, (unit * block) * string list, , unit, raw_context_result) RPC_service.t type operations_param = { contents: bool ; } val operations: ([ `POST ], unit, unit * block, unit, operations_param, (Operation_hash.t * Operation.t option) list list) RPC_service.t val protocol: ([ `POST ], unit, unit * block, unit, unit, Protocol_hash.t) RPC_service.t val test_chain: ([ `POST ], unit, unit * block, unit, unit, Test_chain_status.t) RPC_service.t type list_param = { include_ops: bool ; length: int option ; heads: Block_hash.t list option ; monitor: bool option ; delay: int option ; min_date: Time.t option; min_heads: int option; } val list: ([ `POST ], unit, unit, unit, list_param, block_info list list) RPC_service.t val list_invalid: ([ `POST ], unit, unit, unit, unit, (Block_hash.t * int32 * error list) list) RPC_service.t val unmark_invalid: ([ `POST ], unit, unit * Block_hash.t, unit, unit, unit) RPC_service.t type preapply_param = { timestamp: Time.t ; protocol_data: MBytes.t ; operations: Operation.t list list ; sort_operations: bool ; } val preapply: ([ `POST ], unit, unit * block, unit, preapply_param, preapply_result) RPC_service.t val complete: ([ `POST ], unit, (unit * block) * string, unit, unit, string list) RPC_service.t val proto_path: unit -> ('a, 'a * block) RPC_path.path end