2024-08-18 04:01:41 +00:00
|
|
|
package services
|
|
|
|
|
|
|
|
import (
|
2024-11-02 02:41:31 +00:00
|
|
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/database"
|
|
|
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/models"
|
2024-08-18 04:01:41 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func ListAttachmentPool() ([]models.AttachmentPool, error) {
|
|
|
|
var pools []models.AttachmentPool
|
|
|
|
if err := database.C.Find(&pools).Error; err != nil {
|
|
|
|
return pools, err
|
|
|
|
}
|
|
|
|
return pools, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func GetAttachmentPool(id uint) (models.AttachmentPool, error) {
|
|
|
|
var pool models.AttachmentPool
|
|
|
|
if err := database.C.Where("id = ?", id).First(&pool).Error; err != nil {
|
|
|
|
return pool, err
|
|
|
|
}
|
|
|
|
return pool, nil
|
|
|
|
}
|
|
|
|
|
2024-08-18 06:09:52 +00:00
|
|
|
func GetAttachmentPoolByAlias(alias string) (models.AttachmentPool, error) {
|
|
|
|
var pool models.AttachmentPool
|
|
|
|
if err := database.C.Where("alias = ?", alias).First(&pool).Error; err != nil {
|
|
|
|
return pool, err
|
|
|
|
}
|
|
|
|
return pool, nil
|
|
|
|
}
|
|
|
|
|
2024-08-18 04:01:41 +00:00
|
|
|
func GetAttachmentPoolWithUser(id uint, userId uint) (models.AttachmentPool, error) {
|
|
|
|
var pool models.AttachmentPool
|
|
|
|
if err := database.C.Where("id = ? AND account_id = ?", id, userId).First(&pool).Error; err != nil {
|
|
|
|
return pool, err
|
|
|
|
}
|
|
|
|
return pool, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewAttachmentPool(pool models.AttachmentPool) (models.AttachmentPool, error) {
|
|
|
|
if err := database.C.Save(&pool).Error; err != nil {
|
|
|
|
return pool, err
|
|
|
|
}
|
|
|
|
return pool, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func UpdateAttachmentPool(pool models.AttachmentPool) (models.AttachmentPool, error) {
|
|
|
|
if err := database.C.Save(&pool).Error; err != nil {
|
|
|
|
return pool, err
|
|
|
|
}
|
|
|
|
return pool, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func DeleteAttachmentPool(pool models.AttachmentPool) (models.AttachmentPool, error) {
|
|
|
|
if err := database.C.Delete(&pool).Error; err != nil {
|
|
|
|
return pool, err
|
|
|
|
}
|
|
|
|
return pool, nil
|
|
|
|
}
|