Skip to content
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

xdrill for ledgerCloseMeta #5568

Open
wants to merge 8 commits into
base: master
Choose a base branch
from

Conversation

chowbao
Copy link
Contributor

@chowbao chowbao commented Jan 8, 2025

PR Checklist

PR Structure

  • This PR has reasonably narrow scope (if not, break it down into smaller PRs).
  • This PR avoids mixing refactoring changes with feature changes (split into two PRs
    otherwise).
  • This PR's title starts with name of package that is most changed in the PR, ex.
    services/friendbot, or all or doc if the changes are broad or impact many
    packages.

Thoroughness

  • This PR adds tests for the most critical parts of the new functionality or fixes.
  • I've updated any docs (developer docs, .md
    files, etc... affected by this change). Take a look in the docs folder for a given service,
    like this one.

Release planning

  • I've reviewed the changes in this PR and if I consider them worthwhile for being mentioned on release notes then I have updated the relevant CHANGELOG.md within the component folder structure. For example, if I changed horizon, then I updated (services/horizon/CHANGELOG.md. I add a new line item describing the change and reference to this PR. If I don't update a CHANGELOG, I acknowledge this PR's change may not be mentioned in future release notes.
  • I've decided if this PR requires a new major/minor version according to
    semver, or if it's mainly a patch change. The PR is targeted at the next
    release branch if it's not a patch change.

What

github issue

xdrill functions for LedgerCloseMeta

Why

First commit for xdrill with the low level helper functions from the processors/transforms from stellar-etl for history_ledgers found here

Known limitations

  • Refactor of the processor/transforms to be done in separate ticket/pr

Copy link
Contributor Author

Choose a reason for hiding this comment

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

How exhaustive do we want the testing to be?

Comment on lines 12 to 14
type Ledger struct {
ledger *xdr.LedgerCloseMeta
}
Copy link
Contributor

Choose a reason for hiding this comment

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

this struct definition would not work outside of the xdrill package. Although the Ledger struct is exported, the ledger field remains private to external packages. So, if you would not be able to construct a Ledger instance outside of the xdrill package because you would not be able to reference the ledger field.

To fix this issue you can make the ledger field public:

type Ledger struct {
	Ledger *xdr.LedgerCloseMeta
}

Alternatively, you could create a type definition:

type Ledger xdr.LedgerCloseMeta

func (l Ledger) Sequence() uint32 {
	return uint32(l.ledger.LedgerHeaderHistoryEntry().Header.LedgerSeq)
}

Then to call the helper function you would cast your xdr.LedgerCloseMeta value into an xdrill.Ledger value so you could call the helper function:

package app

import (
	"github.com/stellar/go/exp/xdrill"
	"github.com/stellar/go/xdr"
)

func doSomething(ledger xdr.LedgerCloseMeta) {
  l := xrill.Ledger(ledger)
  seq := l.Sequence()
  ...
}

Or you could make the helper functions take the ledger parameter as the first argument:

func LedgerSequence(ledger xdr.LedgerCloseMeta) uint32 {
	return uint32(ledger.LedgerHeaderHistoryEntry().Header.LedgerSeq)
}

IMO the cleanest API would be define helper functions like these in the xdr package directly on the LedgerCloseMeta type. I think I missed the discussion about this decision. What was the motivation for defining a type equivalent to xdr.LedgerCloseMeta in the xdrill package?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Ah oops yeah it should be public

Copy link
Contributor

Choose a reason for hiding this comment

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

I forgot to mention one other possible solution, you could leave the ledger field as private and expose a public constructor:

type Ledger struct {
	ledger *xdr.LedgerCloseMeta
}

func NewLedger(ledger xdr.LedgerCloseMeta) Ledger {
   return Ledger{ledger: &ledger}
}

Copy link
Contributor Author

Choose a reason for hiding this comment

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

What was the motivation for defining a type equivalent to xdr.LedgerCloseMeta in the xdrill package?

Talked in slack. tl;dr - it's nicer for users as a separate package because they would be given a subset of only XDRill functions instead of all the functions/fields within xdr and ingest

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Updated functions to accept lcm as a param instead of the Ledger struct
d45b0fd

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Moved xdrill ledger functions to go/ingest/ledger
40d5057

exp/xdrill/utils/utils.go Outdated Show resolved Hide resolved
@@ -0,0 +1,128 @@
package utils
Copy link
Contributor

Choose a reason for hiding this comment

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

utils packages are generally discouraged in go:

https://google.github.io/styleguide/go/decisions.html#package-names

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Ah ok. What is the correct way to organize shared "utils"/"common" functions?

Would just renaming the package to xdrillutils be good?
Or should I split it out into more descriptive packages like xdrillschemas, xdrillconversions?

Copy link
Contributor

Choose a reason for hiding this comment

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

I think xdrillutils is basically equivalent to utils. In general, package names should be related to what the code actually does and if there is no unifying theme for all the code in the package then it could be that the code should be separated into multiple packages

for example, CreateSampleTx() is used to generate to testing fixtures. you could argue that it doesn't need to even be exported outside of the testing files which use it.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yeah makes sense. I'll try splitting them up into more relevantly named packages. Maybe ChatGPT can offer some suggestions lol

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Moved util functions to relevant places
40d5057

exp/xdrill/utils/utils.go Outdated Show resolved Hide resolved
Copy link

@sydneynotthecity sydneynotthecity left a comment

Choose a reason for hiding this comment

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

Overall looks like a good start, just had a couple comments about consistency within the package to ensure that we're not carrying over oddities from stellar-etl that we should fix now.

Comment on lines +15 to +18
func ID(l xdr.LedgerCloseMeta) int64 {
return toid.New(int32(l.LedgerSequence()), 0, 0).ToInt64()
}

Choose a reason for hiding this comment

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

I thought ID was deprecated? How does ID differ from Sequence? If there is no difference, we should deprecate this field (including removing from Hubble tables)

}
return encodedAddress, true
default:
return "", false

Choose a reason for hiding this comment

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

is there a reason you don't return an error for unknown id types?

}
}

return operationCount, txSetOperationCount, true

Choose a reason for hiding this comment

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

operationCount vs txSetOperationCount is confusing (I also find it confusing in stellar-etl). Can we update to successfulOperationCount or something more descriptive that indicates what operations are counted?

Comment on lines +164 to +168
return l.MustV0().TxProcessing
case 1:
return l.MustV1().TxProcessing
default:
panic(fmt.Sprintf("Unsupported LedgerCloseMeta.V: %d", l.V))

Choose a reason for hiding this comment

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

This is the only function where you panic if the XDR is not parseable. imo, we should be consistent with either using Get<Thing>() vs Must(). thoughts?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Hmm that's true. I'll make ok, err, and panic more consistent

Comment on lines +107 to +109
if txCount != len(results) {
return 0, 0, false
}
Copy link
Contributor

Choose a reason for hiding this comment

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

I don't know that this case can ever happen. I think we should panic if there is a length mismatch

Comment on lines +136 to +139
operationResults, ok := result.Result.OperationResults()
if !ok {
return 0, 0, false
}
Copy link
Contributor

Choose a reason for hiding this comment

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

if the operation result is successful there will always be a results slice. so there is no need to return the ok boolean

@chowbao chowbao mentioned this pull request Jan 17, 2025
7 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants