-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdeepseek.go
More file actions
79 lines (70 loc) · 2.31 KB
/
deepseek.go
File metadata and controls
79 lines (70 loc) · 2.31 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
package syndicate
import (
"context"
"fmt"
"strings"
deepseek "github.com/cohesion-org/deepseek-go"
)
// DeepseekR1Client implementa LLMClient usando el SDK de DeepseekR1.
type DeepseekR1Client struct {
client *deepseek.Client
}
// NewDeepseekR1Client crea un nuevo cliente para DeepseekR1.
// Recibe la API key y el baseURL (por ejemplo, "https://models.inference.ai.azure.com/").
func NewDeepseekR1Client(apiKey, baseURL string) LLMClient {
return &DeepseekR1Client{
client: deepseek.NewClient(apiKey, baseURL),
}
}
// mapToDeepseekMessages convierte nuestro []Message a []deepseek.ChatCompletionMessage,
// cambiando el role "system" por "user" para evitar problemas.
func mapToDeepseekMessages(messages []Message) []deepseek.ChatCompletionMessage {
msgs := make([]deepseek.ChatCompletionMessage, len(messages))
for i, m := range messages {
role := m.Role
if strings.EqualFold(m.Role, RoleSystem) {
role = RoleUser
}
msgs[i] = deepseek.ChatCompletionMessage{
Role: role,
Content: m.Content,
}
}
return msgs
}
// mapFromDeepseekResponse convierte la respuesta de Deepseek en ChatCompletionResponse.
func mapFromDeepseekResponse(resp *deepseek.ChatCompletionResponse) ChatCompletionResponse {
var choices []Choice
for _, c := range resp.Choices {
choices = append(choices, Choice{
Message: Message{
Role: c.Message.Role,
Content: c.Message.Content,
},
FinishReason: FinishReasonStop,
})
}
usage := Usage{
PromptTokens: resp.Usage.PromptTokens,
CompletionTokens: resp.Usage.CompletionTokens,
TotalTokens: resp.Usage.TotalTokens,
}
return ChatCompletionResponse{
Choices: choices,
Usage: usage,
}
}
// CreateChatCompletion envía la solicitud de chat a DeepseekR1.
// Se ignoran tools y ResponseFormat, ya que DeepseekR1 no los soporta.
func (d *DeepseekR1Client) CreateChatCompletion(ctx context.Context, req ChatCompletionRequest) (ChatCompletionResponse, error) {
deepseekReq := &deepseek.ChatCompletionRequest{
Model: req.Model,
Messages: mapToDeepseekMessages(req.Messages),
// DeepseekR1 no soporta tools ni parámetros como Temperature o ResponseFormat.
}
resp, err := d.client.CreateChatCompletion(ctx, deepseekReq)
if err != nil {
return ChatCompletionResponse{}, fmt.Errorf("deepseek error: %w", err)
}
return mapFromDeepseekResponse(resp), nil
}