2023-01-04 13:41:29 -08:00
|
|
|
package db
|
|
|
|
|
2023-01-30 15:50:17 -08:00
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"codeberg.org/u1f320/pronouns.cc/backend/db/queries"
|
|
|
|
)
|
2023-01-04 13:41:29 -08:00
|
|
|
|
|
|
|
type WordStatus int
|
|
|
|
|
|
|
|
const (
|
|
|
|
StatusUnknown WordStatus = 0
|
|
|
|
StatusFavourite WordStatus = 1
|
|
|
|
StatusOkay WordStatus = 2
|
|
|
|
StatusJokingly WordStatus = 3
|
|
|
|
StatusFriendsOnly WordStatus = 4
|
|
|
|
StatusAvoid WordStatus = 5
|
|
|
|
wordStatusMax WordStatus = 6
|
|
|
|
)
|
|
|
|
|
|
|
|
type FieldEntry struct {
|
|
|
|
Value string `json:"value"`
|
|
|
|
Status WordStatus `json:"status"`
|
|
|
|
}
|
|
|
|
|
2023-01-30 15:50:17 -08:00
|
|
|
func (fe FieldEntry) Validate() string {
|
|
|
|
if fe.Value == "" {
|
|
|
|
return "value cannot be empty"
|
|
|
|
}
|
|
|
|
|
|
|
|
if len([]rune(fe.Value)) > FieldEntryMaxLength {
|
|
|
|
return fmt.Sprintf("name must be %d characters or less, is %d", FieldEntryMaxLength, len([]rune(fe.Value)))
|
|
|
|
}
|
|
|
|
|
|
|
|
if fe.Status == StatusUnknown || fe.Status >= wordStatusMax {
|
|
|
|
return fmt.Sprintf("status is invalid, must be between 1 and %d, is %d", wordStatusMax-1, fe.Status)
|
|
|
|
}
|
|
|
|
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
2023-01-04 13:41:29 -08:00
|
|
|
type PronounEntry struct {
|
|
|
|
Pronouns string `json:"pronouns"`
|
|
|
|
DisplayText *string `json:"display_text"`
|
|
|
|
Status WordStatus `json:"status"`
|
|
|
|
}
|
|
|
|
|
2023-01-30 15:50:17 -08:00
|
|
|
func (p PronounEntry) Validate() string {
|
|
|
|
if p.Pronouns == "" {
|
|
|
|
return "pronouns cannot be empty"
|
|
|
|
}
|
|
|
|
|
|
|
|
if p.DisplayText != nil {
|
|
|
|
if len([]rune(*p.DisplayText)) > FieldEntryMaxLength {
|
|
|
|
return fmt.Sprintf("display_text must be %d characters or less, is %d", FieldEntryMaxLength, len([]rune(*p.DisplayText)))
|
2023-01-04 13:41:29 -08:00
|
|
|
}
|
|
|
|
}
|
2023-01-30 15:50:17 -08:00
|
|
|
|
|
|
|
if len([]rune(p.Pronouns)) > FieldEntryMaxLength {
|
|
|
|
return fmt.Sprintf("pronouns must be %d characters or less, is %d", FieldEntryMaxLength, len([]rune(p.Pronouns)))
|
|
|
|
}
|
|
|
|
|
|
|
|
if p.Status == StatusUnknown || p.Status >= wordStatusMax {
|
|
|
|
return fmt.Sprintf("status is invalid, must be between 1 and %d, is %d", wordStatusMax-1, p.Status)
|
|
|
|
}
|
|
|
|
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p PronounEntry) String() string {
|
|
|
|
if p.DisplayText != nil {
|
|
|
|
return *p.DisplayText
|
|
|
|
}
|
|
|
|
|
|
|
|
split := strings.Split(p.Pronouns, "/")
|
|
|
|
if len(split) <= 2 {
|
|
|
|
return strings.Join(split, "/")
|
|
|
|
}
|
|
|
|
|
|
|
|
return strings.Join(split[:1], "/")
|
2023-01-04 13:41:29 -08:00
|
|
|
}
|
|
|
|
|
2023-01-30 15:50:17 -08:00
|
|
|
func dbEntriesToFieldEntries(entries []queries.FieldEntry) []FieldEntry {
|
|
|
|
out := make([]FieldEntry, len(entries))
|
2023-01-04 13:41:29 -08:00
|
|
|
for i := range entries {
|
2023-01-30 15:50:17 -08:00
|
|
|
out[i] = FieldEntry{
|
|
|
|
*entries[i].Value, WordStatus(*entries[i].Status),
|
2023-01-04 13:41:29 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
|
|
|
func entriesToDBEntries(entries []FieldEntry) []queries.FieldEntry {
|
|
|
|
out := make([]queries.FieldEntry, len(entries))
|
|
|
|
for i := range entries {
|
|
|
|
status := int32(entries[i].Status)
|
|
|
|
out[i] = queries.FieldEntry{
|
2023-01-30 15:50:17 -08:00
|
|
|
Value: &entries[i].Value,
|
|
|
|
Status: &status,
|
2023-01-04 13:41:29 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
|
|
|
func pronounEntriesToDBEntries(entries []PronounEntry) []queries.PronounEntry {
|
|
|
|
out := make([]queries.PronounEntry, len(entries))
|
|
|
|
for i := range entries {
|
|
|
|
status := int32(entries[i].Status)
|
|
|
|
out[i] = queries.PronounEntry{
|
2023-01-30 15:50:17 -08:00
|
|
|
Value: &entries[i].Pronouns,
|
|
|
|
DisplayValue: entries[i].DisplayText,
|
|
|
|
Status: &status,
|
2023-01-04 13:41:29 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return out
|
|
|
|
}
|