package tezos-protocol-012-Psithaca

  1. Overview
  2. Docs
Legend:
Library
Module
Module type
Parameter
Class
Class type
val name : string
include module type of struct include Tezos_raw_protocol_012_Psithaca end
include module type of struct include Tezos_raw_protocol_012_Psithaca.Main end
type validation_mode = Tezos_raw_protocol_012_Psithaca.Main.validation_mode =
  1. | Application of {
    1. block_header : Tezos_raw_protocol_012_Psithaca.Alpha_context.Block_header.t;
    2. fitness : Tezos_raw_protocol_012_Psithaca.Alpha_context.Fitness.t;
    3. payload_producer : Tezos_raw_protocol_012_Psithaca.Alpha_context.public_key_hash;
    4. block_producer : Tezos_raw_protocol_012_Psithaca.Alpha_context.public_key_hash;
    5. predecessor_round : Tezos_raw_protocol_012_Psithaca.Alpha_context.Round.t;
    6. predecessor_level : Tezos_raw_protocol_012_Psithaca.Alpha_context.Level.t;
    }
  2. | Partial_application of {
    1. block_header : Tezos_raw_protocol_012_Psithaca.Alpha_context.Block_header.t;
    2. fitness : Tezos_raw_protocol_012_Psithaca.Alpha_context.Fitness.t;
    3. payload_producer : Tezos_raw_protocol_012_Psithaca.Alpha_context.public_key_hash;
    4. block_producer : Tezos_raw_protocol_012_Psithaca.Alpha_context.public_key_hash;
    5. predecessor_level : Tezos_raw_protocol_012_Psithaca.Alpha_context.Level.t;
    6. predecessor_round : Tezos_raw_protocol_012_Psithaca.Alpha_context.Round.t;
    }
  3. | Partial_construction of {
    1. predecessor : Tezos_protocol_environment_012_Psithaca.Block_hash.t;
    2. predecessor_fitness : Tezos_protocol_environment_012_Psithaca.Fitness.t;
    3. predecessor_level : Tezos_raw_protocol_012_Psithaca.Alpha_context.Level.t;
    4. predecessor_round : Tezos_raw_protocol_012_Psithaca.Alpha_context.Round.t;
    }
  4. | Full_construction of {
    1. predecessor : Tezos_protocol_environment_012_Psithaca.Block_hash.t;
    2. payload_producer : Tezos_raw_protocol_012_Psithaca.Alpha_context.public_key_hash;
    3. block_producer : Tezos_raw_protocol_012_Psithaca.Alpha_context.public_key_hash;
    4. protocol_data_contents : Tezos_raw_protocol_012_Psithaca.Alpha_context.Block_header.contents;
    5. level : Tezos_protocol_environment_012_Psithaca.Int32.t;
    6. round : Tezos_raw_protocol_012_Psithaca.Alpha_context.Round.t;
    7. predecessor_level : Tezos_raw_protocol_012_Psithaca.Alpha_context.Level.t;
    8. predecessor_round : Tezos_raw_protocol_012_Psithaca.Alpha_context.Round.t;
    }

check_manager_signature validation_state op raw_operation The function starts by retrieving the public key hash pkh of the manager operation. In case the operation is batched, the function also checks that the sources are all the same. Once the pkh is retrieved, the function looks for its associated public key. For that, the manager operation is inspected to check if it contains a public key revelation. If not, the public key is searched in the context.

  • returns

    Error Invalid_signature if the signature check fails

  • returns

    Error Unrevealed_manager_key if the manager has not yet been revealed

  • returns

    Error Failure "get_manager_key" if the key is not found in the context

  • returns

    Error Inconsistent_sources if the operations in a batch are not from the same manager

precheck_manager validation_state op returns () if the manager operation op is solveable, returns an error otherwise. An operation is solveable if it is well-formed and can pay the fees to be included in a block with either a success or a failure status. This function uses Apply.precheck_manager_contents_list but discard the context and balance update

include Tezos_protocol_environment_012_Psithaca.Updater.PROTOCOL with type block_header_data = Tezos_raw_protocol_012_Psithaca.Alpha_context.Block_header.protocol_data and type block_header_metadata = Tezos_raw_protocol_012_Psithaca.Apply_results.block_metadata and type block_header = Tezos_raw_protocol_012_Psithaca.Alpha_context.Block_header.t and type operation_data := operation_data and type operation_receipt = Tezos_raw_protocol_012_Psithaca.Apply_results.packed_operation_metadata and type operation := operation and type validation_state := validation_state
val max_block_length : int
val max_operation_data_length : int
val acceptable_passes : operation -> int list
val relative_position_within_block : operation -> operation -> int
OCaml

Innovation. Community. Security.