package octez-shell-libs

  1. Overview
  2. No Docs
Octez shell libraries

Install

dune-project
 Dependency

Authors

Maintainers

Sources

tezos-18.1.tar.gz
sha256=aa2f5bc99cc4ca2217c52a1af2a2cdfd3b383208cb859ca2e79ca0903396ca1d
sha512=d68bb3eb615e3dcccc845fddfc9901c95b3c6dc8e105e39522ce97637b1308a7fa7aa1d271351d5933febd7476b2819e1694f31198f1f0919681f1f9cc97cb3a

doc/octez-shell-libs.shell/Tezos_shell/Block_validator_process/index.html

Module Tezos_shell.Block_validator_processSource

Block_validator_process is used to validate new blocks. This validation can be

  • internal: the same processus is used to run the node and to validate blocks
  • external: another processus is used to validate blocks This module also ensures the liveness of the operations (see Block_validation:check_liveness).
Sourcetype validator_environment = {
  1. user_activated_upgrades : Tezos_base.User_activated.upgrades;
    (*

    user activated upgrades

    *)
  2. user_activated_protocol_overrides : Tezos_base.User_activated.protocol_overrides;
    (*

    user activated protocol overrides

    *)
  3. operation_metadata_size_limit : Tezos_shell_services.Shell_limits.operation_metadata_size_limit;
    (*

    size limit for operation metadata that should be written on disk

    *)
}
Sourcetype validator_kind =
  1. | Internal : Tezos_store.Store.Chain.chain_store -> validator_kind
  2. | External : {
    1. genesis : Tezos_base.Genesis.t;
    2. readonly : bool;
    3. data_dir : string;
    4. context_root : string;
    5. protocol_root : string;
    6. process_path : string;
    7. sandbox_parameters : Tezos_base.TzPervasives.Data_encoding.json option;
    8. dal_config : Tezos_crypto_dal.Cryptobox.Config.t;
    9. internal_events : Tezos_base.Internal_event_config.t;
    } -> validator_kind

For performances reasons, it may be interesting to use another processus (from the OS) to validate blocks (External). However, in that case, only one processus has a write access to the context. Currently informations are exchanged via the file system.

Sourcetype simple_kind =
  1. | External_process
  2. | Single_process
Sourcetype t

Internal representation of the block validator process

Sourceval kind : t -> simple_kind
Sourceval close : t -> unit Lwt.t

close vp closes the given vp. In the case of an External validator process, we first ask the validator to shutdown. If it is still running after 5 seconds, we notice that the block validation process is unresponsive and we force its termination (using a registered Lwt_exit.clean_up_callback).

Sourceval reconfigure_event_logging : t -> Tezos_base_unix.Internal_event_unix.Configuration.t -> unit Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval apply_block : ?simulate:bool -> ?should_precheck:bool -> t -> Tezos_store.Store.chain_store -> predecessor:Tezos_store.Store.Block.t -> Tezos_base.Block_header.t -> Tezos_validation.Block_validation.operation list list -> Tezos_validation.Block_validation.result Tezos_base.TzPervasives.tzresult Lwt.t

apply_block bvp predecessor header ops checks the liveness of the operations and then call Block_validation.apply

should_precheck when set, triggers the block prechecking before applying it, see Block_validation.apply.

If simulate is true, the context resulting from the application will not be committed to disk. Set to false by default.

Sourceval preapply_block : t -> Tezos_store.Store.chain_store -> predecessor:Tezos_store.Store.Block.t -> protocol_data:bytes -> timestamp:Tezos_base.Time.Protocol.t -> Tezos_validation.Block_validation.operation list list -> (Tezos_base.Block_header.shell_header * Tezos_base.TzPervasives.error Tezos_shell_services.Preapply_result.t list) Tezos_base.TzPervasives.tzresult Lwt.t

preapply_block bvp chain_store ~predecessor ~protocol_data ~timestamp ops is a wrapper for Block_validation.preapply.

Sourceval precheck_block : t -> Tezos_store.Store.chain_store -> predecessor:Tezos_store.Store.Block.t -> Tezos_base.Block_header.t -> Tezos_base.TzPervasives.Block_hash.t -> Tezos_validation.Block_validation.operation Tezos_base.TzPervasives.trace Tezos_base.TzPervasives.trace -> unit Tezos_base.TzPervasives.tzresult Lwt.t

precheck_block bvp chain_store ~predecessor header hash ops is a wrapper for Block_validation.precheck.

Sourceval context_garbage_collection : t -> Tezos_context_ops.Context_ops.index -> Tezos_base.TzPervasives.Context_hash.t -> gc_lockfile_path:string -> unit Tezos_base.TzPervasives.tzresult Lwt.t

context_garbage_collection bvp context_index context_hash removes contexts that are below context_hash in the context tree.

context_split bvp context_index splits the context storage layout into a new chunk.

Sourceval commit_genesis : t -> chain_id:Tezos_base.TzPervasives.Chain_id.t -> Tezos_base.TzPervasives.Context_hash.t Tezos_base.TzPervasives.tzresult Lwt.t
Sourceval init_test_chain : t -> Tezos_base.TzPervasives.Chain_id.t -> Tezos_store.Store.Block.t -> Tezos_base.Block_header.t Tezos_base.TzPervasives.tzresult Lwt.t

init_test_chain must only be called on a forking block.