Planner/core/plans.go

125 lines
2.5 KiB
Go
Raw Normal View History

2025-02-12 19:29:00 +01:00
package core
2024-11-09 19:35:44 +01:00
import (
2025-02-11 21:16:39 +01:00
"crypto/rand"
"encoding/base64"
2024-11-09 19:35:44 +01:00
"errors"
2025-02-11 21:16:39 +01:00
"gorm.io/gorm"
2024-11-09 19:35:44 +01:00
)
2025-02-12 20:12:30 +01:00
func CreatePlan(db *gorm.DB, user *User, name string) (*Plan, error) {
join_code := make([]byte, 32)
_, err := rand.Read(join_code)
if err != nil {
return nil, err
}
var plan Plan = Plan{
Name: name,
Owner: user.Username,
Members: []Member{
{
UserID: user.Username,
},
},
JoinCode: base64.URLEncoding.EncodeToString(join_code),
}
result := db.Create(&plan)
if result.Error != nil {
return nil, result.Error
}
return &plan, nil
}
func GetPlan(orm *gorm.DB, id uint) (*Plan, error) {
2024-11-09 19:35:44 +01:00
var plan Plan = Plan{
ID: id,
}
result := orm.Take(&plan)
if errors.Is(result.Error, gorm.ErrRecordNotFound) {
return nil, ErrNotFound
} else if result.Error != nil {
return nil, result.Error
}
return &plan, nil
}
2025-01-14 20:14:07 +01:00
func (p *Plan) GetAllUsers(orm *gorm.DB) ([]Member, error) {
var members []Member
err := orm.Model(p).Association("Members").Find(&members)
return members, err
2024-11-09 19:35:44 +01:00
}
func (p *Plan) IsMember(orm *gorm.DB, u *User) (bool, error) {
2025-01-14 20:14:07 +01:00
var member_count int64
2024-11-09 19:35:44 +01:00
result := orm.
2025-01-14 20:14:07 +01:00
Table("members").
Where("user_id=? AND plan_id=?", u.Username, p.ID).
Count(&member_count).Error
if result != nil {
2024-11-09 19:35:44 +01:00
return false, ErrNotMember
}
2025-01-14 20:14:07 +01:00
return member_count == 1, nil
2024-11-09 19:35:44 +01:00
}
2025-02-11 21:16:39 +01:00
func (p *Plan) GetMember(orm *gorm.DB, u *User) (*Member, error) {
var m Member
result := orm.
Table("members").
Where("user_id=? AND plan_id=?", u.Username, p.ID).
Take(&m).Error
if result != nil {
return nil, ErrNotMember
}
return &m, nil
}
func (p *Plan) HasNonUser(orm *gorm.DB, name string) (bool, error) {
var member_count int64
result := orm.
Table("members").
Where("plan_id=? AND name=?", p.ID, name).
Count(&member_count).Error
if result != nil {
return false, result
}
return member_count == 1, nil
}
func (p *Plan) AddMember(orm *gorm.DB, new_member *Member) error {
if new_member == nil {
return errors.New("Member is nil")
}
new_member.PlanID = p.ID
2025-04-09 18:37:02 +02:00
if new_member.Name != "" {
2025-02-11 21:16:39 +01:00
found, err := p.HasNonUser(orm, new_member.Name)
if err != nil {
return nil
}
if found {
return errors.New("Non user name taken")
}
return orm.Create(&new_member).Error
2025-04-09 18:37:02 +02:00
} else if new_member.UserID != "" {
2025-02-11 21:16:39 +01:00
user, err := GetUser(orm, new_member.UserID)
if err != nil {
return err
}
found, err := p.IsMember(orm, &user)
if err != nil {
return nil
}
if found {
return errors.New("User already is member")
}
2025-02-12 20:12:30 +01:00
return orm.Create(&new_member).Error
2025-02-11 21:16:39 +01:00
} else {
2025-04-09 18:37:02 +02:00
return errors.New("Member object requires one of Name or UserID to be filled")
2025-02-11 21:16:39 +01:00
}
}