| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | package commands | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2019-06-25 03:20:21 +08:00
										 |  |  | 	"strings" | 
					
						
							| 
									
										
										
										
											2016-04-12 06:05:28 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-26 22:13:40 +08:00
										 |  |  | 	"github.com/fatih/color" | 
					
						
							| 
									
										
										
										
											2018-09-26 03:31:24 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/bus" | 
					
						
							| 
									
										
										
										
											2019-05-27 16:47:21 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/cmd/grafana-cli/commands/datamigrations" | 
					
						
							| 
									
										
										
										
											2016-06-03 18:19:04 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/cmd/grafana-cli/logger" | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/cmd/grafana-cli/services" | 
					
						
							| 
									
										
										
										
											2019-05-27 16:47:21 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/cmd/grafana-cli/utils" | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/services/sqlstore" | 
					
						
							| 
									
										
										
										
											2021-08-25 21:11:22 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/services/sqlstore/migrations" | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/setting" | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/util/errutil" | 
					
						
							|  |  |  | 	"github.com/urfave/cli/v2" | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-11 13:21:08 +08:00
										 |  |  | func runDbCommand(command func(commandLine utils.CommandLine, sqlStore *sqlstore.SQLStore) error) func(context *cli.Context) error { | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 	return func(context *cli.Context) error { | 
					
						
							| 
									
										
										
										
											2019-05-27 16:47:21 +08:00
										 |  |  | 		cmd := &utils.ContextCommandLine{Context: context} | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		debug := cmd.Bool("debug") | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		configOptions := strings.Split(cmd.String("configOverrides"), " ") | 
					
						
							| 
									
										
										
										
											2021-08-25 21:11:22 +08:00
										 |  |  | 		cfg, err := setting.NewCfgFromArgs(setting.CommandLineArgs{ | 
					
						
							| 
									
										
										
										
											2019-06-25 03:20:21 +08:00
										 |  |  | 			Config:   cmd.ConfigFile(), | 
					
						
							|  |  |  | 			HomePath: cmd.HomePath(), | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 			Args:     append(configOptions, cmd.Args().Slice()...), // tailing arguments have precedence over the options string
 | 
					
						
							| 
									
										
										
										
											2021-08-25 21:11:22 +08:00
										 |  |  | 		}) | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 			return errutil.Wrap("failed to load configuration", err) | 
					
						
							| 
									
										
										
										
											2019-10-15 22:44:15 +08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-25 03:20:21 +08:00
										 |  |  | 		if debug { | 
					
						
							|  |  |  | 			cfg.LogConfigSources() | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2019-06-17 18:27:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-25 21:11:22 +08:00
										 |  |  | 		sqlStore, err := sqlstore.ProvideService(cfg, nil, bus.GetBus(), &migrations.OSSMigrations{}) | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			return errutil.Wrap("failed to initialize SQL store", err) | 
					
						
							| 
									
										
										
										
											2019-10-15 22:44:15 +08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-25 21:11:22 +08:00
										 |  |  | 		if err := command(cmd, sqlStore); err != nil { | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 			return err | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2019-03-28 00:53:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		logger.Info("\n\n") | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		return nil | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | func runPluginCommand(command func(commandLine utils.CommandLine) error) func(context *cli.Context) error { | 
					
						
							|  |  |  | 	return func(context *cli.Context) error { | 
					
						
							| 
									
										
										
										
											2019-05-27 16:47:21 +08:00
										 |  |  | 		cmd := &utils.ContextCommandLine{Context: context} | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | 		if err := command(cmd); err != nil { | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 			return err | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2019-03-28 00:53:49 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-26 22:13:40 +08:00
										 |  |  | 		logger.Info(color.GreenString("Please restart Grafana after installing plugins. Refer to Grafana documentation for instructions if necessary.\n\n")) | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		return nil | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-14 05:01:12 +08:00
										 |  |  | func runCueCommand(command func(commandLine utils.CommandLine) error) func(context *cli.Context) error { | 
					
						
							|  |  |  | 	return func(context *cli.Context) error { | 
					
						
							|  |  |  | 		return command(&utils.ContextCommandLine{Context: context}) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | // Command contains command state.
 | 
					
						
							|  |  |  | type Command struct { | 
					
						
							|  |  |  | 	Client utils.ApiClient | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var cmd Command = Command{ | 
					
						
							|  |  |  | 	Client: &services.GrafanaComClient{}, | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var pluginCommands = []*cli.Command{ | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		Name:   "install", | 
					
						
							| 
									
										
										
										
											2016-07-27 15:41:33 +08:00
										 |  |  | 		Usage:  "install <plugin id> <plugin version (optional)>", | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		Action: runPluginCommand(cmd.installCommand), | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | 	}, { | 
					
						
							|  |  |  | 		Name:   "list-remote", | 
					
						
							|  |  |  | 		Usage:  "list remote available plugins", | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		Action: runPluginCommand(cmd.listRemoteCommand), | 
					
						
							| 
									
										
										
										
											2016-07-27 15:41:33 +08:00
										 |  |  | 	}, { | 
					
						
							|  |  |  | 		Name:   "list-versions", | 
					
						
							|  |  |  | 		Usage:  "list-versions <plugin id>", | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		Action: runPluginCommand(cmd.listVersionsCommand), | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | 	}, { | 
					
						
							| 
									
										
										
										
											2016-04-12 06:05:28 +08:00
										 |  |  | 		Name:    "update", | 
					
						
							|  |  |  | 		Usage:   "update <plugin id>", | 
					
						
							|  |  |  | 		Aliases: []string{"upgrade"}, | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		Action:  runPluginCommand(cmd.upgradeCommand), | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | 	}, { | 
					
						
							| 
									
										
										
										
											2016-04-12 06:05:28 +08:00
										 |  |  | 		Name:    "update-all", | 
					
						
							|  |  |  | 		Aliases: []string{"upgrade-all"}, | 
					
						
							|  |  |  | 		Usage:   "update all your installed plugins", | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		Action:  runPluginCommand(cmd.upgradeAllCommand), | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | 	}, { | 
					
						
							|  |  |  | 		Name:   "ls", | 
					
						
							|  |  |  | 		Usage:  "list all installed plugins", | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		Action: runPluginCommand(cmd.lsCommand), | 
					
						
							| 
									
										
										
										
											2016-04-11 20:49:12 +08:00
										 |  |  | 	}, { | 
					
						
							| 
									
										
										
										
											2016-06-23 14:21:55 +08:00
										 |  |  | 		Name:    "uninstall", | 
					
						
							|  |  |  | 		Aliases: []string{"remove"}, | 
					
						
							|  |  |  | 		Usage:   "uninstall <plugin id>", | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		Action:  runPluginCommand(cmd.removeCommand), | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 	}, | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | var adminCommands = []*cli.Command{ | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2016-12-09 22:25:02 +08:00
										 |  |  | 		Name:   "reset-admin-password", | 
					
						
							|  |  |  | 		Usage:  "reset-admin-password <new password>", | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 		Action: runDbCommand(resetPasswordCommand), | 
					
						
							| 
									
										
										
										
											2020-07-02 22:29:10 +08:00
										 |  |  | 		Flags: []cli.Flag{ | 
					
						
							|  |  |  | 			&cli.BoolFlag{ | 
					
						
							|  |  |  | 				Name:  "password-from-stdin", | 
					
						
							|  |  |  | 				Usage: "Read the password from stdin", | 
					
						
							|  |  |  | 				Value: false, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2019-05-27 16:47:21 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		Name:  "data-migration", | 
					
						
							|  |  |  | 		Usage: "Runs a script that migrates or cleanups data in your db", | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | 		Subcommands: []*cli.Command{ | 
					
						
							| 
									
										
										
										
											2019-05-27 16:47:21 +08:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				Name:   "encrypt-datasource-passwords", | 
					
						
							|  |  |  | 				Usage:  "Migrates passwords from unsecured fields to secure_json_data field. Return ok unless there is an error. Safe to execute multiple times.", | 
					
						
							| 
									
										
										
										
											2020-06-01 23:11:25 +08:00
										 |  |  | 				Action: runDbCommand(datamigrations.EncryptDatasourcePasswords), | 
					
						
							| 
									
										
										
										
											2019-05-27 16:47:21 +08:00
										 |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2016-02-15 21:09:34 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2016-03-21 17:01:07 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-07 00:21:08 +08:00
										 |  |  | var cueCommands = []*cli.Command{ | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		Name:   "validate-schema", | 
					
						
							| 
									
										
										
										
											2021-07-17 07:53:19 +08:00
										 |  |  | 		Usage:  "validate known *.cue files in the Grafana project", | 
					
						
							| 
									
										
										
										
											2021-08-14 05:01:12 +08:00
										 |  |  | 		Action: runCueCommand(cmd.validateScuemata), | 
					
						
							| 
									
										
										
										
											2021-07-17 07:53:19 +08:00
										 |  |  | 		Description: `validate-schema checks that all CUE schema files are valid with respect | 
					
						
							|  |  |  | to basic standards - valid CUE, valid scuemata, etc. Note that this | 
					
						
							|  |  |  | command checks only paths that existed when grafana-cli was compiled, | 
					
						
							|  |  |  | so must be recompiled to validate newly-added CUE files.`, | 
					
						
							|  |  |  | 		Flags: []cli.Flag{ | 
					
						
							|  |  |  | 			&cli.StringFlag{ | 
					
						
							|  |  |  | 				Name:  "grafana-root", | 
					
						
							|  |  |  | 				Usage: "path to the root of a Grafana repository to validate", | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2021-05-07 00:21:08 +08:00
										 |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2021-05-18 15:30:13 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		Name:   "validate-resource", | 
					
						
							| 
									
										
										
										
											2021-07-16 08:08:03 +08:00
										 |  |  | 		Usage:  "validate resource files (e.g. dashboard JSON) against schema", | 
					
						
							| 
									
										
										
										
											2021-08-14 05:01:12 +08:00
										 |  |  | 		Action: runCueCommand(cmd.validateResources), | 
					
						
							| 
									
										
										
										
											2021-05-18 15:30:13 +08:00
										 |  |  | 		Flags: []cli.Flag{ | 
					
						
							|  |  |  | 			&cli.StringFlag{ | 
					
						
							|  |  |  | 				Name:  "dashboard", | 
					
						
							|  |  |  | 				Usage: "dashboard JSON file to validate", | 
					
						
							|  |  |  | 			}, | 
					
						
							| 
									
										
										
										
											2021-07-16 08:08:03 +08:00
										 |  |  | 			&cli.BoolFlag{ | 
					
						
							|  |  |  | 				Name:  "base-only", | 
					
						
							|  |  |  | 				Usage: "validate using only base schema, not dist (includes plugin schema)", | 
					
						
							|  |  |  | 				Value: false, | 
					
						
							|  |  |  | 			}, | 
					
						
							| 
									
										
										
										
											2021-05-18 15:30:13 +08:00
										 |  |  | 		}, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2021-09-29 16:59:05 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		Name:  "gen-ts", | 
					
						
							|  |  |  | 		Usage: "generate TypeScript from all known CUE file types", | 
					
						
							|  |  |  | 		Description: `gen-ts generates TypeScript from all CUE files at | 
					
						
							|  |  |  | 		expected positions in the filesystem tree of a Grafana repository.`, | 
					
						
							|  |  |  | 		Action: runCueCommand(cmd.generateTypescript), | 
					
						
							|  |  |  | 		Flags: []cli.Flag{ | 
					
						
							|  |  |  | 			&cli.StringFlag{ | 
					
						
							|  |  |  | 				Name:  "grafana-root", | 
					
						
							|  |  |  | 				Usage: "path to the root of a Grafana repository in which to generate TypeScript from CUE files", | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2021-05-07 00:21:08 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-26 19:27:31 +08:00
										 |  |  | var Commands = []*cli.Command{ | 
					
						
							| 
									
										
										
										
											2016-03-21 17:01:07 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		Name:        "plugins", | 
					
						
							|  |  |  | 		Usage:       "Manage plugins for grafana", | 
					
						
							|  |  |  | 		Subcommands: pluginCommands, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2016-12-09 22:25:02 +08:00
										 |  |  | 		Name:        "admin", | 
					
						
							|  |  |  | 		Usage:       "Grafana admin commands", | 
					
						
							|  |  |  | 		Subcommands: adminCommands, | 
					
						
							| 
									
										
										
										
											2016-07-01 05:15:47 +08:00
										 |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2021-05-07 00:21:08 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		Name:        "cue", | 
					
						
							|  |  |  | 		Usage:       "Cue validation commands", | 
					
						
							|  |  |  | 		Subcommands: cueCommands, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2016-03-21 17:01:07 +08:00
										 |  |  | } |