first commit
This commit is contained in:
215
api/handlers/knowledge_handler.go
Normal file
215
api/handlers/knowledge_handler.go
Normal file
@@ -0,0 +1,215 @@
|
||||
package handlers
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"strings"
|
||||
|
||||
"gauth-central/internal/services"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
"github.com/google/uuid"
|
||||
)
|
||||
|
||||
type KnowledgeHandler struct {
|
||||
knowledgeService *services.KnowledgeService
|
||||
}
|
||||
|
||||
func NewKnowledgeHandler(knowledgeService *services.KnowledgeService) *KnowledgeHandler {
|
||||
return &KnowledgeHandler{knowledgeService: knowledgeService}
|
||||
}
|
||||
|
||||
type CreateKnowledgeRequest struct {
|
||||
Title string `json:"title"`
|
||||
ResumeID string `json:"resume_id"`
|
||||
IsActive *bool `json:"is_active"`
|
||||
}
|
||||
|
||||
type UpdateKnowledgeRequest struct {
|
||||
Title *string `json:"title"`
|
||||
ResumeID *string `json:"resume_id"`
|
||||
IsActive *bool `json:"is_active"`
|
||||
}
|
||||
|
||||
// GetAllKnowledges godoc
|
||||
// @Summary Get all active knowledges
|
||||
// @Description Retrieve a list of active knowledge entries
|
||||
// @Tags resume
|
||||
// @Produce json
|
||||
// @Param resume_id query string false "Resume ID"
|
||||
// @Success 200 {array} models.Knowledge
|
||||
// @Failure 400 {object} map[string]string
|
||||
// @Failure 500 {object} map[string]string
|
||||
// @Router /knowledges [get]
|
||||
func (h *KnowledgeHandler) GetAllKnowledges(c *gin.Context) {
|
||||
resumeID := strings.TrimSpace(c.Query("resume_id"))
|
||||
var resumeIDPtr *string
|
||||
if resumeID != "" {
|
||||
resumeIDPtr = &resumeID
|
||||
}
|
||||
items, err := h.knowledgeService.GetAllKnowledges(resumeIDPtr, true)
|
||||
if err != nil {
|
||||
status := http.StatusInternalServerError
|
||||
c.JSON(status, gin.H{"error": err.Error()})
|
||||
return
|
||||
}
|
||||
c.JSON(http.StatusOK, items)
|
||||
}
|
||||
|
||||
// AdminGetAllKnowledges godoc
|
||||
// @Summary Get all knowledges (Admin)
|
||||
// @Description Retrieve a list of all knowledge entries including inactive ones
|
||||
// @Tags admin
|
||||
// @Security ApiKeyAuth
|
||||
// @Produce json
|
||||
// @Param resume_id query string false "Resume ID"
|
||||
// @Success 200 {array} models.Knowledge
|
||||
// @Failure 400 {object} map[string]string
|
||||
// @Failure 500 {object} map[string]string
|
||||
// @Router /admin/knowledges [get]
|
||||
func (h *KnowledgeHandler) AdminGetAllKnowledges(c *gin.Context) {
|
||||
resumeID := strings.TrimSpace(c.Query("resume_id"))
|
||||
var resumeIDPtr *string
|
||||
if resumeID != "" {
|
||||
resumeIDPtr = &resumeID
|
||||
}
|
||||
items, err := h.knowledgeService.GetAllKnowledges(resumeIDPtr, false)
|
||||
if err != nil {
|
||||
status := http.StatusInternalServerError
|
||||
c.JSON(status, gin.H{"error": err.Error()})
|
||||
return
|
||||
}
|
||||
c.JSON(http.StatusOK, items)
|
||||
}
|
||||
|
||||
// AdminGetKnowledgeByID godoc
|
||||
// @Summary Get a knowledge by ID (Admin)
|
||||
// @Description Retrieve details of a specific knowledge entry
|
||||
// @Tags admin
|
||||
// @Security ApiKeyAuth
|
||||
// @Produce json
|
||||
// @Param id path string true "Knowledge ID"
|
||||
// @Success 200 {object} models.Knowledge
|
||||
// @Failure 404 {object} map[string]string
|
||||
// @Router /admin/knowledges/{id} [get]
|
||||
func (h *KnowledgeHandler) AdminGetKnowledgeByID(c *gin.Context) {
|
||||
id := c.Param("id")
|
||||
item, err := h.knowledgeService.GetKnowledgeByID(id)
|
||||
if err != nil {
|
||||
c.JSON(http.StatusNotFound, gin.H{"error": err.Error()})
|
||||
return
|
||||
}
|
||||
c.JSON(http.StatusOK, item)
|
||||
}
|
||||
|
||||
// CreateKnowledge godoc
|
||||
// @Summary Create a new knowledge (Admin)
|
||||
// @Description Create a new knowledge entry
|
||||
// @Tags admin
|
||||
// @Security ApiKeyAuth
|
||||
// @Accept json
|
||||
// @Produce json
|
||||
// @Param request body CreateKnowledgeRequest true "Knowledge Request"
|
||||
// @Success 201 {object} models.Knowledge
|
||||
// @Failure 400 {object} map[string]string
|
||||
// @Router /admin/knowledges [post]
|
||||
func (h *KnowledgeHandler) CreateKnowledge(c *gin.Context) {
|
||||
var req CreateKnowledgeRequest
|
||||
if err := c.ShouldBindJSON(&req); err != nil {
|
||||
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
|
||||
return
|
||||
}
|
||||
|
||||
req.Title = strings.TrimSpace(req.Title)
|
||||
if req.Title == "" {
|
||||
c.JSON(http.StatusBadRequest, gin.H{"error": "title is required"})
|
||||
return
|
||||
}
|
||||
|
||||
isActive := false
|
||||
if req.IsActive != nil {
|
||||
isActive = *req.IsActive
|
||||
}
|
||||
|
||||
resumeUUID, parseErr := parseUUIDPtr(req.ResumeID)
|
||||
if parseErr != nil {
|
||||
c.JSON(http.StatusBadRequest, gin.H{"error": "invalid resume id"})
|
||||
return
|
||||
}
|
||||
item, err := h.knowledgeService.CreateKnowledge(req.Title, resumeUUID, isActive)
|
||||
if err != nil {
|
||||
c.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
|
||||
return
|
||||
}
|
||||
|
||||
c.JSON(http.StatusCreated, item)
|
||||
}
|
||||
|
||||
// UpdateKnowledge godoc
|
||||
// @Summary Update a knowledge (Admin)
|
||||
// @Description Update an existing knowledge entry
|
||||
// @Tags admin
|
||||
// @Security ApiKeyAuth
|
||||
// @Accept json
|
||||
// @Produce json
|
||||
// @Param id path string true "Knowledge ID"
|
||||
// @Param request body UpdateKnowledgeRequest true "Knowledge Request"
|
||||
// @Success 200 {object} models.Knowledge
|
||||
// @Failure 400 {object} map[string]string
|
||||
// @Failure 404 {object} map[string]string
|
||||
// @Router /admin/knowledges/{id} [put]
|
||||
func (h *KnowledgeHandler) UpdateKnowledge(c *gin.Context) {
|
||||
id := c.Param("id")
|
||||
var req UpdateKnowledgeRequest
|
||||
if err := c.ShouldBindJSON(&req); err != nil {
|
||||
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
|
||||
return
|
||||
}
|
||||
|
||||
if req.Title != nil {
|
||||
trimmed := strings.TrimSpace(*req.Title)
|
||||
req.Title = &trimmed
|
||||
}
|
||||
if req.ResumeID != nil {
|
||||
trimmed := strings.TrimSpace(*req.ResumeID)
|
||||
req.ResumeID = &trimmed
|
||||
}
|
||||
|
||||
var resumeUUIDPtr *uuid.UUID
|
||||
if req.ResumeID != nil {
|
||||
parsed, parseErr := parseUUIDPtr(*req.ResumeID)
|
||||
if parseErr != nil {
|
||||
c.JSON(http.StatusBadRequest, gin.H{"error": "invalid resume id"})
|
||||
return
|
||||
}
|
||||
resumeUUIDPtr = parsed
|
||||
}
|
||||
item, err := h.knowledgeService.UpdateKnowledge(id, req.Title, resumeUUIDPtr, req.IsActive)
|
||||
if err != nil {
|
||||
status := http.StatusInternalServerError
|
||||
if err.Error() == "knowledge not found" {
|
||||
status = http.StatusNotFound
|
||||
}
|
||||
c.JSON(status, gin.H{"error": err.Error()})
|
||||
return
|
||||
}
|
||||
|
||||
c.JSON(http.StatusOK, item)
|
||||
}
|
||||
|
||||
// DeleteKnowledge godoc
|
||||
// @Summary Delete a knowledge (Admin)
|
||||
// @Description Delete a knowledge by ID
|
||||
// @Tags admin
|
||||
// @Security ApiKeyAuth
|
||||
// @Param id path string true "Knowledge ID"
|
||||
// @Success 200 {object} map[string]string
|
||||
// @Failure 404 {object} map[string]string
|
||||
// @Router /admin/knowledges/{id} [delete]
|
||||
func (h *KnowledgeHandler) DeleteKnowledge(c *gin.Context) {
|
||||
id := c.Param("id")
|
||||
if err := h.knowledgeService.DeleteKnowledge(id); err != nil {
|
||||
c.JSON(http.StatusNotFound, gin.H{"error": err.Error()})
|
||||
return
|
||||
}
|
||||
c.JSON(http.StatusOK, gin.H{"message": "Knowledge deleted successfully"})
|
||||
}
|
||||
Reference in New Issue
Block a user