handler: Send pre-finish hook before post-finish
Fixes https://github.com/tus/tusd/issues/702
This commit is contained in:
parent
5c7eddb659
commit
63830b35d1
|
@ -695,23 +695,24 @@ func (handler *UnroutedHandler) writeChunk(ctx context.Context, upload Upload, i
|
||||||
func (handler *UnroutedHandler) finishUploadIfComplete(ctx context.Context, upload Upload, info FileInfo, r *http.Request) error {
|
func (handler *UnroutedHandler) finishUploadIfComplete(ctx context.Context, upload Upload, info FileInfo, r *http.Request) error {
|
||||||
// If the upload is completed, ...
|
// If the upload is completed, ...
|
||||||
if !info.SizeIsDeferred && info.Offset == info.Size {
|
if !info.SizeIsDeferred && info.Offset == info.Size {
|
||||||
// ... allow custom mechanism to finish and cleanup the upload
|
// ... allow the data storage to finish and cleanup the upload
|
||||||
if err := upload.FinishUpload(ctx); err != nil {
|
if err := upload.FinishUpload(ctx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
// ... send the info out to the channel
|
// ... allow the hook callback to run before sending the response
|
||||||
if handler.config.NotifyCompleteUploads {
|
|
||||||
handler.CompleteUploads <- newHookEvent(info, r)
|
|
||||||
}
|
|
||||||
|
|
||||||
handler.Metrics.incUploadsFinished()
|
|
||||||
|
|
||||||
if handler.config.PreFinishResponseCallback != nil {
|
if handler.config.PreFinishResponseCallback != nil {
|
||||||
if err := handler.config.PreFinishResponseCallback(newHookEvent(info, r)); err != nil {
|
if err := handler.config.PreFinishResponseCallback(newHookEvent(info, r)); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
handler.Metrics.incUploadsFinished()
|
||||||
|
|
||||||
|
// ... send the info out to the channel
|
||||||
|
if handler.config.NotifyCompleteUploads {
|
||||||
|
handler.CompleteUploads <- newHookEvent(info, r)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|
Loading…
Reference in New Issue