photoprism/internal/entity/share.go
Michael Mayer 1cc8cefc92 Labels: Add cache, fix bugs & improve SQL queries
Signed-off-by: Michael Mayer <michael@liquidbytes.net>
2019-12-16 23:33:52 +01:00

42 lines
925 B
Go

package entity
import (
"time"
"github.com/jinzhu/gorm"
"github.com/photoprism/photoprism/internal/util"
)
// Shared photos and/or albums
type Share struct {
ShareUUID string `gorm:"primary_key;auto_increment:false"`
PhotoUUID string
AlbumUUID string
LabelUUID string
ShareViews uint
ShareUrl string `gorm:"type:varchar(64);"`
ShareToken string `gorm:"type:varchar(64);"`
SharePassword string `gorm:"type:varchar(128);"`
ShareExpires time.Time
Photo *Photo
Album *Album
CreatedAt time.Time
UpdatedAt time.Time
DeletedAt *time.Time `sql:"index"`
}
func (Share) TableName() string {
return "shares"
}
func (s *Share) BeforeCreate(scope *gorm.Scope) error {
if err := scope.SetColumn("ShareUUID", util.UUID()); err != nil {
return err
}
if err := scope.SetColumn("ShareToken", util.RandomToken(4)); err != nil {
return err
}
return nil
}