2025-07-10 13:56:37 +08:00
|
|
|
|
package repo
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
2025-07-17 18:47:58 +08:00
|
|
|
|
"time"
|
|
|
|
|
|
|
2025-07-18 09:42:07 +08:00
|
|
|
|
"github.com/ctwj/urldb/db/entity"
|
2025-07-10 13:56:37 +08:00
|
|
|
|
|
2025-07-24 18:45:32 +08:00
|
|
|
|
gonanoid "github.com/matoous/go-nanoid/v2"
|
2025-07-10 13:56:37 +08:00
|
|
|
|
"gorm.io/gorm"
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
// ReadyResourceRepository ReadyResource的Repository接口
|
|
|
|
|
|
type ReadyResourceRepository interface {
|
|
|
|
|
|
BaseRepository[entity.ReadyResource]
|
|
|
|
|
|
FindByURL(url string) (*entity.ReadyResource, error)
|
|
|
|
|
|
FindByIP(ip string) ([]entity.ReadyResource, error)
|
2025-07-24 18:45:32 +08:00
|
|
|
|
FindByKey(key string) ([]entity.ReadyResource, error)
|
2025-07-10 13:56:37 +08:00
|
|
|
|
BatchCreate(resources []entity.ReadyResource) error
|
|
|
|
|
|
DeleteByURL(url string) error
|
2025-07-24 18:45:32 +08:00
|
|
|
|
DeleteByKey(key string) error
|
2025-07-17 18:47:58 +08:00
|
|
|
|
FindAllWithinDays(days int) ([]entity.ReadyResource, error)
|
2025-07-23 01:11:42 +08:00
|
|
|
|
BatchFindByURLs(urls []string) ([]entity.ReadyResource, error)
|
2025-07-24 18:45:32 +08:00
|
|
|
|
GenerateUniqueKey() (string, error)
|
2025-07-29 01:29:53 +08:00
|
|
|
|
FindWithErrors() ([]entity.ReadyResource, error)
|
|
|
|
|
|
FindWithoutErrors() ([]entity.ReadyResource, error)
|
|
|
|
|
|
ClearErrorMsg(id uint) error
|
2025-07-10 13:56:37 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ReadyResourceRepositoryImpl ReadyResource的Repository实现
|
|
|
|
|
|
type ReadyResourceRepositoryImpl struct {
|
|
|
|
|
|
BaseRepositoryImpl[entity.ReadyResource]
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// NewReadyResourceRepository 创建ReadyResource Repository
|
|
|
|
|
|
func NewReadyResourceRepository(db *gorm.DB) ReadyResourceRepository {
|
|
|
|
|
|
return &ReadyResourceRepositoryImpl{
|
|
|
|
|
|
BaseRepositoryImpl: BaseRepositoryImpl[entity.ReadyResource]{db: db},
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// FindByURL 根据URL查找
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) FindByURL(url string) (*entity.ReadyResource, error) {
|
|
|
|
|
|
var resource entity.ReadyResource
|
|
|
|
|
|
err := r.db.Where("url = ?", url).First(&resource).Error
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
return nil, err
|
|
|
|
|
|
}
|
|
|
|
|
|
return &resource, nil
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// FindByIP 根据IP查找
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) FindByIP(ip string) ([]entity.ReadyResource, error) {
|
|
|
|
|
|
var resources []entity.ReadyResource
|
|
|
|
|
|
err := r.db.Where("ip = ?", ip).Find(&resources).Error
|
|
|
|
|
|
return resources, err
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// BatchCreate 批量创建
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) BatchCreate(resources []entity.ReadyResource) error {
|
|
|
|
|
|
return r.db.Create(&resources).Error
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// DeleteByURL 根据URL删除
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) DeleteByURL(url string) error {
|
|
|
|
|
|
return r.db.Where("url = ?", url).Delete(&entity.ReadyResource{}).Error
|
|
|
|
|
|
}
|
2025-07-17 18:47:58 +08:00
|
|
|
|
|
|
|
|
|
|
// FindAllWithinDays 获取n天内的待处理资源,n=0时不限制
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) FindAllWithinDays(days int) ([]entity.ReadyResource, error) {
|
|
|
|
|
|
var resources []entity.ReadyResource
|
|
|
|
|
|
db := r.db.Model(&entity.ReadyResource{})
|
|
|
|
|
|
if days > 0 {
|
|
|
|
|
|
since := time.Now().AddDate(0, 0, -days)
|
|
|
|
|
|
db = db.Where("create_time >= ?", since)
|
|
|
|
|
|
}
|
|
|
|
|
|
err := db.Find(&resources).Error
|
|
|
|
|
|
return resources, err
|
|
|
|
|
|
}
|
2025-07-23 01:11:42 +08:00
|
|
|
|
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) BatchFindByURLs(urls []string) ([]entity.ReadyResource, error) {
|
|
|
|
|
|
var resources []entity.ReadyResource
|
|
|
|
|
|
if len(urls) == 0 {
|
|
|
|
|
|
return resources, nil
|
|
|
|
|
|
}
|
|
|
|
|
|
err := r.db.Where("url IN ?", urls).Find(&resources).Error
|
|
|
|
|
|
return resources, err
|
|
|
|
|
|
}
|
2025-07-24 18:45:32 +08:00
|
|
|
|
|
|
|
|
|
|
// FindByKey 根据Key查找
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) FindByKey(key string) ([]entity.ReadyResource, error) {
|
|
|
|
|
|
var resources []entity.ReadyResource
|
|
|
|
|
|
err := r.db.Where("key = ?", key).Find(&resources).Error
|
|
|
|
|
|
return resources, err
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// DeleteByKey 根据Key删除
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) DeleteByKey(key string) error {
|
|
|
|
|
|
return r.db.Where("key = ?", key).Delete(&entity.ReadyResource{}).Error
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// GenerateUniqueKey 生成唯一的6位Base62 key
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) GenerateUniqueKey() (string, error) {
|
|
|
|
|
|
for i := 0; i < 20; i++ {
|
|
|
|
|
|
key, err := gonanoid.Generate("0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ", 6)
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
return "", err
|
|
|
|
|
|
}
|
|
|
|
|
|
var count int64
|
|
|
|
|
|
err = r.db.Model(&entity.ReadyResource{}).Where("key = ?", key).Count(&count).Error
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
return "", err
|
|
|
|
|
|
}
|
|
|
|
|
|
if count == 0 {
|
|
|
|
|
|
return key, nil
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return "", gorm.ErrInvalidData
|
|
|
|
|
|
}
|
2025-07-29 01:29:53 +08:00
|
|
|
|
|
|
|
|
|
|
// FindWithErrors 查找有错误信息的资源
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) FindWithErrors() ([]entity.ReadyResource, error) {
|
|
|
|
|
|
var resources []entity.ReadyResource
|
|
|
|
|
|
err := r.db.Where("error_msg != '' AND error_msg IS NOT NULL").Find(&resources).Error
|
|
|
|
|
|
return resources, err
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// FindWithoutErrors 查找没有错误信息的资源
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) FindWithoutErrors() ([]entity.ReadyResource, error) {
|
|
|
|
|
|
var resources []entity.ReadyResource
|
|
|
|
|
|
err := r.db.Where("error_msg = '' OR error_msg IS NULL").Find(&resources).Error
|
|
|
|
|
|
return resources, err
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ClearErrorMsg 清除指定资源的错误信息
|
|
|
|
|
|
func (r *ReadyResourceRepositoryImpl) ClearErrorMsg(id uint) error {
|
|
|
|
|
|
return r.db.Model(&entity.ReadyResource{}).Where("id = ?", id).Update("error_msg", "").Error
|
|
|
|
|
|
}
|