refactor: 更新 RSS 订阅功能,调整 TestRss 函数以异步检查新 RSS,修改 SubscribeToFeed 函数返回值以包含订阅标题,增强代码可读性和功能性
This commit is contained in:
parent
aa52fb16d1
commit
791f411596
@ -22,24 +22,12 @@ func init() {
|
||||
handler.RegisterAtHandler("我的订阅", MySubscribed, constants.LEVEL_USER)
|
||||
handler.RegisterAtHandler("退订", Unsubscribe, constants.LEVEL_USER)
|
||||
//test
|
||||
handler.RegisterHandler("test_rss", TestRss, constants.LEVEL_USER)
|
||||
handler.RegisterHandler("test_rss", TestRss, constants.LEVEL_ADMIN)
|
||||
}
|
||||
|
||||
func TestRss(msg model.Message) (reply *model.Reply) {
|
||||
rssUrl := util.SplitN(msg.StructuredMsg[0].(*qq_message.TextMessage).Data.Text, 2)[1]
|
||||
title, items, err := ParseFeed(rssUrl)
|
||||
if err != nil {
|
||||
return &model.Reply{
|
||||
ReplyMsg: "解析RSS源失败: " + err.Error(),
|
||||
ReferOriginMsg: true,
|
||||
FromMsg: msg,
|
||||
}
|
||||
}
|
||||
return &model.Reply{
|
||||
ReplyMsg: fmt.Sprintf("解析RSS源成功: %s\n%d 个条目\n%v", title, len(items), items[0]),
|
||||
ReferOriginMsg: true,
|
||||
FromMsg: msg,
|
||||
}
|
||||
go CheckNewRss()
|
||||
return nil
|
||||
}
|
||||
|
||||
func Subscribe(msg model.Message) (reply *model.Reply) {
|
||||
@ -51,8 +39,8 @@ func Subscribe(msg model.Message) (reply *model.Reply) {
|
||||
urls := regexp.MustCompile(`(?i)(?:https?://)?(?:[a-zA-Z0-9-]+\.)+[a-zA-Z]{2,}(?:/[^\s]*)?\.xml\b`).FindAllString(data.(*qq_message.TextMessage).Data.Text, -1)
|
||||
if len(urls) > 0 {
|
||||
for _, url := range urls {
|
||||
if err := SubscribeToFeed(url, msg.UserId, msg.GroupInfo.GroupId); err == nil {
|
||||
subscribedFeeds = append(subscribedFeeds, url)
|
||||
if title, err := SubscribeToFeed(url, msg.UserId, msg.GroupInfo.GroupId); err == nil {
|
||||
subscribedFeeds = append(subscribedFeeds, title)
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -61,7 +49,7 @@ func Subscribe(msg model.Message) (reply *model.Reply) {
|
||||
|
||||
if len(subscribedFeeds) > 0 {
|
||||
return &model.Reply{
|
||||
ReplyMsg: fmt.Sprintf("成功订阅 %d 个RSS源", len(subscribedFeeds)),
|
||||
ReplyMsg: fmt.Sprintf("成功订阅 %d 个RSS源:%s", len(subscribedFeeds), strings.Join(subscribedFeeds, "\n")),
|
||||
ReferOriginMsg: true,
|
||||
FromMsg: msg,
|
||||
}
|
||||
@ -75,7 +63,7 @@ func Subscribe(msg model.Message) (reply *model.Reply) {
|
||||
}
|
||||
|
||||
// SubscribeToFeed 订阅RSS源
|
||||
func SubscribeToFeed(feedURL string, userID int64, groupID int64) error {
|
||||
func SubscribeToFeed(feedURL string, userID int64, groupID int64) (string, error) {
|
||||
db := sqlite3.GetGormDB().Begin()
|
||||
defer db.Rollback()
|
||||
|
||||
@ -87,7 +75,7 @@ func SubscribeToFeed(feedURL string, userID int64, groupID int64) error {
|
||||
//检测rss源是否有效
|
||||
|
||||
if err := CheckRssFeed(feedURL); err != nil {
|
||||
return fmt.Errorf("RSS源无效: %v", err)
|
||||
return "", fmt.Errorf("RSS源无效: %v", err)
|
||||
}
|
||||
|
||||
// 检查RSS源是否已存在
|
||||
@ -103,7 +91,7 @@ func SubscribeToFeed(feedURL string, userID int64, groupID int64) error {
|
||||
LastUpdate: time.Now(),
|
||||
}
|
||||
if err := db.Create(&newFeed).Error; err != nil {
|
||||
return fmt.Errorf("创建RSS源失败: %v", err)
|
||||
return "", fmt.Errorf("创建RSS源失败: %v", err)
|
||||
}
|
||||
feedID = newFeed.ID
|
||||
} else {
|
||||
@ -114,13 +102,13 @@ func SubscribeToFeed(feedURL string, userID int64, groupID int64) error {
|
||||
var existingSubscribe RssSubscribe
|
||||
result = db.Where("feed_id = ? AND group_id = ?", feedID, groupID).First(&existingSubscribe)
|
||||
if result.Error == nil {
|
||||
return fmt.Errorf("该群已订阅过此RSS源")
|
||||
return "", fmt.Errorf("该群已订阅过此RSS源")
|
||||
}
|
||||
|
||||
//获取最新文章hash
|
||||
_, items, err := ParseFeed(feedURL)
|
||||
title, items, err := ParseFeed(feedURL)
|
||||
if err != nil {
|
||||
return err
|
||||
return "", err
|
||||
}
|
||||
|
||||
// 创建订阅关系
|
||||
@ -130,9 +118,9 @@ func SubscribeToFeed(feedURL string, userID int64, groupID int64) error {
|
||||
LastItemHash: items[0].Hash,
|
||||
}
|
||||
if err := db.Create(&newSubscribe).Error; err != nil {
|
||||
return fmt.Errorf("创建订阅关系失败: %v", err)
|
||||
return "", fmt.Errorf("创建订阅关系失败: %v", err)
|
||||
}
|
||||
return db.Commit().Error
|
||||
return title, db.Commit().Error
|
||||
}
|
||||
|
||||
func MySubscribed(msg model.Message) (reply *model.Reply) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user