Commit 68cc3f86 by Torkel Ödegaard

Handle default datasource management

parent d562dcd9
Subproject commit 1b9b8ba2bff651a38592805c9210bd1864dc1e79
Subproject commit 1d769fe41cf348d88636938fcb06afcf3425d45b
......@@ -29,6 +29,7 @@ func GetDataSources(c *middleware.Context) {
Database: ds.Database,
User: ds.User,
BasicAuth: ds.BasicAuth,
IsDefault: ds.IsDefault,
}
}
......@@ -69,8 +70,6 @@ func AddDataSource(c *middleware.Context) {
return
}
//bus.Publish(&m.DataSourceCreatedEvent{Account: c.GetAccountId(), })
c.JsonOK("Datasource added")
}
......
......@@ -30,6 +30,7 @@ type DataSource struct {
User string `json:"user"`
Database string `json:"database"`
BasicAuth bool `json:"basicAuth"`
IsDefault bool `json:"isDefault"`
}
type MetricQueryResultDto struct {
......
......@@ -35,6 +35,7 @@ func getFrontendSettings(c *middleware.Context) (map[string]interface{}, error)
var dsMap = map[string]interface{}{
"type": ds.Type,
"url": url,
"default": ds.IsDefault,
}
if ds.Type == m.DS_INFLUXDB {
......
......@@ -10,11 +10,14 @@ type Msg interface{}
type Bus interface {
Dispatch(msg Msg) error
Publish(msg Msg) error
AddHandler(handler HandlerFunc)
AddEventListener(handler HandlerFunc)
}
type InProcBus struct {
handlers map[string]HandlerFunc
listeners map[string][]HandlerFunc
}
// temp stuff, not sure how to handle bus instance, and init yet
......@@ -23,6 +26,7 @@ var globalBus = New()
func New() Bus {
bus := &InProcBus{}
bus.handlers = make(map[string]HandlerFunc)
bus.listeners = make(map[string][]HandlerFunc)
return bus
}
......@@ -46,17 +50,55 @@ func (b *InProcBus) Dispatch(msg Msg) error {
}
}
func (b *InProcBus) Publish(msg Msg) error {
var msgName = reflect.TypeOf(msg).Elem().Name()
var listeners = b.listeners[msgName]
if len(listeners) == 0 {
return nil
}
var params = make([]reflect.Value, 1)
params[0] = reflect.ValueOf(msg)
for listenerHandler := range listeners {
ret := reflect.ValueOf(listenerHandler).Call(params)
err := ret[0].Interface()
if err != nil {
return err.(error)
}
}
return nil
}
func (b *InProcBus) AddHandler(handler HandlerFunc) {
handlerType := reflect.TypeOf(handler)
queryTypeName := handlerType.In(0).Elem().Name()
b.handlers[queryTypeName] = handler
}
func (b *InProcBus) AddEventListener(handler HandlerFunc) {
handlerType := reflect.TypeOf(handler)
eventName := handlerType.In(0).Elem().Name()
list, exists := b.listeners[eventName]
if !exists {
list = make([]HandlerFunc, 0)
b.listeners[eventName] = list
}
list = append(list, handler)
}
// Package level functions
func AddHandler(implName string, handler HandlerFunc) {
globalBus.AddHandler(handler)
}
// Package level functions
func AddEventListener(handler HandlerFunc) {
globalBus.AddEventListener(handler)
}
func Dispatch(msg Msg) error {
return globalBus.Dispatch(msg)
}
......@@ -43,3 +43,26 @@ func TestQueryHandlerReturn(t *testing.T) {
t.Fatal("Failed to get response from handler")
}
}
func TestEventListeners(t *testing.T) {
bus := New()
count := 0
bus.AddEventListener(func(query *TestQuery) error {
count += 1
return nil
})
bus.AddEventListener(func(query *TestQuery) error {
count += 10
return nil
})
err := bus.Publish(&TestQuery{})
if err != nil {
t.Fatal("Publish event failed " + err.Error())
} else if count != 0 {
t.Fatal("Publish event failed, listeners called: %v, expected: %v", count, 11)
}
}
......@@ -23,7 +23,6 @@ type Account struct {
Company string
NextDashboardId int
UsingAccountId int64
DefaultDataSourceId int64
Created time.Time
Updated time.Time
......@@ -48,11 +47,6 @@ type SetUsingAccountCommand struct {
UsingAccountId int64
}
type SetDefaultDataSourceCommand struct {
AccountId int64
DataSourceId int64
}
// ----------------------
// QUERIES
......
......@@ -33,6 +33,7 @@ type DataSource struct {
User string
Database string
BasicAuth bool
IsDefault bool
Created time.Time
Updated time.Time
......@@ -41,8 +42,9 @@ type DataSource struct {
// ----------------------
// COMMANDS
// Also acts as api DTO
type AddDataSourceCommand struct {
AccountId int64
AccountId int64 `json:"-"`
Name string
Type DsType
Access DsAccess
......@@ -50,10 +52,12 @@ type AddDataSourceCommand struct {
Password string
Database string
User string
IsDefault bool
Result *DataSource
}
// Also acts as api DTO
type UpdateDataSourceCommand struct {
Id int64
AccountId int64
......@@ -64,6 +68,7 @@ type UpdateDataSourceCommand struct {
Password string
User string
Database string
IsDefault bool
}
type DeleteDataSourceCommand struct {
......
package account
import (
"github.com/torkelo/grafana-pro/pkg/bus"
)
func InitAccountService() {
bus.ListenTo()
}
......@@ -45,9 +45,7 @@ func DeleteDataSource(cmd *m.DeleteDataSourceCommand) error {
func AddDataSource(cmd *m.AddDataSourceCommand) error {
return inTransaction(func(sess *xorm.Session) error {
var err error
ds := m.DataSource{
ds := &m.DataSource{
AccountId: cmd.AccountId,
Name: cmd.Name,
Type: cmd.Type,
......@@ -56,23 +54,38 @@ func AddDataSource(cmd *m.AddDataSourceCommand) error {
User: cmd.User,
Password: cmd.Password,
Database: cmd.Database,
IsDefault: cmd.IsDefault,
Created: time.Now(),
Updated: time.Now(),
}
_, err = sess.Insert(&ds)
cmd.Result = &ds
if _, err := sess.Insert(ds); err != nil {
return err
}
if err := updateIsDefaultFlag(ds, sess); err != nil {
return err
}
cmd.Result = ds
return nil
})
}
func updateIsDefaultFlag(ds *m.DataSource, sess *xorm.Session) error {
// Handle is default flag
if ds.IsDefault {
rawSql := "UPDATE data_source SET is_default = 0 WHERE account_id=? AND id <> ?"
if _, err := sess.Exec(rawSql, ds.AccountId, ds.Id); err != nil {
return err
}
}
return nil
}
func UpdateDataSource(cmd *m.UpdateDataSourceCommand) error {
return inTransaction(func(sess *xorm.Session) error {
var err error
ds := m.DataSource{
ds := &m.DataSource{
Id: cmd.Id,
AccountId: cmd.AccountId,
Name: cmd.Name,
......@@ -83,9 +96,17 @@ func UpdateDataSource(cmd *m.UpdateDataSourceCommand) error {
Password: cmd.Password,
Database: cmd.Database,
Updated: time.Now(),
IsDefault: cmd.IsDefault,
}
sess.UseBool("is_default")
_, err := sess.Where("id=? and account_id=?", ds.Id, ds.AccountId).Update(ds)
if err != nil {
return err
}
_, err = sess.Where("id=? and account_id=?", ds.Id, ds.AccountId).Update(&ds)
err = updateIsDefaultFlag(ds, sess)
return err
})
}
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