mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
CLI: Add datasource:info command
Describes the full datasource details given an account and datasource name.
This commit is contained in:
2
main.go
2
main.go
@@ -33,7 +33,7 @@ func main() {
|
|||||||
app.Version = version
|
app.Version = version
|
||||||
app.Commands = []cli.Command{cmd.Web, cmd.ImportJson,
|
app.Commands = []cli.Command{cmd.Web, cmd.ImportJson,
|
||||||
cmd.ListAccounts, cmd.CreateAccount, cmd.DeleteAccount,
|
cmd.ListAccounts, cmd.CreateAccount, cmd.DeleteAccount,
|
||||||
cmd.ListDataSources}
|
cmd.ListDataSources, cmd.DescribeDataSource}
|
||||||
app.Flags = append(app.Flags, []cli.Flag{
|
app.Flags = append(app.Flags, []cli.Flag{
|
||||||
cli.StringFlag{
|
cli.StringFlag{
|
||||||
Name: "config",
|
Name: "config",
|
||||||
|
|||||||
@@ -12,12 +12,20 @@ import (
|
|||||||
"text/tabwriter"
|
"text/tabwriter"
|
||||||
)
|
)
|
||||||
|
|
||||||
var ListDataSources = cli.Command{
|
var (
|
||||||
Name: "datasource",
|
ListDataSources = cli.Command{
|
||||||
Usage: "list datasources",
|
Name: "datasource",
|
||||||
Description: "Lists the datasources in the system",
|
Usage: "list datasources",
|
||||||
Action: listDatasources,
|
Description: "Lists the datasources in the system",
|
||||||
}
|
Action: listDatasources,
|
||||||
|
}
|
||||||
|
DescribeDataSource = cli.Command{
|
||||||
|
Name: "datasource:info",
|
||||||
|
Usage: "describe the details of a datasource",
|
||||||
|
Description: "Describes the details of a datasource",
|
||||||
|
Action: describeDataSource,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
func listDatasources(c *cli.Context) {
|
func listDatasources(c *cli.Context) {
|
||||||
setting.NewConfigContext()
|
setting.NewConfigContext()
|
||||||
@@ -50,3 +58,46 @@ func listDatasources(c *cli.Context) {
|
|||||||
}
|
}
|
||||||
w.Flush()
|
w.Flush()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func describeDataSource(c *cli.Context) {
|
||||||
|
setting.NewConfigContext()
|
||||||
|
sqlstore.NewEngine()
|
||||||
|
sqlstore.EnsureAdminUser()
|
||||||
|
|
||||||
|
if len(c.Args()) != 2 {
|
||||||
|
log.ConsoleFatal("Account and datasource name args are required")
|
||||||
|
}
|
||||||
|
|
||||||
|
name := c.Args().First()
|
||||||
|
ds := c.Args()[1]
|
||||||
|
|
||||||
|
accountQuery := m.GetAccountByNameQuery{Name: name}
|
||||||
|
if err := bus.Dispatch(&accountQuery); err != nil {
|
||||||
|
log.ConsoleFatalf("Failed to find account: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
accountId := accountQuery.Result.Id
|
||||||
|
|
||||||
|
query := m.GetDataSourceByNameQuery{AccountId: accountId, Name: ds}
|
||||||
|
if err := bus.Dispatch(&query); err != nil {
|
||||||
|
log.ConsoleFatalf("Failed to find accounts: %s", err)
|
||||||
|
}
|
||||||
|
datasource := query.Result
|
||||||
|
|
||||||
|
w := tabwriter.NewWriter(os.Stdout, 20, 1, 4, ' ', 0)
|
||||||
|
fmt.Fprintf(w, "NAME\t%s\n", datasource.Name)
|
||||||
|
fmt.Fprintf(w, "URL\t%s\n", datasource.Url)
|
||||||
|
fmt.Fprintf(w, "DEFAULT\t%t\n", datasource.IsDefault)
|
||||||
|
fmt.Fprintf(w, "ACCESS\t%s\n", datasource.Access)
|
||||||
|
fmt.Fprintf(w, "TYPE\t%s\n", datasource.Type)
|
||||||
|
|
||||||
|
switch datasource.Type {
|
||||||
|
case m.DS_INFLUXDB:
|
||||||
|
fmt.Fprintf(w, "DATABASE\t%s\n", datasource.Database)
|
||||||
|
fmt.Fprintf(w, "DB USER\t%s\n", datasource.User)
|
||||||
|
fmt.Fprintf(w, "DB PASSWORD\t%s\n", datasource.Password)
|
||||||
|
case m.DS_ES:
|
||||||
|
fmt.Fprintf(w, "INDEX\t%s\n", datasource.Database)
|
||||||
|
}
|
||||||
|
w.Flush()
|
||||||
|
}
|
||||||
|
|||||||
@@ -93,6 +93,12 @@ type GetDataSourceByIdQuery struct {
|
|||||||
Result DataSource
|
Result DataSource
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type GetDataSourceByNameQuery struct {
|
||||||
|
Name string
|
||||||
|
AccountId int64
|
||||||
|
Result DataSource
|
||||||
|
}
|
||||||
|
|
||||||
// ---------------------
|
// ---------------------
|
||||||
// EVENTS
|
// EVENTS
|
||||||
type DataSourceCreatedEvent struct {
|
type DataSourceCreatedEvent struct {
|
||||||
|
|||||||
@@ -15,6 +15,7 @@ func init() {
|
|||||||
bus.AddHandler("sql", DeleteDataSource)
|
bus.AddHandler("sql", DeleteDataSource)
|
||||||
bus.AddHandler("sql", UpdateDataSource)
|
bus.AddHandler("sql", UpdateDataSource)
|
||||||
bus.AddHandler("sql", GetDataSourceById)
|
bus.AddHandler("sql", GetDataSourceById)
|
||||||
|
bus.AddHandler("sql", GetDataSourceByName)
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetDataSourceById(query *m.GetDataSourceByIdQuery) error {
|
func GetDataSourceById(query *m.GetDataSourceByIdQuery) error {
|
||||||
@@ -27,6 +28,16 @@ func GetDataSourceById(query *m.GetDataSourceByIdQuery) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func GetDataSourceByName(query *m.GetDataSourceByNameQuery) error {
|
||||||
|
sess := x.Limit(100, 0).Where("account_id=? AND name=?", query.AccountId, query.Name)
|
||||||
|
has, err := sess.Get(&query.Result)
|
||||||
|
|
||||||
|
if !has {
|
||||||
|
return m.ErrDataSourceNotFound
|
||||||
|
}
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
func GetDataSources(query *m.GetDataSourcesQuery) error {
|
func GetDataSources(query *m.GetDataSourcesQuery) error {
|
||||||
sess := x.Limit(100, 0).Where("account_id=?", query.AccountId).Asc("name")
|
sess := x.Limit(100, 0).Where("account_id=?", query.AccountId).Asc("name")
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user