123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- package chatgpt
- import (
- "context"
- "net/http"
- "net/url"
- "time"
- "github.com/eryajf/chatgpt-dingtalk/public"
- openai "github.com/sashabaranov/go-openai"
- )
- type ChatGPT struct {
- client *openai.Client
- ctx context.Context
- userId string
- maxQuestionLen int
- maxText int
- maxAnswerLen int
- timeOut time.Duration // 超时时间, 0表示不超时
- doneChan chan struct{}
- cancel func()
- ChatContext *ChatContext
- }
- func New(userId string) *ChatGPT {
- var ctx context.Context
- var cancel func()
- ctx, cancel = context.WithTimeout(context.Background(), 600*time.Second)
- timeOutChan := make(chan struct{}, 1)
- go func() {
- <-ctx.Done()
- timeOutChan <- struct{}{} // 发送超时信号,或是提示结束,用于聊天机器人场景,配合GetTimeOutChan() 使用
- }()
- config := openai.DefaultConfig(public.Config.ApiKey)
- if public.Config.AzureOn {
- config = openai.DefaultAzureConfig(
- public.Config.AzureOpenAIToken,
- "https://"+public.Config.AzureResourceName+".openai."+
- "azure.com/",
- )
- } else {
- if public.Config.HttpProxy != "" {
- config.HTTPClient.Transport = &http.Transport{
- // 设置代理
- Proxy: func(req *http.Request) (*url.URL, error) {
- return url.Parse(public.Config.HttpProxy)
- }}
- }
- if public.Config.BaseURL != "" {
- config.BaseURL = public.Config.BaseURL + "/v1"
- }
- }
- return &ChatGPT{
- client: openai.NewClientWithConfig(config),
- ctx: ctx,
- userId: userId,
- maxQuestionLen: public.Config.MaxQuestionLen, // 最大问题长度
- maxAnswerLen: public.Config.MaxAnswerLen, // 最大答案长度
- maxText: public.Config.MaxText, // 最大文本 = 问题 + 回答, 接口限制
- timeOut: public.Config.SessionTimeout,
- doneChan: timeOutChan,
- cancel: func() {
- cancel()
- },
- ChatContext: NewContext(),
- }
- }
- func (c *ChatGPT) Close() {
- c.cancel()
- }
- func (c *ChatGPT) GetDoneChan() chan struct{} {
- return c.doneChan
- }
- func (c *ChatGPT) SetMaxQuestionLen(maxQuestionLen int) int {
- if maxQuestionLen > c.maxText-c.maxAnswerLen {
- maxQuestionLen = c.maxText - c.maxAnswerLen
- }
- c.maxQuestionLen = maxQuestionLen
- return c.maxQuestionLen
- }
|