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 FollowRequest
- type Follower
- 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) RequestFollow(ctx context.Context, fr *FollowRequest) 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 FollowRequest ¶
type Follower ¶
type Follower struct { ID uint32 `json:"id" db:"id"` Follower uint32 `json:"follower" db:"follower"` Followee uint32 `json:"followee" db:"followee"` }
Follower represents a follower-followee relationship
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"` Visibility string `json:"visibility" db:"visibility"` Followers activitypub.Collection `json:"followers,omitempty" db:"followers"` }
Member holds the core information about a member
type MemberInput ¶
type MemberInput struct { MemberName string `json:"membername"` Email string `json:"email"` Password string `json:"password"` }
MemberInput holds the information required to create a new member account
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 ¶
CreateSession creates a JWT token for the member
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)
GetPassHash retrieves the password hash required for JWT on the basis of one of the credentials, i.e. email or login
func (*MemberStorage) RequestFollow ¶
func (s *MemberStorage) RequestFollow(ctx context.Context, fr *FollowRequest) error
RequestFollow creates a follow request in the local database upon the reception of a request into the inbox
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"` }