2020-02-05 14:51:46 +01:00
|
|
|
package resolvers
|
2020-02-01 17:58:45 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2020-09-21 12:34:56 +02:00
|
|
|
"time"
|
2020-02-01 17:58:45 +01:00
|
|
|
|
2020-12-17 22:51:43 +01:00
|
|
|
"github.com/photoview/photoview/api/graphql/models"
|
|
|
|
"github.com/photoview/photoview/api/scanner"
|
2020-06-23 00:40:47 +02:00
|
|
|
"github.com/pkg/errors"
|
2020-11-30 16:42:13 +01:00
|
|
|
"gorm.io/gorm"
|
2020-02-01 17:58:45 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func (r *mutationResolver) ScanAll(ctx context.Context) (*models.ScannerResult, error) {
|
2020-06-23 15:13:07 +02:00
|
|
|
err := scanner.AddAllToQueue()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
startMessage := "Scanner started"
|
|
|
|
|
|
|
|
return &models.ScannerResult{
|
|
|
|
Finished: false,
|
|
|
|
Success: true,
|
|
|
|
Message: &startMessage,
|
|
|
|
}, nil
|
2020-02-01 17:58:45 +01:00
|
|
|
}
|
2020-04-15 11:21:16 +02:00
|
|
|
|
2020-02-09 21:25:33 +01:00
|
|
|
func (r *mutationResolver) ScanUser(ctx context.Context, userID int) (*models.ScannerResult, error) {
|
2020-11-27 16:02:10 +01:00
|
|
|
|
|
|
|
var user models.User
|
|
|
|
|
|
|
|
if err := r.Database.First(&user, userID).Error; err != nil {
|
2020-06-23 00:40:47 +02:00
|
|
|
return nil, errors.Wrap(err, "get user from database")
|
|
|
|
}
|
2020-06-22 23:52:41 +02:00
|
|
|
|
2020-11-27 16:02:10 +01:00
|
|
|
scanner.AddUserToQueue(&user)
|
2020-06-23 00:40:47 +02:00
|
|
|
|
|
|
|
startMessage := "Scanner started"
|
|
|
|
return &models.ScannerResult{
|
|
|
|
Finished: false,
|
|
|
|
Success: true,
|
|
|
|
Message: &startMessage,
|
|
|
|
}, nil
|
2020-02-01 17:58:45 +01:00
|
|
|
}
|
2020-09-21 11:50:39 +02:00
|
|
|
|
|
|
|
func (r *mutationResolver) SetPeriodicScanInterval(ctx context.Context, interval int) (int, error) {
|
|
|
|
if interval < 0 {
|
|
|
|
return 0, errors.New("interval must be 0 or above")
|
|
|
|
}
|
|
|
|
|
2020-12-17 23:21:51 +01:00
|
|
|
if err := r.Database.Session(&gorm.Session{AllowGlobalUpdate: true}).Model(&models.SiteInfo{}).Update("periodic_scan_interval", interval).Error; err != nil {
|
2020-09-21 11:50:39 +02:00
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
|
2020-11-27 16:02:10 +01:00
|
|
|
var siteInfo models.SiteInfo
|
|
|
|
if err := r.Database.First(&siteInfo).Error; err != nil {
|
2020-09-21 11:50:39 +02:00
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
|
2020-11-27 16:02:10 +01:00
|
|
|
scanner.ChangePeriodicScanInterval(time.Duration(siteInfo.PeriodicScanInterval) * time.Second)
|
2020-09-21 12:34:56 +02:00
|
|
|
|
2020-11-27 16:02:10 +01:00
|
|
|
return siteInfo.PeriodicScanInterval, nil
|
2020-09-21 11:50:39 +02:00
|
|
|
}
|
2020-09-21 21:32:30 +02:00
|
|
|
|
|
|
|
func (r *mutationResolver) SetScannerConcurrentWorkers(ctx context.Context, workers int) (int, error) {
|
2020-09-25 19:21:03 +02:00
|
|
|
if workers < 1 {
|
|
|
|
return 0, errors.New("concurrent workers must at least be 1")
|
2020-09-21 21:32:30 +02:00
|
|
|
}
|
|
|
|
|
2020-11-30 16:42:13 +01:00
|
|
|
if err := r.Database.Session(&gorm.Session{AllowGlobalUpdate: true}).Model(&models.SiteInfo{}).Update("concurrent_workers", workers).Error; err != nil {
|
2020-09-21 21:32:30 +02:00
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
|
2020-11-27 16:02:10 +01:00
|
|
|
var siteInfo models.SiteInfo
|
|
|
|
if err := r.Database.First(&siteInfo).Error; err != nil {
|
2020-09-21 21:32:30 +02:00
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
|
2020-11-27 16:02:10 +01:00
|
|
|
scanner.ChangeScannerConcurrentWorkers(siteInfo.ConcurrentWorkers)
|
2020-09-21 21:32:30 +02:00
|
|
|
|
2020-11-27 16:02:10 +01:00
|
|
|
return siteInfo.ConcurrentWorkers, nil
|
2020-09-21 21:32:30 +02:00
|
|
|
}
|