 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Index ¶
- Variables
- func UpdateRating[U UpdateableKeyTypes](ctx context.Context, rs *RatingStorage, id int64, values []U) (err error)
- type ActorCast
- type Album
- type AlbumArtist
- type Book
- type BookValues
- type Cast
- type CastRating
- type City
- type Country
- type DirectorCast
- type Entity
- type Episode
- type Film
- type Genre
- type Group
- type Image
- type Keyword
- type KeywordStorage
- func (ks *KeywordStorage) AddKeyword(ctx context.Context, keyword string, mediaID uuid.UUID) (err error)
- func (ks *KeywordStorage) CastVote(ctx context.Context, k Keyword) error
- func (ks *KeywordStorage) GetAll(ctx context.Context) (keywords []Keyword, err error)
- func (ks *KeywordStorage) GetKeyword(ctx context.Context, keyword string, mediaID uuid.UUID) (k Keyword, err error)
- func (ks *KeywordStorage) GetKeywordByID(ctx context.Context, id int32) (k Keyword, err error)
- func (ks *KeywordStorage) GetKeywords(ctx context.Context, mediaID uuid.UUID) (keywords []Keyword, err error)
- func (ks *KeywordStorage) RemoveVote(ctx context.Context, k Keyword) error
 
- type KeywordStorer
- type LangID
- type Media
- type MediaDetails
- type MediaObject
- type MediaService
- type MediaStorage
- func (ms *MediaStorage) Add(ctx context.Context, props *Media) (mediaID uuid.UUID, err error)
- func (ms *MediaStorage) AddCast(ctx context.Context, mediaID uuid.UUID, actors, directors []Person) (castID int64, err error)
- func (ms *MediaStorage) AddCreators(ctx context.Context, uuid uuid.UUID, creators []Person) error
- func (ms *MediaStorage) AddFilm(ctx context.Context, film *Film) error
- func (ms *MediaStorage) Delete(ctx context.Context, mediaID uuid.UUID) error
- func (ms *MediaStorage) Get(ctx context.Context, id uuid.UUID) (media Media, err error)
- func (ms *MediaStorage) GetAll() ([]*interface{}, error)
- func (ms *MediaStorage) GetCast(ctx context.Context, mediaID uuid.UUID) (cast Cast, err error)
- func (ms *MediaStorage) GetImagePath(ctx context.Context, id uuid.UUID) (path string, err error)
- func (ms *MediaStorage) GetKind(ctx context.Context, id uuid.UUID) (string, error)
- func (ms *MediaStorage) GetMediaDetails(ctx context.Context, mediaKind string, id uuid.UUID) (interface{}, error)
- func (ms *MediaStorage) GetRandom(ctx context.Context, count int, blacklistKinds ...string) (mwks map[uuid.UUID]string, err error)
- func (ms *MediaStorage) Update(ctx context.Context, key string, value interface{}, mediaID uuid.UUID) error
- func (ms *MediaStorage) UpdateFilm(ctx context.Context, film *Film) error
 
- type MediaStorer
- type Member
- type MemberInput
- type MemberStorage
- func (s *MemberStorage) CacheNicknames(ctx context.Context) error
- func (s *MemberStorage) CreateSession(ctx context.Context, m Member) (t string, err error)
- func (s *MemberStorage) Delete(ctx context.Context, member *Member) error
- func (s *MemberStorage) GetID(ctx context.Context, credential string) (uint32, error)
- func (s *MemberStorage) GetNicknames() []string
- func (s *MemberStorage) GetPassHash(email, login string) (string, error)
- func (s *MemberStorage) Read(ctx context.Context, keyName, key string) (*Member, error)
- func (s *MemberStorage) Save(ctx context.Context, member *Member) error
- func (s *MemberStorage) Update(ctx context.Context, member *Member) error
 
- type MemberStorer
- type PeopleStorage
- func (p *PeopleStorage) GetGroup(ctx context.Context, id int32) (Group, error)
- func (p *PeopleStorage) GetGroupName(ctx context.Context, id int32) (Group, error)
- func (p *PeopleStorage) GetPerson(ctx context.Context, id int64) (Person, error)
- func (p *PeopleStorage) GetPersonNames(ctx context.Context, id int32) (Person, error)
- func (p *PeopleStorage) GetStudio(ctx context.Context, id int32) (*Studio, error)
 
- type Person
- type Place
- type Rating
- type RatingInput
- type RatingStorage
- func (rs *RatingStorage) Delete(ctx context.Context, id int64) (err error)
- func (rs *RatingStorage) Get(ctx context.Context, id int64) (r Rating, err error)
- func (rs *RatingStorage) GetAll() (ratings []*Rating, err error)
- func (rs *RatingStorage) GetAverageStars(ctx context.Context, rating interface{}, mediaID uuid.UUID) (avgStars float64, err error)
- func (rs *RatingStorage) GetByMediaID(ctx context.Context, mediaID uuid.UUID) (ratings []*Rating, err error)
- func (rs *RatingStorage) GetLatest(ctx context.Context, limit int, offset int) (ratings []*Rating, err error)
- func (rs *RatingStorage) New(ctx context.Context, rating *RatingInput) error
 
- type RatingStorer
- type Season
- type StaticStorage
- type Studio
- type TVShow
- type Track
- type TrackRating
- type UpdateableKeyTypes
- type Venue
- type Video
Constants ¶
This section is empty.
Variables ¶
var BookKeys = []string{
	"media_id", "title", "authors",
	"genres", "edition", "languages",
}
    var GroupKinds = []string{
	"Orchestra",
	"Choir",
	"Ensemble",
	"Collective",
	"Band",
	"Troupe",
	"Other",
}
    Functions ¶
func UpdateRating ¶
func UpdateRating[U UpdateableKeyTypes](ctx context.Context, rs *RatingStorage, id int64, values []U) (err error)
Types ¶
type Album ¶
type Album struct {
	MediaID      *uuid.UUID     `json:"media_id" db:"media_id,pk,unique"`
	Name         string         `json:"name" db:"name"`
	AlbumArtists AlbumArtist    `json:"album_artists" db:"album_artists"`
	ImagePaths   pq.StringArray `json:"image_paths,omitempty"` // we make use of a junction table that utilizes the image IDs
	ReleaseDate  time.Time      `json:"release_date" db:"release_date"`
	Genres       []Genre        `json:"genres,omitempty" db:"genres"`
	//	Studio       Studio                       `json:"studio,omitempty" db:"studio"`
	Keywords []Keyword    `json:"keywords,omitempty" db:"keywords"`
	Duration sql.NullTime `json:"duration,omitempty" db:"duration"`
	Tracks   []Track      `json:"tracks,omitempty" db:"tracks"`
}
    type AlbumArtist ¶
type Book ¶
type Book struct {
	MediaID         *uuid.UUID `json:"media_id" db:"media_id,pk,unique"`
	Title           string     `json:"title" db:"title"`
	Authors         []Person   `json:"author" db:"author"`
	Publisher       string     `json:"publisher" db:"publisher"`
	PublicationDate time.Time  `json:"publication_date" db:"publication_date"`
	Genres          []string   `json:"genres" db:"genres"`
	Keywords        []string   `json:"keywords,omitempty" db:"keywords,omitempty"`
	Languages       []string   `json:"languages" db:"languages"`
	Pages           int16      `json:"pages" db:"pages"`
	ISBN            string     `json:"isbn,omitempty" db:"isbn,unique,omitempty"`
	ASIN            string     `json:"asin,omitempty" db:"asin,unique,omitempty"`
	Cover           string     `json:"cover,omitempty" db:"cover,omitempty"`
	Summary         string     `json:"summary" db:"summary"`
}
    type CastRating ¶
type DirectorCast ¶
type Episode ¶
type Episode struct {
	MediaID   *uuid.UUID    `json:"media_id" db:"media_id,pk,unique"`
	ShowID    *uuid.UUID    `json:"show_id" db:"show_id,pk,unique"`
	SeasonID  *uuid.UUID    `json:"season_id" db:"season_id,pk,unique"`
	Number    uint16        `json:"number" db:"number,autoinc"`
	Title     string        `json:"title" db:"title"`
	Season    uint16        `json:"season" db:"season"`
	Episode   uint16        `json:"episode" db:"episode"`
	AirDate   time.Time     `json:"air_date" db:"air_date"`
	Duration  time.Duration `json:"duration" db:"duration"`
	Languages []string      `json:"languages" db:"languages"`
	Plot      string        `json:"plot" db:"plot"`
}
    type Film ¶
type Film struct {
	MediaID     *uuid.UUID     `json:"media_id" db:"media_id,pk,unique"`
	Title       string         `json:"title" db:"title"`
	Cast        Cast           `json:"cast"` // this data is stored in the people schema, so no db tag
	ReleaseDate sql.NullTime   `json:"release_date" db:"release_date"`
	Duration    sql.NullTime   `json:"duration" db:"duration"`
	Synopsis    sql.NullString `json:"synopsis" db:"synopsis"`
	// TODO: check if nullFloat64 is the right type for this
	Rating sql.NullFloat64 `json:"rating"` // stored in the reviews.rating table, can be queried with a join on media ID
}
    nolint:musttag
func (*Film) GetPosterPath ¶
type Genre ¶
type Genre struct {
	ID          int16    `json:"id" db:"id,pk,autoinc"`
	Name        string   `json:"name" db:"name"`
	DescShort   string   `json:"desc_short" db:"desc_short"`
	DescLong    string   `json:"desc_long" db:"desc_long"`
	Keywords    []string `json:"keywords" db:"keywords"`
	ParentGenre *Genre   `json:"parent_genre omitempty" db:"parent"`
	Children    []Genre  `json:"children omitempty" db:"children"`
}
    Genre does not hage a UUID due to parent-child relationshiPs
type Group ¶
type Group struct {
	ID              int32          `json:"id,omitempty" db:"id"`
	Locations       []Place        `json:"locations,omitempty" db:"locations"`
	Name            string         `json:"name" db:"name"`
	Active          bool           `json:"active,omitempty" db:"active"`
	Formed          sql.NullTime   `json:"formed,omitempty" db:"formed"`
	Disbanded       sql.NullTime   `json:"disbanded,omitempty" db:"disbanded"`
	Website         sql.NullString `json:"website,omitempty" db:"website"`
	Photos          []string       `json:"photos,omitempty" db:"photos"`
	Works           []*uuid.UUID   `json:"works,omitempty" db:"works"`
	Members         []Person       `json:"members,omitempty" db:"members"`
	PrimaryGenre    Genre          `json:"primary_genre,omitempty" db:"primary_genre_id"`
	SecondaryGenres []Genre        `json:"genres,omitempty" db:"genres"`
	Kind            string         `json:"kind,omitempty" db:"kind"` // Orchestra, Choir, Ensemble, Collective, etc.
	Added           time.Time      `json:"added" db:"added"`
	Modified        sql.NullTime   `json:"modified,omitempty" db:"modified"`
	Wikipedia       sql.NullString `json:"wikipedia,omitempty" db:"wikipedia"`
	Bandcamp        sql.NullString `json:"bandcamp,omitempty" db:"bandcamp"`
	Soundcloud      sql.NullString `json:"soundcloud,omitempty" db:"soundcloud"`
	Bio             sql.NullString `json:"bio,omitempty" db:"bio"`
}
    type Image ¶
type Image struct {
	ID        int64          `json:"id" db:"id,pk,unique,autoinc"`
	Source    string         `json:"source" db:"source"`
	Thumbnail sql.NullString `json:"thumbnail" db:"thumbnail"`
	Alt       sql.NullString `json:"alt" db:"alt"`
}
    type KeywordStorage ¶
type KeywordStorage struct {
	// contains filtered or unexported fields
}
    func NewKeywordStorage ¶
func NewKeywordStorage(db *sqlx.DB, log *zerolog.Logger) *KeywordStorage
func (*KeywordStorage) AddKeyword ¶
func (ks *KeywordStorage) AddKeyword(ctx context.Context, keyword string, mediaID uuid.UUID) (err error)
func (*KeywordStorage) CastVote ¶
func (ks *KeywordStorage) CastVote(ctx context.Context, k Keyword) error
func (*KeywordStorage) GetAll ¶
func (ks *KeywordStorage) GetAll(ctx context.Context) (keywords []Keyword, err error)
func (*KeywordStorage) GetKeyword ¶
func (*KeywordStorage) GetKeywordByID ¶
func (*KeywordStorage) GetKeywords ¶
func (ks *KeywordStorage) GetKeywords(ctx context.Context, mediaID uuid.UUID) (keywords []Keyword, err error)
func (*KeywordStorage) RemoveVote ¶
func (ks *KeywordStorage) RemoveVote(ctx context.Context, k Keyword) error
type KeywordStorer ¶
type KeywordStorer interface {
	CastVote(ctx context.Context, k Keyword) error
	RemoveVote(ctx context.Context, k Keyword) error
	AddKeyword(ctx context.Context, k Keyword) error
	GetKeyword(ctx context.Context, mediaID uuid.UUID) (Keyword, error)
	GetKeywords(ctx context.Context, mediaID uuid.UUID) ([]Keyword, error)
}
    type LangID ¶
type LangID int16
const ( English LangID = iota Spanish French German Chinese Japanese Korean Arabic Hebrew Hindi Polish Russian Czech Dutch Greek Italian Swedish Turkish Norwegian Portuguese Finnish Thai Indonesian Vietnamese Farsi Tagalog Swahili Serbian Croatian Bosnian Slovenian Slovak Macedonian Albanian Bulgarian Romanian Hungarian Latvian Lithuanian Estonian Ukrainian Belarusian Malay Malayalam Tamil Telugu Kannada Marathi Gujarati Bengali Punjabi Urdu Mongolian Amharic Icelandic Maltese Unknown Others )
type Media ¶
type Media struct {
	ID       uuid.UUID     `json:"id" db:"id,pk,unique"`
	Title    string        `json:"title" db:"title"`
	Kind     string        `json:"kind" db:"kind"`
	Created  time.Time     `json:"keywords,omitempty" db:"created"`
	Creator  sql.NullInt32 `json:"creator,omitempty" db:"creator"`
	Creators []Person      `json:"creators,omitempty"` // no db tag, we're using a junction table
	Added    time.Time     `json:"added,omitempty" db:"added"`
	Modified sql.NullTime  `json:"modified,omitempty" db:"modified"`
}
    type MediaDetails ¶
type MediaDetails struct {
	Kind    string      `json:"kind" db:"kind"`
	Details interface{} `json:"details" db:"details"`
}
    type MediaService ¶
type MediaService interface {
	IsMedia() bool // dummy placeholder so that we can have somewhat idiomatic parametric polymorphism
}
    type MediaStorage ¶
type MediaStorage struct {
	Log *zerolog.Logger
	Ps *PeopleStorage
	// contains filtered or unexported fields
}
    func (*MediaStorage) Add ¶
Add is a generic method that adds an object to the media.media table. It needs to be run BEFORE the object is added to its respective table, since it needs the media ID to be generated first.
func (*MediaStorage) AddCreators ¶
func (*MediaStorage) Get ¶
Get scans into a complete Media struct In most cases though, all we need is an intermediate, partial instance with the UUID and Kind fields to be passed to GetMediaDetails
func (*MediaStorage) GetImagePath ¶
func (*MediaStorage) GetMediaDetails ¶
func (*MediaStorage) GetRandom ¶
func (ms *MediaStorage) GetRandom(ctx context.Context, count int, blacklistKinds ...string) ( mwks map[uuid.UUID]string, err error, )
mwks - media IDs with their corresponding kind
type MediaStorer ¶
type Member ¶
type Member struct {
	ID           uint32         `json:"id" db:"id"`
	UUID         string         `json:"_key,omitempty" db:"uuid"`
	PassHash     string         `json:"passhash" db:"passhash"`
	MemberName   string         `json:"memberName" db:"nick"` // i.e. @nick@instance
	DisplayName  sql.NullString `json:"displayName,omitempty" db:"display_name"`
	Email        string         `json:"email" db:"email" validate:"required,email"`
	Bio          sql.NullString `json:"bio,omitempty" db:"bio"`
	Active       bool           `json:"active" db:"active"`
	Roles        []uint8        `json:"roles,omitempty" db:"roles"`
	RegTimestamp time.Time      `json:"regdate" db:"reg_timestamp"`
	ProfilePic   *Image         `json:"profilepic,omitempty" db:"profilepic_id"`
	Homepage     sql.NullString `json:"homepage,omitempty" db:"homepage"`
	IRC          sql.NullString `json:"irc,omitempty" db:"irc"`
	XMPP         sql.NullString `json:"xmpp,omitempty" db:"xmpp"`
	Matrix       sql.NullString `json:"matrix,omitempty" db:"matrix"`
}
    Member holds the core information about a member
type MemberInput ¶
type MemberStorage ¶
type MemberStorage struct {
	// contains filtered or unexported fields
}
    func NewMemberStorage ¶
func (*MemberStorage) CacheNicknames ¶
func (s *MemberStorage) CacheNicknames(ctx context.Context) error
func (*MemberStorage) CreateSession ¶
func (*MemberStorage) Delete ¶
func (s *MemberStorage) Delete(ctx context.Context, member *Member) error
func (*MemberStorage) GetID ¶
GetID retrieves the ID required for JWT on the basis of one of the credentials, i.e. email or login
func (*MemberStorage) GetNicknames ¶
func (s *MemberStorage) GetNicknames() []string
func (*MemberStorage) GetPassHash ¶
func (s *MemberStorage) GetPassHash(email, login string) (string, error)
type MemberStorer ¶
type PeopleStorage ¶
type PeopleStorage struct {
	// contains filtered or unexported fields
}
    func NewPeopleStorage ¶
func NewPeopleStorage(dbConn *sqlx.DB, logger *zerolog.Logger) *PeopleStorage
func (*PeopleStorage) GetGroupName ¶
func (*PeopleStorage) GetPersonNames ¶
type Person ¶
type Person struct {
	ID         int32          `json:"id,omitempty" db:"id,pk,unique,autoincrement"`
	FirstName  string         `json:"first_name" db:"first_name"`
	OtherNames pq.StringArray `json:"other_names,omitempty" db:"other_names"`
	LastName   string         `json:"last_name" db:"last_name"`
	NickNames  pq.StringArray `json:"nick_names,omitempty" db:"nick_names"`
	Roles      pq.StringArray `json:"roles,omitempty" db:"roles"`
	Works      []*uuid.UUID   `json:"works,omitempty" db:"works"`
	Birth      sql.NullTime   `json:"birth,omitempty" db:"birth"` // DOB can also be unknown
	Death      sql.NullTime   `json:"death,omitempty" db:"death"`
	Website    sql.NullString `json:"website,omitempty" db:"website"`
	Bio        sql.NullString `json:"bio,omitempty" db:"bio"`
	Photos     pq.StringArray `json:"photos,omitempty" db:"photos"`
	Hometown   Place          `json:"hometown,omitempty" db:"hometown"`
	Residence  Place          `json:"residence,omitempty" db:"residence"`
	Added      time.Time      `json:"added,omitempty" db:"added"`
	Modified   sql.NullTime   `json:"modified,omitempty" db:"modified"`
}
    type Rating ¶
type Rating struct {
	ID          int64     `json:"_key" db:"id,pk"`
	CreatedAt   time.Time `json:"created_at" db:"created_at"`
	NumStars    uint8     `json:"numstars" binding:"required" validate:"min=1,max=10" error:"numstars must be between 1 and 10" db:"stars" `
	Comment     string    `json:"comment,omitempty" db:"comment"`
	Topic       string    `json:"topic,omitempty" db:"topic"`
	Attribution string    `json:"attribution,omitempty" db:"attribution"`
	UserID      uint32    `json:"userid" db:"user_id"`
	MediaID     uuid.UUID `json:"mediaid" db:"media_id"`
	// track/cast/theme
	TrackRatings *TrackRating `json:"trackRatings,omitempty" db:"track_rating"`
	CastRating   *CastRating  `json:"castRating,omitempty" db:"cast_rating"`
}
    type RatingInput ¶
type RatingInput struct {
	// TODO: allow for setting dynamic rating scales
	NumStars    uint8     `json:"numstars" binding:"required" validate:"min=1,max=10" error:"numstars must be between 1 and 10" db:"stars"`
	Comment     string    `json:"comment,omitempty" db:"comment"`
	Topic       string    `json:"topic,omitempty" db:"topic"`
	Attribution string    `json:"attribution,omitempty" db:"attribution"`
	UserID      uint32    `json:"userid" db:"user_id"`
	MediaID     uuid.UUID `json:"mediaid" db:"media_id"`
}
    type RatingStorage ¶
type RatingStorage struct {
	// contains filtered or unexported fields
}
    func NewRatingStorage ¶
func NewRatingStorage(db *sqlx.DB, log *zerolog.Logger) *RatingStorage
func (*RatingStorage) Delete ¶
func (rs *RatingStorage) Delete(ctx context.Context, id int64) (err error)
func (*RatingStorage) GetAll ¶
func (rs *RatingStorage) GetAll() (ratings []*Rating, err error)
func (*RatingStorage) GetAverageStars ¶
func (rs *RatingStorage) GetAverageStars(ctx context.Context, rating interface{}, mediaID uuid.UUID, ) (avgStars float64, err error)
func (*RatingStorage) GetByMediaID ¶
func (rs *RatingStorage) GetByMediaID(ctx context.Context, mediaID uuid.UUID) (ratings []*Rating, err error)
func (*RatingStorage) GetLatest ¶
func (rs *RatingStorage) GetLatest(ctx context.Context, limit int, offset int) (ratings []*Rating, err error)
GetLatestRatings retrieves the latest reviews for all media items. The limit and offset parameters are used for pagination.
func (*RatingStorage) New ¶
func (rs *RatingStorage) New(ctx context.Context, rating *RatingInput) error
type RatingStorer ¶
type RatingStorer interface {
	New(ri *RatingInput) error
	Get(ctx context.Context, ID int64) (*Rating, error)
	GetAll() ([]*Rating, error)
	GetByMediaID(ctx context.Context, mediaID uuid.UUID) ([]*Rating, error)
}
    Update is not present, because methods cannot have type parameters
type StaticStorage ¶
func (*StaticStorage) AddVideo ¶
func (ss *StaticStorage) AddVideo(v *Video) error
type Studio ¶
type Studio struct {
	ID           int32    `json:"id" db:"id,pk,serial,unique"`
	Name         string   `json:"name" db:"name"`
	Active       bool     `json:"active" db:"active"`
	City         *City    `json:"city,omitempty" db:"city"`
	Artists      []Person `json:"artists,omitempty" db:"artists"`
	Works        Media    `json:"works,omitempty" db:"works"`
	IsFilm       bool     `json:"is_film" db:"is_film"`
	IsMusic      bool     `json:"is_music" db:"is_music"`
	IsTV         bool     `json:"is_tv" db:"is_tv"`
	IsPublishing bool     `json:"is_publishing" db:"is_publishing"`
	IsGame       bool     `json:"is_game" db:"is_game"`
}
    type TVShow ¶
type TVShow struct {
	MediaID *uuid.UUID `json:"media_id" db:"media_id,pk,unique"`
	Title   string     `json:"title" db:"title"`
	Cast    Cast       `json:"cast" db:"cast"`
	Year    int        `json:"year" db:"year"`
	Active  bool       `json:"active" db:"active"`
	Seasons []Season   `json:"seasons" db:"seasons"`
	Studio  Studio     `json:"studio" db:"studio"`
}
    type Track ¶
type Track struct {
	MediaID *uuid.UUID `json:"media_id" db:"media_id,pk,unique"`
	Name    string     `json:"name" db:"name"`
	AlbumID *uuid.UUID `json:"album_id" db:"album"`
	//		Artists   mo.Either[[]Person, []Group] `json:"artists" db:"artists"`
	Duration time.Time `json:"duration" db:"duration"`
	Lyrics   string    `json:"lyrics,omitempty" db:"lyrics"`
	Number   int16     `json:"track_number" db:"track_number"`
}
    type TrackRating ¶
type UpdateableKeyTypes ¶
type Venue ¶
type Venue struct {
	UUID    uuid.UUID `json:"uuid" db:"uuid,pk"`
	Name    string    `json:"name" db:"name"`
	Active  bool      `json:"active" db:"active"`
	Street  string    `json:"street" db:"street"`
	Zip     string    `json:"zip" db:"zip"`
	Unit    string    `json:"unit" db:"unit"`
	City    *City     `json:"city" db:"city"`
	Country *Country  `json:"country" db:"country"`
}
    type Video ¶
type Video struct {
	ID        int64          `json:"id" db:"id,pk,unique,autoinc"`
	Source    string         `json:"source" db:"source"`
	Thumbnail sql.NullString `json:"thumbnail" db:"thumbnail"`
	Alt       sql.NullString `json:"alt" db:"alt"`
}