package octez-protocol-019-PtParisB-libs
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
sha256=ddfb5076eeb0b32ac21c1eed44e8fc86a6743ef18ab23fff02d36e365bb73d61
    
    
  sha512=d22a827df5146e0aa274df48bc2150b098177ff7e5eab52c6109e867eb0a1f0ec63e6bfbb0e3645a6c2112de3877c91a17df32ccbff301891ce4ba630c997a65
    
    
  doc/octez-protocol-019-PtParisB-libs.plugin/Tezos_protocol_plugin_019_PtParisB/Mempool/index.html
Module Tezos_protocol_plugin_019_PtParisB.MempoolSource
Plugin for the shell mempool. It must include the signature FILTER.Mempool from lib_shell/shell_plugin.mli.
Settings for the pre_filter:
- minimal fees to accept an operation (absolute, relative to the gas limit, and relative to the byte size)
- clock drift for the prefiltering of consensus operations
and for the conflict_handler:
- replacement factor, that is, how much better a new manager operation needs to be, in terms of both absolute fees and fee/gas ratios, in order to replace an old conflicting manager operation.
Static information needed by pre_filter.
It depends on the head block upon which a mempool is built.
val init : 
  Tezos_protocol_019_PtParisB.Environment.Context.t ->
  head:Tezos_base.TzPervasives.Block_header.shell_header ->
  (info, Tezos_base.TzPervasives.tztrace) result Lwt.tCreate an info based on the head block and the current context.
val flush : 
  info ->
  head:Tezos_base.TzPervasives.Block_header.shell_header ->
  info Tezos_base.TzPervasives.tzresult Lwt.tval syntactic_check : 
  Tezos_protocol_019_PtParisB.Protocol.Alpha_context.packed_operation ->
  [ `Well_formed | `Ill_formed ] Lwt.tPerform some syntactic checks on the operation.
To be used mostly as an exceptional mechanism to prevent ill-formed operations to block block application.
Should be called before the pre_filter, does not need a context.
val pre_filter : 
  info ->
  config ->
  Tezos_protocol_019_PtParisB.Protocol.Alpha_context.packed_operation ->
  [ `Passed_prefilter of [ `High | `Medium | `Low of Q.t list ]
  | `Branch_delayed of Tezos_base.TzPervasives.tztrace
  | `Branch_refused of Tezos_base.TzPervasives.tztrace
  | `Refused of Tezos_base.TzPervasives.tztrace
  | `Outdated of Tezos_base.TzPervasives.tztrace ]
    Lwt.tPerform some preliminary checks on an operation.
For manager operations, check that its fee, fee/gas ratio, and fee/size ratio all meet the minimal requirements specified in the config.
For consensus operations, check that it is possible for the operation to have been produced before now (plus additional time equal to the clock_drift from config, as a safety margin). Indeed, without this check, a baker could flood the network with consensus operations for any future rounds or levels. The ml file contains more detailled explanations with diagrams.
val conflict_handler : 
  config ->
  Tezos_protocol_019_PtParisB.Protocol.Mempool.conflict_handlerReturn a conflict handler for Protocol.Mempool.add_operation (see Protocol.Mempool.conflict_handler).
For non-manager operations, select the greater operation according to Protocol.Alpha_context.Operation.compare.
A manager operation is replaced only when the new operation's fee and fee/gas ratio both exceed (or match) the old operation's metrics multiplied by the replace_by_fee factor specified in the config.
Precondition: both operations must be individually valid (to be able to call Protocol.Alpha_context.Operation.compare).
The purpose of this module is to provide the fee_needed_to_replace_by_fee function. For this function to be correct, the caller must maintain the state of type t by calling update on each successfully validated operation and its induced replacements.
val fee_needed_to_overtake : 
  op_to_overtake:
    Tezos_protocol_019_PtParisB.Protocol.Alpha_context.packed_operation ->
  candidate_op:
    Tezos_protocol_019_PtParisB.Protocol.Alpha_context.packed_operation ->
  int64 optionCompute the minimal fee (expressed in mutez) that candidate_op would need to have in order to be strictly greater than op_to_overtake according to Protocol.Alpha_context.Operation.compare, when both operations are manager operations.
Return None when at least one operation is not a manager operation.
Also return None if both operations are manager operations but there was an error while computing the needed fee. However, note that this cannot happen when both manager operations have been successfully validated by the protocol.
The following type, encoding, and default values are exported for bin_sc_rollup_node/configuration.ml.
An amount of fees in nanotez.
Minimal absolute fees in default_config.
Minimal fee over gas_limit ratio in default_config.
Minimal fee over byte size ratio in default_config.