diff --git a/pkg/authkit/models/accounts.go b/pkg/authkit/models/accounts.go index 7b8d4b5..a6e6482 100644 --- a/pkg/authkit/models/accounts.go +++ b/pkg/authkit/models/accounts.go @@ -2,10 +2,11 @@ package models import ( "fmt" + "time" + "git.solsynth.dev/hypernet/nexus/pkg/nex" "git.solsynth.dev/hypernet/nexus/pkg/proto" "gorm.io/datatypes" - "time" "github.com/samber/lo" "github.com/spf13/viper" @@ -22,6 +23,7 @@ type Account struct { ConfirmedAt *time.Time `json:"confirmed_at"` SuspendedAt *time.Time `json:"suspended_at"` PermNodes datatypes.JSONMap `json:"perm_nodes"` + Language string `json:"language"` AutomatedBy *Account `json:"automated_by" gorm:"foreignKey:AutomatedID"` AutomatedID *uint `json:"automated_id"` diff --git a/pkg/internal/http/api/accounts_api.go b/pkg/internal/http/api/accounts_api.go index 75f6849..58c1227 100644 --- a/pkg/internal/http/api/accounts_api.go +++ b/pkg/internal/http/api/accounts_api.go @@ -120,6 +120,33 @@ func updateUserinfo(c *fiber.Ctx) error { return c.SendStatus(fiber.StatusOK) } +func updateAccountLanguage(c *fiber.Ctx) error { + if err := exts.EnsureAuthenticated(c); err != nil { + return err + } + user := c.Locals("user").(models.Account) + + var data struct { + Language string `json:"language" validate:"required"` + } + + if err := exts.BindAndValidate(c, &data); err != nil { + return err + } + + if err := database.C.Model(&models.Account{}).Where("id = ?", user.ID). + Updates(&models.Account{Language: data.Language}).Error; err != nil { + return fiber.NewError(fiber.StatusBadRequest, err.Error()) + } + + services.AddEvent(user.ID, "profile.edit.language", strconv.Itoa(int(user.ID)), c.IP(), c.Get(fiber.HeaderUserAgent)) + services.InvalidAuthCacheWithUser(user.ID) + + user.Language = data.Language + + return c.JSON(user) +} + func doRegister(c *fiber.Ctx) error { var data struct { Name string `json:"name" validate:"required,lowercase,alphanum,min=4,max=16"` diff --git a/pkg/internal/http/api/index.go b/pkg/internal/http/api/index.go index 3f1b1f3..bf5ace7 100644 --- a/pkg/internal/http/api/index.go +++ b/pkg/internal/http/api/index.go @@ -61,6 +61,7 @@ func MapAPIs(app *fiber.App, baseURL string) { me.Get("/", getUserinfo) me.Get("/oidc", getUserinfoForOidc) me.Put("/", updateUserinfo) + me.Put("/language", updateAccountLanguage) me.Get("/events", getEvents) me.Get("/tickets", getTickets) me.Delete("/tickets/:ticketId", killTicket)