/
permissions.go
89 lines (72 loc) · 2.28 KB
/
permissions.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
// This file is part of the Smart Home
// Program complex distribution https://github.com/e154/smart-home
// Copyright (C) 2016-2020, Filippov Alex
//
// This library is free software: you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 3 of the License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Library General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library. If not, see
// <https://www.gnu.org/licenses/>.
package adaptors
import (
"github.com/jinzhu/gorm"
"github.com/e154/smart-home/db"
m "github.com/e154/smart-home/models"
)
type Permission struct {
table *db.Permissions
db *gorm.DB
}
func GetPermissionAdaptor(d *gorm.DB) *Permission {
return &Permission{
table: &db.Permissions{Db: d},
db: d,
}
}
func (n *Permission) Add(permission *m.Permission) (id int64, err error) {
dbPermission := n.toDb(permission)
if id, err = n.table.Add(dbPermission); err != nil {
return
}
return
}
func (n *Permission) Delete(packageName string, levelName []string) (err error) {
err = n.table.Delete(packageName, levelName)
return
}
func (n *Permission) GetAllPermissions(roleName string) (permissions []*m.Permission, err error) {
var dbPermissions []*db.Permission
if dbPermissions, err = n.table.GetAllPermissions(roleName); err != nil {
return
}
for _, dbVer := range dbPermissions {
ver := n.fromDb(dbVer)
permissions = append(permissions, ver)
}
return
}
func (n *Permission) fromDb(dbPermission *db.Permission) (permission *m.Permission) {
permission = &m.Permission{
Id: dbPermission.Id,
RoleName: dbPermission.RoleName,
PackageName: dbPermission.PackageName,
LevelName: dbPermission.LevelName,
}
return
}
func (n *Permission) toDb(permission *m.Permission) (dbPermission *db.Permission) {
dbPermission = &db.Permission{
RoleName: permission.RoleName,
LevelName: permission.LevelName,
PackageName: permission.PackageName,
}
return
}