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,29 +1,50 @@
|
||||
package gallery
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"github.com/stashapp/stash/pkg/models"
|
||||
"github.com/stashapp/stash/pkg/sliceutil/intslice"
|
||||
)
|
||||
|
||||
func UpdateFileModTime(qb models.GalleryWriter, id int, modTime models.NullSQLiteTimestamp) (*models.Gallery, error) {
|
||||
return qb.UpdatePartial(models.GalleryPartial{
|
||||
type PartialUpdater interface {
|
||||
UpdatePartial(ctx context.Context, updatedGallery models.GalleryPartial) (*models.Gallery, error)
|
||||
}
|
||||
|
||||
type ImageUpdater interface {
|
||||
GetImageIDs(ctx context.Context, galleryID int) ([]int, error)
|
||||
UpdateImages(ctx context.Context, galleryID int, imageIDs []int) error
|
||||
}
|
||||
|
||||
type PerformerUpdater interface {
|
||||
GetPerformerIDs(ctx context.Context, galleryID int) ([]int, error)
|
||||
UpdatePerformers(ctx context.Context, galleryID int, performerIDs []int) error
|
||||
}
|
||||
|
||||
type TagUpdater interface {
|
||||
GetTagIDs(ctx context.Context, galleryID int) ([]int, error)
|
||||
UpdateTags(ctx context.Context, galleryID int, tagIDs []int) error
|
||||
}
|
||||
|
||||
func UpdateFileModTime(ctx context.Context, qb PartialUpdater, id int, modTime models.NullSQLiteTimestamp) (*models.Gallery, error) {
|
||||
return qb.UpdatePartial(ctx, models.GalleryPartial{
|
||||
ID: id,
|
||||
FileModTime: &modTime,
|
||||
})
|
||||
}
|
||||
|
||||
func AddImage(qb models.GalleryReaderWriter, galleryID int, imageID int) error {
|
||||
imageIDs, err := qb.GetImageIDs(galleryID)
|
||||
func AddImage(ctx context.Context, qb ImageUpdater, galleryID int, imageID int) error {
|
||||
imageIDs, err := qb.GetImageIDs(ctx, galleryID)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
imageIDs = intslice.IntAppendUnique(imageIDs, imageID)
|
||||
return qb.UpdateImages(galleryID, imageIDs)
|
||||
return qb.UpdateImages(ctx, galleryID, imageIDs)
|
||||
}
|
||||
|
||||
func AddPerformer(qb models.GalleryReaderWriter, 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
|
||||
}
|
||||
@@ -32,7 +53,7 @@ func AddPerformer(qb models.GalleryReaderWriter, id int, performerID int) (bool,
|
||||
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
|
||||
}
|
||||
|
||||
@@ -42,8 +63,8 @@ func AddPerformer(qb models.GalleryReaderWriter, id int, performerID int) (bool,
|
||||
return false, nil
|
||||
}
|
||||
|
||||
func AddTag(qb models.GalleryReaderWriter, 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
|
||||
}
|
||||
@@ -52,7 +73,7 @@ func AddTag(qb models.GalleryReaderWriter, 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