Skip to content

Commit

Permalink
ObscuroScan: server oldest batches first
Browse files Browse the repository at this point in the history
  • Loading branch information
BedrockSquirrel committed Nov 4, 2023
1 parent 5c3fc3c commit 93e94e8
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 22 deletions.
1 change: 1 addition & 0 deletions go/common/query_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ type PublicTransaction struct {

type PublicBatch struct {
BatchHeader
TxHashes []TxHash `json:"txHashes"`
}

type PublicBlock struct {
Expand Down
23 changes: 14 additions & 9 deletions go/host/db/batches.go
Original file line number Diff line number Diff line change
Expand Up @@ -132,25 +132,30 @@ func (db *DB) GetBatchBySequenceNumber(sequenceNumber *big.Int) (*common.ExtBatc
return db.GetBatch(*batchHash)
}

// GetBatchListing returns BatchListingResponse given a pagination
// GetBatchListing returns latest BatchListingResponse given a pagination. For example, page 0, size 10 will return the
// latest 10 batches.
// todo change this when the db changes - this is not super performant
func (db *DB) GetBatchListing(pagination *common.QueryPagination) (*common.BatchListingResponse, error) {
// fetch requested batches
// fetch the total batches so we can paginate
header, err := db.GetHeadBatchHeader()
if err != nil {
return nil, err
}

batchesFrom := header.SequencerOrderNo.Uint64() - pagination.Offset

var batches []common.PublicBatch
for i := pagination.Offset; i < pagination.Offset+uint64(pagination.Size); i++ {
// fetch requested batches - looping backwards from the latest batch subtracting any pagination offset
// (e.g. front-end showing latest batches first, page 3 of size 10 would be skipping the 30 most recent batches)
for i := batchesFrom; i > batchesFrom-uint64(pagination.Size); i-- {
extBatch, err := db.GetBatchBySequenceNumber(big.NewInt(int64(i)))
if err != nil && !errors.Is(err, errutil.ErrNotFound) {
return nil, err
}
if extBatch != nil {
batches = append(batches, common.PublicBatch{BatchHeader: *extBatch.Header})
batches = append(batches, common.PublicBatch{BatchHeader: *extBatch.Header, TxHashes: extBatch.TxHashes})
}
}
// fetch the total batches so we can paginate
header, err := db.GetHeadBatchHeader()
if err != nil {
return nil, err
}

return &common.BatchListingResponse{
BatchesData: batches,
Expand Down
21 changes: 8 additions & 13 deletions tools/obscuroscan_v2/frontend/src/components/BatchDataGrid.vue
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,8 @@
<Timestamp :unixTimestampSeconds="Number(scope.row.timestamp)" />
</template>
</el-table-column>
<el-table-column prop="l1Proof" label="Included in Rollup"/>
<el-table-column label="No. Transactions" :formatter="function(row) { return row.txHashes ? row.txHashes.length : 0; }" width="180" />
<el-table-column prop="l1Proof" label="L1 block"/>
</el-table>
<el-pagination
@size-change="handleSizeChange"
Expand Down Expand Up @@ -47,14 +48,9 @@ export default {
setup() {
const store = useBatchStore()
// Start polling when the component is mounted
// Reload batch data onMount
onMounted(() => {
store.startPolling()
})
// Ensure to stop polling when component is destroyed or deactivated
onUnmounted(() => {
store.stopPolling()
store.fetch()
})
return {
Expand All @@ -80,21 +76,20 @@ export default {
const store = useBatchStore()
store.size = newSize
store.offset = (this.currentPage - 1) * store.size
// reload data
store.fetch()
},
// Called when the current page is changed
handleCurrentChange(newPage) {
const store = useBatchStore()
this.currentPage = newPage
store.offset = (newPage - 1) * store.size
// reload data
store.fetch()
},
toggleWindow(data) {
this.$refs.batchInfoWindowRef.displayData(data.hash);
},
},
computed: {
tableRowClassName() {
return "hover"
}
}
}
</script>
Expand Down

0 comments on commit 93e94e8

Please sign in to comment.