Compare commits

...

18 Commits

Author SHA1 Message Date
李寻欢
d8a8bf4efc Merge pull request '🎨 页面优化' (#58) from hotfix into main
Reviewed-on: https://gitee.ltd/lxh/go-wxhelper/pulls/58
2024-06-17 08:58:51 +08:00
李寻欢
42339e3c51 🎨 页面优化 2024-06-17 08:58:01 +08:00
李寻欢
8f6b7cb68d Merge pull request 'hotfix' (#57) from hotfix into main
Reviewed-on: https://gitee.ltd/lxh/go-wxhelper/pulls/57
2024-06-14 08:36:55 +08:00
李寻欢
20aeeefb3c Merge remote-tracking branch 'origin/hotfix' into hotfix 2024-06-14 08:36:27 +08:00
李寻欢
08ffd4de6c 🎨 修改一个错别字 2024-06-14 08:36:21 +08:00
李寻欢
72a2e694f8 Merge pull request '🎨 优化好友列表同步处理逻辑' (#56) from hotfix into main
Reviewed-on: https://gitee.ltd/lxh/go-wxhelper/pulls/56
2024-06-13 07:02:45 +08:00
李寻欢
2238e23c8d 🎨 优化好友列表同步处理逻辑 2024-06-13 07:02:00 +08:00
李寻欢
a13e39dc0a Merge pull request '🎨 优化好友列表同步处理逻辑' (#55) from hotfix into main
Reviewed-on: https://gitee.ltd/lxh/go-wxhelper/pulls/55
2024-06-12 21:48:04 +08:00
李寻欢
0f506e5afc 🎨 优化好友列表同步处理逻辑 2024-06-12 21:47:35 +08:00
李寻欢
74f19e9d03 Merge pull request 'hotfix' (#54) from hotfix into main
Reviewed-on: https://gitee.ltd/lxh/go-wxhelper/pulls/54
2024-06-06 14:18:58 +08:00
李寻欢
44c45d11f2 Merge remote-tracking branch 'origin/hotfix' into hotfix 2024-06-06 14:18:23 +08:00
李寻欢
50e91680bb 🎨 逻辑优化 2024-06-06 14:18:18 +08:00
李寻欢
3554c95edc Merge pull request '🎨 消息总结新增传入群名称和过滤排行榜及前一天的总结消息' (#53) from hotfix into main
Reviewed-on: https://gitee.ltd/lxh/go-wxhelper/pulls/53
2024-05-31 07:27:55 +08:00
李寻欢
b2598f2406 🎨 消息总结新增传入群名称和过滤排行榜及前一天的总结消息 2024-05-31 07:27:17 +08:00
李寻欢
db8c460b42 Merge pull request '🎨 优化消息格式' (#52) from hotfix into main
Reviewed-on: https://gitee.ltd/lxh/go-wxhelper/pulls/52
2024-05-29 14:12:51 +08:00
李寻欢
6818b10f4a 🎨 优化消息格式 2024-05-29 14:12:26 +08:00
李寻欢
7747a4b634 Merge pull request '🎨 优化消息格式' (#51) from hotfix into main
Reviewed-on: https://gitee.ltd/lxh/go-wxhelper/pulls/51
2024-05-20 08:36:12 +08:00
李寻欢
727b06e143 🎨 优化消息格式 2024-05-16 08:32:44 +08:00
8 changed files with 37 additions and 17 deletions

View File

@@ -42,7 +42,7 @@ mysql:
schema: public # postgres 专用
task:
enable: true
enable: false
news:
enable: true
cron: '14 11 * * *' # 每天0:30
@@ -101,6 +101,10 @@ ai:
model: moonshot-v1-128k
- name: 跃问
model: StepChat
- name: 豆包Lite-4k
model: Doubao-lite-4k
- name: 豆包Pro-4k
model: Doubao-pro-4k
# 资源配置
# map[k]v结构k 会变成全小写,所以这儿不能用大写字母

View File

@@ -4,6 +4,7 @@ import (
"github.com/go-resty/resty/v2"
"go-wechat/utils"
"log"
"net/http"
)
// KfcCrazyThursdayCmd
@@ -33,8 +34,9 @@ func kfcApi1() string {
res := resty.New()
resp, err := res.R().
Post("https://api.jixs.cc/api/wenan-fkxqs/index.php")
if err != nil {
log.Panicf("KFC接口1文案获取失败: %s", err.Error())
if err != nil || resp.StatusCode() != http.StatusOK {
log.Printf("KFC接口1文案获取失败: %v", err)
return ""
}
log.Printf("KFC接口1文案获取结果: %s", resp.String())
return resp.String()
@@ -58,8 +60,9 @@ func kfcApi2() string {
resp, err := res.R().
SetResult(&resData).
Post("https://api.jixs.cc/api/wenan-fkxqs/index.php")
if err != nil {
log.Panicf("KFC接口2文案获取失败: %s", err.Error())
if err != nil || resp.StatusCode() != http.StatusOK {
log.Printf("KFC接口2文案获取失败: %v", err)
return ""
}
log.Printf("KFC接口2文案获取结果: %s", resp.String())
if resData.Data.Msg != "" {
@@ -84,8 +87,9 @@ func kfcApi3() string {
resp, err := res.R().
SetResult(&resData).
Post("https://api.pearktrue.cn/api/kfc")
if err != nil {
log.Panicf("KFC接口3文案获取失败: %s", err.Error())
if err != nil || resp.StatusCode() != http.StatusOK {
log.Printf("KFC接口3文案获取失败: %v", err)
return ""
}
log.Printf("KFC接口3文案获取结果: %s", resp.String())
if resData.Text != "" {

View File

@@ -73,6 +73,8 @@ func GetTextMessagesById(id string) (records []vo.TextMessageItem, err error) {
Where("tm.`from_user` = ?", id).
Where(`(tm.type = 1 OR ( tm.type = 49 AND EXTRACTVALUE ( tm.content, "/msg/appmsg/type" ) IN (?) ))`, appMsgList).
Where("DATE ( tm.create_at ) = DATE ( CURDATE() - INTERVAL 1 DAY )").
Where("tm.content NOT LIKE '#昨日水群排行榜%'").
Where("tm.content NOT LIKE '#昨日消息总结%'").
Order("tm.create_at ASC")
err = tx.Find(&records).Error

View File

@@ -44,7 +44,7 @@ func ClearGroupUser() {
for k, v := range memberMap {
ms = append(ms, fmt.Sprintf("昵称:%s\n最后活跃时间%s", k, v))
}
msg := fmt.Sprintf("#清理群成员\n\n很遗憾地通知各位就在刚刚有%d名群友活跃度不够暂时离开了我们,希望还健在的群友引以为戒、保持活跃!\n\n活跃信息: \n%s",
msg := fmt.Sprintf("#清理群成员\n\n很遗憾地通知各位就在刚刚有%d名群友活跃度不够暂时离开了我们,希望还健在的群友引以为戒、保持活跃!\n\n详细信息: \n%s",
memberCount, strings.Join(ms, "\n"))
utils.SendMessage(group.Wxid, "", msg, 0)
}

View File

@@ -103,6 +103,7 @@ func Sync() {
"custom_account": friend.CustomAccount,
"pinyin": friend.Pinyin,
"pinyin_all": friend.PinyinAll,
"is_ok": true,
}
err = tx.Model(&entity.Friend{}).Where("wxid = ?", friend.Wxid).Updates(pm).Error
if err != nil {
@@ -122,18 +123,30 @@ func Sync() {
// 组装成一句话
msg := []string{"#新好友通知\n"}
for wxId, nickname := range newItmes {
msg = append(msg, "微信Id: "+wxId+" -> 昵称: "+nickname)
msg = append(msg, "微信Id: "+wxId+"\n昵称: "+nickname)
}
for _, user := range config.Conf.System.NewFriendNotify.ToUser {
if user != "" {
// 发送一条新消息
utils.SendMessage(user, "", strings.Join(msg, "\n"), 0)
utils.SendMessage(user, "", strings.Join(msg, "\n-------\n"), 0)
}
}
}
// 清理不在列表中的好友
err = tx.Model(&entity.Friend{}).Where("wxid NOT IN (?)", nowIds).Update("is_ok", false).Error
clearPm := map[string]any{
"is_ok": false,
"enable_chat_rank": false,
"enable_welcome": false,
"enable_summary": false,
"enable_news": false,
"clear_member": false,
"enable_ai": false,
}
err = tx.Model(&entity.Friend{}).Where("wxid NOT IN (?)", nowIds).Updates(clearPm).Error
if err != nil {
log.Printf("清理好友失败: %s", err.Error())
}
log.Println("同步好友列表完成")
}

View File

@@ -24,7 +24,7 @@ func DailyNews() {
return
}
newsStr := fmt.Sprintf("#每日早报#\n\n又是新的一天了让我们康康一觉醒来世界又发生了哪些变化~\n\n%s", strings.Join(news, "\n"))
newsStr := fmt.Sprintf("#每日早报\n\n又是新的一天了让我们康康一觉醒来世界又发生了哪些变化~\n\n%s", strings.Join(news, "\n"))
// 循环发送新闻
for _, group := range groups {

View File

@@ -42,11 +42,12 @@ func AiSummary() {
注意,他们可能是多个话题,请仔细甄别。
每一行代表一个人的发言,每一行的的格式为: {"{nickname}": "{content}"}--end--
群名称: %s
聊天记录如下:
%s
`
msg := fmt.Sprintf(msgTmp, strings.Join(content, "\n"))
msg := fmt.Sprintf(msgTmp, group.Nickname, strings.Join(content, "\n"))
// AI总结
messages := []openai.ChatCompletionMessage{

View File

@@ -82,10 +82,6 @@
<select id="location" name="location"
class="mt-2 block w-full rounded-md border-0 py-1.5 pl-3 pr-10 text-gray-900 ring-1 ring-inset ring-gray-300 focus:ring-2 focus:ring-green-600 sm:text-sm sm:leading-6"
onchange="aiModelChange(event, {{.Wxid}})">
<option value="" {{ if eq .AiModel
"" }}selected{{ end }}>默认(gpt-3.5-turbo-0613)
</option>
{{$useModel := .AiModel}}
{{ range $.aiModels }}
<option value="{{.Model}}" {{ if eq $useModel .Model}}selected{{ end }}>