Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Trace verifier #256

Merged
merged 6 commits into from
Mar 14, 2025
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions flake.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion flake.nix
Original file line number Diff line number Diff line change
@@ -7,7 +7,7 @@
url = "github:input-output-hk/iogx";
};

leios-spec.url = "github:input-output-hk/ouroboros-leios-formal-spec?ref=ee654a42c81f1a2e6290ee13c9c6abcd03b30079";
leios-spec.url = "github:input-output-hk/ouroboros-leios-formal-spec?ref=1bea2eaedf3cc38448a11819f3e2a7ab75b24735";
};


50 changes: 33 additions & 17 deletions leios-trace-verifier/Parser.agda
Original file line number Diff line number Diff line change
@@ -6,9 +6,6 @@ module Parser where
{-# LANGUAGE OverloadedStrings #-}
#-}

open import Leios.Foreign.Defaults 2 fzero
open import Leios.Foreign.Types hiding (EndorserBlock)

{-# FOREIGN GHC
import Data.Word
import Data.Fixed
@@ -56,33 +53,52 @@ record Endorsement : Type where

data Event : Type where
Cpu : String Time String Event

IBSent EBSent VTBundleSent RBSent IBReceived EBReceived VTBundleReceived RBReceived :
Maybe Node Node Maybe Bytes Maybe Time Maybe String Maybe (List String) Event

IBSent EBSent VTBundleSent RBSent IBReceived EBReceived VTBundleReceived RBReceived : Maybe Node Node Maybe Bytes Maybe Time Maybe String Maybe (List String) Event
IBEnteredState EBEnteredState VTBundleEnteredState RBEnteredState : String String Word64 Event

IBGenerated : String String SlotNo Maybe Bytes Maybe Bytes Maybe String Event

EBGenerated : String String Word64 Word64 List BlockRef Event

RBGenerated : String Maybe String Maybe Int Word64 Maybe Word64 Maybe Endorsement Maybe (List Endorsement) Maybe Word64 Event

VTBundleGenerated : String String Word64 Word64 Map String Word64 Event

{-# COMPILE GHC Event = data Event (Cpu | IBSent | EBSent | VTBundleSent | RBSent | IBReceived | EBReceived | VTBundleReceived | RBReceived
| IBEnteredState | EBEnteredState | VTBundleEnteredState | RBEnteredState
| IBGenerated | EBGenerated | RBGenerated | VTBundleGenerated) #-}
| IBEnteredState | EBEnteredState | VTBundleEnteredState | RBEnteredState | IBGenerated | EBGenerated | RBGenerated | VTBundleGenerated) #-}

record TraceEvent : Type where
field time_s : Time
message : Event

{-# COMPILE GHC TraceEvent = data TraceEvent (TraceEvent) #-}

-- FIXME: Implementation
verifyTrace : List TraceEvent Bool
verifyTrace [] = false
verifyTrace (_ ∷ _) = true
open import Leios.SpecStructure using (SpecStructure)
open import Leios.Trace.Verifier

open import Leios.Defaults 2 fzero using (st)
open import Leios.Short st

EventLog = List TraceEvent

traceEvent→action : TraceEvent Maybe (Action × LeiosInput)
traceEvent→action record { message = Cpu x x₁ x₂ } = nothing
traceEvent→action record { message = IBSent x x₁ x₂ x₃ x₄ x₅ } = nothing
traceEvent→action record { message = EBSent x x₁ x₂ x₃ x₄ x₅ } = nothing
traceEvent→action record { message = VTBundleSent x x₁ x₂ x₃ x₄ x₅ } = nothing
traceEvent→action record { message = RBSent x x₁ x₂ x₃ x₄ x₅ } = nothing
traceEvent→action record { message = IBReceived x x₁ x₂ x₃ x₄ x₅ } = nothing
traceEvent→action record { message = EBReceived x x₁ x₂ x₃ x₄ x₅ } = nothing
traceEvent→action record { message = VTBundleReceived x x₁ x₂ x₃ x₄ x₅ } = nothing
traceEvent→action record { message = RBReceived x x₁ x₂ x₃ x₄ x₅ } = nothing
traceEvent→action record { message = IBEnteredState x x₁ x₂ } = nothing
traceEvent→action record { message = EBEnteredState x x₁ x₂ } = nothing
traceEvent→action record { message = VTBundleEnteredState x x₁ x₂ } = nothing
traceEvent→action record { message = RBEnteredState x x₁ x₂ } = nothing
traceEvent→action record { message = IBGenerated p _ s _ _ _ } = just (IB-Role-Action , SLOT)
traceEvent→action record { message = EBGenerated p _ s _ ibs } = just (EB-Role-Action , SLOT)
traceEvent→action record { message = RBGenerated x x₁ x₂ x₃ x₄ x₅ x₆ x₇ } = nothing
traceEvent→action record { message = VTBundleGenerated x x₁ x₂ x₃ x₄ } = just (V-Role-Action , SLOT)

verifyTrace : EventLog Bool
verifyTrace l =
let αs = L.catMaybes $ L.map traceEvent→action l
in ¿ ValidTrace αs ¿ᵇ

{-# COMPILE GHC verifyTrace as verifyTrace #-}