123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437(*****************************************************************************)(* *)(* Open Source License *)(* Copyright (c) 2022 Nomadic Labs. <contact@nomadic-labs.com> *)(* Copyright (c) 2018 Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)(* Copyright (c) 2020 Metastate AG <hello@metastate.dev> *)(* *)(* Permission is hereby granted, free of charge, to any person obtaining a *)(* copy of this software and associated documentation files (the "Software"),*)(* to deal in the Software without restriction, including without limitation *)(* the rights to use, copy, modify, merge, publish, distribute, sublicense, *)(* and/or sell copies of the Software, and to permit persons to whom the *)(* Software is furnished to do so, subject to the following conditions: *)(* *)(* The above copyright notice and this permission notice shall be included *)(* in all copies or substantial portions of the Software. *)(* *)(* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR*)(* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *)(* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL *)(* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER*)(* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING *)(* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER *)(* DEALINGS IN THE SOFTWARE. *)(* *)(*****************************************************************************)moduleShell_error_monad=Error_monadtypeshell_error=error=..openEnvironment_contextopenEnvironment_protocol_TmoduletypeT=sigincludeTezos_protocol_environment_sigs.V7.TwithtypeFormat.formatter=Format.formatterandtype'aSeq.node='aSeq.nodeandtype'aSeq.t=unit-> 'aSeq.nodeandtype'aData_encoding.t='aData_encoding.tandtype'aData_encoding.Compact.t='aData_encoding.Compact.tandtype'aData_encoding.lazy_t='aData_encoding.lazy_tandtype'aLwt.t='aLwt.tandtype('a,'b)Pervasives.result=('a,'b)resultandtypeChain_id.t=Tezos_crypto.Hashed.Chain_id.tandtypeBlock_hash.t=Tezos_crypto.Hashed.Block_hash.tandtypeOperation_hash.t=Tezos_crypto.Hashed.Operation_hash.tandtypeOperation_list_hash.t=Tezos_crypto.Hashed.Operation_list_hash.tandtypeOperation_list_list_hash.t=Tezos_crypto.Hashed.Operation_list_list_hash.tandtypeContext.t=Context.tandtypeContext.cache_key=Environment_context.Context.cache_keyandtypeContext.cache_value=Environment_context.Context.cache_valueandtypeContext_hash.t=Tezos_crypto.Hashed.Context_hash.tandtypeContext_hash.Version.t=Tezos_crypto.Hashed.Context_hash.Version.tandtypeContext.config=Tezos_context_sigs.Config.tandmoduleContext.Proof=Environment_context.Context.ProofandtypeProtocol_hash.t=Tezos_crypto.Hashed.Protocol_hash.tandtypeTime.t=Time.Protocol.tandtypeOperation.shell_header=Operation.shell_headerandtypeOperation.t=Operation.tandtypeBlock_header.shell_header=Block_header.shell_headerandtypeBlock_header.t=Block_header.tandtype'aRPC_directory.t='aTezos_rpc.Directory.tandtypeEd25519.Public_key_hash.t=Signature.Ed25519.Public_key_hash.tandtypeEd25519.Public_key.t=Signature.Ed25519.Public_key.tandtypeEd25519.t=Signature.Ed25519.tandtypeSecp256k1.Public_key_hash.t=Signature.Secp256k1.Public_key_hash.tandtypeSecp256k1.Public_key.t=Signature.Secp256k1.Public_key.tandtypeSecp256k1.t=Signature.Secp256k1.tandtypeP256.Public_key_hash.t=Signature.P256.Public_key_hash.tandtypeP256.Public_key.t=Signature.P256.Public_key.tandtypeP256.t=Signature.P256.tandtypeBls.Public_key_hash.t=Signature.Bls.Public_key_hash.tandtypeBls.Public_key.t=Signature.Bls.Public_key.tandtypeBls.t=Signature.Bls.tandtypeSignature.public_key_hash=Signature.V0.public_key_hashandtypeSignature.public_key=Signature.V0.public_keyandtypeSignature.t=Signature.V0.tandtypeSignature.watermark=Signature.V0.watermarkandtypeMicheline.canonical_location=Micheline.canonical_locationandtype'aMicheline.canonical='aMicheline.canonicalandtypeZ.t=Z.tandtypeQ.t=Q.tandtype('a,'b)Micheline.node=('a,'b)Micheline.nodeandtypeData_encoding.json_schema=Data_encoding.json_schemaandtype('a,'b)RPC_path.t=('a,'b)Tezos_rpc.Path.tandtypeRPC_service.meth=Tezos_rpc.Service.methandtype(+'m,'pr,'p,'q,'i,'o)RPC_service.t=('m,'pr,'p,'q,'i,'o)Tezos_rpc.Service.tandtypeError_monad.shell_tztrace=Error_monad.tztraceandtype'aError_monad.shell_tzresult=('a,Error_monad.tztrace)resultandtypeTimelock.chest=Tezos_crypto.Timelock_legacy.chestandtypeTimelock.chest_key=Tezos_crypto.Timelock_legacy.chest_keyandtypeTimelock.opening_result=Tezos_crypto.Timelock_legacy.opening_resultandmoduleSapling=Tezos_sapling.Core.Validatorandtype('a,'b)Either.t=('a,'b)Stdlib.Either.tandtypeBls.Primitive.Fr.t=Bls12_381.Fr.tandtypePlonk.proof=Tezos_protocol_environment_structs.V7.Plonk.proofandtypePlonk.public_parameters=Tezos_protocol_environment_structs.V7.Plonk.verifier_public_parameters*Tezos_protocol_environment_structs.V7.Plonk.transcriptandtypeDal.parameters=Tezos_crypto_dal.Cryptobox.Verifier.parametersandtypeDal.commitment=Tezos_crypto_dal.Cryptobox.Verifier.commitmentandtypeBounded.Non_negative_int32.t=Tezos_base.Bounded.Non_negative_int32.tandtypeWasm_2_0_0.input=Tezos_scoru_wasm.Wasm_pvm_state.input_infoandtypeWasm_2_0_0.output=Tezos_scoru_wasm.Wasm_pvm_state.output_infotypeerror+=Ecoproto_errorofError_monad.errorvalwrap_tzerror:Error_monad.error->errorvalwrap_tztrace:Error_monad.errorError_monad.trace->errortracevalwrap_tzresult:'aError_monad.tzresult->'atzresultmoduleLift(P:Updater.PROTOCOL):PROTOCOLwithtypeblock_header_data=P.block_header_dataandtypeblock_header_metadata=P.block_header_metadataandtypeblock_header=P.block_headerandtypeoperation_data=P.operation_dataandtypeoperation_receipt=P.operation_receiptandtypeoperation=P.operationandtypevalidation_state=P.validation_stateandtypeapplication_state=P.application_stateclass['chain,'block]proto_rpc_context:Tezos_rpc.Context.t->(unit,(unit*'chain)*'block)RPC_path.t->['chain*'block]RPC_context.simpleclass['block]proto_rpc_context_of_directory:('block->RPC_context.t)->RPC_context.tRPC_directory.t->['block]RPC_context.simpleendmoduleMake(Param:sigvalname:stringend)()=struct(* The protocol V7 only supports 64-bits architectures. We ensure this the
hard way with a dynamic check. *)let()=matchSys.word_sizewith|32->Printf.eprintf"FAILURE: Environment V7 does not support 32-bit architectures\n%!";Stdlib.exit1|64->()|n->Printf.eprintf"FAILURE: Unknown, unsupported architecture (%d bits)\n%!"n;Stdlib.exit1moduleCamlinternalFormatBasics=CamlinternalFormatBasicsincludeStdlibmodulePervasives=StdlibmoduleLogging=structtypelevel=Internal_event.level=|Debug|Info|Notice|Warning|Error|Fatalletlogging_function=refNoneletname_colon_space=Param.name^": "letnull_formatter=Format.make_formatter(fun___->())(fun()->())letlog(level:Internal_event.level)=match!logging_functionwith|None->Format.ikfprintfignorenull_formatter|Somef->Format.kasprintf(funs->flevel(name_colon_space^s))letlog_string(level:Internal_event.level)s=match!logging_functionwith|None->()|Somef->flevel(name_colon_space^s)endmoduleCompare=ComparemoduleEither=EithermoduleSeq=Tezos_protocol_environment_structs.V7.SeqmoduleList=Tezos_error_monad.TzLwtreslib.ListmoduleArray=Tezos_protocol_environment_structs.V7.ArraymoduleChar=CharmoduleBytes=BytesmoduleHex=Tezos_stdlib.HexmoduleString=StringmoduleBits=BitsmoduleTzEndian=TzEndianmoduleSet=Tezos_error_monad.TzLwtreslib.SetmoduleMap=Tezos_error_monad.TzLwtreslib.MapmoduleInt32=Int32moduleInt64=Int64moduleFormat=FormatmoduleFallbackArray=FallbackArrayletnot_a_sys_excnext_classifier=function|Unix.Unix_error_|UnixLabels.Unix_error_|Sys_error_->false|e->next_classifieremoduleOption=structincludeTezos_error_monad.TzLwtreslib.Option(* This as well as the catchers in [Result] and [Error_monad] are different
from the ones in Lwtreslib/Error Monad in that they also hide the Unix
and System errors. This is because, from the point-of-view of the
protocol, these exceptions are too abstract and too indeterministic. *)letcatch?(catch_only=fun_->true)f=(* Note that [catch] also special-cases its own set of exceptions. *)catch~catch_only:(not_a_sys_exccatch_only)fletcatch_s?(catch_only=fun_->true)f=catch_s~catch_only:(not_a_sys_exccatch_only)fendmoduleResult=structincludeTezos_error_monad.TzLwtreslib.Resultletcatch?(catch_only=fun_->true)f=catch~catch_only:(not_a_sys_exccatch_only)fletcatch_f?(catch_only=fun_->true)f=catch_f~catch_only:(not_a_sys_exccatch_only)fletcatch_s?(catch_only=fun_->true)f=catch_s~catch_only:(not_a_sys_exccatch_only)fendmoduleRaw_hashes=structletsha256=Tezos_crypto.Hacl.Hash.SHA256.digestletsha512=Tezos_crypto.Hacl.Hash.SHA512.digestletblake2bmsg=Tezos_crypto.Blake2B.to_bytes(Tezos_crypto.Blake2B.hash_bytes[msg])letkeccak256msg=Tezos_crypto.Hacl.Hash.Keccak_256.digestmsgletsha3_256msg=Tezos_crypto.Hacl.Hash.SHA3_256.digestmsgletsha3_512msg=Tezos_crypto.Hacl.Hash.SHA3_512.digestmsgendmoduleZ=ZmoduleQ=QmoduleLwt=LwtmoduleData_encoding=structincludeTezos_protocol_environment_structs.V7.Data_encodingtypetag_size=[`Uint8|`Uint16]letdefname?title?descriptionencoding=def(Param.name^"."^name)?title?descriptionencodingendmoduleTime=Time.ProtocolmoduleEd25519=Signature.Ed25519moduleSecp256k1=Signature.Secp256k1moduleP256=Signature.P256moduleBls=Signature.BlsmoduleSignature=Signature.V0moduleTimelock=Tezos_crypto.Timelock_legacymoduleVdf=Class_group_vdf.Vdf_self_containedmoduleS=structmoduletypeT=Tezos_base.S.TmoduletypeHASHABLE=Tezos_base.S.HASHABLEmoduletypeMINIMAL_HASH=Tezos_crypto.Intfs.MINIMAL_HASHmoduletypeB58_DATA=sigtypetvalto_b58check:t->stringvalto_short_b58check:t->stringvalof_b58check_exn:string->tvalof_b58check_opt:string->toptiontypeTezos_crypto.Base58.data+=Dataoftvalb58check_encoding:tTezos_crypto.Base58.encodingendmoduletypeRAW_DATA=sigtypetvalsize:int(* in bytes *)valto_bytes:t->Bytes.tvalof_bytes_opt:Bytes.t->toptionvalof_bytes_exn:Bytes.t->tendmoduletypeENCODER=sigtypetvalencoding:tData_encoding.tvalrpc_arg:tTezos_rpc.Arg.tendmoduletypeINDEXES_SET=sigincludeSet.Svalrandom_elt:t->eltvalencoding:tData_encoding.tendmoduletypeINDEXES_MAP=sigincludeMap.Svalencoding:'aData_encoding.t->'atData_encoding.tendmoduletypeINDEXES=sigtypetmoduleSet:INDEXES_SETwithtypeelt=tmoduleMap:INDEXES_MAPwithtypekey=tendmoduletypeHASH=sigincludeMINIMAL_HASHincludeRAW_DATAwithtypet:=tincludeB58_DATAwithtypet:=tincludeENCODERwithtypet:=tincludeINDEXESwithtypet:=tendmoduletypeMERKLE_TREE=sigtypeeltincludeHASHvalcompute:eltlist->tvalempty:ttypepath=Leftofpath*t|Rightoft*path|Opvalcompute_path:eltlist->int->pathvalcheck_path:path->elt->t*intvalpath_encoding:pathData_encoding.tendmoduletypeSIGNATURE_PUBLIC_KEY_HASH=sigtypetvalpp:Format.formatter->t->unitvalpp_short:Format.formatter->t->unitincludeCompare.Swithtypet:=tincludeRAW_DATAwithtypet:=tincludeB58_DATAwithtypet:=tincludeENCODERwithtypet:=tincludeINDEXESwithtypet:=tvalzero:tendmoduletypeSIGNATURE_PUBLIC_KEY=sigtypetvalpp:Format.formatter->t->unitincludeCompare.Swithtypet:=tincludeB58_DATAwithtypet:=tincludeENCODERwithtypet:=ttypepublic_key_hash_tvalhash:t->public_key_hash_tvalsize:t->int(* in bytes *)valof_bytes_without_validation:bytes->toptionendmoduletypeSIGNATURE=sigmodulePublic_key_hash:SIGNATURE_PUBLIC_KEY_HASHmodulePublic_key:SIGNATURE_PUBLIC_KEYwithtypepublic_key_hash_t:=Public_key_hash.ttypetvalpp:Format.formatter->t->unitincludeRAW_DATAwithtypet:=tincludeCompare.Swithtypet:=tincludeB58_DATAwithtypet:=tincludeENCODERwithtypet:=tvalzero:ttypewatermark(** Check a signature *)valcheck:?watermark:watermark->Public_key.t->t->Bytes.t->boolendmoduletypeAGGREGATE_SIGNATURE=sigincludeSIGNATUREvalaggregate_check:(Public_key.t*watermarkoption*bytes)list->t->boolvalaggregate_signature_opt:tlist->toptionendmoduletypeFIELD=sigtypet(** The order of the finite field *)valorder:Z.t(** Minimal number of bytes required to encode a value of the field. *)valsize_in_bytes:int(** [check_bytes bs] returns [true] if [bs] is a correct byte
representation of a field element *)valcheck_bytes:Bytes.t->bool(** The neutral element for the addition *)valzero:t(** The neutral element for the multiplication *)valone:t(** [add a b] returns [a + b mod order] *)valadd:t->t->t(** [mul a b] returns [a * b mod order] *)valmul:t->t->t(** [eq a b] returns [true] if [a = b mod order], else [false] *)valeq:t->t->bool(** [negate x] returns [-x mod order]. Equivalently, [negate x] returns the
unique [y] such that [x + y mod order = 0]
*)valnegate:t->t(** [inverse_opt x] returns [x^-1] if [x] is not [0] as an option, else [None] *)valinverse_opt:t->toption(** [pow x n] returns [x^n] *)valpow:t->Z.t->t(** From a predefined bytes representation, construct a value t. It is not
required that to_bytes [(Option.get (of_bytes_opt t)) = t]. By default, little endian encoding
is used and the given element is modulo the prime order *)valof_bytes_opt:Bytes.t->toption(** Convert the value t to a bytes representation which can be used for
hashing for instance. It is not required that [Option.get (to_bytes
(of_bytes_opt t)) = t]. By default, little endian encoding is used, and
length of the resulting bytes may vary depending on the order.
*)valto_bytes:t->Bytes.tend(** Module type for the prime fields GF(p) *)moduletypePRIME_FIELD=sigincludeFIELD(** Actual number of bytes allocated for a value of type t *)valsize_in_memory:int(** [of_z x] builds an element t from the Zarith element [x]. [mod order] is
applied if [x >= order] or [x < 0]. *)valof_z:Z.t->t(** [to_z x] builds a Zarith element, using the decimal representation.
Arithmetic on the result can be done using the modular functions on
integers *)valto_z:t->Z.tendmoduletypeCURVE=sig(** The type of the element in the elliptic curve *)typet(** Actual number of bytes allocated for a value of type t *)valsize_in_memory:int(** The size of a point representation, in bytes *)valsize_in_bytes:intmoduleScalar:FIELD(** Check if a point, represented as a byte array, is on the curve **)valcheck_bytes:Bytes.t->bool(** Attempt to construct a point from a byte array *)valof_bytes_opt:Bytes.t->toption(** Return a representation in bytes *)valto_bytes:t->Bytes.t(** Zero of the elliptic curve *)valzero:t(** A fixed generator of the elliptic curve *)valone:t(** Return the addition of two element *)valadd:t->t->t(** Double the element *)valdouble:t->t(** Return the opposite of the element *)valnegate:t->t(** Return [true] if the two elements are algebraically the same *)valeq:t->t->bool(** Multiply an element by a scalar *)valmul:t->Scalar.t->tendendmoduleError_core=structincludeTezos_error_monad.Core_maker.Make(structletid=Format.asprintf"proto.%s."Param.nameend)(structtypet=[`Branch(** Errors that may not happen in another context *)|`Temporary(** Errors that may not happen in a later context *)|`Permanent(** Errors that will happen no matter the context *)|`Outdated(** Errors that happen when the context is too old *)]letdefault_category=`Temporaryletstring_of_category=function|`Permanent->"permanent"|`Outdated->"outdated"|`Branch->"branch"|`Temporary->"temporary"letclassify=function|`Permanent->Tezos_error_monad.Error_classification.Permanent|`Branch->Branch|`Temporary->Temporary|`Outdated->Outdatedend)endtypeerror_category=Error_core.error_categorytypeshell_error+=Ecoproto_errorofError_core.errormoduleWrapped_error_monad=structtypeunwrapped=Error_core.error=..include(Error_core:sigincludeTezos_error_monad.Sig.COREwithtypeerror:=unwrappedandtypeerror_category=error_categoryend)letunwrap=functionEcoproto_errorecoerror->Someecoerror|_->Noneletwrapecoerror=Ecoproto_errorecoerrorendmoduleError_monad=structtypeshell_tztrace=Error_monad.tztracetype'ashell_tzresult=('a,Error_monad.tztrace)resultincludeError_coreincludeTezos_error_monad.TzLwtreslib.MonadmoduleTzresult_syntax=Traced_result_syntaxmoduleLwt_tzresult_syntax=Lwt_traced_result_syntaxincludeTezos_error_monad.Monad_maker.Make(Error_core)(TzTrace)(Tezos_error_monad.TzLwtreslib.Monad)(* Backwards compatibility additions (dont_wait, trace helpers) *)includeTezos_protocol_environment_structs.V7.Error_monad_infix_globalsletfaile=Lwt.return_error(TzTrace.makee)leterrore=Error(TzTrace.makee)letdont_waitexerf=dont_waitferexlettrace_of_errore=TzTrace.makeeletmake_trace_encodinge=TzTrace.encodingeletpp_trace=pp_print_tracetype'errtrace='errTzTrace.trace(* Shadowing catch to prevent catching system exceptions *)typeerror+=Exnofexnlet()=register_error_kind`Temporary~id:"failure"~title:"Exception"~description:"Exception safely wrapped in an error"~pp:(funppfs->Format.fprintfppf"@[<h 0>%a@]"Format.pp_print_texts)Data_encoding.(obj1(req"msg"string))(function|Exn(Failuremsg)->Somemsg|Exnexn->Some(Printexc.to_stringexn)|_->None)(funmsg->Exn(Failuremsg))leterror_of_exne=TzTrace.make@@Exneletcatch?catch_onlyf=Result.catch?catch_onlyf|>Result.map_errorerror_of_exnletcatch_f?catch_onlyfh=Result.catch?catch_onlyf|>Result.map_error(fune->trace_of_error(he))letcatch_s?catch_onlyf=letopenLwt_syntaxinlet+r=Result.catch_s?catch_onlyfinResult.map_error(fune->error_of_exne)rletboth_e=Tezos_error_monad.TzLwtreslib.Monad.Traced_result_syntax.bothletjoin_e=Tezos_error_monad.TzLwtreslib.Monad.Traced_result_syntax.joinletall_e=Tezos_error_monad.TzLwtreslib.Monad.Traced_result_syntax.allendlet()=letid=Format.asprintf"proto.%s.wrapper"Param.nameinShell_error_monad.register_wrapped_error_kind(moduleWrapped_error_monad)~id~title:("Error returned by protocol "^Param.name)~description:("Wrapped error for economic protocol "^Param.name^".")letwrap_tzerrorerror=Ecoproto_errorerrorletwrap_tztracet=List.mapwrap_tzerrortletwrap_tzresultr=Result.map_errorwrap_tztracermoduleChain_id=Tezos_crypto.Hashed.Chain_idmoduleBlock_hash=Tezos_crypto.Hashed.Block_hashmoduleOperation_hash=Tezos_crypto.Hashed.Operation_hashmoduleOperation_list_hash=Tezos_crypto.Hashed.Operation_list_hashmoduleOperation_list_list_hash=Tezos_crypto.Hashed.Operation_list_list_hashmoduleContext_hash=Tezos_crypto.Hashed.Context_hashmoduleProtocol_hash=Tezos_crypto.Hashed.Protocol_hashmoduleBlake2B=Tezos_crypto.Blake2BmoduleFitness=FitnessmoduleOperation=OperationmoduleBlock_header=Block_headermoduleBounded=BoundedmoduleProtocol=ProtocolmoduleRPC_arg=Tezos_rpc.ArgmoduleRPC_path=Tezos_rpc.PathmoduleRPC_query=Tezos_rpc.QuerymoduleRPC_service=Tezos_rpc.ServicemoduleRPC_answer=structtype'ot=[`Okof'o(* 200 *)|`OkChunkof'o(* 200 but with chunked transfer encoding *)|`OkStreamof'ostream(* 200 *)|`Createdofstringoption(* 201 *)|`No_content(* 204 *)|`UnauthorizedofError_monad.errorlistoption(* 401 *)|`ForbiddenofError_monad.errorlistoption(* 403 *)|`Not_foundofError_monad.errorlistoption(* 404 *)|`ConflictofError_monad.errorlistoption(* 409 *)|`ErrorofError_monad.errorlistoption(* 500 *)]and'astream='aResto_directory.Answer.stream={next:unit->'aoptionLwt.t;shutdown:unit->unit;}letreturnx=Lwt.return(`Okx)letreturn_chunkedx=Lwt.return(`OkChunkx)letreturn_streamx=Lwt.return(`OkStreamx)letnot_found=Lwt.return(`Not_foundNone)letfailerr=Lwt.return(`Error(Someerr))endmoduleRPC_directory=structincludeTezos_rpc.Directoryletgen_registerdirservicehandler=letopenLwt_syntaxingen_registerdirservice(funpqi->let*r=handlerpqiinmatchrwith|`Oko->RPC_answer.returno|`OkChunko->RPC_answer.return_chunkedo|`OkStreams->RPC_answer.return_streams|`Createds->Lwt.return(`Createds)|`No_content->Lwt.return`No_content|`Unauthorizede->lete=Option.map(List.map(fune->Ecoproto_errore))einLwt.return(`Unauthorized e)|`Forbiddene->lete=Option.map(List.map(fune->Ecoproto_errore))einLwt.return(`Forbiddene)|`Not_founde->let e=Option.map(List.map(fune->Ecoproto_errore))einLwt.return(`Not_founde)|`Conflicte->lete=Option.map(List.map(fune->Ecoproto_errore))einLwt.return(`Conflicte)|`Errore->lete=Option.map(List.map(fune->Ecoproto_errore))einLwt.return(`Errore))letregister~chunkeddirservicehandler=letopenLwt_syntaxingen_registerdirservice(funpqi->let*r=handlerpqiinmatchrwith|Okowhenchunked->RPC_answer.return_chunkedo|Oko(* otherwise *)->RPC_answer.returno|Errore->RPC_answer.faile)letopt_register~chunkeddirservicehandler=letopenLwt_syntaxingen_registerdirservice(funpqi->let*r=handlerpqiinmatchrwith|Ok(Someo)whenchunked->RPC_answer.return_chunkedo|Ok(Someo)(* otherwise *)->RPC_answer.returno|OkNone->RPC_answer.not_found|Errore->RPC_answer.faile)letlwt_register~chunkeddirservicehandler=letopenLwt_syntaxingen_registerdirservice(funpqi->let*o=handlerpqiinifchunkedthenRPC_answer.return_chunkedoelseRPC_answer.returno)openCurryletregister0~chunkedrootsf=register~chunkedroots(curryZf)letregister1~chunkedrootsf=register~chunkedroots(curry(SZ)f)letregister2~chunkedrootsf=register~chunkedroots(curry(S(SZ))f)letregister3~chunkedrootsf=register~chunkedroots(curry(S(S(SZ)))f)letregister4~chunkedrootsf=register~chunkedroots(curry(S(S(S(SZ))))f)letregister5~chunkedrootsf=register~chunkedroots(curry(S(S(S(S(SZ)))))f)letopt_register0~chunkedrootsf=opt_register~chunkedroots(curryZf)letopt_register1~chunkedrootsf=opt_register~chunkedroots(curry(SZ)f)letopt_register2~chunkedrootsf=opt_register~chunkedroots(curry(S(SZ))f)letopt_register3~chunkedrootsf=opt_register~chunkedroots(curry(S(S(SZ)))f)letopt_register4~chunkedrootsf=opt_register~chunkedroots(curry(S(S(S(SZ))))f)letopt_register5~chunkedrootsf=opt_register~chunkedroots(curry(S(S(S(S(SZ)))))f)letgen_register0rootsf=gen_registerroots(curryZf)letgen_register1rootsf=gen_registerroots(curry(SZ)f)letgen_register2rootsf=gen_registerroots(curry(S(SZ))f)letgen_register3rootsf=gen_registerroots(curry(S(S(SZ)))f)letgen_register4rootsf=gen_registerroots(curry(S(S(S(SZ))))f)letgen_register5rootsf=gen_registerroots(curry(S(S(S(S(SZ)))))f)letlwt_register0~chunkedrootsf=lwt_register~chunkedroots(curryZf)letlwt_register1~chunkedrootsf=lwt_register~chunkedroots(curry(SZ)f)letlwt_register2~chunkedrootsf=lwt_register~chunkedroots(curry(S(SZ))f)letlwt_register3~chunkedrootsf=lwt_register~chunkedroots(curry(S(S(SZ)))f)letlwt_register4~chunkedrootsf=lwt_register~chunkedroots(curry(S(S(S(SZ))))f)letlwt_register5~chunkedrootsf=lwt_register~chunkedroots(curry(S(S(S(S(SZ)))))f)endmoduleRPC_context=structtypet=rpc_contextclasstype['pr]simple=objectmethodcall_proto_service0:'m'q'i'o.(([<RPC_service.meth]as'm),t,t,'q,'i,'o)RPC_service.t->'pr->'q->'i->'oError_monad.shell_tzresultLwt.tmethodcall_proto_service1:'m'a'q'i'o.(([<RPC_service.meth]as'm),t,t*'a,'q,'i,'o)RPC_service.t->'pr->'a->'q->'i->'oError_monad.shell_tzresultLwt.tmethodcall_proto_service2:'m'a'b'q'i'o.(([<RPC_service.meth]as'm),t,(t*'a)*'b,'q,'i,'o)RPC_service.t->'pr->'a->'b->'q->'i->'oError_monad.shell_tzresultLwt.tmethodcall_proto_service3:'m'a'b'c'q'i'o.(([<RPC_service.meth]as'm),t,((t*'a)*'b)*'c,'q,'i,'o)RPC_service.t->'pr->'a->'b->'c->'q->'i->'oError_monad.shell_tzresultLwt.tendletmake_call0s(ctxt:_simple)=ctxt#call_proto_service0sletmake_call0=(make_call0:_->_simple->_:>_->_#simple->_)letmake_call1s(ctxt:_simple)=ctxt#call_proto_service1sletmake_call1=(make_call1:_->_simple->_:>_->_#simple->_)letmake_call2s(ctxt:_simple)=ctxt#call_proto_service2sletmake_call2=(make_call2:_->_simple->_:>_->_#simple->_)letmake_call3s(ctxt:_simple)=ctxt#call_proto_service3sletmake_call3=(make_call3:_->_simple->_:>_->_#simple->_)letmake_opt_call0sctxtblockqi=letopenLwt_syntaxinlet*r=make_call0sctxtblockqiinmatchrwith|Error[Tezos_rpc.Context.Not_found_]->Lwt.return_okNone|Error_asv->Lwt.returnv|Okv->Lwt.return_ok(Somev)letmake_opt_call1sctxtblocka1qi=letopenLwt_syntaxinlet*r=make_call1sctxtblocka1qiinmatchrwith|Error[Tezos_rpc.Context.Not_found_]->Lwt.return_okNone|Error_asv->Lwt.returnv|Okv->Lwt.return_ok(Somev)letmake_opt_call2sctxtblocka1a2qi=letopenLwt_syntaxinlet*r=make_call2sctxtblocka1a2qiinmatchrwith|Error[Tezos_rpc.Context.Not_found_]->Lwt.return_okNone|Error_asv->Lwt.returnv|Okv->Lwt.return_ok(Somev)letmake_opt_call3sctxtblocka1a2a3qi=letopenLwt_syntaxinlet*r=make_call3sctxtblocka1a2a3qiinmatchrwith|Error[Tezos_rpc.Context.Not_found_]->Lwt.return_okNone|Error_asv->Lwt.returnv|Okv->Lwt.return_ok(Somev)endmoduleSapling=Tezos_sapling.Core.ValidatormoduleMicheline=structincludeMichelineincludeMicheline_encoding(* The environment exposes a single canonical encoding for Micheline
expression. Since env-V4, it is encoding-v2 because this is the most
recent, most correct-at-time-of-writing encoding. For backwards
compatibility reason, you should never upgrade (nor downgrade) this.
Future fixes and improvements of the encoding should be made available in
future environments only. *)letcanonical_encoding~variantencoding=canonical_encoding_v2~variant:(Param.name^"."^variant)encodingendmoduleUpdater=structtypenonrecvalidation_result=validation_result={context:Context.t;fitness:Fitness.t;message:stringoption;max_operations_ttl:int;last_allowed_fork_level:Int32.t;}typenonrecquota=quota={max_size:int;max_op:intoption}typenonrecrpc_context=rpc_context={block_hash:Block_hash.t;block_header:Block_header.shell_header;context:Context.t;}letactivate=Context.set_protocolmoduletypePROTOCOL=Environment_protocol_T_V7.Twithtypecontext:=Context.tandtypecache_value:=Environment_context.Context.cache_valueandtypecache_key:=Environment_context.Context.cache_keyandtypequota:=quotaandtypevalidation_result:=validation_resultandtyperpc_context:=rpc_contextandtypetztrace:=Error_monad.tztraceandtype'atzresult:='aError_monad.tzresultendmoduleBase58=structincludeTezos_crypto.Base58letsimple_encodeencs=simple_encodeencsletsimple_decodeencs=simple_decodeencsincludeMake(structtypecontext=Context.tend)letdecodes=decodesendmoduleContext=structincludeContextincludeEnvironment_context.V7moduletypePROOF_ENCODING=Tezos_context_sigs.Context.PROOF_ENCODINGmoduleProof_encoding=Tezos_context_merkle_proof_encoding.Merkle_proof_encodingletcompletectxts=Base58.completectxtsendmoduleWasm_2_0_0=structtypeinput=Tezos_scoru_wasm.Wasm_pvm_state.input_info={inbox_level:Bounded.Non_negative_int32.t;message_counter :Z.t;}typeoutput=Tezos_scoru_wasm.Wasm_pvm_state.output_info={outbox_level:Bounded.Non_negative_int32.t;message_index:Z.t;}typeinput_request=No_input_required|Input_requiredtypeinfo={current_tick:Z.t;last_input_read:inputoption;input_request:input_request;}moduleMake(Tree:Context.TREEwithtypekey=stringlistandtypevalue=bytes)=structtypeTezos_tree_encoding.tree_instance+=PVM_treeofTree.treemoduleWasm=Tezos_scoru_wasm.Wasm_pvm.Make(structincludeTreeletselect=function|PVM_treet->t|_->raiseTezos_tree_encoding.Incorrect_tree_typeletwrapt=PVM_treetend)letcompute_step(tree:Tree.tree)=Wasm.compute_steptreeletset_input_stepinputpayload(tree:Tree.tree)=Wasm.set_input_stepinputpayloadtreeletget_outputoutput(tree:Tree.tree)=letopenLwt_syntaxinlet+payload=Wasm.get_outputoutputtreeinmatchpayloadwithSomepayload->payload|None->""letget_info(tree:Tree.tree)=letopenLwt_syntaxinlet+{current_tick;last_input_read;input_request}=Wasm.get_infotreein{current_tick;last_input_read;input_request=(matchinput_requestwith|Reveal_required_|No_input_required->No_input_required|Input_required->Input_required);}endendmoduleLift(P:Updater.PROTOCOL)=structletenvironment_version=Protocol.V7letexpected_context_hash=Resulting_contextincludePletblock_header_metadata_encoding_with_legacy_attestation_name=block_header_metadata_encodingletoperation_data_encoding_with_legacy_attestation_name=operation_data_encodingletoperation_receipt_encoding_with_legacy_attestation_name=operation_receipt_encodingletoperation_data_and_receipt_encoding_with_legacy_attestation_name=operation_data_and_receipt_encodingletvalue_of_key~chain_id~predecessor_context~predecessor_timestamp~predecessor_level~predecessor_fitness~predecessor~timestamp=letopenLwt_result_syntaxinlet*!r=value_of_key~chain_id~predecessor_context~predecessor_timestamp~predecessor_level~predecessor_fitness~predecessor~timestampinlet*?f=wrap_tzresultrinreturn(funx->let*!r=fxinLwt.return(wrap_tzresultr))(** Ensure that the cache is correctly loaded in memory
before running any operations. *)letload_predecessor_cachepredecessor_contextchain_idmode(predecessor_header:Block_header.shell_header)cache=letopenLwt_result_syntaxinletpredecessor_hash,timestamp=matchmodewith|Applicationblock_header|Partial_validationblock_header->(block_header.shell.predecessor,block_header.shell.timestamp)|Construction{predecessor_hash;timestamp;_}|Partial_construction{predecessor_hash;timestamp}->(predecessor_hash,timestamp)inlet*value_of_key=value_of_key~chain_id~predecessor_context~predecessor_timestamp:predecessor_header.timestamp~predecessor_level:predecessor_header.level~predecessor_fitness:predecessor_header.fitness~predecessor:predecessor_hash~timestampinContext.load_cachepredecessor_hashpredecessor_contextcachevalue_of_keyletbegin_validationctxtchain_idmode~predecessor~cache=letopenLwt_result_syntaxinlet*ctxt=load_predecessor_cachectxtchain_idmodepredecessorcacheinlet*!validation_state=begin_validationctxtchain_idmode~predecessorinLwt.return(wrap_tzresultvalidation_state)letvalidate_operation?check_signaturevalidation_stateophoperation=letopenLwt_syntaxinlet+validation_state=validate_operation?check_signaturevalidation_stateophoperationinwrap_tzresultvalidation_stateletfinalize_validationvalidation_state=letopenLwt_syntaxinlet+res=finalize_validationvalidation_stateinwrap_tzresultresletbegin_applicationctxtchain_idmode~predecessor~cache=letopenLwt_result_syntaxinlet*ctxt=load_predecessor_cachectxtchain_idmodepredecessorcacheinlet*!application_state=begin_applicationctxtchain_id~predecessormodeinLwt.return(wrap_tzresultapplication_state)letapply_operationapplication_stateophoperation=letopenLwt_syntaxinlet+application_state=apply_operationapplication_stateophoperationinwrap_tzresultapplication_stateletfinalize_applicationstateshell_header=letopenLwt_syntaxinlet+res=finalize_applicationstateshell_headerinwrap_tzresultresletinitchain_idcbh=letopenLwt_syntaxinlet+r=initchain_idcbhinwrap_tzresultrletset_log_message_consumerf=Logging.logging_function:=SomefmoduleMempool=structincludeMempooltypeadd_error=|Validation_errorofError_monad.shell_tztrace|Add_conflictofoperation_conflictletadd_operation?check_signature?conflict_handlerinfomempoolop:(t*add_result,add_error)resultLwt.t=letopenLwt_syntaxinlet+r=Mempool.add_operation?check_signature?conflict_handlerinfomempoolopinmatchrwith|Okv->Okv|Error(Mempool.Validation_errore)->Error(Validation_error(wrap_tztracee))|Error(Mempool.Add_conflictc)->Error(Add_conflictc)letinitctxtchain_id~head_hash~head~cache=letopenLwt_result_syntaxinlet*ctxt=load_predecessor_cachectxtchain_id(Partial_construction{predecessor_hash=head_hash;timestamp=head.Block_header.timestamp;})headcacheinlet*!r=initctxtchain_id~head_hash~headinLwt.return(wrap_tzresultr)endendclass['chain,'block]proto_rpc_context(t:Tezos_rpc.Context.t)(prefix:(unit,(unit*'chain)*'block)RPC_path.t)=objectmethodcall_proto_service0:'m'q'i'o.(([<RPC_service.meth]as'm),RPC_context.t,RPC_context.t,'q,'i,'o)RPC_service.t->'chain*'block->'q->'i->'otzresultLwt.t=funs(chain,block)qi->lets=RPC_service.subst0sinlets=RPC_service.prefixprefixsint#call_services(((),chain),block)qimethodcall_proto_service1:'m'a'q'i'o.(([<RPC_service.meth]as'm),RPC_context.t,RPC_context.t*'a,'q,'i,'o)RPC_service.t->'chain*'block->'a->'q->'i->'otzresultLwt.t=funs(chain,block)a1qi->lets=RPC_service.subst1sinlets=RPC_service.prefixprefixsint#call_services((((),chain),block),a1)qimethodcall_proto_service2:'m'a'b'q'i'o.(([<RPC_service.meth]as'm),RPC_context.t,(RPC_context.t*'a)*'b,'q,'i,'o)RPC_service.t->'chain*'block->'a->'b->'q->'i->'otzresultLwt.t=funs(chain,block)a1a2qi->lets=RPC_service.subst2sinlets=RPC_service.prefixprefixsint#call_services(((((),chain),block),a1),a2)qimethodcall_proto_service3:'m'a'b'c'q'i'o.(([<RPC_service.meth]as'm),RPC_context.t,((RPC_context.t*'a)*'b)*'c,'q,'i,'o)RPC_service.t->'chain*'block->'a->'b->'c->'q->'i->'otzresultLwt.t=funs(chain,block)a1a2a3qi->lets=RPC_service.subst3sinlets=RPC_service.prefixprefixsint#call_services((((((),chain),block),a1),a2),a3)qiendclass['block]proto_rpc_context_of_directoryconvdir:['block]RPC_context.simple=letlookup=newTezos_rpc.Context.of_directorydirinobjectmethodcall_proto_service0:'m'q'i'o.(([<RPC_service.meth]as'm),RPC_context.t,RPC_context.t,'q,'i,'o)RPC_service.t->'block->'q->'i->'otzresultLwt.t=funsblockqi->letrpc_context=convblockinlookup#call_servicesrpc_contextqimethodcall_proto_service1:'m'a'q'i'o.(([<RPC_service.meth]as'm),RPC_context.t,RPC_context.t*'a,'q,'i,'o)RPC_service.t->'block->'a->'q->'i->'otzresultLwt.t=funsblocka1qi->letrpc_context=convblockinlookup#call_services(rpc_context,a1)qimethodcall_proto_service2:'m'a'b'q'i'o.(([<RPC_service.meth]as'm),RPC_context.t,(RPC_context.t*'a)*'b,'q,'i,'o)RPC_service.t->'block->'a->'b->'q->'i->'otzresultLwt.t=funsblocka1a2qi->letrpc_context=convblockinlookup#call_services((rpc_context,a1),a2)qimethodcall_proto_service3:'m'a'b'c'q'i'o.(([<RPC_service.meth]as'm),RPC_context.t,((RPC_context.t*'a)*'b)*'c,'q,'i,'o)RPC_service.t->'block->'a->'b->'c->'q->'i->'otzresultLwt.t=funsblocka1a2a3qi->letrpc_context=convblockinlookup#call_services(((rpc_context,a1),a2),a3)qiendmoduleEquality_witness=Environment_context.Equality_witnessmodulePlonk=Tezos_protocol_environment_structs.V7.PlonkmoduleDal=structincludeTezos_crypto_dal.Cryptobox.Verifiertypepage={index:int;content:bytes}letverify_pagetshpageproof=matchverify_pagetsh~page_index:page.indexpage.contentproofwith|Error`Page_length_mismatch->Okfalse|Error`Page_index_out_of_range->Error`Segment_index_out_of_range|Error(`Invalid_page|`Invalid_degree_strictly_less_than_expected_)->Okfalse|Ok()->Oktrueletcommitment_proof_encoding=Commitment_proof.encodingendend