2024-11-07 19:07:41 +00:00
|
|
|
package hosts
|
|
|
|
|
|
|
|
import (
|
|
|
|
"gorm.io/gorm"
|
|
|
|
"rul.sh/vaulterm/db"
|
|
|
|
"rul.sh/vaulterm/models"
|
2024-11-10 18:49:18 +07:00
|
|
|
"rul.sh/vaulterm/utils"
|
2024-11-07 19:07:41 +00:00
|
|
|
)
|
|
|
|
|
2024-11-10 18:49:18 +07:00
|
|
|
type Hosts struct {
|
|
|
|
db *gorm.DB
|
|
|
|
User *utils.UserContext
|
|
|
|
}
|
2024-11-07 19:07:41 +00:00
|
|
|
|
2024-11-10 18:49:18 +07:00
|
|
|
func NewRepository(r *Hosts) *Hosts {
|
|
|
|
if r == nil {
|
|
|
|
r = &Hosts{}
|
|
|
|
}
|
|
|
|
r.db = db.Get()
|
|
|
|
return r
|
2024-11-07 19:07:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Hosts) GetAll() ([]*models.Host, error) {
|
2024-11-10 18:49:18 +07:00
|
|
|
query := r.ACL(r.db.Order("id DESC"))
|
|
|
|
|
2024-11-07 19:07:41 +00:00
|
|
|
var rows []*models.Host
|
2024-11-10 18:49:18 +07:00
|
|
|
ret := query.Find(&rows)
|
2024-11-07 19:07:41 +00:00
|
|
|
|
|
|
|
return rows, ret.Error
|
|
|
|
}
|
|
|
|
|
2024-11-09 14:37:09 +00:00
|
|
|
func (r *Hosts) Get(id string) (*models.HostDecrypted, error) {
|
2024-11-10 18:49:18 +07:00
|
|
|
query := r.ACL(r.db)
|
2024-11-07 19:07:41 +00:00
|
|
|
|
2024-11-10 18:49:18 +07:00
|
|
|
var host models.Host
|
|
|
|
ret := query.Joins("Key").Joins("AltKey").Where("hosts.id = ?", id).First(&host)
|
2024-11-07 19:07:41 +00:00
|
|
|
if ret.Error != nil {
|
|
|
|
return nil, ret.Error
|
|
|
|
}
|
|
|
|
|
2024-11-09 14:37:09 +00:00
|
|
|
res, err := host.DecryptKeys()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
2024-11-07 19:07:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return res, ret.Error
|
|
|
|
}
|
|
|
|
|
2024-11-09 10:33:07 +00:00
|
|
|
func (r *Hosts) Exists(id string) (bool, error) {
|
|
|
|
var count int64
|
2024-11-10 18:49:18 +07:00
|
|
|
ret := r.ACL(r.db.Model(&models.Host{}).Where("id = ?", id)).Count(&count)
|
2024-11-09 10:33:07 +00:00
|
|
|
return count > 0, ret.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Hosts) Delete(id string) error {
|
2024-11-10 18:49:18 +07:00
|
|
|
query := r.ACL(r.db)
|
|
|
|
return query.Delete(&models.Host{Model: models.Model{ID: id}}).Error
|
2024-11-09 10:33:07 +00:00
|
|
|
}
|
|
|
|
|
2024-11-07 19:07:41 +00:00
|
|
|
func (r *Hosts) Create(item *models.Host) error {
|
|
|
|
return r.db.Create(item).Error
|
|
|
|
}
|
2024-11-09 10:33:07 +00:00
|
|
|
|
2024-11-09 18:57:36 +00:00
|
|
|
func (r *Hosts) Update(id string, item *models.Host) error {
|
2024-11-10 18:49:18 +07:00
|
|
|
query := r.ACL(r.db.Where("id = ?", id))
|
|
|
|
|
|
|
|
return query.Updates(item).Error
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Hosts) ACL(query *gorm.DB) *gorm.DB {
|
|
|
|
if r.User.IsAdmin {
|
|
|
|
return query
|
|
|
|
}
|
|
|
|
|
|
|
|
return query.Where("hosts.owner_id = ?", r.User.ID)
|
2024-11-09 10:33:07 +00:00
|
|
|
}
|