🐛 Yeah, fix bugs

This commit is contained in:
LittleSheep 2025-02-21 23:35:52 +08:00
parent 65cb542985
commit a8dbcfdb05
3 changed files with 64 additions and 66 deletions

View File

@ -2,14 +2,12 @@ package api
import ( import (
"git.solsynth.dev/hypernet/messaging/pkg/internal/gap" "git.solsynth.dev/hypernet/messaging/pkg/internal/gap"
"git.solsynth.dev/hypernet/messaging/pkg/internal/http/exts"
"git.solsynth.dev/hypernet/nexus/pkg/nex/cruda" "git.solsynth.dev/hypernet/nexus/pkg/nex/cruda"
"git.solsynth.dev/hypernet/nexus/pkg/nex/sec" "git.solsynth.dev/hypernet/nexus/pkg/nex/sec"
"git.solsynth.dev/hypernet/passport/pkg/authkit" "git.solsynth.dev/hypernet/passport/pkg/authkit"
authm "git.solsynth.dev/hypernet/passport/pkg/authkit/models" authm "git.solsynth.dev/hypernet/passport/pkg/authkit/models"
"strconv" "strconv"
"strings"
"git.solsynth.dev/hypernet/messaging/pkg/internal/http/exts"
"git.solsynth.dev/hypernet/messaging/pkg/internal/database" "git.solsynth.dev/hypernet/messaging/pkg/internal/database"
"git.solsynth.dev/hypernet/messaging/pkg/internal/models" "git.solsynth.dev/hypernet/messaging/pkg/internal/models"
@ -48,31 +46,6 @@ func listChannelMembers(c *fiber.Ctx) error {
} }
} }
func getChannelProfileOfMyself(c *fiber.Ctx) error {
alias := c.Params("channel")
if err := sec.EnsureAuthenticated(c); err != nil {
return err
}
user := c.Locals("user").(authm.Account)
var err error
var channel models.Channel
if val, ok := c.Locals("realm").(authm.Realm); ok {
channel, err = services.GetChannelWithAlias(alias, val.ID)
} else {
channel, err = services.GetChannelWithAlias(alias)
}
if err != nil {
return fiber.NewError(fiber.StatusNotFound, err.Error())
}
if member, err := services.GetChannelMember(user, channel.ID); err != nil {
return fiber.NewError(fiber.StatusNotFound, err.Error())
} else {
return c.JSON(member)
}
}
func addChannelMember(c *fiber.Ctx) error { func addChannelMember(c *fiber.Ctx) error {
if err := sec.EnsureAuthenticated(c); err != nil { if err := sec.EnsureAuthenticated(c); err != nil {
return err return err
@ -132,6 +105,11 @@ func removeChannelMember(c *fiber.Ctx) error {
alias := c.Params("channel") alias := c.Params("channel")
memberId := c.Params("memberId") memberId := c.Params("memberId")
numericId, err := strconv.Atoi(memberId)
if err != nil {
return fiber.NewError(fiber.StatusBadRequest, "invalid member id")
}
var channel models.Channel var channel models.Channel
if err := database.C.Where(&models.Channel{ if err := database.C.Where(&models.Channel{
Alias: alias, Alias: alias,
@ -144,31 +122,17 @@ func removeChannelMember(c *fiber.Ctx) error {
} }
var member models.ChannelMember var member models.ChannelMember
if strings.EqualFold(memberId, "me") { if me, err := services.GetChannelMember(user, channel.ID); err != nil {
if err := database.C.Where(&models.ChannelMember{ return fiber.NewError(fiber.StatusForbidden, err.Error())
BaseModel: cruda.BaseModel{ID: user.ID}, } else if me.PowerLevel < 50 {
ChannelID: channel.ID, return fiber.NewError(fiber.StatusForbidden, "you must be a moderator of a channel to remove member from it")
}).First(&member).Error; err != nil { }
return fiber.NewError(fiber.StatusNotFound, err.Error())
}
} else {
numericId, err := strconv.Atoi(memberId)
if err != nil {
return fiber.NewError(fiber.StatusBadRequest, "invalid member id")
}
if me, err := services.GetChannelMember(user, channel.ID); err != nil { if err := database.C.Where(&models.ChannelMember{
return fiber.NewError(fiber.StatusForbidden, err.Error()) BaseModel: cruda.BaseModel{ID: uint(numericId)},
} else if me.PowerLevel < 50 { ChannelID: channel.ID,
return fiber.NewError(fiber.StatusForbidden, "you must be a moderator of a channel to remove member from it") }).First(&member).Error; err != nil {
} return fiber.NewError(fiber.StatusNotFound, err.Error())
if err := database.C.Where(&models.ChannelMember{
BaseModel: cruda.BaseModel{ID: uint(numericId)},
ChannelID: channel.ID,
}).First(&member).Error; err != nil {
return fiber.NewError(fiber.StatusNotFound, err.Error())
}
} }
if err := services.RemoveChannelMember(member, channel); err != nil { if err := services.RemoveChannelMember(member, channel); err != nil {
@ -178,7 +142,40 @@ func removeChannelMember(c *fiber.Ctx) error {
} }
} }
func editChannelProfileOfMyself(c *fiber.Ctx) error { func deleteChannelIdentity(c *fiber.Ctx) error {
if err := sec.EnsureAuthenticated(c); err != nil {
return err
}
user := c.Locals("user").(authm.Account)
alias := c.Params("channel")
var err error
var channel models.Channel
if val, ok := c.Locals("realm").(authm.Realm); ok {
channel, err = services.GetChannelWithAlias(alias, val.ID)
} else {
channel, err = services.GetChannelWithAlias(alias)
}
if err != nil {
return fiber.NewError(fiber.StatusNotFound, err.Error())
}
var membership models.ChannelMember
if err := database.C.Where(&models.ChannelMember{
ChannelID: channel.ID,
AccountID: user.ID,
}).First(&membership).Error; err != nil {
return fiber.NewError(fiber.StatusNotFound, err.Error())
}
if err = services.RemoveChannelMember(membership, channel); err != nil {
return fiber.NewError(fiber.StatusBadRequest, err.Error())
} else {
return c.JSON(membership)
}
}
func editChannelIdentity(c *fiber.Ctx) error {
if err := sec.EnsureAuthenticated(c); err != nil { if err := sec.EnsureAuthenticated(c); err != nil {
return err return err
} }
@ -226,7 +223,7 @@ func editChannelProfileOfMyself(c *fiber.Ctx) error {
} }
} }
func editChannelNotifyLevelOfMyself(c *fiber.Ctx) error { func editChannelNotifyLevel(c *fiber.Ctx) error {
if err := sec.EnsureAuthenticated(c); err != nil { if err := sec.EnsureAuthenticated(c); err != nil {
return err return err
} }

View File

@ -35,26 +35,28 @@ func getChannel(c *fiber.Ctx) error {
} }
func getChannelIdentity(c *fiber.Ctx) error { func getChannelIdentity(c *fiber.Ctx) error {
alias := c.Params("channel")
if err := sec.EnsureAuthenticated(c); err != nil { if err := sec.EnsureAuthenticated(c); err != nil {
return err return err
} }
user := c.Locals("user").(authm.Account) user := c.Locals("user").(authm.Account)
alias := c.Params("channel")
var err error var err error
var member models.ChannelMember var channel models.Channel
if val, ok := c.Locals("realm").(authm.Realm); ok { if val, ok := c.Locals("realm").(authm.Realm); ok {
_, member, err = services.GetChannelIdentity(alias, user.ID, val) channel, err = services.GetChannelWithAlias(alias, val.ID)
} else { } else {
_, member, err = services.GetChannelIdentity(alias, user.ID) channel, err = services.GetChannelWithAlias(alias)
} }
if err != nil { if err != nil {
return c.SendStatus(fiber.StatusForbidden) return fiber.NewError(fiber.StatusNotFound, err.Error())
} }
return c.JSON(member) if member, err := services.GetChannelMember(user, channel.ID); err != nil {
return fiber.NewError(fiber.StatusNotFound, err.Error())
} else {
return c.JSON(member)
}
} }
func listChannel(c *fiber.Ctx) error { func listChannel(c *fiber.Ctx) error {

View File

@ -20,16 +20,15 @@ func MapAPIs(app *fiber.App, baseURL string) {
channels.Get("/me/available", listAvailableChannel) channels.Get("/me/available", listAvailableChannel)
channels.Get("/:channel", getChannel) channels.Get("/:channel", getChannel)
channels.Get("/:channel/me", getChannelIdentity) channels.Get("/:channel/me", getChannelIdentity)
channels.Put("/:channel/me", editChannelIdentity)
channels.Put("/:channel/me/notify", editChannelNotifyLevel)
channels.Delete("/:channel/me", deleteChannelIdentity)
channels.Post("/", createChannel) channels.Post("/", createChannel)
channels.Post("/dm", createDirectChannel) channels.Post("/dm", createDirectChannel)
channels.Put("/:channelId", editChannel) channels.Put("/:channelId", editChannel)
channels.Delete("/:channelId", deleteChannel) channels.Delete("/:channelId", deleteChannel)
channels.Get("/:channel/members", listChannelMembers) channels.Get("/:channel/members", listChannelMembers)
channels.Get("/:channel/members/me", getChannelProfileOfMyself)
channels.Put("/:channel/members/me", editChannelProfileOfMyself)
channels.Put("/:channel/members/me/notify", editChannelNotifyLevelOfMyself)
channels.Post("/:channel/members", addChannelMember) channels.Post("/:channel/members", addChannelMember)
channels.Delete("/:channel/members/:memberId", removeChannelMember) channels.Delete("/:channel/members/:memberId", removeChannelMember)