tencent_ocr/.history/pkg/handler/ocr_20250115162804.go
2025-01-15 16:59:27 +08:00

86 lines
2.0 KiB
Go

package handler
import (
"context"
"net/http"
"github.com/gin-gonic/gin"
"tencent_ocr/pkg/service"
"tencent_ocr/pkg/middleware"
"tencent_ocr/pkg/errors"
)
type OCRHandler struct {
ocrService *service.OCRService
geminiService *service.GeminiService
}
func NewOCRHandler(ocrService *service.OCRService, geminiService *service.GeminiService) *OCRHandler {
return &OCRHandler{
ocrService: ocrService,
geminiService: geminiService,
}
}
type OCRRequest struct {
ImageBase64 string `json:"image_base64"`
ImageURL string `json:"image_url"`
Scene string `json:"scene"`
}
type OCRResponse struct {
OriginalText string `json:"original_text"`
Result string `json:"result"`
Success bool `json:"success"`
Error string `json:"error,omitempty"`
}
func (h *OCRHandler) HandleOCR(c *gin.Context) {
var req OCRRequest
if err := c.ShouldBindJSON(&req); err != nil {
c.JSON(http.StatusBadRequest, OCRResponse{
Success: false,
Error: "Invalid request format",
})
return
}
// Validate that at least one of ImageURL or ImageBase64 is provided
if req.ImageURL == "" && req.ImageBase64 == "" {
c.JSON(http.StatusBadRequest, OCRResponse{
Success: false,
Error: "Either image_url or image_base64 must be provided",
})
return
}
// Process image
ocrText, err := h.ocrService.ProcessImage(c.Request.Context(), req.ImageBase64)
if err != nil {
status := http.StatusInternalServerError
if errors.IsClientError(err) {
status = http.StatusBadRequest
}
c.JSON(status, OCRResponse{
Success: false,
Error: err.Error(),
})
return
}
// Process with Gemini
processedText, err := h.geminiService.ProcessText(c.Request.Context(), ocrText)
if err != nil {
c.JSON(http.StatusInternalServerError, OCRResponse{
Success: false,
Error: "Text processing failed: " + err.Error(),
})
return
}
c.JSON(http.StatusOK, OCRResponse{
Success: true,
OriginalText: ocrText,
Result: processedText,
})
}