mukan-ibc/modules/light-clients/08-wasm/keeper/migrations.go
Mukan Erkin Törük 88dd97a9f8
Some checks failed
CodeQL / Analyze (push) Waiting to run
golangci-lint / lint (push) Waiting to run
Tests / Code Coverage / build (amd64) (push) Waiting to run
Tests / Code Coverage / build (arm64) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[additional-args:-tags="test_e2e" name:e2e path:./e2e]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:08-wasm path:./modules/light-clients/08-wasm]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:ibc-go path:.]) (push) Waiting to run
Docker Build & Push Simapp (main) / docker-build (push) Has been cancelled
refactor: replace all github.com upstream refs with git.cw.tr/mukan-network
2026-05-11 03:36:22 +03:00

72 lines
1.8 KiB
Go

package keeper
import (
sdk "git.cw.tr/mukan-network/mukan-sdk/types"
"github.com/cosmos/ibc-go/modules/light-clients/08-wasm/v10/types"
)
// Migrator is a struct for handling in-place store migrations.
type Migrator struct {
keeper Keeper
}
// NewMigrator returns a new Migrator.
func NewMigrator(keeper Keeper) Migrator {
return Migrator{
keeper: keeper,
}
}
// MigrateChecksums migrates the wasm store from using a single key to
// store a list of checksums to using a collections.KeySet to store the checksums.
//
// It grabs the checksums stored previously under the old key and stores
// them in the global KeySet collection. It then deletes the old key and
// the checksums stored under it.
func (m Migrator) MigrateChecksums(ctx sdk.Context) error {
checksums, err := m.getStoredChecksums(ctx)
if err != nil {
return err
}
for _, hash := range checksums {
if err := m.keeper.GetChecksums().Set(ctx, hash); err != nil {
return err
}
}
// delete the previously stored checksums
if err := m.deleteChecksums(ctx); err != nil {
return err
}
m.keeper.Logger(ctx).Info("successfully migrated Checksums to collections")
return nil
}
// getStoredChecksums returns the checksums stored under the KeyChecksums key.
func (m Migrator) getStoredChecksums(ctx sdk.Context) ([][]byte, error) {
store := m.keeper.storeService.OpenKVStore(ctx)
bz, err := store.Get([]byte(types.KeyChecksums))
if err != nil {
return [][]byte{}, err
}
var hashes types.Checksums
err = m.keeper.cdc.Unmarshal(bz, &hashes)
if err != nil {
return [][]byte{}, err
}
return hashes.Checksums, nil
}
// deleteChecksums deletes the checksums stored under the KeyChecksums key.
func (m Migrator) deleteChecksums(ctx sdk.Context) error {
store := m.keeper.storeService.OpenKVStore(ctx)
err := store.Delete([]byte(types.KeyChecksums))
return err
}