photoprism/internal/entity/country.go

123 lines
3.4 KiB
Go
Raw Normal View History

package entity
2018-09-19 09:20:57 +02:00
import (
"github.com/gosimple/slug"
2018-09-19 09:20:57 +02:00
"github.com/jinzhu/gorm"
"github.com/photoprism/photoprism/internal/event"
"github.com/photoprism/photoprism/internal/maps"
2018-09-19 09:20:57 +02:00
)
2020-10-01 12:15:43 +02:00
// altCountryNames defines mapping between different names for the same country
var altCountryNames = map[string]string{
"United States of America": "USA",
"United States": "USA",
"": "Unknown",
}
2021-09-02 14:45:26 +02:00
// Countries represents a list of countries.
type Countries []Country
// Country represents a country location, used for labeling photos.
2018-09-19 09:20:57 +02:00
type Country struct {
ID string `gorm:"type:VARBINARY(2);primary_key" json:"ID" yaml:"ID"`
CountrySlug string `gorm:"type:VARBINARY(255);unique_index;" json:"Slug" yaml:"-"`
CountryName string `json:"Name" yaml:"Name,omitempty"`
CountryDescription string `gorm:"type:TEXT;" json:"Description,omitempty" yaml:"Description,omitempty"`
CountryNotes string `gorm:"type:TEXT;" json:"Notes,omitempty" yaml:"Notes,omitempty"`
CountryPhoto *Photo `json:"-" yaml:"-"`
CountryPhotoID uint `json:"-" yaml:"-"`
New bool `gorm:"-" json:"-" yaml:"-"`
2018-09-19 09:20:57 +02:00
}
// UnknownCountry is defined here to use it as a default
var UnknownCountry = Country{
ID: UnknownID,
CountryName: maps.CountryNames[UnknownID],
CountrySlug: UnknownID,
}
// CreateUnknownCountry is used to initialize the database with the default country
func CreateUnknownCountry() {
FirstOrCreateCountry(&UnknownCountry)
}
// NewCountry creates a new country, with default country code if not provided
func NewCountry(countryCode string, countryName string) *Country {
if countryCode == "" {
return &UnknownCountry
}
if altName, ok := altCountryNames[countryName]; ok {
countryName = altName
}
countrySlug := slug.MakeLang(countryName, "en")
result := &Country{
ID: countryCode,
CountryName: countryName,
CountrySlug: countrySlug,
}
return result
}
// Create inserts a new row to the database.
func (m *Country) Create() error {
return Db().Create(m).Error
}
// FirstOrCreateCountry returns the existing row, inserts a new row or nil in case of errors.
func FirstOrCreateCountry(m *Country) *Country {
if cacheData, ok := countryCache.Get(m.ID); ok {
log.Debugf("country: cache hit for %s", m.ID)
return cacheData.(*Country)
}
result := Country{}
if findErr := Db().Where("id = ?", m.ID).First(&result).Error; findErr == nil {
countryCache.SetDefault(m.ID, &result)
return &result
} else if createErr := m.Create(); createErr == nil {
if !m.Unknown() {
event.EntitiesCreated("countries", []*Country{m})
event.Publish("count.countries", event.Data{
"count": 1,
})
}
countryCache.SetDefault(m.ID, m)
return m
} else if err := Db().Where("id = ?", m.ID).First(&result).Error; err == nil {
countryCache.SetDefault(m.ID, &result)
return &result
} else {
2020-12-14 13:31:18 +01:00
log.Errorf("country: %s (find or create %s)", createErr, m.ID)
}
return &UnknownCountry
}
// AfterCreate sets the New column used for database callback
func (m *Country) AfterCreate(scope *gorm.Scope) error {
m.New = true
return nil
}
// Code returns country code
func (m *Country) Code() string {
return m.ID
}
// Name returns country name
func (m *Country) Name() string {
return m.CountryName
}
// Unknown returns true if the country is not a known country.
func (m *Country) Unknown() bool {
return m.ID == "" || m.ID == UnknownCountry.ID
}