aboutsummaryrefslogtreecommitdiff
path: root/mediaapi/storage/storage.go
diff options
context:
space:
mode:
Diffstat (limited to 'mediaapi/storage/storage.go')
-rw-r--r--mediaapi/storage/storage.go94
1 files changed, 18 insertions, 76 deletions
diff --git a/mediaapi/storage/storage.go b/mediaapi/storage/storage.go
index bef134a9..0f39c1d0 100644
--- a/mediaapi/storage/storage.go
+++ b/mediaapi/storage/storage.go
@@ -1,4 +1,4 @@
-// Copyright 2017 Vector Creations Ltd
+// Copyright 2020 The Matrix.org Foundation C.I.C.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
@@ -16,90 +16,32 @@ package storage
import (
"context"
- "database/sql"
+ "errors"
+ "net/url"
- // Import the postgres database driver.
- _ "github.com/lib/pq"
+ "github.com/matrix-org/dendrite/mediaapi/storage/postgres"
"github.com/matrix-org/dendrite/mediaapi/types"
"github.com/matrix-org/gomatrixserverlib"
)
-// Database is used to store metadata about a repository of media files.
-type Database struct {
- statements statements
- db *sql.DB
+type Database interface {
+ StoreMediaMetadata(ctx context.Context, mediaMetadata *types.MediaMetadata) error
+ GetMediaMetadata(ctx context.Context, mediaID types.MediaID, mediaOrigin gomatrixserverlib.ServerName) (*types.MediaMetadata, error)
+ StoreThumbnail(ctx context.Context, thumbnailMetadata *types.ThumbnailMetadata) error
+ GetThumbnail(ctx context.Context, mediaID types.MediaID, mediaOrigin gomatrixserverlib.ServerName, width, height int, resizeMethod string) (*types.ThumbnailMetadata, error)
+ GetThumbnails(ctx context.Context, mediaID types.MediaID, mediaOrigin gomatrixserverlib.ServerName) ([]*types.ThumbnailMetadata, error)
}
// Open opens a postgres database.
-func Open(dataSourceName string) (*Database, error) {
- var d Database
- var err error
- if d.db, err = sql.Open("postgres", dataSourceName); err != nil {
+func Open(dataSourceName string) (Database, error) {
+ uri, err := url.Parse(dataSourceName)
+ if err != nil {
return nil, err
}
- if err = d.statements.prepare(d.db); err != nil {
- return nil, err
- }
- return &d, nil
-}
-
-// StoreMediaMetadata inserts the metadata about the uploaded media into the database.
-// Returns an error if the combination of MediaID and Origin are not unique in the table.
-func (d *Database) StoreMediaMetadata(
- ctx context.Context, mediaMetadata *types.MediaMetadata,
-) error {
- return d.statements.media.insertMedia(ctx, mediaMetadata)
-}
-
-// GetMediaMetadata returns metadata about media stored on this server.
-// The media could have been uploaded to this server or fetched from another server and cached here.
-// Returns nil metadata if there is no metadata associated with this media.
-func (d *Database) GetMediaMetadata(
- ctx context.Context, mediaID types.MediaID, mediaOrigin gomatrixserverlib.ServerName,
-) (*types.MediaMetadata, error) {
- mediaMetadata, err := d.statements.media.selectMedia(ctx, mediaID, mediaOrigin)
- if err != nil && err == sql.ErrNoRows {
- return nil, nil
- }
- return mediaMetadata, err
-}
-
-// StoreThumbnail inserts the metadata about the thumbnail into the database.
-// Returns an error if the combination of MediaID and Origin are not unique in the table.
-func (d *Database) StoreThumbnail(
- ctx context.Context, thumbnailMetadata *types.ThumbnailMetadata,
-) error {
- return d.statements.thumbnail.insertThumbnail(ctx, thumbnailMetadata)
-}
-
-// GetThumbnail returns metadata about a specific thumbnail.
-// The media could have been uploaded to this server or fetched from another server and cached here.
-// Returns nil metadata if there is no metadata associated with this thumbnail.
-func (d *Database) GetThumbnail(
- ctx context.Context,
- mediaID types.MediaID,
- mediaOrigin gomatrixserverlib.ServerName,
- width, height int,
- resizeMethod string,
-) (*types.ThumbnailMetadata, error) {
- thumbnailMetadata, err := d.statements.thumbnail.selectThumbnail(
- ctx, mediaID, mediaOrigin, width, height, resizeMethod,
- )
- if err != nil && err == sql.ErrNoRows {
- return nil, nil
- }
- return thumbnailMetadata, err
-}
-
-// GetThumbnails returns metadata about all thumbnails for a specific media stored on this server.
-// The media could have been uploaded to this server or fetched from another server and cached here.
-// Returns nil metadata if there are no thumbnails associated with this media.
-func (d *Database) GetThumbnails(
- ctx context.Context, mediaID types.MediaID, mediaOrigin gomatrixserverlib.ServerName,
-) ([]*types.ThumbnailMetadata, error) {
- thumbnails, err := d.statements.thumbnail.selectThumbnails(ctx, mediaID, mediaOrigin)
- if err != nil && err == sql.ErrNoRows {
- return nil, nil
+ switch uri.Scheme {
+ case "postgres":
+ return postgres.Open(dataSourceName)
+ default:
+ return nil, errors.New("unknown schema")
}
- return thumbnails, err
}