|
|
|
@ -1,7 +1,6 @@ |
|
|
|
|
package api |
|
|
|
|
|
|
|
|
|
import ( |
|
|
|
|
"github.com/torkelo/grafana-pro/pkg/api/dtos" |
|
|
|
|
"github.com/torkelo/grafana-pro/pkg/bus" |
|
|
|
|
"github.com/torkelo/grafana-pro/pkg/middleware" |
|
|
|
|
m "github.com/torkelo/grafana-pro/pkg/models" |
|
|
|
@ -53,63 +52,60 @@ func AddCollaborator(c *middleware.Context) { |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
func GetOtherAccounts(c *middleware.Context) { |
|
|
|
|
query := m.GetOtherAccountsQuery{AccountId: c.UserAccount.Id} |
|
|
|
|
err := bus.Dispatch(&query) |
|
|
|
|
|
|
|
|
|
otherAccounts, err := m.GetOtherAccountsFor(c.UserAccount.Id) |
|
|
|
|
if err != nil { |
|
|
|
|
c.JSON(500, utils.DynMap{"message": err.Error()}) |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
var result []*dtos.OtherAccount |
|
|
|
|
result = append(result, &dtos.OtherAccount{ |
|
|
|
|
Id: c.UserAccount.Id, |
|
|
|
|
Role: "owner", |
|
|
|
|
IsUsing: c.UserAccount.Id == c.UserAccount.UsingAccountId, |
|
|
|
|
Name: c.UserAccount.Email, |
|
|
|
|
result := append(query.Result, &m.OtherAccountDTO{ |
|
|
|
|
Id: c.UserAccount.Id, |
|
|
|
|
Role: "owner", |
|
|
|
|
Email: c.UserAccount.Email, |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
for _, other := range otherAccounts { |
|
|
|
|
result = append(result, &dtos.OtherAccount{ |
|
|
|
|
Id: other.Id, |
|
|
|
|
Role: other.Role, |
|
|
|
|
Name: other.Email, |
|
|
|
|
IsUsing: other.Id == c.UserAccount.UsingAccountId, |
|
|
|
|
}) |
|
|
|
|
for _, ac := range result { |
|
|
|
|
if ac.Id == c.UserAccount.UsingAccountId { |
|
|
|
|
ac.IsUsing = true |
|
|
|
|
break |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
c.JSON(200, result) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
func SetUsingAccount(c *middleware.Context) { |
|
|
|
|
usingAccountId := c.ParamsInt64(":id") |
|
|
|
|
|
|
|
|
|
account := c.UserAccount |
|
|
|
|
otherAccounts, err := m.GetOtherAccountsFor(c.UserAccount.Id) |
|
|
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
c.JSON(500, utils.DynMap{"message": err.Error()}) |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// validate that the account id in the list
|
|
|
|
|
valid := false |
|
|
|
|
for _, other := range otherAccounts { |
|
|
|
|
if other.Id == usingAccountId { |
|
|
|
|
valid = true |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if !valid { |
|
|
|
|
c.Status(401) |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
account.UsingAccountId = usingAccountId |
|
|
|
|
err = m.SaveAccount(account) |
|
|
|
|
if err != nil { |
|
|
|
|
c.JSON(500, utils.DynMap{"message": err.Error()}) |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
c.Status(204) |
|
|
|
|
// usingAccountId := c.ParamsInt64(":id")
|
|
|
|
|
//
|
|
|
|
|
// account := c.UserAccount
|
|
|
|
|
// otherAccounts, err := m.GetOtherAccountsFor(c.UserAccount.Id)
|
|
|
|
|
//
|
|
|
|
|
// if err != nil {
|
|
|
|
|
// c.JSON(500, utils.DynMap{"message": err.Error()})
|
|
|
|
|
// return
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// // validate that the account id in the list
|
|
|
|
|
// valid := false
|
|
|
|
|
// for _, other := range otherAccounts {
|
|
|
|
|
// if other.Id == usingAccountId {
|
|
|
|
|
// valid = true
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// if !valid {
|
|
|
|
|
// c.Status(401)
|
|
|
|
|
// return
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// account.UsingAccountId = usingAccountId
|
|
|
|
|
// err = m.SaveAccount(account)
|
|
|
|
|
// if err != nil {
|
|
|
|
|
// c.JSON(500, utils.DynMap{"message": err.Error()})
|
|
|
|
|
// return
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// c.Status(204)
|
|
|
|
|
} |
|
|
|
|