mirror of
https://github.com/stashapp/stash.git
synced 2025-12-18 04:44:37 +03:00
Restructure data layer (#2532)
* Add new txn manager interface * Add txn management to sqlite * Rename get to getByID * Add contexts to repository methods * Update query builders * Add context to reader writer interfaces * Use repository in resolver * Tighten interfaces * Tighten interfaces in dlna * Tighten interfaces in match package * Tighten interfaces in scraper package * Tighten interfaces in scan code * Tighten interfaces on autotag package * Remove ReaderWriter usage * Merge database package into sqlite
This commit is contained in:
@@ -1,19 +1,35 @@
|
||||
package image
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"github.com/stashapp/stash/pkg/models"
|
||||
"github.com/stashapp/stash/pkg/sliceutil/intslice"
|
||||
)
|
||||
|
||||
func UpdateFileModTime(qb models.ImageWriter, id int, modTime models.NullSQLiteTimestamp) (*models.Image, error) {
|
||||
return qb.Update(models.ImagePartial{
|
||||
type PartialUpdater interface {
|
||||
Update(ctx context.Context, updatedImage models.ImagePartial) (*models.Image, error)
|
||||
}
|
||||
|
||||
type PerformerUpdater interface {
|
||||
GetPerformerIDs(ctx context.Context, imageID int) ([]int, error)
|
||||
UpdatePerformers(ctx context.Context, imageID int, performerIDs []int) error
|
||||
}
|
||||
|
||||
type TagUpdater interface {
|
||||
GetTagIDs(ctx context.Context, imageID int) ([]int, error)
|
||||
UpdateTags(ctx context.Context, imageID int, tagIDs []int) error
|
||||
}
|
||||
|
||||
func UpdateFileModTime(ctx context.Context, qb PartialUpdater, id int, modTime models.NullSQLiteTimestamp) (*models.Image, error) {
|
||||
return qb.Update(ctx, models.ImagePartial{
|
||||
ID: id,
|
||||
FileModTime: &modTime,
|
||||
})
|
||||
}
|
||||
|
||||
func AddPerformer(qb models.ImageReaderWriter, id int, performerID int) (bool, error) {
|
||||
performerIDs, err := qb.GetPerformerIDs(id)
|
||||
func AddPerformer(ctx context.Context, qb PerformerUpdater, id int, performerID int) (bool, error) {
|
||||
performerIDs, err := qb.GetPerformerIDs(ctx, id)
|
||||
if err != nil {
|
||||
return false, err
|
||||
}
|
||||
@@ -22,7 +38,7 @@ func AddPerformer(qb models.ImageReaderWriter, id int, performerID int) (bool, e
|
||||
performerIDs = intslice.IntAppendUnique(performerIDs, performerID)
|
||||
|
||||
if len(performerIDs) != oldLen {
|
||||
if err := qb.UpdatePerformers(id, performerIDs); err != nil {
|
||||
if err := qb.UpdatePerformers(ctx, id, performerIDs); err != nil {
|
||||
return false, err
|
||||
}
|
||||
|
||||
@@ -32,8 +48,8 @@ func AddPerformer(qb models.ImageReaderWriter, id int, performerID int) (bool, e
|
||||
return false, nil
|
||||
}
|
||||
|
||||
func AddTag(qb models.ImageReaderWriter, id int, tagID int) (bool, error) {
|
||||
tagIDs, err := qb.GetTagIDs(id)
|
||||
func AddTag(ctx context.Context, qb TagUpdater, id int, tagID int) (bool, error) {
|
||||
tagIDs, err := qb.GetTagIDs(ctx, id)
|
||||
if err != nil {
|
||||
return false, err
|
||||
}
|
||||
@@ -42,7 +58,7 @@ func AddTag(qb models.ImageReaderWriter, id int, tagID int) (bool, error) {
|
||||
tagIDs = intslice.IntAppendUnique(tagIDs, tagID)
|
||||
|
||||
if len(tagIDs) != oldLen {
|
||||
if err := qb.UpdateTags(id, tagIDs); err != nil {
|
||||
if err := qb.UpdateTags(ctx, id, tagIDs); err != nil {
|
||||
return false, err
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user