package frontend import ( "context" "github.com/ethereum-optimism/optimism/op-service/eth" "github.com/ethereum-optimism/optimism/op-supervisor/supervisor/types" "github.com/ethereum/go-ethereum/common" ) type AdminBackend interface { Start(ctx context.Context) error Stop(ctx context.Context) error AddL2RPC(ctx context.Context, rpc string) error } type QueryBackend interface { CheckMessage(identifier types.Identifier, payloadHash common.Hash) (types.SafetyLevel, error) CheckMessages(messages []types.Message, minSafety types.SafetyLevel) error CrossDerivedFrom(ctx context.Context, chainID types.ChainID, derived eth.BlockID) (derivedFrom eth.BlockRef, err error) UnsafeView(ctx context.Context, chainID types.ChainID, unsafe types.ReferenceView) (types.ReferenceView, error) SafeView(ctx context.Context, chainID types.ChainID, safe types.ReferenceView) (types.ReferenceView, error) Finalized(ctx context.Context, chainID types.ChainID) (eth.BlockID, error) } type UpdatesBackend interface { UpdateLocalUnsafe(ctx context.Context, chainID types.ChainID, head eth.BlockRef) error UpdateLocalSafe(ctx context.Context, chainID types.ChainID, derivedFrom eth.BlockRef, lastDerived eth.BlockRef) error UpdateFinalizedL1(ctx context.Context, chainID types.ChainID, finalized eth.BlockRef) error } type Backend interface { AdminBackend QueryBackend UpdatesBackend } type QueryFrontend struct { Supervisor QueryBackend } var _ QueryBackend = (*QueryFrontend)(nil) // CheckMessage checks the safety-level of an individual message. // The payloadHash references the hash of the message-payload of the message. func (q *QueryFrontend) CheckMessage(identifier types.Identifier, payloadHash common.Hash) (types.SafetyLevel, error) { return q.Supervisor.CheckMessage(identifier, payloadHash) } // CheckMessage checks the safety-level of a collection of messages, // and returns if the minimum safety-level is met for all messages. func (q *QueryFrontend) CheckMessages( messages []types.Message, minSafety types.SafetyLevel) error { return q.Supervisor.CheckMessages(messages, minSafety) } func (q *QueryFrontend) UnsafeView(ctx context.Context, chainID types.ChainID, unsafe types.ReferenceView) (types.ReferenceView, error) { return q.Supervisor.UnsafeView(ctx, chainID, unsafe) } func (q *QueryFrontend) SafeView(ctx context.Context, chainID types.ChainID, safe types.ReferenceView) (types.ReferenceView, error) { return q.Supervisor.SafeView(ctx, chainID, safe) } func (q *QueryFrontend) Finalized(ctx context.Context, chainID types.ChainID) (eth.BlockID, error) { return q.Supervisor.Finalized(ctx, chainID) } func (q *QueryFrontend) CrossDerivedFrom(ctx context.Context, chainID types.ChainID, derived eth.BlockID) (derivedFrom eth.BlockRef, err error) { return q.Supervisor.CrossDerivedFrom(ctx, chainID, derived) } type AdminFrontend struct { Supervisor Backend } var _ AdminBackend = (*AdminFrontend)(nil) // Start starts the service, if it was previously stopped. func (a *AdminFrontend) Start(ctx context.Context) error { return a.Supervisor.Start(ctx) } // Stop stops the service, if it was previously started. func (a *AdminFrontend) Stop(ctx context.Context) error { return a.Supervisor.Stop(ctx) } // AddL2RPC adds a new L2 chain to the supervisor backend func (a *AdminFrontend) AddL2RPC(ctx context.Context, rpc string) error { return a.Supervisor.AddL2RPC(ctx, rpc) } type UpdatesFrontend struct { Supervisor UpdatesBackend } var _ UpdatesBackend = (*UpdatesFrontend)(nil) func (u *UpdatesFrontend) UpdateLocalUnsafe(ctx context.Context, chainID types.ChainID, head eth.BlockRef) error { return u.Supervisor.UpdateLocalUnsafe(ctx, chainID, head) } func (u *UpdatesFrontend) UpdateLocalSafe(ctx context.Context, chainID types.ChainID, derivedFrom eth.BlockRef, lastDerived eth.BlockRef) error { return u.Supervisor.UpdateLocalSafe(ctx, chainID, derivedFrom, lastDerived) } func (u *UpdatesFrontend) UpdateFinalizedL1(ctx context.Context, chainID types.ChainID, finalized eth.BlockRef) error { return u.Supervisor.UpdateFinalizedL1(ctx, chainID, finalized) }