Skip to content
New issue

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

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

Already on GitHub? # to your account

Ingest dev guide #1415

Merged

Conversation

urvisavla
Copy link
Contributor

@urvisavla urvisavla commented Mar 13, 2025

addresses #1328

This PR addressed the ledger backend documentation for the ingest library, as outlined in
requirements. It covers prerequisites, installation, setup, and code examples for ledger backends. Placeholders have been added for processors and ledger readers. I'd like to get some initial feedback on the structure and level of details before expanding remaining sections.

@stellar-jenkins
Copy link

Copy link
Member

@leighmcculloch leighmcculloch left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👏🏻 Woohoo ingest docs 🎉

sidebar_position: 10
---

A ledger backend is a source of Stellar network ledger data. he ingest library supports two primary ledger backends, both implementing the [ledgerbackend](https://github.com/stellar/go/blob/master/ingest/ledgerbackend/ledger_backend.go) interface. This interface always returns ledger data as `xdr.LedgerCloseMeta`, which is XDR-encoded ledger metadata object.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It would be helpful to mention a summary of the different types of data that are available in xdr.LedgerCloseMeta

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@mollykarcher
Copy link
Contributor

This should have been a comment on the nav conflict rebase - #1405 - but I missed that review and I'm just seeing it here. We wanted "ingest library/SDK" to be under the "Indexers -> Build your own" not in the top-level nav. Not sure if you want to handle that here since you're mostly just adding actual content. If not, we should address that on the review/merge of the feature branch back into master

@stellar-jenkins
Copy link

4 similar comments
@stellar-jenkins
Copy link

@stellar-jenkins
Copy link

@stellar-jenkins
Copy link

@stellar-jenkins
Copy link


## Package Structure

The ingest library is broadly split into three main packages:
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we include mention of HistoryArchive usage via the github.com/stellar/go/historyarchive package at this level it's significant for ledger entry aspect. And the xdr bindings from github.com/stellar/go/xdr as it contains all data models.

I think it might be worthwhile to include the formal package names for each item mentioned either expressed as code formatted markup likegithub.heygears.com/stellar/go/ingest/ledgerbackend or as link to gh repo path github.com/stellar/go/ingest/ledgerbackend

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it might be worthwhile to include the formal package names for each item mentioned either expressed as code formatted markup likegithub.heygears.com/stellar/go/ingest/ledgerbackend or as link to gh repo path github.com/stellar/go/ingest/ledgerbackend

done.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we include mention of HistoryArchive usage via the github.com/stellar/go/historyarchive package at this level it's significant for ledger entry aspect. And the xdr bindings from github.com/stellar/go/xdr as it contains all data models.

I'm not sure about including historyarchives here since it's outside the ingest package at least for now. For xdr, I'll add more details about the data available in ledgerclosemeta object (see Tamir's comment here) and will include the link to the xdr package there.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, historyarchive is not under github.com/stellar/go/ingest, but its functionality is a subset of ingestion development, we reference consuming history archives to get ledger entries as a use case for ingest sdk in the introduction

@sreuland
Copy link
Contributor

sreuland commented Mar 13, 2025

This should have been a comment on the nav conflict rebase - #1405 - but I missed that review and I'm just seeing it here. We wanted "ingest library/SDK" to be under the "Indexers -> Build your own" not in the top-level nav. Not sure if you want to handle that here since you're mostly just adding actual content. If not, we should address that on the review/merge of the feature branch back into master

I'll fix the nav for ingest library on #1346.
I can take the rename to 'Ingest SDK' request at the same time.

[edit] done on #1422

@stellar-jenkins
Copy link

@stellar-jenkins
Copy link

@sreuland
Copy link
Contributor

I'd like to get some initial feedback on the structure and level of details before expanding remaining sections.

content looks solid, do you think it's worthwhile to carve out the processors and ledgerreaders sections to second pr which could be merged directly to main later?

We could proceed to merge this and I think we're then ready to merge ingest feature branch to main.

I'm ready to approve, thanks!

@stellar-jenkins
Copy link

@urvisavla
Copy link
Contributor Author

content looks solid, do you think it's worthwhile to carve out the processors and ledgerreaders sections to second pr which could be merged directly to main later?

We could proceed to merge this and I think we're then ready to merge ingest feature branch to main.

Sounds good. I've made a few updates including adding architecture diagrams, section on the LedgerCloseMeta struct and content to the LedgerReaders page. If everything looks good, I can go ahead and merge it. The only remaining items are adding information about Processors and the history archives.

@urvisavla urvisavla requested review from sreuland and tamirms March 17, 2025 17:48
…rchitecture.mdx

Co-authored-by: shawn <sreuland@users.noreply.github.com>
…edgerbackends/captivecore.mdx

Co-authored-by: shawn <sreuland@users.noreply.github.com>
Copy link
Contributor

@sreuland sreuland left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nice work, preview looks great! left a few comments for consideration.

urvisavla and others added 2 commits March 17, 2025 11:56
…edgerbackends/captivecore.mdx

Co-authored-by: shawn <sreuland@users.noreply.github.com>
@stellar-jenkins
Copy link

3 similar comments
@stellar-jenkins
Copy link

@stellar-jenkins
Copy link

@stellar-jenkins
Copy link

@stellar-jenkins
Copy link

@urvisavla urvisavla merged commit 1779897 into stellar:feature-branch/platform-docpoc25 Mar 17, 2025
1 check passed
@urvisavla urvisavla deleted the ingest-dev-guide branch March 17, 2025 22:48
# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants