2022-06-07 03:24:50 +00:00
|
|
|
package datadir
|
|
|
|
|
|
|
|
import (
|
|
|
|
"path/filepath"
|
|
|
|
)
|
|
|
|
|
2022-06-07 04:54:04 +00:00
|
|
|
// Dirs is the file system folder the node should use for any data storage
|
|
|
|
// requirements. The configured data directory will not be directly shared with
|
|
|
|
// registered services, instead those can use utility methods to create/access
|
|
|
|
// databases or flat files
|
2022-06-07 03:24:50 +00:00
|
|
|
type Dirs struct {
|
2022-08-11 04:17:03 +00:00
|
|
|
DataDir string // usually is a root of all other dirs, but user may mount/symlink any sub-dir
|
2022-06-07 05:08:24 +00:00
|
|
|
RelativeDataDir string // like dataDir, but without filepath.Abs() resolution
|
|
|
|
Chaindata string
|
|
|
|
Tmp string
|
|
|
|
Snap string
|
|
|
|
TxPool string
|
|
|
|
Nodes string
|
2022-06-07 03:24:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func New(datadir string) Dirs {
|
2022-06-07 05:08:24 +00:00
|
|
|
relativeDataDir := datadir
|
2022-06-07 04:54:04 +00:00
|
|
|
if datadir != "" {
|
2022-06-07 05:08:24 +00:00
|
|
|
var err error
|
2022-06-07 04:54:04 +00:00
|
|
|
absdatadir, err := filepath.Abs(datadir)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
datadir = absdatadir
|
|
|
|
}
|
|
|
|
|
2022-06-07 03:24:50 +00:00
|
|
|
return Dirs{
|
2022-06-07 05:08:24 +00:00
|
|
|
RelativeDataDir: relativeDataDir,
|
|
|
|
DataDir: datadir,
|
|
|
|
Chaindata: filepath.Join(datadir, "chaindata"),
|
|
|
|
Tmp: filepath.Join(datadir, "etl-temp"),
|
|
|
|
Snap: filepath.Join(datadir, "snapshots"),
|
|
|
|
TxPool: filepath.Join(datadir, "txpool"),
|
|
|
|
Nodes: filepath.Join(datadir, "nodes"),
|
2022-06-07 03:24:50 +00:00
|
|
|
}
|
|
|
|
}
|