mirror of https://github.com/guggero/chantools
cmd: add migratedb command
parent
fa62a57e95
commit
729e71f751
@ -0,0 +1,52 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
|
||||
"github.com/guggero/chantools/lnd"
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
type migrateDBCommand struct {
|
||||
ChannelDB string
|
||||
|
||||
cmd *cobra.Command
|
||||
}
|
||||
|
||||
func newMigrateDBCommand() *cobra.Command {
|
||||
cc := &migrateDBCommand{}
|
||||
cc.cmd = &cobra.Command{
|
||||
Use: "migratedb",
|
||||
Short: "Apply all recent lnd channel database migrations",
|
||||
Long: `This command opens an lnd channel database in write mode
|
||||
and applies all recent database migrations to it. This can be used to update
|
||||
an old database file to be compatible with the current version that chantools
|
||||
needs to read the database content.
|
||||
|
||||
CAUTION: Running this command will make it impossible to use the channel DB
|
||||
with an older version of lnd. Downgrading is not possible and you'll need to
|
||||
run lnd v0.12.0-beta or later after using this command!'`,
|
||||
Example: `chantools migratedb \
|
||||
--channeldb ~/.lnd/data/graph/mainnet/channel.db`,
|
||||
RunE: cc.Execute,
|
||||
}
|
||||
cc.cmd.Flags().StringVar(
|
||||
&cc.ChannelDB, "channeldb", "", "lnd channel.db file to "+
|
||||
"migrate",
|
||||
)
|
||||
|
||||
return cc.cmd
|
||||
}
|
||||
|
||||
func (c *migrateDBCommand) Execute(_ *cobra.Command, _ []string) error {
|
||||
// Check that we have a channel DB.
|
||||
if c.ChannelDB == "" {
|
||||
return fmt.Errorf("channel DB is required")
|
||||
}
|
||||
db, err := lnd.OpenDB(c.ChannelDB, false)
|
||||
if err != nil {
|
||||
return fmt.Errorf("error opening DB: %v", err)
|
||||
}
|
||||
|
||||
return db.Close()
|
||||
}
|
@ -0,0 +1,44 @@
|
||||
## chantools migratedb
|
||||
|
||||
Apply all recent lnd channel database migrations
|
||||
|
||||
### Synopsis
|
||||
|
||||
This command opens an lnd channel database in write mode
|
||||
and applies all recent database migrations to it. This can be used to update
|
||||
an old database file to be compatible with the current version that chantools
|
||||
needs to read the database content.
|
||||
|
||||
CAUTION: Running this command will make it impossible to use the channel DB
|
||||
with an older version of lnd. Downgrading is not possible and you'll need to
|
||||
run lnd v0.12.0-beta or later after using this command!'
|
||||
|
||||
```
|
||||
chantools migratedb [flags]
|
||||
```
|
||||
|
||||
### Examples
|
||||
|
||||
```
|
||||
chantools migratedb \
|
||||
--channeldb ~/.lnd/data/graph/mainnet/channel.db
|
||||
```
|
||||
|
||||
### Options
|
||||
|
||||
```
|
||||
--channeldb string lnd channel.db file to migrate
|
||||
-h, --help help for migratedb
|
||||
```
|
||||
|
||||
### Options inherited from parent commands
|
||||
|
||||
```
|
||||
-r, --regtest Indicates if regtest parameters should be used
|
||||
-t, --testnet Indicates if testnet parameters should be used
|
||||
```
|
||||
|
||||
### SEE ALSO
|
||||
|
||||
* [chantools](chantools.md) - Chantools helps recover funds from lightning channels
|
||||
|
Loading…
Reference in New Issue