All checks were successful
continuous-integration/drone/push Build is passing
83 lines
2.2 KiB
Go
83 lines
2.2 KiB
Go
package models
|
|
|
|
import (
|
|
"errors"
|
|
"log"
|
|
)
|
|
|
|
type Group struct {
|
|
GroupId int `db:"GroupId" json:"groupId"`
|
|
GroupName string `db:"GroupName" json:"groupName"`
|
|
LdapGroup bool `db:"LdapGroup" json:"ldapGroup"`
|
|
LdapDn string `db:"LdapDn" json:"ldapDn"`
|
|
Admin bool `db:"Admin" json:"admin"`
|
|
}
|
|
|
|
// GroupGetByName queries the database for the specified group name
|
|
func GroupGetByName(groupname string) (Group, error) {
|
|
var g Group
|
|
|
|
// Query database for matching group object
|
|
err := db.QueryRowx("SELECT * FROM groups WHERE GroupName=?", groupname).StructScan(&g)
|
|
if err != nil {
|
|
return g, errors.New("group not found")
|
|
}
|
|
|
|
return g, nil
|
|
}
|
|
|
|
// GroupList returns a list of all groups in database
|
|
func GroupList() ([]Group, error) {
|
|
var results []Group
|
|
|
|
// Query database for role definitions
|
|
rows, err := db.Queryx("SELECT * FROM groups")
|
|
|
|
if err != nil {
|
|
log.Printf("GroupList error executing sql record : '%s'\n", err)
|
|
return results, err
|
|
} else {
|
|
// parse all the results into a slice
|
|
for rows.Next() {
|
|
var g Group
|
|
err = rows.StructScan(&g)
|
|
if err != nil {
|
|
log.Printf("GroupList error parsing sql record : '%s'\n", err)
|
|
return results, err
|
|
}
|
|
results = append(results, g)
|
|
|
|
}
|
|
log.Printf("GroupList retrieved '%d' results\n", len(results))
|
|
}
|
|
|
|
return results, nil
|
|
}
|
|
|
|
// GroupAdd adds a new group definition to the database
|
|
func (g *Group) GroupAdd() (*Group, error) {
|
|
var err error
|
|
|
|
// Validate role not already in use
|
|
_, err = GroupGetByName(g.GroupName)
|
|
|
|
if err != nil && err.Error() == "group not found" {
|
|
log.Printf("GroupAdd confirmed no existing group, continuing with creation of group '%s'\n", g.GroupName)
|
|
|
|
result, err := db.NamedExec(("INSERT INTO groups (GroupName, LdapGroup, LdapDn, Admin) VALUES (:GroupName, :LdapGroup, :LdapDn, :Admin);"), g)
|
|
|
|
if err != nil {
|
|
log.Printf("GroupAdd error executing sql record : '%s'\n", err)
|
|
return &Group{}, err
|
|
} else {
|
|
affected, _ := result.RowsAffected()
|
|
id, _ := result.LastInsertId()
|
|
log.Printf("GroupAdd insert returned result id '%d' affecting %d row(s).\n", id, affected)
|
|
}
|
|
} else {
|
|
log.Printf("GroupAdd group name already exists : '%v'\n", err)
|
|
}
|
|
|
|
return g, nil
|
|
}
|