Kim Alvefur
cdbb77ccbf
mod_http_file_share: Collect cache hit/miss statistics for downloads
2021-02-02 22:16:20 +01:00
Kim Alvefur
e45dee37bd
mod_http_file_share: Measure how long it takes to prune expired files
2021-02-02 22:11:53 +01:00
Kim Alvefur
da5cd9c963
mod_http_file_share: Collect statistics of files uploaded
2021-02-02 22:08:51 +01:00
Kim Alvefur
5d9802727b
mod_http_file_share: Reorder arguments
...
'filetype' is optional, so having it last seems sensible.
'slot' is pretty important, so moving it earlier seems sensible.
2021-01-31 20:38:40 +01:00
Kim Alvefur
f5baa83714
mod_http_file_share: Update cached value while it is reasonably fresh
...
This should ensure that cache entries until the oldest file that counted
to the last 24h becomes older than 24h.
2021-01-31 17:44:19 +01:00
Kim Alvefur
864708efb7
mod_http_file_share: Cache quotas to avoid hitting storage
2021-01-31 17:56:49 +01:00
Kim Alvefur
855542e2ca
mod_http_file_share: Split out some variables for later reuse
2021-01-31 17:56:35 +01:00
Kim Alvefur
4d3ffbf0f7
mod_http_file_share: Add support for daily upload quotas.
...
Daily instead of total quotas, should be more efficient to calculate.
Still O(n), but a smaller n. Less affected by total retention period.
2021-01-31 14:43:42 +01:00
Kim Alvefur
b1b3f09a5c
mod_http_file_share: Add missing semicolon
...
Last comma or semicolon isn't required but makes the diffs nicer once
you add another item after it.
2021-01-31 14:41:56 +01:00
Kim Alvefur
1998e74fd4
mod_http_file_share: Clarify log message
...
No expired ... what? Could be inferred from the module logging it, but
better to be explicit.
2021-01-30 17:35:13 +01:00
Kim Alvefur
88ce2f1c94
mod_http_file_share: Indicate missing token via WWW-Authenticate header
2021-01-29 15:34:36 +01:00
Kim Alvefur
610278afa0
mod_http_file_share: Clarify message about missing Authorization header
2021-01-29 15:34:15 +01:00
Kim Alvefur
0289a561e6
mod_http_file_share: Allow started uploads to complete after token expired
...
Otherwise uploads taking longer than 5 minutes would be rejected on
completion, and that's probably annoying.
Thanks jonas’
2021-01-28 17:24:37 +01:00
Kim Alvefur
fab6ebb1e6
mod_http_file_share: Serve configurable set of safe mime types inline (thanks jonas’)
...
Otherwise people complain about browser 'Save as' dialog.
2021-01-28 17:13:49 +01:00
Kim Alvefur
22e4d92ce5
mod_http_file_share: Cache file metadata
...
For faster access by avoiding archive ID.
No benchmarks were harmed in the making of this commit.
... no benchmarks were performed at all.
2021-01-28 16:34:13 +01:00
Kim Alvefur
318d357557
mod_http_file_share: Extract all file properties into variables earlier
...
A step towards adding caching, which will unpack into the same
variables.
2021-01-28 16:23:38 +01:00
Kim Alvefur
217450a727
mod_http_file_share: Fix the obligatory misplaced closing bracket (thanks scansion)
2021-01-27 23:38:14 +01:00
Kim Alvefur
2cff8727c7
mod_http_file_share: Insert pauses to avoid blocknig for long periods
...
Similar to the mod_mam cleanup job
2021-01-27 22:10:11 +01:00
Kim Alvefur
395de7cde5
mod_http_file_share: Add support for removing old files (default 2 weeks)
2021-01-27 22:09:26 +01:00
Kim Alvefur
da882b75ab
mod_http_file_share: More security headers
2021-01-27 19:51:36 +01:00
Kim Alvefur
6ce4972bf4
mod_http_file_share: Strip authorization type prefix a bit earlier
2021-01-27 18:26:24 +01:00
Kim Alvefur
3abab1efc3
mod_http_file_share: Factor out function for generating full filename
2021-01-27 18:13:15 +01:00
Kim Alvefur
17a85e6d3b
mod_http_file_share: Use '.bin' file extension
...
Distinct from '.dat' used by datamanager / internal stortage for Lua
object storage so that they can't easily be loaded by accident that way.
2021-01-27 17:48:12 +01:00
Kim Alvefur
e4a97b8e7a
mod_http_file_share: Validate file size early in HTTP PUT request
2021-01-27 17:47:04 +01:00
Kim Alvefur
93494930ea
mod_http_file_share: Move Authorization type string
...
It belongs with the header more than the token itself
2021-01-27 17:34:48 +01:00
Kim Alvefur
943dc18486
mod_http_file_share: Add some logging
2021-01-27 17:29:26 +01:00
Kim Alvefur
5a99373c07
mod_http_file_share: Handle content-type being optional
2021-01-27 09:47:21 +01:00
Kim Alvefur
3ab51f6864
mod_http_file_share: Reject invalid file sizes
2021-01-27 00:36:49 +01:00
Kim Alvefur
debea1badc
mod_http_file_share: Fix name of max-file-size tag
2021-01-27 00:29:12 +01:00
Kim Alvefur
78b0c08aac
mod_http_file_share: Expand registry to fix extra tag
...
Error registry compact format doesn't support extra.tag so needs to be
the more verbose format
2021-01-27 00:28:42 +01:00
Kim Alvefur
987976f20f
mod_http_file_share: Verify final file size on completion of upload
2021-01-27 00:09:49 +01:00
Kim Alvefur
456ca909e2
mod_http_file_share: Add file type filter
...
Unlike mod_http_upload, this can't be bypassed by uploading with a
different file extension.
2021-01-26 14:53:43 +01:00
Kim Alvefur
a98f3a3e64
mod_http_file_share: Add file size limit (default 10M)
2021-01-26 14:53:24 +01:00
Kim Alvefur
ea3b09dea8
mod_http_file_share: Validate that filename does not contain '/'
2021-01-26 14:52:37 +01:00
Kim Alvefur
62f77b9ac9
mod_http_file_share: Return proper error if unauthorized
2021-01-26 14:51:55 +01:00
Kim Alvefur
112b174e2d
mod_http_file_share: Add basic access control
...
Partly lifted from mod_external_services
2021-01-26 14:39:11 +01:00
Kim Alvefur
c26e8b4898
mod_http_file_share: Add support for external file upload service
...
PUT /upload/:slot/:filename
Authorization: Bearer JWT{ uploader, filename, filesize, filetype, exp }
2021-01-26 14:27:51 +01:00
Kim Alvefur
4be9b33741
mod_http_file_share: Let's write another XEP-0363 implementation
...
This variant is meant to improve upon mod_http_upload in some ways:
* Handle files much of arbitrary size efficiently
* Allow GET and PUT URLs to be different
* Remember Content-Type sent by client
* Avoid dependency on mod_http_files
* Built-in way to delegate storage to another httpd
2021-01-26 03:19:17 +01:00