mirror of
https://github.com/opencloud-eu/opencloud.git
synced 2026-01-24 22:08:58 -05:00
Bumps [github.com/tus/tusd](https://github.com/tus/tusd) from 1.12.1 to 1.13.0. - [Release notes](https://github.com/tus/tusd/releases) - [Commits](https://github.com/tus/tusd/compare/v1.12.1...v1.13.0) --- updated-dependencies: - dependency-name: github.com/tus/tusd dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com>
159 lines
7.1 KiB
Go
159 lines
7.1 KiB
Go
package handler
|
|
|
|
import (
|
|
"errors"
|
|
"log"
|
|
"net/url"
|
|
"os"
|
|
"regexp"
|
|
)
|
|
|
|
// Config provides a way to configure the Handler depending on your needs.
|
|
type Config struct {
|
|
// StoreComposer points to the store composer from which the core data store
|
|
// and optional dependencies should be taken. May only be nil if DataStore is
|
|
// set.
|
|
// TODO: Remove pointer?
|
|
StoreComposer *StoreComposer
|
|
// MaxSize defines how many bytes may be stored in one single upload. If its
|
|
// value is is 0 or smaller no limit will be enforced.
|
|
MaxSize int64
|
|
// BasePath defines the URL path used for handling uploads, e.g. "/files/".
|
|
// If no trailing slash is presented it will be added. You may specify an
|
|
// absolute URL containing a scheme, e.g. "http://tus.io"
|
|
BasePath string
|
|
isAbs bool
|
|
// EnableExperimentalProtocol controls whether the new resumable upload protocol draft
|
|
// from the IETF's HTTP working group is accepted next to the current tus v1 protocol.
|
|
// See https://datatracker.ietf.org/doc/draft-ietf-httpbis-resumable-upload/
|
|
EnableExperimentalProtocol bool
|
|
// DisableDownload indicates whether the server will refuse downloads of the
|
|
// uploaded file, by not mounting the GET handler.
|
|
DisableDownload bool
|
|
// DisableTermination indicates whether the server will refuse termination
|
|
// requests of the uploaded file, by not mounting the DELETE handler.
|
|
DisableTermination bool
|
|
// Disable cors headers. If set to true, tusd will not send any CORS related header.
|
|
// This is useful if you have a proxy sitting in front of tusd that handles CORS.
|
|
//
|
|
// Deprecated: All CORS-related settings are available in via the Cors field. Use
|
|
// Cors.Disable instead of DisableCors.
|
|
DisableCors bool
|
|
// Cors can be used to customize the handling of Cross-Origin Resource Sharing (CORS).
|
|
// See the CorsConfig struct for more details.
|
|
// Defaults to DefaultCorsConfig.
|
|
Cors *CorsConfig
|
|
// NotifyCompleteUploads indicates whether sending notifications about
|
|
// completed uploads using the CompleteUploads channel should be enabled.
|
|
NotifyCompleteUploads bool
|
|
// NotifyTerminatedUploads indicates whether sending notifications about
|
|
// terminated uploads using the TerminatedUploads channel should be enabled.
|
|
NotifyTerminatedUploads bool
|
|
// NotifyUploadProgress indicates whether sending notifications about
|
|
// the upload progress using the UploadProgress channel should be enabled.
|
|
NotifyUploadProgress bool
|
|
// NotifyCreatedUploads indicates whether sending notifications about
|
|
// the upload having been created using the CreatedUploads channel should be enabled.
|
|
NotifyCreatedUploads bool
|
|
// Logger is the logger to use internally, mostly for printing requests.
|
|
Logger *log.Logger
|
|
// Respect the X-Forwarded-Host, X-Forwarded-Proto and Forwarded headers
|
|
// potentially set by proxies when generating an absolute URL in the
|
|
// response to POST requests.
|
|
RespectForwardedHeaders bool
|
|
// PreUploadCreateCallback will be invoked before a new upload is created, if the
|
|
// property is supplied. If the callback returns nil, the upload will be created.
|
|
// Otherwise the HTTP request will be aborted. This can be used to implement
|
|
// validation of upload metadata etc.
|
|
PreUploadCreateCallback func(hook HookEvent) error
|
|
// PreFinishResponseCallback will be invoked after an upload is completed but before
|
|
// a response is returned to the client. Error responses from the callback will be passed
|
|
// back to the client. This can be used to implement post-processing validation.
|
|
PreFinishResponseCallback func(hook HookEvent) error
|
|
}
|
|
|
|
// CorsConfig provides a way to customize the the handling of Cross-Origin Resource Sharing (CORS).
|
|
// More details about CORS are available at https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS.
|
|
type CorsConfig struct {
|
|
// Disable instructs the handler to ignore all CORS-related headers and never set a
|
|
// CORS-related header in a response. This is useful if CORS is already handled by a proxy.
|
|
Disable bool
|
|
// AllowOrigin is a regular expression used to check if a request is allowed to participate in the
|
|
// CORS protocol. If the request's Origin header matches the regular expression, CORS is allowed.
|
|
// If not, a 403 Forbidden response is sent, rejecting the CORS request.
|
|
AllowOrigin *regexp.Regexp
|
|
// AllowCredentials defines whether the `Access-Control-Allow-Credentials: true` header should be
|
|
// included in CORS responses. This allows clients to share credentials using the Cookie and
|
|
// Authorization header
|
|
AllowCredentials bool
|
|
// AllowMethods defines the value for the `Access-Control-Allow-Methods` header in the response to
|
|
// preflight requests. You can add custom methods here, but make sure that all tus-specific methods
|
|
// from DefaultConfig.AllowMethods are included as well.
|
|
AllowMethods string
|
|
// AllowHeaders defines the value for the `Access-Control-Allow-Headers` header in the response to
|
|
// preflight requests. You can add custom headers here, but make sure that all tus-specific header
|
|
// from DefaultConfig.AllowHeaders are included as well.
|
|
AllowHeaders string
|
|
// MaxAge defines the value for the `Access-Control-Max-Age` header in the response to preflight
|
|
// requests.
|
|
MaxAge string
|
|
// ExposeHeaders defines the value for the `Access-Control-Expose-Headers` header in the response to
|
|
// actual requests. You can add custom headers here, but make sure that all tus-specific header
|
|
// from DefaultConfig.ExposeHeaders are included as well.
|
|
ExposeHeaders string
|
|
}
|
|
|
|
// DefaultCorsConfig is the configuration that will be used in none is provided.
|
|
var DefaultCorsConfig = CorsConfig{
|
|
Disable: false,
|
|
AllowOrigin: regexp.MustCompile(".*"),
|
|
AllowCredentials: false,
|
|
AllowMethods: "POST, HEAD, PATCH, OPTIONS, GET, DELETE",
|
|
AllowHeaders: "Authorization, Origin, X-Requested-With, X-Request-ID, X-HTTP-Method-Override, Content-Type, Upload-Length, Upload-Offset, Tus-Resumable, Upload-Metadata, Upload-Defer-Length, Upload-Concat, Upload-Incomplete, Upload-Draft-Interop-Version",
|
|
MaxAge: "86400",
|
|
ExposeHeaders: "Upload-Offset, Location, Upload-Length, Tus-Version, Tus-Resumable, Tus-Max-Size, Tus-Extension, Upload-Metadata, Upload-Defer-Length, Upload-Concat, Upload-Incomplete, Upload-Draft-Interop-Version",
|
|
}
|
|
|
|
func (config *Config) validate() error {
|
|
if config.Logger == nil {
|
|
config.Logger = log.New(os.Stdout, "[tusd] ", log.Ldate|log.Lmicroseconds)
|
|
}
|
|
|
|
base := config.BasePath
|
|
uri, err := url.Parse(base)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// Ensure base path ends with slash to remove logic from absFileURL
|
|
if base != "" && string(base[len(base)-1]) != "/" {
|
|
base += "/"
|
|
}
|
|
|
|
// Ensure base path begins with slash if not absolute (starts with scheme)
|
|
if !uri.IsAbs() && len(base) > 0 && string(base[0]) != "/" {
|
|
base = "/" + base
|
|
}
|
|
config.BasePath = base
|
|
config.isAbs = uri.IsAbs()
|
|
|
|
if config.StoreComposer == nil {
|
|
return errors.New("tusd: StoreComposer must no be nil")
|
|
}
|
|
|
|
if config.StoreComposer.Core == nil {
|
|
return errors.New("tusd: StoreComposer in Config needs to contain a non-nil core")
|
|
}
|
|
|
|
if config.Cors == nil {
|
|
config.Cors = &DefaultCorsConfig
|
|
}
|
|
|
|
// Support previous settings for disabling CORS.
|
|
if config.DisableCors {
|
|
config.Cors.Disable = true
|
|
}
|
|
|
|
return nil
|
|
}
|