61 lines
1.6 KiB
Go
61 lines
1.6 KiB
Go
package resolvers
|
|
|
|
import (
|
|
"context"
|
|
|
|
api "github.com/viktorstrate/photoview/api/graphql"
|
|
"github.com/viktorstrate/photoview/api/graphql/auth"
|
|
"github.com/viktorstrate/photoview/api/graphql/models"
|
|
)
|
|
|
|
func (r *queryResolver) MyAlbums(ctx context.Context) ([]*models.Album, error) {
|
|
panic("Not implemented")
|
|
}
|
|
func (r *queryResolver) Album(ctx context.Context, id *string) (*models.Album, error) {
|
|
user := auth.UserFromContext(ctx)
|
|
if user == nil {
|
|
return nil, auth.ErrUnauthorized
|
|
}
|
|
|
|
row := r.Database.QueryRow("SELECT * FROM album WHERE album_id = ? AND owner_id = ?", id, user.UserID)
|
|
album, err := models.NewAlbumFromRow(row)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return album, nil
|
|
}
|
|
|
|
func (r *Resolver) Album() api.AlbumResolver {
|
|
return &albumResolver{r}
|
|
}
|
|
|
|
type albumResolver struct{ *Resolver }
|
|
|
|
func (r *albumResolver) Photos(ctx context.Context, obj *models.Album) ([]*models.Photo, error) {
|
|
photoRows, err := r.Database.Query("SELECT photo.* FROM album, photo WHERE album.album_id = ? AND photo.album_id = album.album_id", obj.AlbumID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
defer photoRows.Close()
|
|
|
|
photos, err := models.NewPhotosFromRows(photoRows)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return photos, nil
|
|
}
|
|
|
|
func (r *albumResolver) SubAlbums(ctx context.Context, obj *models.Album) ([]*models.Album, error) {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (r *albumResolver) ParentAlbum(ctx context.Context, obj *models.Album) (*models.Album, error) {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (r *albumResolver) Owner(ctx context.Context, obj *models.Album) (*models.User, error) {
|
|
panic("not implemented")
|
|
}
|