65 lines
1.8 KiB
Go
65 lines
1.8 KiB
Go
package availabilities
|
|
|
|
import "github.com/johannesbuehl/golunteer/backend/pkg/db"
|
|
|
|
type AvailabilityID int
|
|
|
|
type AvailabilityDB struct {
|
|
AvailabilityID AvailabilityID `db:"availabilityID" json:"availabilityID" validate:"required"`
|
|
Availability `validate:"required"`
|
|
}
|
|
|
|
type Availability struct {
|
|
AvailabilityName string `db:"availabilityName" json:"availabilityName" validate:"required"`
|
|
Enabled bool `db:"enabled" json:"enabled"`
|
|
Color string `db:"color" json:"color" validate:"required"`
|
|
}
|
|
|
|
func Add(a Availability) error {
|
|
_, err := db.DB.NamedExec("INSERT INTO AVAILABILITIES (availabilityName, color, enabled) VALUES (:availabilityName, :color, :enabled)", a)
|
|
|
|
return err
|
|
}
|
|
|
|
func Update(a AvailabilityDB) error {
|
|
_, err := db.DB.NamedExec("UPDATE AVAILABILITIES SET availabilityName = :availabilityName, color = :color, enabled = :enabled WHERE availabilityID = :availabilityID", a)
|
|
|
|
return err
|
|
}
|
|
|
|
func Slice() ([]AvailabilityDB, error) {
|
|
// get the availabilitiesRaw from the database
|
|
var availabilitiesRaw []AvailabilityDB
|
|
|
|
if err := db.DB.Select(&availabilitiesRaw, "SELECT * FROM AVAILABILITIES"); err != nil {
|
|
return nil, err
|
|
} else {
|
|
return availabilitiesRaw, nil
|
|
}
|
|
}
|
|
|
|
func Keys() (map[AvailabilityID]Availability, error) {
|
|
if availabilitiesRaw, err := Slice(); err != nil {
|
|
return nil, err
|
|
} else {
|
|
// convert the result in a map
|
|
availabilities := map[AvailabilityID]Availability{}
|
|
|
|
for _, a := range availabilitiesRaw {
|
|
availabilities[a.AvailabilityID] = Availability{
|
|
AvailabilityName: a.AvailabilityName,
|
|
Enabled: a.Enabled,
|
|
Color: a.Color,
|
|
}
|
|
}
|
|
|
|
return availabilities, nil
|
|
}
|
|
}
|
|
|
|
func Delete(id int) error {
|
|
_, err := db.DB.Exec("DELETE FROM AVAILABILITIES WHERE availabilityID = $1", id)
|
|
|
|
return err
|
|
}
|