-
Notifications
You must be signed in to change notification settings - Fork 248
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
Update gateway HTTP server object mapping format #3334
Conversation
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.
This would work, but why can't we just make a breaking change here? Is anyone except us using gateway? Can't they change the way they send data when upgrading gateway backend at once?
@clostao are you happy to just make a breaking change here? It would be simpler for us. If we did it that way, next time you upgraded the gateway, you'd also need to upgrade to a version of the indexer which sent block numbers as integers (rather than block number strings). |
No problem with that |
b333b86
to
6699fa6
Compare
We also wanted to make breaking changes to allow batch retrieval of mappings, so we can cache pieces and use them with multiple mappings. So I made all those breaking changes in this PR. The gateway and indexer request formats are compatible with the existing format. If you want to support multiple hashes, they can be fetched as The indexer response format was: {
"hash": "0000000000000000000000000000000000000000000000000000000000000000",
"pieceIndex": 0,
"pieceOffset": 0,
"blockNumber": 0
} And it's now the same format as the inner part of the RPC subscription. It's more compact to support batches (piece index is first, followed by piece offset), with a version to support future format changes: {
"blockNumber": 0,
"v0": {
"objects": [
[
"0000000000000000000000000000000000000000000000000000000000000000",
0,
0
]
]
}
} If that's too much change, let me know, and we'll work out how to do it in stages. |
@clostao just checking these changes work for you? |
Looks good to me |
@@ -28,7 +28,7 @@ use tracing::{debug, trace}; | |||
// This code was copied and modified from subspace_service::sync_from_dsn::download_and_reconstruct_blocks(): | |||
// <https://github.com/autonomys/subspace/blob/d71ca47e45e1b53cd2e472413caa23472a91cd74/crates/subspace-service/src/sync_from_dsn/import_blocks.rs#L236-L322> | |||
pub async fn download_pieces<PG>( | |||
piece_indexes: Vec<PieceIndex>, | |||
piece_indexes: &Vec<PieceIndex>, |
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.
Should be &[PieceIndex]
in such cases
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.
Yeah I tried that and something weird happened with type inference. Happy to have another go next time around.
/// Response to object mapping subscription, including a block height. | ||
/// Large responses are batched, so the block height can be repeated in different responses. | ||
#[derive(Debug, Clone, PartialEq, Eq, Ord, PartialOrd)] | ||
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))] | ||
#[cfg_attr(feature = "serde", serde(rename_all = "camelCase"))] | ||
pub struct ObjectMappingResponse { | ||
/// The block number that the object mapping is from. | ||
pub block_number: BlockNumber, | ||
|
||
/// The object mappings. | ||
#[cfg_attr(feature = "serde", serde(flatten))] | ||
pub objects: GlobalObjectMapping, | ||
} |
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.
I don't think "Response" belongs to the core primitives, this is very high-level much application level stuff. We have a separate crate for RPC primitives, would that be a better place for it?
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.
It’s used as an RPC response, then as an RPC and HTTP argument, so that makes sense. I’ll move it next time we change that code.
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.
Think of subspace-core-protocol
as something third-party would have to have in order to build an alternative client. The bare minimum that is mandatory in all cases regardless of what the rest of the implementation looks like.
RPC stuff is much higher level than that, might look different or be missing altogether in some clients, etc.
This PR makes the gateway use the same object mapping format as the RPC server subscription. This is a breaking change.
The format is documented here (it's the same as the
result
inside the subscription wrapper):https://github.com/autonomys/subspace/tree/main/crates/subspace-gateway-rpc#using-the-gateway-rpcs
As part of this change, the gateway:
+
separator if there is more than one mapping. (Preparation for Re-use downloaded pieces in subspace-gateway #3316.)I also made the logging inside the object fetcher more consistent.
Close #3323.
Code contributor checklist: