2019-12-28 20:24:20 +01:00
|
|
|
package entity
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/jinzhu/gorm"
|
|
|
|
"github.com/photoprism/photoprism/internal/maps"
|
2020-01-08 19:51:21 +01:00
|
|
|
"github.com/photoprism/photoprism/internal/mutex"
|
2019-12-28 20:24:20 +01:00
|
|
|
)
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// Place used to associate photos to places
|
2019-12-28 20:24:20 +01:00
|
|
|
type Place struct {
|
2019-12-31 01:34:27 +01:00
|
|
|
ID string `gorm:"type:varbinary(16);primary_key;auto_increment:false;"`
|
2020-01-22 13:43:07 +01:00
|
|
|
LocLabel string `gorm:"type:varbinary(512);unique_index;"`
|
|
|
|
LocCity string `gorm:"type:varchar(128);"`
|
|
|
|
LocState string `gorm:"type:varchar(128);"`
|
|
|
|
LocCountry string `gorm:"type:varbinary(2);"`
|
2019-12-28 20:24:20 +01:00
|
|
|
LocNotes string `gorm:"type:text;"`
|
|
|
|
LocFavorite bool
|
|
|
|
CreatedAt time.Time
|
|
|
|
UpdatedAt time.Time
|
|
|
|
New bool `gorm:"-"`
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// UnknownPlace is the default unknown place
|
2019-12-31 01:34:27 +01:00
|
|
|
var UnknownPlace = NewPlace("-", "Unknown", "Unknown", "Unknown", "zz")
|
2019-12-28 20:24:20 +01:00
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// CreateUnknownPlace initializes default place in the database
|
2019-12-28 20:24:20 +01:00
|
|
|
func CreateUnknownPlace(db *gorm.DB) {
|
|
|
|
UnknownPlace.FirstOrCreate(db)
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// AfterCreate sets the New column used for database callback
|
2019-12-28 20:24:20 +01:00
|
|
|
func (m *Place) AfterCreate(scope *gorm.Scope) error {
|
|
|
|
return scope.SetColumn("New", true)
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// FindPlace returns place from a token
|
2019-12-31 01:34:27 +01:00
|
|
|
func FindPlace(token string, db *gorm.DB) *Place {
|
2019-12-28 20:24:20 +01:00
|
|
|
place := &Place{}
|
|
|
|
|
2019-12-31 01:34:27 +01:00
|
|
|
if err := db.First(place, "id = ?", token).Error; err != nil {
|
|
|
|
log.Debugf("place: %s for token %s", err.Error(), token)
|
2019-12-28 20:24:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return place
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// FindPlaceByLabel returns a place from an id or a label
|
2020-01-02 05:38:21 +01:00
|
|
|
func FindPlaceByLabel(id string, label string, db *gorm.DB) *Place {
|
2019-12-28 20:24:20 +01:00
|
|
|
place := &Place{}
|
|
|
|
|
2020-01-02 05:38:21 +01:00
|
|
|
if err := db.First(place, "id = ? OR loc_label = ?", id, label).Error; err != nil {
|
|
|
|
log.Debugf("place: %s for id %s or label \"%s\"", err.Error(), id, label)
|
2019-12-28 20:24:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return place
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// NewPlace registers a new place in database
|
2020-01-02 05:38:21 +01:00
|
|
|
func NewPlace(id, label, city, state, countryCode string) *Place {
|
2019-12-28 20:24:20 +01:00
|
|
|
result := &Place{
|
2020-01-02 05:38:21 +01:00
|
|
|
ID: id,
|
2019-12-28 20:24:20 +01:00
|
|
|
LocLabel: label,
|
|
|
|
LocCity: city,
|
|
|
|
LocState: state,
|
|
|
|
LocCountry: countryCode,
|
|
|
|
}
|
|
|
|
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// Find returns db record of place
|
2019-12-28 20:24:20 +01:00
|
|
|
func (m *Place) Find(db *gorm.DB) error {
|
|
|
|
if err := db.First(m, "id = ?", m.ID).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// FirstOrCreate checks wether the place already exists in the database
|
2019-12-28 20:24:20 +01:00
|
|
|
func (m *Place) FirstOrCreate(db *gorm.DB) *Place {
|
2020-01-08 19:51:21 +01:00
|
|
|
mutex.Db.Lock()
|
|
|
|
defer mutex.Db.Unlock()
|
|
|
|
|
2019-12-28 20:24:20 +01:00
|
|
|
if err := db.FirstOrCreate(m, "id = ? OR loc_label = ?", m.ID, m.LocLabel).Error; err != nil {
|
2019-12-31 01:34:27 +01:00
|
|
|
log.Debugf("place: %s for token %s or label \"%s\"", err.Error(), m.ID, m.LocLabel)
|
2019-12-28 20:24:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return m
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// NoID checks is the place has no id
|
2020-04-16 20:57:00 +02:00
|
|
|
func (m Place) NoID() bool {
|
2019-12-31 01:34:27 +01:00
|
|
|
return m.ID == ""
|
2019-12-28 20:24:20 +01:00
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// Label returns place label
|
2020-04-16 20:57:00 +02:00
|
|
|
func (m Place) Label() string {
|
2019-12-28 20:24:20 +01:00
|
|
|
return m.LocLabel
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// City returns place City
|
2020-04-16 20:57:00 +02:00
|
|
|
func (m Place) City() string {
|
2019-12-28 20:24:20 +01:00
|
|
|
return m.LocCity
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// State returns place State
|
2020-04-16 20:57:00 +02:00
|
|
|
func (m Place) State() string {
|
2019-12-28 20:24:20 +01:00
|
|
|
return m.LocState
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// CountryCode returns place CountryCode
|
2020-04-16 20:57:00 +02:00
|
|
|
func (m Place) CountryCode() string {
|
2019-12-28 20:24:20 +01:00
|
|
|
return m.LocCountry
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// CountryName returns place CountryName
|
2020-04-16 20:57:00 +02:00
|
|
|
func (m Place) CountryName() string {
|
2019-12-28 20:24:20 +01:00
|
|
|
return maps.CountryNames[m.LocCountry]
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:14:45 +00:00
|
|
|
// Notes returns place Notes
|
2020-04-16 20:57:00 +02:00
|
|
|
func (m Place) Notes() string {
|
2019-12-28 20:24:20 +01:00
|
|
|
return m.LocNotes
|
|
|
|
}
|