mirror of
				https://github.com/usememos/memos.git
				synced 2025-10-25 22:07:19 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			123 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package server
 | |
| 
 | |
| import (
 | |
| 	"encoding/json"
 | |
| 	"fmt"
 | |
| 	"net/http"
 | |
| 	"strconv"
 | |
| 
 | |
| 	"github.com/usememos/memos/api"
 | |
| 
 | |
| 	"github.com/labstack/echo/v4"
 | |
| )
 | |
| 
 | |
| func (s *Server) registerShortcutRoutes(g *echo.Group) {
 | |
| 	g.POST("/shortcut", func(c echo.Context) error {
 | |
| 		userID := c.Get(getUserIDContextKey()).(int)
 | |
| 		shortcutCreate := &api.ShortcutCreate{
 | |
| 			CreatorID: userID,
 | |
| 		}
 | |
| 		if err := json.NewDecoder(c.Request().Body).Decode(shortcutCreate); err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusBadRequest, "Malformatted post shortcut request").SetInternal(err)
 | |
| 		}
 | |
| 
 | |
| 		shortcut, err := s.Store.CreateShortcut(shortcutCreate)
 | |
| 		if err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusInternalServerError, "Failed to create shortcut").SetInternal(err)
 | |
| 		}
 | |
| 
 | |
| 		c.Response().Header().Set(echo.HeaderContentType, echo.MIMEApplicationJSONCharsetUTF8)
 | |
| 		if err := json.NewEncoder(c.Response().Writer).Encode(composeResponse(shortcut)); err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusInternalServerError, "Failed to encode shortcut response").SetInternal(err)
 | |
| 		}
 | |
| 		return nil
 | |
| 	})
 | |
| 
 | |
| 	g.PATCH("/shortcut/:shortcutId", func(c echo.Context) error {
 | |
| 		shortcutID, err := strconv.Atoi(c.Param("shortcutId"))
 | |
| 		if err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("ID is not a number: %s", c.Param("shortcutId"))).SetInternal(err)
 | |
| 		}
 | |
| 
 | |
| 		shortcutPatch := &api.ShortcutPatch{
 | |
| 			ID: shortcutID,
 | |
| 		}
 | |
| 		if err := json.NewDecoder(c.Request().Body).Decode(shortcutPatch); err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusBadRequest, "Malformatted patch shortcut request").SetInternal(err)
 | |
| 		}
 | |
| 
 | |
| 		shortcut, err := s.Store.PatchShortcut(shortcutPatch)
 | |
| 		if err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusInternalServerError, "Failed to patch shortcut").SetInternal(err)
 | |
| 		}
 | |
| 
 | |
| 		c.Response().Header().Set(echo.HeaderContentType, echo.MIMEApplicationJSONCharsetUTF8)
 | |
| 		if err := json.NewEncoder(c.Response().Writer).Encode(composeResponse(shortcut)); err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusInternalServerError, "Failed to encode shortcut response").SetInternal(err)
 | |
| 		}
 | |
| 		return nil
 | |
| 	})
 | |
| 
 | |
| 	g.GET("/shortcut", func(c echo.Context) error {
 | |
| 		shortcutFind := &api.ShortcutFind{}
 | |
| 
 | |
| 		if userID, err := strconv.Atoi(c.QueryParam("creatorId")); err == nil {
 | |
| 			shortcutFind.CreatorID = &userID
 | |
| 		} else {
 | |
| 			userID, ok := c.Get(getUserIDContextKey()).(int)
 | |
| 			if !ok {
 | |
| 				return echo.NewHTTPError(http.StatusBadRequest, "Missing user id to find shortcut")
 | |
| 			}
 | |
| 
 | |
| 			shortcutFind.CreatorID = &userID
 | |
| 		}
 | |
| 
 | |
| 		list, err := s.Store.FindShortcutList(shortcutFind)
 | |
| 		if err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusInternalServerError, "Failed to fetch shortcut list").SetInternal(err)
 | |
| 		}
 | |
| 
 | |
| 		c.Response().Header().Set(echo.HeaderContentType, echo.MIMEApplicationJSONCharsetUTF8)
 | |
| 		if err := json.NewEncoder(c.Response().Writer).Encode(composeResponse(list)); err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusInternalServerError, "Failed to encode shortcut list response").SetInternal(err)
 | |
| 		}
 | |
| 		return nil
 | |
| 	})
 | |
| 
 | |
| 	g.GET("/shortcut/:shortcutId", func(c echo.Context) error {
 | |
| 		shortcutID, err := strconv.Atoi(c.Param("shortcutId"))
 | |
| 		if err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("ID is not a number: %s", c.Param("shortcutId"))).SetInternal(err)
 | |
| 		}
 | |
| 
 | |
| 		shortcutFind := &api.ShortcutFind{
 | |
| 			ID: &shortcutID,
 | |
| 		}
 | |
| 		shortcut, err := s.Store.FindShortcut(shortcutFind)
 | |
| 		if err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusInternalServerError, fmt.Sprintf("Failed to fetch shortcut by ID %d", *shortcutFind.ID)).SetInternal(err)
 | |
| 		}
 | |
| 
 | |
| 		c.Response().Header().Set(echo.HeaderContentType, echo.MIMEApplicationJSONCharsetUTF8)
 | |
| 		if err := json.NewEncoder(c.Response().Writer).Encode(composeResponse(shortcut)); err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusInternalServerError, "Failed to encode shortcut response").SetInternal(err)
 | |
| 		}
 | |
| 		return nil
 | |
| 	})
 | |
| 
 | |
| 	g.DELETE("/shortcut/:shortcutId", func(c echo.Context) error {
 | |
| 		shortcutID, err := strconv.Atoi(c.Param("shortcutId"))
 | |
| 		if err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("ID is not a number: %s", c.Param("shortcutId"))).SetInternal(err)
 | |
| 		}
 | |
| 
 | |
| 		shortcutDelete := &api.ShortcutDelete{
 | |
| 			ID: shortcutID,
 | |
| 		}
 | |
| 		if err := s.Store.DeleteShortcut(shortcutDelete); err != nil {
 | |
| 			return echo.NewHTTPError(http.StatusInternalServerError, "Failed to delete shortcut").SetInternal(err)
 | |
| 		}
 | |
| 
 | |
| 		return c.JSON(http.StatusOK, true)
 | |
| 	})
 | |
| }
 |