2022-05-11 18:47:31 -04:00
|
|
|
package stream
|
|
|
|
|
|
|
|
import (
|
|
|
|
"npm/internal/database"
|
2023-05-25 21:04:43 -04:00
|
|
|
"npm/internal/entity"
|
2022-05-11 18:47:31 -04:00
|
|
|
"npm/internal/types"
|
2023-02-24 02:19:07 -05:00
|
|
|
|
|
|
|
"github.com/rotisserie/eris"
|
2022-05-11 18:47:31 -04:00
|
|
|
)
|
|
|
|
|
2023-05-25 21:04:43 -04:00
|
|
|
// Model is the model
|
2022-05-11 18:47:31 -04:00
|
|
|
type Model struct {
|
2023-05-25 21:04:43 -04:00
|
|
|
entity.ModelBase
|
|
|
|
ExpiresOn types.DBDate `json:"expires_on" gorm:"column:expires_on" filter:"expires_on,integer"`
|
2023-05-29 00:33:58 -04:00
|
|
|
UserID uint `json:"user_id" gorm:"column:user_id" filter:"user_id,integer"`
|
2023-05-25 21:04:43 -04:00
|
|
|
Provider string `json:"provider" gorm:"column:provider" filter:"provider,string"`
|
|
|
|
Name string `json:"name" gorm:"column:name" filter:"name,string"`
|
|
|
|
DomainNames types.JSONB `json:"domain_names" gorm:"column:domain_names" filter:"domain_names,string"`
|
|
|
|
Meta types.JSONB `json:"-" gorm:"column:meta"`
|
2022-05-11 18:47:31 -04:00
|
|
|
}
|
|
|
|
|
2023-05-25 21:04:43 -04:00
|
|
|
// TableName overrides the table name used by gorm
|
|
|
|
func (Model) TableName() string {
|
|
|
|
return "stream"
|
2022-05-11 18:47:31 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// LoadByID will load from an ID
|
2023-05-25 21:04:43 -04:00
|
|
|
func (m *Model) LoadByID(id uint) error {
|
|
|
|
db := database.GetDB()
|
|
|
|
result := db.First(&m, id)
|
|
|
|
return result.Error
|
2022-05-11 18:47:31 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// Save will save this model to the DB
|
|
|
|
func (m *Model) Save() error {
|
|
|
|
if m.UserID == 0 {
|
2023-02-24 02:19:07 -05:00
|
|
|
return eris.Errorf("User ID must be specified")
|
2022-05-11 18:47:31 -04:00
|
|
|
}
|
|
|
|
|
2023-05-25 21:04:43 -04:00
|
|
|
db := database.GetDB()
|
|
|
|
result := db.Save(m)
|
|
|
|
return result.Error
|
2022-05-11 18:47:31 -04:00
|
|
|
}
|
|
|
|
|
2023-05-25 21:04:43 -04:00
|
|
|
// Delete will mark row as deleted
|
2022-05-11 18:47:31 -04:00
|
|
|
func (m *Model) Delete() bool {
|
2023-05-25 21:04:43 -04:00
|
|
|
if m.ID == 0 {
|
|
|
|
// Can't delete a new object
|
2022-05-11 18:47:31 -04:00
|
|
|
return false
|
|
|
|
}
|
2023-05-25 21:04:43 -04:00
|
|
|
db := database.GetDB()
|
|
|
|
result := db.Delete(m)
|
|
|
|
return result.Error == nil
|
2022-05-11 18:47:31 -04:00
|
|
|
}
|