✨ Account preferred language
This commit is contained in:
parent
509390b38a
commit
820d96f6b0
@ -2,10 +2,11 @@ package models
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"time"
|
||||||
|
|
||||||
"git.solsynth.dev/hypernet/nexus/pkg/nex"
|
"git.solsynth.dev/hypernet/nexus/pkg/nex"
|
||||||
"git.solsynth.dev/hypernet/nexus/pkg/proto"
|
"git.solsynth.dev/hypernet/nexus/pkg/proto"
|
||||||
"gorm.io/datatypes"
|
"gorm.io/datatypes"
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/samber/lo"
|
"github.com/samber/lo"
|
||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
@ -22,6 +23,7 @@ type Account struct {
|
|||||||
ConfirmedAt *time.Time `json:"confirmed_at"`
|
ConfirmedAt *time.Time `json:"confirmed_at"`
|
||||||
SuspendedAt *time.Time `json:"suspended_at"`
|
SuspendedAt *time.Time `json:"suspended_at"`
|
||||||
PermNodes datatypes.JSONMap `json:"perm_nodes"`
|
PermNodes datatypes.JSONMap `json:"perm_nodes"`
|
||||||
|
Language string `json:"language"`
|
||||||
|
|
||||||
AutomatedBy *Account `json:"automated_by" gorm:"foreignKey:AutomatedID"`
|
AutomatedBy *Account `json:"automated_by" gorm:"foreignKey:AutomatedID"`
|
||||||
AutomatedID *uint `json:"automated_id"`
|
AutomatedID *uint `json:"automated_id"`
|
||||||
|
@ -120,6 +120,33 @@ func updateUserinfo(c *fiber.Ctx) error {
|
|||||||
return c.SendStatus(fiber.StatusOK)
|
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 {
|
func doRegister(c *fiber.Ctx) error {
|
||||||
var data struct {
|
var data struct {
|
||||||
Name string `json:"name" validate:"required,lowercase,alphanum,min=4,max=16"`
|
Name string `json:"name" validate:"required,lowercase,alphanum,min=4,max=16"`
|
||||||
|
@ -61,6 +61,7 @@ func MapAPIs(app *fiber.App, baseURL string) {
|
|||||||
me.Get("/", getUserinfo)
|
me.Get("/", getUserinfo)
|
||||||
me.Get("/oidc", getUserinfoForOidc)
|
me.Get("/oidc", getUserinfoForOidc)
|
||||||
me.Put("/", updateUserinfo)
|
me.Put("/", updateUserinfo)
|
||||||
|
me.Put("/language", updateAccountLanguage)
|
||||||
me.Get("/events", getEvents)
|
me.Get("/events", getEvents)
|
||||||
me.Get("/tickets", getTickets)
|
me.Get("/tickets", getTickets)
|
||||||
me.Delete("/tickets/:ticketId", killTicket)
|
me.Delete("/tickets/:ticketId", killTicket)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user