|
|
@@ -16,13 +16,14 @@ func init() {
|
|
|
|
|
|
func AddOrUpdateDashboardPermission(cmd *m.AddOrUpdateDashboardPermissionCommand) error {
|
|
|
return inTransaction(func(sess *xorm.Session) error {
|
|
|
- if res, err := sess.Query("SELECT 1 from dashboard_acl WHERE dashboard_id =? and (user_group_id=? or user_id=?)", cmd.DashboardId, cmd.UserGroupId, cmd.UserId); err != nil {
|
|
|
+ if res, err := sess.Query("SELECT 1 from "+dialect.Quote("dashboard_acl")+" WHERE dashboard_id =? and (user_group_id=? or user_id=?)", cmd.DashboardId, cmd.UserGroupId, cmd.UserId); err != nil {
|
|
|
return err
|
|
|
} else if len(res) == 1 {
|
|
|
entity := m.DashboardAcl{
|
|
|
Permissions: cmd.PermissionType,
|
|
|
+ Updated: time.Now(),
|
|
|
}
|
|
|
- if _, err := sess.Cols("permissions").Where("dashboard_id =? and (user_group_id=? or user_id=?)", cmd.DashboardId, cmd.UserGroupId, cmd.UserId).Update(&entity); err != nil {
|
|
|
+ if _, err := sess.Cols("updated", "permissions").Where("dashboard_id =? and (user_group_id=? or user_id=?)", cmd.DashboardId, cmd.UserGroupId, cmd.UserId).Update(&entity); err != nil {
|
|
|
return err
|
|
|
}
|
|
|
|
|
|
@@ -67,8 +68,8 @@ func AddOrUpdateDashboardPermission(cmd *m.AddOrUpdateDashboardPermissionCommand
|
|
|
|
|
|
func RemoveDashboardPermission(cmd *m.RemoveDashboardPermissionCommand) error {
|
|
|
return inTransaction(func(sess *xorm.Session) error {
|
|
|
- var rawSql = "DELETE FROM dashboard_acl WHERE dashboard_id =? and (user_group_id=? or user_id=?)"
|
|
|
- _, err := sess.Exec(rawSql, cmd.DashboardId, cmd.UserGroupId, cmd.UserId)
|
|
|
+ var rawSQL = "DELETE FROM " + dialect.Quote("dashboard_acl") + " WHERE dashboard_id =? and (user_group_id=? or user_id=?)"
|
|
|
+ _, err := sess.Exec(rawSQL, cmd.DashboardId, cmd.UserGroupId, cmd.UserId)
|
|
|
if err != nil {
|
|
|
return err
|
|
|
}
|
|
|
@@ -78,7 +79,19 @@ func RemoveDashboardPermission(cmd *m.RemoveDashboardPermissionCommand) error {
|
|
|
}
|
|
|
|
|
|
func GetDashboardPermissions(query *m.GetDashboardPermissionsQuery) error {
|
|
|
- sess := x.Where("dashboard_id=?", query.DashboardId)
|
|
|
- query.Result = make([]*m.DashboardAcl, 0)
|
|
|
- return sess.Find(&query.Result)
|
|
|
+ rawSQL := `SELECT
|
|
|
+ da.*,
|
|
|
+ u.login AS user_login,
|
|
|
+ u.email AS user_email,
|
|
|
+ ug.name AS user_group
|
|
|
+ FROM` + dialect.Quote("dashboard_acl") + ` as da
|
|
|
+ LEFT OUTER JOIN ` + dialect.Quote("user") + ` AS u ON u.id = da.user_id
|
|
|
+ LEFT OUTER JOIN user_group ug on ug.id = da.user_group_id
|
|
|
+ WHERE dashboard_id=?`
|
|
|
+
|
|
|
+ query.Result = make([]*m.DashboardAclInfoDTO, 0)
|
|
|
+
|
|
|
+ err := x.SQL(rawSQL, query.DashboardId).Find(&query.Result)
|
|
|
+
|
|
|
+ return err
|
|
|
}
|