2020-08-12 02:57:55 +00:00
|
|
|
package migrations
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/ledgerwatch/turbo-geth/common/dbutils"
|
|
|
|
"github.com/ledgerwatch/turbo-geth/common/etl"
|
|
|
|
"github.com/ledgerwatch/turbo-geth/ethdb"
|
|
|
|
)
|
|
|
|
|
2020-08-15 07:11:40 +00:00
|
|
|
var dupSortHashState = Migration{
|
2020-08-12 02:57:55 +00:00
|
|
|
Name: "dupsort_hash_state",
|
|
|
|
Up: func(db ethdb.Database, datadir string, OnLoadCommit etl.LoadCommitHandler) error {
|
|
|
|
if exists, err := db.(ethdb.NonTransactional).BucketExists(dbutils.CurrentStateBucketOld1); err != nil {
|
|
|
|
return err
|
|
|
|
} else if !exists {
|
|
|
|
return OnLoadCommit(db, nil, true)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := db.(ethdb.NonTransactional).ClearBuckets(dbutils.CurrentStateBucket); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
extractFunc := func(k []byte, v []byte, next etl.ExtractNextFunc) error {
|
|
|
|
return next(k, k, v)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := etl.Transform(
|
|
|
|
db,
|
|
|
|
dbutils.CurrentStateBucketOld1,
|
|
|
|
dbutils.CurrentStateBucket,
|
|
|
|
datadir,
|
|
|
|
extractFunc,
|
|
|
|
etl.IdentityLoadFunc,
|
|
|
|
etl.TransformArgs{OnLoadCommit: OnLoadCommit},
|
|
|
|
); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := db.(ethdb.NonTransactional).DropBuckets(dbutils.CurrentStateBucketOld1); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
2020-08-15 07:11:40 +00:00
|
|
|
|
|
|
|
var dupSortPlainState = Migration{
|
|
|
|
Name: "dupsort_plain_state",
|
|
|
|
Up: func(db ethdb.Database, datadir string, OnLoadCommit etl.LoadCommitHandler) error {
|
|
|
|
if exists, err := db.(ethdb.NonTransactional).BucketExists(dbutils.PlainStateBucketOld1); err != nil {
|
|
|
|
return err
|
|
|
|
} else if !exists {
|
|
|
|
return OnLoadCommit(db, nil, true)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := db.(ethdb.NonTransactional).ClearBuckets(dbutils.PlainStateBucket); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
extractFunc := func(k []byte, v []byte, next etl.ExtractNextFunc) error {
|
|
|
|
return next(k, k, v)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := etl.Transform(
|
|
|
|
db,
|
|
|
|
dbutils.PlainStateBucketOld1,
|
|
|
|
dbutils.PlainStateBucket,
|
|
|
|
datadir,
|
|
|
|
extractFunc,
|
|
|
|
etl.IdentityLoadFunc,
|
|
|
|
etl.TransformArgs{OnLoadCommit: OnLoadCommit},
|
|
|
|
); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := db.(ethdb.NonTransactional).DropBuckets(dbutils.PlainStateBucketOld1); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|