2021-03-28 20:09:31 +08:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/bakito/adguardhome-sync/pkg/log"
|
|
|
|
"github.com/bakito/adguardhome-sync/pkg/sync"
|
|
|
|
"github.com/spf13/cobra"
|
2021-04-06 03:04:01 +08:00
|
|
|
"github.com/spf13/viper"
|
2021-03-28 20:09:31 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
// runCmd represents the run command
|
|
|
|
var doCmd = &cobra.Command{
|
|
|
|
Use: "run",
|
|
|
|
Short: "Start a synchronisation from origin to replica",
|
|
|
|
Long: `Synchronizes the configuration form an origin instance to a replica`,
|
2021-04-06 01:26:35 +08:00
|
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
2021-03-29 02:00:22 +08:00
|
|
|
logger = log.GetLogger("run")
|
2021-04-06 03:04:01 +08:00
|
|
|
cfg, err := getConfig()
|
|
|
|
if err != nil {
|
2021-03-28 20:09:31 +08:00
|
|
|
logger.Error(err)
|
2021-04-06 01:26:35 +08:00
|
|
|
return err
|
2021-03-28 20:09:31 +08:00
|
|
|
}
|
|
|
|
|
2021-04-06 01:26:35 +08:00
|
|
|
return sync.Sync(cfg)
|
2021-03-28 20:09:31 +08:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
rootCmd.AddCommand(doCmd)
|
2021-03-28 22:29:18 +08:00
|
|
|
doCmd.PersistentFlags().String("cron", "", "The cron expression to run in daemon mode")
|
|
|
|
_ = viper.BindPFlag(configCron, doCmd.PersistentFlags().Lookup("cron"))
|
2021-04-19 04:20:08 +08:00
|
|
|
doCmd.PersistentFlags().Bool("runOnStart", true, "Run the sync job on start.")
|
|
|
|
_ = viper.BindPFlag(configRunOnStart, doCmd.PersistentFlags().Lookup("runOnStart"))
|
2021-03-29 02:39:19 +08:00
|
|
|
doCmd.PersistentFlags().Int("api-port", 8080, "Sync API Port, the API endpoint will be started to enable remote triggering; if 0 port API is disabled.")
|
|
|
|
_ = viper.BindPFlag(configAPIPort, doCmd.PersistentFlags().Lookup("api-port"))
|
|
|
|
doCmd.PersistentFlags().String("api-username", "", "Sync API username")
|
|
|
|
_ = viper.BindPFlag(configAPIUsername, doCmd.PersistentFlags().Lookup("api-username"))
|
|
|
|
doCmd.PersistentFlags().String("api-password", "", "Sync API password")
|
|
|
|
_ = viper.BindPFlag(configAPIPassword, doCmd.PersistentFlags().Lookup("api-password"))
|
2021-03-28 20:09:31 +08:00
|
|
|
|
2021-11-01 15:56:12 +08:00
|
|
|
doCmd.PersistentFlags().Bool("feature-dhcp-server-config", true, "Enable DHCP server config feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureDHCPServerConfig, doCmd.PersistentFlags().Lookup("feature-dhcp-server-config"))
|
|
|
|
doCmd.PersistentFlags().Bool("feature-dhcp-static-leases", true, "Enable DHCP server static leases feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureDHCPStaticLeases, doCmd.PersistentFlags().Lookup("feature-dhcp-static-leases"))
|
|
|
|
|
2021-11-02 01:20:14 +08:00
|
|
|
doCmd.PersistentFlags().Bool("feature-dns-server-config", true, "Enable DNS server config feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureDNServerConfig, doCmd.PersistentFlags().Lookup("feature-dns-server-config"))
|
|
|
|
doCmd.PersistentFlags().Bool("feature-dns-access-lists", true, "Enable DNS server access lists feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureDNSPAccessLists, doCmd.PersistentFlags().Lookup("feature-dns-access-lists"))
|
|
|
|
doCmd.PersistentFlags().Bool("feature-dns-rewrites", true, "Enable DNS rewrites feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureDNSRewrites, doCmd.PersistentFlags().Lookup("feature-dns-rewrites"))
|
|
|
|
doCmd.PersistentFlags().Bool("feature-general-settings", true, "Enable general settings feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureGeneralSettings, doCmd.PersistentFlags().Lookup("feature-general-settings"))
|
2021-11-02 01:38:35 +08:00
|
|
|
_ = viper.BindPFlag("features.generalSettings", doCmd.PersistentFlags().Lookup("feature-general-settings"))
|
2021-11-02 01:20:14 +08:00
|
|
|
doCmd.PersistentFlags().Bool("feature-query-log-config", true, "Enable query log config feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureQueryLogConfig, doCmd.PersistentFlags().Lookup("feature-query-log-config"))
|
|
|
|
doCmd.PersistentFlags().Bool("feature-stats-config", true, "Enable stats config feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureStatsConfig, doCmd.PersistentFlags().Lookup("feature-stats-config"))
|
|
|
|
doCmd.PersistentFlags().Bool("feature-client-settings", true, "Enable client settings feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureClientSettings, doCmd.PersistentFlags().Lookup("feature-client-settings"))
|
|
|
|
doCmd.PersistentFlags().Bool("feature-services", true, "Enable services sync feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureServices, doCmd.PersistentFlags().Lookup("feature-services"))
|
|
|
|
doCmd.PersistentFlags().Bool("feature-filters", true, "Enable filters sync feature")
|
|
|
|
_ = viper.BindPFlag(configFeatureFilters, doCmd.PersistentFlags().Lookup("feature-filters"))
|
|
|
|
|
2021-03-28 20:09:31 +08:00
|
|
|
doCmd.PersistentFlags().String("origin-url", "", "Origin instance url")
|
|
|
|
_ = viper.BindPFlag(configOriginURL, doCmd.PersistentFlags().Lookup("origin-url"))
|
|
|
|
doCmd.PersistentFlags().String("origin-api-path", "/control", "Origin instance API path")
|
|
|
|
_ = viper.BindPFlag(configOriginAPIPath, doCmd.PersistentFlags().Lookup("origin-api-path"))
|
|
|
|
doCmd.PersistentFlags().String("origin-username", "", "Origin instance username")
|
|
|
|
_ = viper.BindPFlag(configOriginUsername, doCmd.PersistentFlags().Lookup("origin-username"))
|
|
|
|
doCmd.PersistentFlags().String("origin-password", "", "Origin instance password")
|
|
|
|
_ = viper.BindPFlag(configOriginPassword, doCmd.PersistentFlags().Lookup("origin-password"))
|
|
|
|
doCmd.PersistentFlags().String("origin-insecure-skip-verify", "", "Enable Origin instance InsecureSkipVerify")
|
|
|
|
_ = viper.BindPFlag(configOriginInsecureSkipVerify, doCmd.PersistentFlags().Lookup("origin-insecure-skip-verify"))
|
|
|
|
|
|
|
|
doCmd.PersistentFlags().String("replica-url", "", "Replica instance url")
|
|
|
|
_ = viper.BindPFlag(configReplicaURL, doCmd.PersistentFlags().Lookup("replica-url"))
|
|
|
|
doCmd.PersistentFlags().String("replica-api-path", "/control", "Replica instance API path")
|
|
|
|
_ = viper.BindPFlag(configReplicaAPIPath, doCmd.PersistentFlags().Lookup("replica-api-path"))
|
|
|
|
doCmd.PersistentFlags().String("replica-username", "", "Replica instance username")
|
|
|
|
_ = viper.BindPFlag(configReplicaUsername, doCmd.PersistentFlags().Lookup("replica-username"))
|
|
|
|
doCmd.PersistentFlags().String("replica-password", "", "Replica instance password")
|
|
|
|
_ = viper.BindPFlag(configReplicaPassword, doCmd.PersistentFlags().Lookup("replica-password"))
|
2021-04-19 04:03:57 +08:00
|
|
|
doCmd.PersistentFlags().Bool("replica-insecure-skip-verify", false, "Enable Replica instance InsecureSkipVerify")
|
2021-03-28 20:09:31 +08:00
|
|
|
_ = viper.BindPFlag(configReplicaInsecureSkipVerify, doCmd.PersistentFlags().Lookup("replica-insecure-skip-verify"))
|
2021-04-19 04:03:57 +08:00
|
|
|
doCmd.PersistentFlags().Bool("replica-auto-setup", false, "Enable automatic setup of new AdguardHome instances. This replaces the setup wizard.")
|
|
|
|
_ = viper.BindPFlag(configReplicaAutoSetup, doCmd.PersistentFlags().Lookup("replica-auto-setup"))
|
2021-03-28 20:09:31 +08:00
|
|
|
}
|