warehouse/database/controller.go

57 lines
1.4 KiB
Go
Raw Normal View History

2024-11-13 21:16:22 +01:00
package database
import (
"git.schreifuchs.ch/schreifuchs/warehouse/api"
"git.schreifuchs.ch/schreifuchs/warehouse/model"
)
func (db *DB) InsertBucket(bucket *model.Bucket) error {
return db.conn.Create(bucket).Error
}
func (db *DB) FindApiBuckets(limit, offset int) (buckets []api.Bucket, err error) {
err = db.conn.Model(&model.Bucket{}).Limit(limit).Offset(offset).Find(&buckets).Error
return
}
2024-11-17 22:08:06 +01:00
func (db *DB) FindBucketByName(name string) (bucket model.Bucket, err error) {
err = db.conn.First(&bucket).Where("name = ?", name).Error
return
}
2024-11-13 21:16:22 +01:00
func (db *DB) FindBucketIdByName(name string) (id uint, err error) {
b := &model.Bucket{}
err = db.conn.Select("id").First(b).Error
return b.ID, err
}
func (db *DB) DeleteBucket(id uint) error {
return db.conn.Delete(&model.Bucket{}, id).Error
}
func (db *DB) DeleteBucketByName(name string) error {
return db.conn.Delete(&model.Bucket{}).Where("name = ?", name).Error
}
2024-11-17 22:08:06 +01:00
func (db *DB) FindObjectByKey(bucketName, key string) (object *model.Object, err error) {
bid, err := db.FindBucketIdByName(bucketName)
if err != nil {
return
}
err = db.conn.Find(object).Where("key = ? AND bucket_id = ?", key, bid).Error
return
}
func (db *DB) DeleteObjectByKey(bucketName, key string) (err error) {
bid, err := db.FindBucketIdByName(bucketName)
if err != nil {
return
}
err = db.conn.Delete(&model.Object{}).Where("key = ? AND bucket_id = ?", key, bid).Error
return
}