2025-04-14 15:28:51 +08:00

79 lines
1.7 KiB
Go

package system
import (
"context"
"management/internal/db/model/dto"
"management/internal/erpserver/model/system"
"management/internal/erpserver/repository"
)
type loginLogRepository struct {
store repository.Store
}
var _ system.LoginLogRepository = (*loginLogRepository)(nil)
func NewLoginLogRepository(store repository.Store) *loginLogRepository {
return &loginLogRepository{
store: store,
}
}
func (s *loginLogRepository) Create(ctx context.Context, obj *system.LoginLog) error {
return s.store.DB(ctx).Create(obj).Error
}
func (s *loginLogRepository) GetLatest(ctx context.Context, email string) (*system.LoginLog, error) {
var log system.LoginLog
err := s.store.DB(ctx).
Where("email = ?", email).
Order("id DESC").
First(&log).
Error
if err != nil {
return nil, err
}
return &log, nil
}
func (s *loginLogRepository) List(ctx context.Context, q dto.SearchDto) ([]*system.LoginLog, int64, error) {
query := s.store.DB(ctx).
Model(&system.LoginLog{}).
Where("created_at BETWEEN ? AND ?", q.SearchTimeBegin, q.SearchTimeEnd)
if q.SearchEmail != "" {
query = query.Where("email LIKE ?", "%"+q.SearchEmail+"%")
}
var count int64
err := query.Count(&count).Error
if err != nil {
return nil, 0, err
}
var logs []*system.LoginLog
err = query.
Order("id DESC").
Offset((q.Page - 1) * q.Rows).
Limit(q.Rows).
Find(&logs).
Error
if err != nil {
return nil, 0, err
}
return logs, count, nil
}
func (s *loginLogRepository) Count(ctx context.Context, email string) (int64, error) {
var count int64
err := s.store.DB(ctx).
Model(&system.LoginLog{}).
Where("email = ?", email).
Count(&count).
Error
if err != nil {
return 0, err
}
return count, nil
}