2021-04-19 20:42:19 +03:00
|
|
|
/*
|
|
|
|
GoToSocial
|
2021-12-20 20:42:19 +03:00
|
|
|
Copyright (C) 2021-2022 GoToSocial Authors admin@gotosocial.org
|
2021-04-19 20:42:19 +03:00
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Affero General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Affero General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2021-04-01 21:46:45 +03:00
|
|
|
package fileserver
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2021-04-19 20:42:19 +03:00
|
|
|
"net/http"
|
2021-04-01 21:46:45 +03:00
|
|
|
|
2021-05-08 15:25:55 +03:00
|
|
|
"github.com/superseriousbusiness/gotosocial/internal/api"
|
2021-05-30 14:12:00 +03:00
|
|
|
"github.com/superseriousbusiness/gotosocial/internal/processing"
|
2021-04-01 21:46:45 +03:00
|
|
|
"github.com/superseriousbusiness/gotosocial/internal/router"
|
2021-12-20 17:19:53 +03:00
|
|
|
"github.com/superseriousbusiness/gotosocial/internal/uris"
|
2021-04-01 21:46:45 +03:00
|
|
|
)
|
|
|
|
|
2021-04-19 20:42:19 +03:00
|
|
|
const (
|
2021-12-20 17:19:53 +03:00
|
|
|
// FileServeBasePath forms the first part of the fileserver path.
|
|
|
|
FileServeBasePath = "/" + uris.FileserverPath
|
2021-06-13 19:42:28 +03:00
|
|
|
// AccountIDKey is the url key for account id (an account ulid)
|
2021-04-19 20:42:19 +03:00
|
|
|
AccountIDKey = "account_id"
|
2021-04-20 19:14:23 +03:00
|
|
|
// MediaTypeKey is the url key for media type (usually something like attachment or header etc)
|
2021-04-19 20:42:19 +03:00
|
|
|
MediaTypeKey = "media_type"
|
2021-04-20 19:14:23 +03:00
|
|
|
// MediaSizeKey is the url key for the desired media size--original/small/static
|
2021-04-19 20:42:19 +03:00
|
|
|
MediaSizeKey = "media_size"
|
2021-04-20 19:14:23 +03:00
|
|
|
// FileNameKey is the actual filename being sought. Will usually be a UUID then something like .jpeg
|
2021-05-08 15:25:55 +03:00
|
|
|
FileNameKey = "file_name"
|
2021-04-19 20:42:19 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
// FileServer implements the RESTAPIModule interface.
|
2021-04-01 21:46:45 +03:00
|
|
|
// The goal here is to serve requested media files if the gotosocial server is configured to use local storage.
|
2021-04-19 20:42:19 +03:00
|
|
|
type FileServer struct {
|
2021-12-20 17:19:53 +03:00
|
|
|
processor processing.Processor
|
2021-04-01 21:46:45 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// New returns a new fileServer module
|
2021-12-07 15:31:39 +03:00
|
|
|
func New(processor processing.Processor) api.ClientModule {
|
2021-04-19 20:42:19 +03:00
|
|
|
return &FileServer{
|
2021-12-20 17:19:53 +03:00
|
|
|
processor: processor,
|
2021-04-01 21:46:45 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Route satisfies the RESTAPIModule interface
|
2021-04-19 20:42:19 +03:00
|
|
|
func (m *FileServer) Route(s router.Router) error {
|
2021-12-20 17:19:53 +03:00
|
|
|
// something like "/fileserver/:account_id/:media_type/:media_size/:file_name"
|
|
|
|
fileServePath := fmt.Sprintf("%s/:%s/:%s/:%s/:%s", FileServeBasePath, AccountIDKey, MediaTypeKey, MediaSizeKey, FileNameKey)
|
|
|
|
s.AttachHandler(http.MethodGet, fileServePath, m.ServeFile)
|
2022-07-30 15:42:47 +03:00
|
|
|
s.AttachHandler(http.MethodHead, fileServePath, m.ServeFile)
|
2021-04-01 21:46:45 +03:00
|
|
|
return nil
|
|
|
|
}
|