Commit f443b708 by Jason Wilder

CLI: Add datasource:info command

Describes the full datasource details given an account and
datasource name.
parent 9cb11703
...@@ -33,7 +33,7 @@ func main() { ...@@ -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 ( ...@@ -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) { ...@@ -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 { ...@@ -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() { ...@@ -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 { ...@@ -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")
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment