Skip to content

Commit

Permalink
registry: Add overrides for field decoders (centrifuge#359)
Browse files Browse the repository at this point in the history
  • Loading branch information
cdamian authored Jul 20, 2023
1 parent 8a67d7b commit 093cfb1
Show file tree
Hide file tree
Showing 3 changed files with 62 additions and 24 deletions.
38 changes: 23 additions & 15 deletions registry/registry.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,21 +27,34 @@ type ErrorRegistry map[string]*Type
// EventRegistry maps an event ID to its Type.
type EventRegistry map[types.EventID]*Type

// FieldOverride is used to override the default FieldDecoder for a particular type.
type FieldOverride struct {
FieldLookupIndex int64
FieldDecoder FieldDecoder
}

type factory struct {
fieldStorage map[int64]FieldDecoder
recursiveFieldStorage map[int64]*RecursiveDecoder
}

// NewFactory creates a new Factory.
func NewFactory() Factory {
return &factory{}
// NewFactory creates a new Factory using the provided overrides, if any.
func NewFactory(fieldOverrides ...FieldOverride) Factory {
f := &factory{}

f.fieldStorage = make(map[int64]FieldDecoder)
f.recursiveFieldStorage = make(map[int64]*RecursiveDecoder)

for _, fieldOverride := range fieldOverrides {
f.fieldStorage[fieldOverride.FieldLookupIndex] = fieldOverride.FieldDecoder
}

return f
}

// CreateErrorRegistry creates the registry that contains the types for errors.
// nolint:dupl
func (f *factory) CreateErrorRegistry(meta *types.Metadata) (ErrorRegistry, error) {
f.initStorages()

errorRegistry := make(map[string]*Type)

for _, mod := range meta.AsMetadataV14.Pallets {
Expand Down Expand Up @@ -85,8 +98,6 @@ func (f *factory) CreateErrorRegistry(meta *types.Metadata) (ErrorRegistry, erro
// CreateCallRegistry creates the registry that contains the types for calls.
// nolint:dupl
func (f *factory) CreateCallRegistry(meta *types.Metadata) (CallRegistry, error) {
f.initStorages()

callRegistry := make(map[types.CallIndex]*Type)

for _, mod := range meta.AsMetadataV14.Pallets {
Expand Down Expand Up @@ -134,8 +145,6 @@ func (f *factory) CreateCallRegistry(meta *types.Metadata) (CallRegistry, error)

// CreateEventRegistry creates the registry that contains the types for events.
func (f *factory) CreateEventRegistry(meta *types.Metadata) (EventRegistry, error) {
f.initStorages()

eventRegistry := make(map[types.EventID]*Type)

for _, mod := range meta.AsMetadataV14.Pallets {
Expand Down Expand Up @@ -178,16 +187,15 @@ func (f *factory) CreateEventRegistry(meta *types.Metadata) (EventRegistry, erro
return eventRegistry, nil
}

// initStorages initializes the storages used when creating registries.
func (f *factory) initStorages() {
f.fieldStorage = make(map[int64]FieldDecoder)
f.recursiveFieldStorage = make(map[int64]*RecursiveDecoder)
}

// resolveRecursiveDecoders resolves all recursive decoders with their according FieldDecoder.
// nolint:lll
func (f *factory) resolveRecursiveDecoders() error {
for recursiveFieldLookupIndex, recursiveFieldDecoder := range f.recursiveFieldStorage {
if recursiveFieldDecoder.FieldDecoder != nil {
// Skip if the inner FieldDecoder is present, this could be an override.
continue
}

fieldDecoder, ok := f.fieldStorage[recursiveFieldLookupIndex]

if !ok {
Expand Down
45 changes: 37 additions & 8 deletions registry/registry_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -209,7 +209,7 @@ func TestFactory_CreateErrorRegistry_GetTypeFieldsError(t *testing.T) {
assert.Empty(t, reg)
}

func TestFactory_CreateCallRegistryWithLiveMetadata(t *testing.T) {
func TestFactory_CreateCallRegistry_WithLiveMetadata(t *testing.T) {
var tests = []struct {
Chain string
MetadataHex string
Expand Down Expand Up @@ -282,6 +282,41 @@ func TestFactory_CreateCallRegistryWithLiveMetadata(t *testing.T) {
}
}

func TestFactory_CreateCallRegistry_Overrides(t *testing.T) {
var meta types.Metadata

err := codec.DecodeFromHex(test.CentrifugeMetadataHex, &meta)
assert.NoError(t, err)

t.Log("Metadata was decoded successfully")

// Lookup index for U64 in the test.CentrifugeMetadataHex
targetLookupIndex := int64(10)

f := NewFactory().(*factory)

_, err = f.CreateCallRegistry(&meta)
assert.NoError(t, err)

assert.Equal(t, f.fieldStorage[targetLookupIndex], &ValueDecoder[types.U64]{})

// With override

fieldOverride := FieldOverride{
FieldLookupIndex: targetLookupIndex,
FieldDecoder: &ValueDecoder[types.I64]{},
}

f = NewFactory(fieldOverride).(*factory)

assert.Equal(t, f.fieldStorage[targetLookupIndex], &ValueDecoder[types.I64]{})

_, err = f.CreateCallRegistry(&meta)
assert.NoError(t, err)

assert.Equal(t, f.fieldStorage[targetLookupIndex], &ValueDecoder[types.I64]{})
}

func TestFactory_CreateCallRegistry_NoPalletWithCalls(t *testing.T) {
testMeta := &types.Metadata{
AsMetadataV14: types.MetadataV14{
Expand Down Expand Up @@ -413,7 +448,7 @@ func TestFactory_CreateCallRegistry_GetTypeFieldsError(t *testing.T) {
assert.Empty(t, reg)
}

func TestFactory_CreateEventRegistryWithLiveMetadata(t *testing.T) {
func TestFactory_CreateEventRegistry_WithLiveMetadata(t *testing.T) {
var tests = []struct {
Chain string
MetadataHex string
Expand Down Expand Up @@ -655,7 +690,6 @@ func TestFactory_getTypeFields(t *testing.T) {
}

factory := NewFactory().(*factory)
factory.initStorages()

res, err := factory.getTypeFields(testMeta, testFields)
assert.NoError(t, err)
Expand Down Expand Up @@ -709,7 +743,6 @@ func TestFactory_getTypeFields_FieldDecoderRetrievalError(t *testing.T) {
}

factory := NewFactory().(*factory)
factory.initStorages()

res, err := factory.getTypeFields(testMeta, testFields)
assert.ErrorIs(t, err, ErrFieldDecoderRetrieval)
Expand Down Expand Up @@ -882,7 +915,6 @@ func TestFactory_getFieldDecoder_Composite(t *testing.T) {
}

factory := NewFactory().(*factory)
factory.initStorages()

res, err := factory.getFieldDecoder(testMeta, testFieldName, testFieldTypeDef)
assert.NoError(t, err)
Expand Down Expand Up @@ -951,7 +983,6 @@ func TestFactory_getFieldDecoder_Composite_FieldError(t *testing.T) {
}

factory := NewFactory().(*factory)
factory.initStorages()

res, err := factory.getFieldDecoder(testMeta, testFieldName, testFieldTypeDef)
assert.ErrorIs(t, err, ErrCompositeTypeFieldsRetrieval)
Expand Down Expand Up @@ -1010,7 +1041,6 @@ func TestFactory_getFieldDecoder_Variant(t *testing.T) {
}

factory := NewFactory().(*factory)
factory.initStorages()

res, err := factory.getFieldDecoder(testMeta, testFieldName, testFieldTypeDef)
assert.NoError(t, err)
Expand Down Expand Up @@ -1575,7 +1605,6 @@ func TestFactory_getVariantFieldType_CompositeVariantTypeFieldError(t *testing.T
}

factory := NewFactory().(*factory)
factory.initStorages()

res, err := factory.getVariantFieldDecoder(testMeta, testFieldTypeDef)
assert.ErrorIs(t, err, ErrVariantTypeFieldsRetrieval)
Expand Down
3 changes: 2 additions & 1 deletion registry/retriever/event_retriever.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,9 +69,10 @@ func NewEventRetriever(
func NewDefaultEventRetriever(
eventProvider regState.EventProvider,
stateRPC state.State,
fieldOverrides ...registry.FieldOverride,
) (EventRetriever, error) {
eventParser := parser.NewEventParser()
registryFactory := registry.NewFactory()
registryFactory := registry.NewFactory(fieldOverrides...)

eventStorageExecutor := exec.NewRetryableExecutor[*types.StorageDataRaw](exec.WithRetryTimeout(1 * time.Second))
eventParsingExecutor := exec.NewRetryableExecutor[[]*parser.Event](exec.WithMaxRetryCount(1))
Expand Down

0 comments on commit 093cfb1

Please sign in to comment.