aboutsummaryrefslogtreecommitdiffstats
path: root/cmd
diff options
context:
space:
mode:
authorMeng-Ying Yang <garfield@dexon.org>2018-12-27 19:22:41 +0800
committerWei-Ning Huang <w@dexon.org>2018-12-28 14:15:39 +0800
commitd6a3661830f80ef57be208cec457d49c44a8d435 (patch)
tree9bcc12b6677df1f05a8992538f787ae600651807 /cmd
parentd19dc5239ff44267f9bd3a9e8c6d182e56dd3a6f (diff)
downloaddexon-d6a3661830f80ef57be208cec457d49c44a8d435.tar
dexon-d6a3661830f80ef57be208cec457d49c44a8d435.tar.gz
dexon-d6a3661830f80ef57be208cec457d49c44a8d435.tar.bz2
dexon-d6a3661830f80ef57be208cec457d49c44a8d435.tar.lz
dexon-d6a3661830f80ef57be208cec457d49c44a8d435.tar.xz
dexon-d6a3661830f80ef57be208cec457d49c44a8d435.tar.zst
dexon-d6a3661830f80ef57be208cec457d49c44a8d435.zip
indexer: support data exporting/forwarding (#103)
To support more effective and flexible blockchain info exploring, we add `indexer` package, defines the flow of indexer dameon, and integrate into dex.Dexon fullnode. For more export options, we use Golang built-in `plugin` package to support mulitple implementations.
Diffstat (limited to 'cmd')
-rw-r--r--cmd/gdex/main.go2
-rw-r--r--cmd/gdex/usage.go7
-rw-r--r--cmd/utils/flags.go23
3 files changed, 32 insertions, 0 deletions
diff --git a/cmd/gdex/main.go b/cmd/gdex/main.go
index 28e918f84..df1be3083 100644
--- a/cmd/gdex/main.go
+++ b/cmd/gdex/main.go
@@ -137,6 +137,8 @@ var (
utils.GpoPercentileFlag,
utils.EWASMInterpreterFlag,
utils.EVMInterpreterFlag,
+ utils.IndexerEnableFlag,
+ utils.IndexerPluginFlag,
configFileFlag,
}
diff --git a/cmd/gdex/usage.go b/cmd/gdex/usage.go
index e657e032b..df63460d0 100644
--- a/cmd/gdex/usage.go
+++ b/cmd/gdex/usage.go
@@ -239,6 +239,13 @@ var AppHelpFlagGroups = []flagGroup{
},
},
{
+ Name: "INDEXER",
+ Flags: []cli.Flag{
+ utils.IndexerEnableFlag,
+ utils.IndexerPluginFlag,
+ },
+ },
+ {
Name: "WHISPER (EXPERIMENTAL)",
Flags: whisperFlags,
},
diff --git a/cmd/utils/flags.go b/cmd/utils/flags.go
index f262d0786..4ecc2865d 100644
--- a/cmd/utils/flags.go
+++ b/cmd/utils/flags.go
@@ -643,6 +643,17 @@ var (
Usage: "External EVM configuration (default = built-in interpreter)",
Value: "",
}
+
+ // Data sources options.
+ IndexerEnableFlag = cli.BoolFlag{
+ Name: "indexer",
+ Usage: "Enable indexer",
+ }
+ IndexerPluginFlag = cli.StringFlag{
+ Name: "indexer.plugin",
+ Usage: "External indexer plugin shared object path",
+ Value: "",
+ }
)
// MakeDataDir retrieves the currently requested data directory, terminating
@@ -1274,6 +1285,18 @@ func SetDexConfig(ctx *cli.Context, stack *node.Node, cfg *dex.Config) {
now.Hour(), now.Minute(), (now.Second()/5+1)*5,
0, now.Location()).Unix()
}
+
+ // Set indexer config.
+ setIndexerConfig(ctx, cfg)
+}
+
+func setIndexerConfig(ctx *cli.Context, cfg *dex.Config) {
+ cfg.Indexer.Enable = ctx.GlobalBool(IndexerEnableFlag.Name)
+ if !cfg.Indexer.Enable {
+ return
+ }
+
+ cfg.Indexer.Plugin = ctx.GlobalString(IndexerPluginFlag.Name)
}
// SetDashboardConfig applies dashboard related command line flags to the config.