313 lines
7.2 KiB
Go
313 lines
7.2 KiB
Go
package controllers
|
|
|
|
import (
|
|
"encoding/json"
|
|
"io"
|
|
"server/models"
|
|
"server/pkg/jwtutil"
|
|
"strconv"
|
|
"strings"
|
|
"time"
|
|
|
|
"github.com/beego/beego/v2/client/orm"
|
|
beego "github.com/beego/beego/v2/server/web"
|
|
)
|
|
|
|
type PlatformNotebookController struct {
|
|
beego.Controller
|
|
}
|
|
|
|
// requireAuth 验证平台用户权限
|
|
func requireNotebookAuth(c *beego.Controller) (*jwtutil.Claims, error) {
|
|
auth := c.Ctx.Request.Header.Get("Authorization")
|
|
if auth == "" {
|
|
return nil, orm.ErrNoRows
|
|
}
|
|
parts := strings.SplitN(auth, " ", 2)
|
|
if len(parts) != 2 || parts[0] != "Bearer" {
|
|
return nil, orm.ErrNoRows
|
|
}
|
|
claims, err := jwtutil.ParseToken(parts[1])
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if claims.UserType != "platform" {
|
|
return nil, orm.ErrNoRows
|
|
}
|
|
return claims, nil
|
|
}
|
|
|
|
// jsonResponse 统一JSON响应
|
|
func jsonResponse(c *beego.Controller, httpStatus, code int, msg string, data interface{}) {
|
|
c.Ctx.Output.SetStatus(httpStatus)
|
|
resp := map[string]interface{}{
|
|
"code": code,
|
|
"msg": msg,
|
|
}
|
|
if data != nil {
|
|
resp["data"] = data
|
|
}
|
|
c.Data["json"] = resp
|
|
_ = c.ServeJSON()
|
|
}
|
|
|
|
// List 获取笔记列表
|
|
// GET /platform/notebook/list
|
|
func (c *PlatformNotebookController) List() {
|
|
claims, err := requireNotebookAuth(&c.Controller)
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 401, 401, "未登录或无权限", nil)
|
|
return
|
|
}
|
|
|
|
page, _ := c.GetInt("page", 1)
|
|
pageSize, _ := c.GetInt("pageSize", 20)
|
|
keyword := strings.TrimSpace(c.GetString("keyword"))
|
|
|
|
if page < 1 {
|
|
page = 1
|
|
}
|
|
if pageSize < 1 || pageSize > 100 {
|
|
pageSize = 20
|
|
}
|
|
|
|
qs := models.Orm.QueryTable(new(models.PlatformNotebook)).
|
|
Filter("is_deleted", 0).
|
|
Filter("user_id", claims.UserID)
|
|
|
|
if keyword != "" {
|
|
qs = qs.Filter("title__icontains", keyword)
|
|
}
|
|
|
|
total, err := qs.Count()
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 500, 500, "查询失败", nil)
|
|
return
|
|
}
|
|
|
|
var list []models.PlatformNotebook
|
|
_, err = qs.OrderBy("-update_time", "-create_time").
|
|
Limit(pageSize).
|
|
Offset((page - 1) * pageSize).
|
|
All(&list)
|
|
|
|
if err != nil && err != orm.ErrNoRows {
|
|
jsonResponse(&c.Controller, 500, 500, "查询失败", nil)
|
|
return
|
|
}
|
|
|
|
if list == nil {
|
|
list = []models.PlatformNotebook{}
|
|
}
|
|
|
|
jsonResponse(&c.Controller, 200, 200, "success", map[string]interface{}{
|
|
"list": list,
|
|
"total": total,
|
|
})
|
|
}
|
|
|
|
// Detail 获取笔记详情
|
|
// GET /platform/notebook/detail/:id
|
|
func (c *PlatformNotebookController) Detail() {
|
|
claims, err := requireNotebookAuth(&c.Controller)
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 401, 401, "未登录或无权限", nil)
|
|
return
|
|
}
|
|
|
|
id, err := strconv.ParseUint(c.Ctx.Input.Param(":id"), 10, 64)
|
|
if err != nil || id == 0 {
|
|
jsonResponse(&c.Controller, 400, 400, "无效ID", nil)
|
|
return
|
|
}
|
|
|
|
var note models.PlatformNotebook
|
|
err = models.Orm.QueryTable(new(models.PlatformNotebook)).
|
|
Filter("id", id).
|
|
Filter("is_deleted", 0).
|
|
Filter("user_id", claims.UserID).
|
|
One(¬e)
|
|
|
|
if err != nil {
|
|
if err == orm.ErrNoRows {
|
|
jsonResponse(&c.Controller, 404, 404, "笔记不存在", nil)
|
|
} else {
|
|
jsonResponse(&c.Controller, 500, 500, "查询失败", nil)
|
|
}
|
|
return
|
|
}
|
|
|
|
jsonResponse(&c.Controller, 200, 200, "success", note)
|
|
}
|
|
|
|
// Create 创建笔记
|
|
// POST /platform/notebook/create
|
|
func (c *PlatformNotebookController) Create() {
|
|
claims, err := requireNotebookAuth(&c.Controller)
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 401, 401, "未登录或无权限", nil)
|
|
return
|
|
}
|
|
|
|
raw, err := io.ReadAll(c.Ctx.Request.Body)
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 400, 400, "参数错误", nil)
|
|
return
|
|
}
|
|
|
|
var payload struct {
|
|
Title string `json:"title"`
|
|
Content string `json:"content"`
|
|
}
|
|
|
|
if err := json.Unmarshal(raw, &payload); err != nil {
|
|
jsonResponse(&c.Controller, 400, 400, "参数错误", nil)
|
|
return
|
|
}
|
|
|
|
payload.Title = strings.TrimSpace(payload.Title)
|
|
if payload.Title == "" {
|
|
payload.Title = "无标题"
|
|
}
|
|
|
|
userID := uint64(claims.UserID)
|
|
note := &models.PlatformNotebook{
|
|
Title: payload.Title,
|
|
Content: payload.Content,
|
|
UserID: &userID,
|
|
UserName: &claims.Username,
|
|
IsDeleted: 0,
|
|
}
|
|
|
|
id, err := models.Orm.Insert(note)
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 500, 500, "创建失败", nil)
|
|
return
|
|
}
|
|
|
|
note.ID = uint64(id)
|
|
jsonResponse(&c.Controller, 200, 200, "创建成功", note)
|
|
}
|
|
|
|
// Update 更新笔记
|
|
// POST /platform/notebook/update/:id
|
|
func (c *PlatformNotebookController) Update() {
|
|
claims, err := requireNotebookAuth(&c.Controller)
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 401, 401, "未登录或无权限", nil)
|
|
return
|
|
}
|
|
|
|
id, err := strconv.ParseUint(c.Ctx.Input.Param(":id"), 10, 64)
|
|
if err != nil || id == 0 {
|
|
jsonResponse(&c.Controller, 400, 400, "无效ID", nil)
|
|
return
|
|
}
|
|
|
|
raw, err := io.ReadAll(c.Ctx.Request.Body)
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 400, 400, "参数错误", nil)
|
|
return
|
|
}
|
|
|
|
var payload struct {
|
|
Title string `json:"title"`
|
|
Content string `json:"content"`
|
|
}
|
|
|
|
if err := json.Unmarshal(raw, &payload); err != nil {
|
|
jsonResponse(&c.Controller, 400, 400, "参数错误", nil)
|
|
return
|
|
}
|
|
|
|
payload.Title = strings.TrimSpace(payload.Title)
|
|
if payload.Title == "" {
|
|
payload.Title = "无标题"
|
|
}
|
|
|
|
// 验证笔记是否存在且属于当前用户
|
|
var note models.PlatformNotebook
|
|
err = models.Orm.QueryTable(new(models.PlatformNotebook)).
|
|
Filter("id", id).
|
|
Filter("is_deleted", 0).
|
|
Filter("user_id", claims.UserID).
|
|
One(¬e)
|
|
|
|
if err != nil {
|
|
if err == orm.ErrNoRows {
|
|
jsonResponse(&c.Controller, 404, 404, "笔记不存在", nil)
|
|
} else {
|
|
jsonResponse(&c.Controller, 500, 500, "查询失败", nil)
|
|
}
|
|
return
|
|
}
|
|
|
|
now := time.Now()
|
|
_, err = models.Orm.QueryTable(new(models.PlatformNotebook)).
|
|
Filter("id", id).
|
|
Update(map[string]interface{}{
|
|
"title": payload.Title,
|
|
"content": payload.Content,
|
|
"update_time": now,
|
|
})
|
|
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 500, 500, "更新失败", nil)
|
|
return
|
|
}
|
|
|
|
note.Title = payload.Title
|
|
note.Content = payload.Content
|
|
note.UpdateTime = &now
|
|
|
|
jsonResponse(&c.Controller, 200, 200, "更新成功", note)
|
|
}
|
|
|
|
// Delete 删除笔记(软删除)
|
|
// DELETE /platform/notebook/delete/:id
|
|
func (c *PlatformNotebookController) Delete() {
|
|
claims, err := requireNotebookAuth(&c.Controller)
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 401, 401, "未登录或无权限", nil)
|
|
return
|
|
}
|
|
|
|
id, err := strconv.ParseUint(c.Ctx.Input.Param(":id"), 10, 64)
|
|
if err != nil || id == 0 {
|
|
jsonResponse(&c.Controller, 400, 400, "无效ID", nil)
|
|
return
|
|
}
|
|
|
|
// 验证笔记是否存在且属于当前用户
|
|
var note models.PlatformNotebook
|
|
err = models.Orm.QueryTable(new(models.PlatformNotebook)).
|
|
Filter("id", id).
|
|
Filter("is_deleted", 0).
|
|
Filter("user_id", claims.UserID).
|
|
One(¬e)
|
|
|
|
if err != nil {
|
|
if err == orm.ErrNoRows {
|
|
jsonResponse(&c.Controller, 404, 404, "笔记不存在", nil)
|
|
} else {
|
|
jsonResponse(&c.Controller, 500, 500, "查询失败", nil)
|
|
}
|
|
return
|
|
}
|
|
|
|
now := time.Now()
|
|
_, err = models.Orm.QueryTable(new(models.PlatformNotebook)).
|
|
Filter("id", id).
|
|
Update(map[string]interface{}{
|
|
"is_deleted": 1,
|
|
"delete_time": now,
|
|
})
|
|
|
|
if err != nil {
|
|
jsonResponse(&c.Controller, 500, 500, "删除失败", nil)
|
|
return
|
|
}
|
|
|
|
jsonResponse(&c.Controller, 200, 200, "删除成功", nil)
|
|
}
|