package sql import ( "context" "tercul/internal/domain" "tercul/internal/domain/copyright_claim" "gorm.io/gorm" ) type copyrightClaimRepository struct { domain.BaseRepository[domain.CopyrightClaim] db *gorm.DB } // NewCopyrightClaimRepository creates a new CopyrightClaimRepository. func NewCopyrightClaimRepository(db *gorm.DB) copyright_claim.Copyright_claimRepository { return ©rightClaimRepository{ BaseRepository: NewBaseRepositoryImpl[domain.CopyrightClaim](db), db: db, } } // ListByWorkID finds claims by work ID func (r *copyrightClaimRepository) ListByWorkID(ctx context.Context, workID uint) ([]domain.CopyrightClaim, error) { var claims []domain.CopyrightClaim if err := r.db.WithContext(ctx).Where("work_id = ?", workID).Find(&claims).Error; err != nil { return nil, err } return claims, nil } // ListByUserID finds claims by user ID func (r *copyrightClaimRepository) ListByUserID(ctx context.Context, userID uint) ([]domain.CopyrightClaim, error) { var claims []domain.CopyrightClaim if err := r.db.WithContext(ctx).Where("user_id = ?", userID).Find(&claims).Error; err != nil { return nil, err } return claims, nil }