-
Notifications
You must be signed in to change notification settings - Fork 16
adds QGB querier interfaces #45
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
package p2p | ||
|
||
import ( | ||
"context" | ||
"time" | ||
|
||
celestiatypes "github.com/celestiaorg/celestia-app/x/qgb/types" | ||
"github.com/celestiaorg/orchestrator-relayer/types" | ||
) | ||
|
||
// QuerierI queries the P2P network for confirms. | ||
// Note: for now, we will be querying the P2P network directly without storing anything in the store. | ||
// this would make it easier to have a simple working version. Then, we can iterate from there on. | ||
type QuerierI interface { | ||
// QueryTwoThirdsDataCommitmentConfirms queries the p2p network for data commitments signed by more | ||
// than 2/3s of the last validator set. | ||
// It takes a timeout to wait for validators to sign and broadcast their signatures. | ||
// Should return an empty slice and no error if it couldn't find enough signatures. | ||
QueryTwoThirdsDataCommitmentConfirms( | ||
ctx context.Context, | ||
timeout time.Duration, | ||
dc celestiatypes.DataCommitment, | ||
) ([]types.DataCommitmentConfirm, error) | ||
|
||
// QueryTwoThirdsValsetConfirms queries the p2p network for valsets signed by more | ||
// than 2/3s of the last validator set. | ||
// It takes a timeout to wait for validators to sign and broadcast their signatures. | ||
// Should return an empty slice and no error if it couldn't find enough signatures. | ||
QueryTwoThirdsValsetConfirms( | ||
ctx context.Context, | ||
timeout time.Duration, | ||
valset celestiatypes.Valset, | ||
) ([]types.ValsetConfirm, error) | ||
|
||
// QueryValsetConfirmByOrchestratorAddress get the valset confirm having nonce `nonce` | ||
// and signed by the orchestrator whose address is `address`. | ||
QueryValsetConfirmByOrchestratorAddress( | ||
ctx context.Context, | ||
nonce uint64, | ||
address string, | ||
) (*types.ValsetConfirm, error) | ||
|
||
// QueryDataCommitmentConfirmByOrchestratorAddress get the data commitment confirm having nonce `nonce` | ||
// and signed by the orchestrator whose address is `address`. | ||
QueryDataCommitmentConfirmByOrchestratorAddress( | ||
ctx context.Context, | ||
nonce uint64, | ||
address string, | ||
) (*types.DataCommitmentConfirm, error) | ||
|
||
// QueryDataCommitmentConfirms get all the data commitment confirms in store for a certain nonce. | ||
QueryDataCommitmentConfirms( | ||
ctx context.Context, | ||
nonce uint64, | ||
) ([]types.DataCommitmentConfirm, error) | ||
|
||
// QueryValsetConfirms get all the valset confirms in store for a certain nonce. | ||
QueryValsetConfirms( | ||
ctx context.Context, | ||
nonce uint64, | ||
) ([]types.ValsetConfirm, error) | ||
} | ||
Comment on lines
+11
to
+62
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm not sure if this is a good starting point for the interface we're looking for imho. For example, We are not planning on having multiple implementations of If these things are just for testing purposes, then we might still mock a different more standard (smaller) interface There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Yes, 100% they are. As stated here #50 (comment), I would love to see some examples of mocks to improve these big interfaces. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think we should just not mock anything, and use the testnode code, which should be pretty easy to setup a testsuite for, and can have super short block times. If we really wanted to get clever, we can store some state/blocks as test data, and then boot up that "frozen" chain. Alternatively, we could generate mocks for all of the core/app rpc endpoints needed, but that's only marginally better than the other form of mocks and not be worth the effort |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
package rpc | ||
|
||
import ( | ||
"context" | ||
|
||
celestiatypes "github.com/celestiaorg/celestia-app/x/qgb/types" | ||
) | ||
|
||
// AppQuerierI queries the application for attestations and unbonding periods. | ||
type AppQuerierI interface { | ||
// QueryAttestationByNonce query an attestation by nonce from the state machine. | ||
QueryAttestationByNonce(ctx context.Context, nonce uint64) (celestiatypes.AttestationRequestI, error) | ||
|
||
// QueryLatestAttestationNonce query the latest attestation nonce from the state machine. | ||
QueryLatestAttestationNonce(ctx context.Context) (uint64, error) | ||
|
||
// QueryDataCommitmentByNonce query a data commitment by its nonce. | ||
QueryDataCommitmentByNonce(ctx context.Context, nonce uint64) (*celestiatypes.DataCommitment, error) | ||
|
||
// QueryValsetByNonce query a valset by nonce. | ||
QueryValsetByNonce(ctx context.Context, nonce uint64) (*celestiatypes.Valset, error) | ||
|
||
// QueryLatestValset query the latest recorded valset in the state machine. | ||
QueryLatestValset(ctx context.Context) (*celestiatypes.Valset, error) | ||
|
||
// QueryLastValsetBeforeNonce query the last valset before a certain nonce from the state machine. | ||
// this will be needed when signing to know the validator set at that particular nonce. | ||
QueryLastValsetBeforeNonce(ctx context.Context, nonce uint64) (*celestiatypes.Valset, error) | ||
|
||
// QueryLastUnbondingHeight query the last unbonding height from state machine. | ||
QueryLastUnbondingHeight(ctx context.Context) (int64, error) | ||
|
||
// QueryLastUnbondingAttestationNonce query the attestation nonce that corresponds to the | ||
// latest attestation nonce. | ||
QueryLastUnbondingAttestationNonce(ctx context.Context) (uint64, error) | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package rpc | ||
|
||
import ( | ||
"context" | ||
|
||
"github.com/tendermint/tendermint/libs/bytes" | ||
coretypes "github.com/tendermint/tendermint/rpc/core/types" | ||
) | ||
|
||
// TmQuerierI queries tendermint for commitments and events. | ||
type TmQuerierI interface { | ||
Stop() error | ||
// QueryCommitment queries tendermint for a commitment for the set of blocks | ||
// defined by `beginBlock` and `endBlock`. | ||
QueryCommitment(ctx context.Context, beginBlock uint64, endBlock uint64) (bytes.HexBytes, error) | ||
|
||
// SubscribeEvents subscribe to the events named `eventName`. | ||
SubscribeEvents(ctx context.Context, subscriptionName string, eventName string) (<-chan coretypes.ResultEvent, error) | ||
} | ||
Comment on lines
+10
to
+19
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. do you think we should add proofs to this? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm not sure where to put the proof generation code. I was thinking of adding it to V1, but we will be deploying a mocked version of it, should it belong to V1-mocked? The thing is, the versions have different structures. Thus, it won't be as easy as back porting the PR to the version we want. What do you think? Where should the command generating the proofs and verifying them be? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. we can add them later, I'm not sure where to add them, but will defer to you |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[not blocking nit]
The I at the end feels redundant and is usually not added unless there is something else that using the same name. If that's the case, then imho I think we should change one of the names so they don't match
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There will be the implementation of
QuerierI
calledQuerier
, unless we find a better name for it 🐱 . I agree, the current naming scheme I have been following for these PRs is a bit dullThere was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
okay, yeah its not the end of the world lol
on a unrelated note, why is the querier in the p2p package?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
there are multiple queriers, the tendermint querier (for getting the data commitments, the roots etc from tendermint) and the qgb module querier (for getting the attestations from the state machine) and the p2p querier (for eventually getting the attestations confirms)