✨ Boost CRUD API
This commit is contained in:
96
pkg/internal/services/boost.go
Normal file
96
pkg/internal/services/boost.go
Normal file
@@ -0,0 +1,96 @@
|
||||
package services
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
|
||||
"git.solsynth.dev/hypernet/nexus/pkg/nex/sec"
|
||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/database"
|
||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/fs"
|
||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/models"
|
||||
jsoniter "github.com/json-iterator/go"
|
||||
"github.com/rs/zerolog/log"
|
||||
"github.com/spf13/cast"
|
||||
"github.com/spf13/viper"
|
||||
)
|
||||
|
||||
func GetBoostByID(id uint) (models.AttachmentBoost, error) {
|
||||
var boost models.AttachmentBoost
|
||||
if err := database.C.
|
||||
Where("id = ?", id).
|
||||
Preload("Attachment").
|
||||
First(&boost).Error; err != nil {
|
||||
return boost, err
|
||||
}
|
||||
return boost, nil
|
||||
}
|
||||
|
||||
func CreateBoost(user *sec.UserInfo, source models.Attachment, destination int) (models.AttachmentBoost, error) {
|
||||
boost := models.AttachmentBoost{
|
||||
Status: models.BoostStatusPending,
|
||||
Destination: destination,
|
||||
AttachmentID: source.ID,
|
||||
Attachment: source,
|
||||
AccountID: user.ID,
|
||||
}
|
||||
|
||||
dests := cast.ToSlice(viper.Get("destinations"))
|
||||
if destination >= len(dests) {
|
||||
return boost, fmt.Errorf("invalid destination: %d", destination)
|
||||
}
|
||||
|
||||
if err := database.C.Create(&boost).Error; err != nil {
|
||||
return boost, err
|
||||
}
|
||||
|
||||
boost.Attachment = source
|
||||
go ActivateBoost(boost)
|
||||
|
||||
return boost, nil
|
||||
}
|
||||
|
||||
func ActivateBoost(boost models.AttachmentBoost) {
|
||||
dests := cast.ToSlice(viper.Get("destinations"))
|
||||
if boost.Destination >= len(dests) {
|
||||
log.Warn().Any("boost", boost).Msg("Unable to activate boost, invalid destination...")
|
||||
database.C.Model(&boost).Update("status", models.BoostStatusError)
|
||||
return
|
||||
}
|
||||
|
||||
if err := ReUploadFile(boost.Attachment, boost.Destination); err != nil {
|
||||
log.Warn().Any("boost", boost).Err(err).Msg("Unable to activate boost...")
|
||||
database.C.Model(&boost).Update("status", models.BoostStatusError)
|
||||
return
|
||||
}
|
||||
|
||||
log.Info().Any("boost", boost).Msg("Boost was activated successfully.")
|
||||
database.C.Model(&boost).Update("status", models.BoostStatusActive)
|
||||
}
|
||||
|
||||
func UpdateBoostStatus(boost models.AttachmentBoost, status int) (models.AttachmentBoost, error) {
|
||||
if status != models.BoostStatusActive && status != models.BoostStatusSuspended {
|
||||
return boost, fmt.Errorf("invalid status: %d", status)
|
||||
}
|
||||
err := database.C.Save(&boost).Error
|
||||
return boost, err
|
||||
}
|
||||
|
||||
func DeleteBoost(boost models.AttachmentBoost) error {
|
||||
destMap := viper.GetStringMap(fmt.Sprintf("destinations.%d", boost.Destination))
|
||||
|
||||
var dest models.BaseDestination
|
||||
rawDest, _ := jsoniter.Marshal(destMap)
|
||||
_ = jsoniter.Unmarshal(rawDest, &dest)
|
||||
|
||||
switch dest.Type {
|
||||
case models.DestinationTypeLocal:
|
||||
var destConfigured models.LocalDestination
|
||||
_ = jsoniter.Unmarshal(rawDest, &destConfigured)
|
||||
return fs.DeleteFileFromLocal(destConfigured, boost.Attachment.Uuid)
|
||||
case models.DestinationTypeS3:
|
||||
var destConfigured models.S3Destination
|
||||
_ = jsoniter.Unmarshal(rawDest, &destConfigured)
|
||||
return fs.DeleteFileFromS3(destConfigured, boost.Attachment.Uuid)
|
||||
default:
|
||||
return fmt.Errorf("invalid destination: unsupported protocol %s", dest.Type)
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user