mirror of
https://github.com/bakito/adguardhome-sync.git
synced 2025-01-27 09:30:02 +08:00
63 lines
3.5 KiB
Go
63 lines
3.5 KiB
Go
package cmd
|
|
|
|
import (
|
|
"github.com/bakito/adguardhome-sync/pkg/log"
|
|
"github.com/bakito/adguardhome-sync/pkg/sync"
|
|
"github.com/spf13/cobra"
|
|
"github.com/spf13/viper"
|
|
)
|
|
|
|
// 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`,
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
logger = log.GetLogger("run")
|
|
cfg, err := getConfig()
|
|
if err != nil {
|
|
logger.Error(err)
|
|
return err
|
|
}
|
|
|
|
return sync.Sync(cfg)
|
|
},
|
|
}
|
|
|
|
func init() {
|
|
rootCmd.AddCommand(doCmd)
|
|
doCmd.PersistentFlags().String("cron", "", "The cron expression to run in daemon mode")
|
|
_ = viper.BindPFlag(configCron, doCmd.PersistentFlags().Lookup("cron"))
|
|
doCmd.PersistentFlags().Bool("runOnStart", true, "Run the sync job on start.")
|
|
_ = viper.BindPFlag(configRunOnStart, doCmd.PersistentFlags().Lookup("runOnStart"))
|
|
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"))
|
|
|
|
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"))
|
|
doCmd.PersistentFlags().Bool("replica-insecure-skip-verify", false, "Enable Replica instance InsecureSkipVerify")
|
|
_ = viper.BindPFlag(configReplicaInsecureSkipVerify, doCmd.PersistentFlags().Lookup("replica-insecure-skip-verify"))
|
|
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"))
|
|
}
|