17dab63662
Clippy
2022-09-25 20:44:24 -05:00
80c83eb491
Add ffprobe for details inspection - vastly improve video detection speed
2022-09-25 20:39:09 -05:00
5449bb82f1
Better identify video uploads with ffprobe
2022-09-25 19:34:51 -05:00
21e3e63ac3
Instrument upload store methods
2022-09-25 18:46:50 -05:00
51d8621015
Defensively format errors in traces to avoid deadlocks
2022-09-25 18:46:26 -05:00
890478e794
Support audio in uploaded videos, allow webm uploads
2022-09-25 18:16:37 -05:00
c57a48db8a
Start introducing more video controls
2022-09-25 17:36:07 -05:00
c9a74a73ca
Reduce redundancy in process module
2022-09-25 17:35:52 -05:00
50d118a2a7
Implement image pre-processing on upload
2022-09-25 15:17:33 -05:00
04bc586a26
Fix hasher test
2022-09-25 09:09:05 -05:00
dc95417846
Improve concurrency for upload streams part 2
2022-09-25 08:27:11 -05:00
bf3c47e457
Improve concurrency for upload streams
2022-09-24 22:07:06 -05:00
a6adde874e
Implement s3 multipart uploads
2022-09-24 20:33:59 -05:00
25209e29c0
Make it compile
2022-09-24 17:18:53 -05:00
ff1771e016
More migration work for rusty-s3
2022-09-24 14:18:49 -05:00
ab7fd9aaf7
Start work on using rusty-s3 instead of rust-s3
2022-09-24 13:39:27 -05:00
c5b107eb4c
clippy
2022-09-11 10:04:37 -05:00
7f49af58fe
Update actix-form-data, impl Store & Repo for Data<T>
2022-09-10 19:29:22 -05:00
e0bc95f785
Remove unneeded reborrow
2022-08-15 15:00:12 -05:00
547934071a
Don't migrate from the old database if it doesn't exist
2022-08-14 11:49:20 -05:00
e0543b2c1c
Add HEAD endpoints for process, serve
2022-07-17 11:15:43 -05:00
cb9a594f24
Fix content type on already processed images
2022-06-21 11:27:22 -05:00
dc73bdbad4
Make already-claimed a 400
2022-06-05 23:24:58 -05:00
2db76ad8c5
Update dependencies
2022-04-29 15:54:54 -05:00
8ee26ccf4f
change some import paths
2022-04-27 20:13:49 -05:00
4ac20546ce
Improve migration from 0.3 formats
2022-04-24 17:10:15 -05:00
b3cbda1337
Add internal endpoint for cleaning variants
2022-04-11 16:56:39 -05:00
e50ccfb48c
Update deps
2022-04-11 15:17:54 -05:00
05533f7e3a
Use rfc3339 dates for details responses
2022-04-08 13:36:06 -05:00
7436f15267
Dry download client logic
2022-04-08 13:16:22 -05:00
5f19b63166
Extract details processing
2022-04-08 13:03:00 -05:00
31c5a36c77
Better instrument drops, jobs. Properly disarm backgrounded downloads
2022-04-08 12:51:33 -05:00
55d5e43cd2
Consolidate endpoints for downloading media, cached or backgrounded
2022-04-08 12:05:14 -05:00
07c61cbe87
Add download backgrounded
2022-04-07 19:07:30 -05:00
8781bc8f28
Add follows-from relation for background tasks
2022-04-07 13:28:28 -05:00
e493e90dd4
Defensive tracing
2022-04-07 12:56:40 -05:00
c80d207a87
Improve tracing
2022-04-06 21:40:49 -05:00
05e2cf5e08
Cache on Alias rather than Hash
...
Make sled repo blocking tasks share parent span
2022-04-06 12:14:12 -05:00
865f4ee09c
Caching works:
...
- Insert new bucket for current access time before removing
previous access time record.
- Add instrument to more methods for more precise tracing
2022-04-05 21:47:35 -05:00
6cdae7b318
Add 'cache' endpoint for ingesting ephemeral media
...
By default, cached media should only stick around for 7 days, however
The timeout is reset every time media is accessed, so only obscure
cached media will be flushed from the cache. This '7 days' number is
configurable through the commandline run options as --media-cache-duration
and in the pict-rs.toml file as [media] cache_duration
2022-04-05 20:29:30 -05:00
b0670c2f66
Move migrate to old
2022-04-03 15:07:31 -05:00
409b7d4c54
Remove unused conversions
2022-04-03 12:51:21 -05:00
29f0774331
Add ability to claim uploads
2022-04-02 21:15:39 -05:00
8734dfbdc7
Add backgrounding routes
...
- Accept backgrounded uploads
- Allow backgrounded processing
Still TODO:
- Endpoint for waiting on/claiming an upload
2022-04-02 20:56:29 -05:00
c4d014597e
Better job recovery
2022-04-02 18:53:03 -05:00
77a400c7ca
Implement UploadRepo
2022-04-02 17:41:00 -05:00
132e395e5c
Multiple items:
...
- Reduce duplicate work in generate job
- Use hash instead of identifier for unique processing
- Move motion ident generation behind concurrent processor lock
2022-04-02 17:40:08 -05:00
09f53b9ce6
Move away from UploadManager to direct repo & store actions
2022-04-02 16:44:03 -05:00
6ed592c432
In Progress: process jobs
...
- Is this a good idea? it definitely will make interacting with pict-rs harder. Maybe it's best not to do this
2022-04-01 16:51:12 -05:00
c0d8e0e8e3
Support multiple queues for job processor
2022-04-01 11:51:46 -05:00
09281d9ae8
Move stream timeout to all response bodies
2022-03-29 16:48:26 -05:00
63d66050c8
Enable buffering iterator items for iterstream
2022-03-29 16:18:00 -05:00
5adb3fde89
Move some Stream implementations into 'stream' module
2022-03-29 15:59:17 -05:00
0e490ff54a
Remove custom BytesFreezer stream
2022-03-29 14:28:08 -05:00
25f4480809
Remove custom stream error mapping types
2022-03-29 14:17:20 -05:00
8226a3571d
Enable multi-threaded job processing
2022-03-29 13:18:47 -05:00
602d1ea935
Begin implementing queue, put cleanups in it
2022-03-29 12:51:16 -05:00
e25a4781a8
Remove unneeded variable
2022-03-29 11:09:23 -05:00
99d042f36e
Allow disabling gif/mp4
2022-03-29 11:04:56 -05:00
eb5e39c634
Use color-eyre
2022-03-28 20:47:46 -05:00
1291bf8beb
Divorce reqwest from main application's spans
2022-03-28 18:42:22 -05:00
1662f153ce
Numerous changes:
...
- Improve error printing (display chain in addition to spantrace)
- Fix migration (read main identifier from identifier tree, not filename tree)
- Ensure uniqueness for processed images in ConcurrentProcessor (use source identifier in addition to thumbnail path, include extension in thumbnail path)
- Update default log levels (make pict-rs quieter)
- Add timeout for serving images from object storage (5 seconds)
2022-03-28 15:34:36 -05:00
3792a8923a
Finish redoing config probably
2022-03-27 23:27:07 -05:00
ca28f68ef5
Start redoing config again
2022-03-27 19:10:06 -05:00
37e6b21b55
Fix Range, consolidate errors, test object storage
2022-03-26 20:45:12 -05:00
15b52ba6ec
Get it compiling again
2022-03-26 16:49:23 -05:00
323016f994
Build out migration path
2022-03-25 18:47:50 -05:00
750ce4782e
Rework configuration
2022-03-24 22:06:29 -05:00
d6567fbbbd
Implement sled repo
2022-03-24 17:09:15 -05:00
a0c99d05eb
Create initial trait representation for database
2022-03-24 13:16:41 -05:00
2ad536db17
Promote console from compile flag to runtime flag
2022-03-21 22:41:51 -05:00
f13f870a92
Only use console config when console feature is enabled
2022-03-21 22:05:32 -05:00
62615be371
Allow configuring console buffer capacity
2022-03-21 21:56:19 -05:00
d30415bb49
Don't debug PathStore
2022-03-21 21:43:38 -05:00
9a8dc0e44f
Fix sled cache capacity help text
2022-03-21 21:18:51 -05:00
da159c69cb
Try setting a lower default cache capacity
2022-03-21 21:15:43 -05:00
21b6e1dc08
Use actix-web's Range header
2022-03-01 11:23:15 -06:00
73137ede21
Release candidate 1
2022-02-26 12:22:30 -06:00
0e948a2bf5
Add flag for console
2022-02-01 10:10:52 -06:00
445c99dbf1
Re-use existing BytesMut when streaming file
2022-01-13 18:11:46 -06:00
f79d38df8d
Update rust-runner image, improve tokio-console support
2021-12-19 12:59:51 -06:00
c48808c1e1
Update deps
2021-12-18 20:24:22 -06:00
44d171252b
console
2021-12-16 20:46:46 -06:00
c445615c47
Update to latest betas
2021-12-12 14:48:37 -06:00
e209a282d9
No more follows-from for process
2021-12-06 21:11:43 -06:00
11739cd42c
Remove fancy span following code
2021-12-06 20:35:22 -06:00
a47f2a3428
Log on new span, no pretty
2021-12-06 18:48:07 -06:00
920f1f154c
Improve follows-from and parent span relationships
2021-12-06 12:43:03 -06:00
42aed5165c
Update tracing-awc, add drone
2021-12-03 14:21:31 -06:00
7a3d1bef5a
Only log closing spans, not opening spans
2021-11-24 21:54:27 -06:00
5f5c1d3530
Merge branch 'main' of git.asonix.dog:asonix/pict-rs into main
2021-11-23 16:31:19 -06:00
5b44de2070
clippy
2021-11-23 16:31:15 -06:00
79afd0e8ea
Update deps
2021-11-23 12:29:42 -06:00
0d153ca239
Make stores take filename into account when saving files
2021-11-16 09:45:16 -06:00
c5d6610276
Properly handle out-of-bounds range requests
2021-11-03 12:04:59 -05:00
4c8da2b414
Keep a reqwest client around for sharing an object storage connection pool
2021-11-02 17:21:00 -05:00
ad7c323985
Update readme, cleanup migration key on completion
2021-11-01 10:44:49 -05:00
93c268fc58
Flush at every migrated file
2021-11-01 10:38:11 -05:00
ccb9f49b8b
Implement storage migration
2021-10-31 21:11:35 -05:00
cf50da30ec
Use rust-s3 fork with asyncwrite support
2021-10-31 12:35:11 -05:00
76e3d37009
Clean up ObjectStore's Debug impl
2021-10-28 21:07:31 -05:00
366db1e1fe
Make object storage with minio work
2021-10-28 20:59:11 -05:00
657152e1a8
Don't println
2021-10-28 00:18:18 -05:00
f596edc363
Improve configuration documentation
2021-10-28 00:17:37 -05:00
f9f4fc63d6
Optionally support s3-compatible storage (untested)
2021-10-27 23:06:03 -05:00
26a2401027
Use tmp files for mp4s
2021-10-23 14:14:12 -05:00
6f04595c3b
Remove unneeded mime conversions
2021-10-23 12:35:07 -05:00
36b83f114a
Merge branch 'main' into asonix/generic-pictrs-storage
2021-10-22 23:49:47 -05:00
48557bc2ea
Make pict-rs generic over file storage
2021-10-22 23:48:56 -05:00
2295837ea4
2021
2021-10-21 16:36:31 -05:00
f67aeb92fa
Keep better track of gif/mp4 thumbnail
2021-10-20 21:36:18 -05:00
1767942e31
Remove recursion
2021-10-20 20:36:10 -05:00
d69d261999
Make it actually compilable
2021-10-20 20:30:21 -05:00
4aefc0403a
Remove more boxes
2021-10-20 20:13:39 -05:00
877390878b
Remove more boxes
2021-10-20 19:28:40 -05:00
e7c3e2c96c
Rename stream module
2021-10-20 19:00:41 -05:00
e7b4e4d1cc
Remove a few boxes
2021-10-20 18:58:32 -05:00
922200673e
Update to latest betas
2021-10-20 18:16:53 -05:00
9559a8b202
Update cli flags
2021-10-18 23:51:04 -05:00
3fe66129be
Update opentelemetry url info
2021-10-18 23:44:56 -05:00
34038a0f16
Fix restructure, upload
2021-10-18 23:37:11 -05:00
195f614a4b
Restructure attempt 1
2021-10-18 20:29:06 -05:00
0f3be6566e
Split upload_manager files
2021-10-18 18:44:05 -05:00
2fb8d3e39a
Reduce required Unpin bounds with pin-project-lite
2021-10-18 18:02:33 -05:00
4c5482b3a8
Add more instrumentation
2021-10-13 20:31:40 -05:00
786d8469ee
It works
2021-10-13 19:50:07 -05:00
09cb2a53b0
Rewrite to avoid direct AsyncX impls
2021-10-13 19:06:53 -05:00
2318fd9dca
Enable io-uring
2021-10-12 23:16:31 -05:00
23e6657208
Re-enable skipping validation on import, strip when converting to prescribed format
2021-09-26 11:02:19 -05:00
15dc79d10e
Instrument a couple more functions
2021-09-25 17:09:55 -05:00
f390c62cbf
Wrap BytesFreezer in span
2021-09-25 16:39:10 -05:00
ba68bcbde3
Add better span information to commands, spawned tasks
2021-09-25 15:23:05 -05:00
7cb6a15acd
Wire up cross-application propagation
2021-09-19 14:36:53 -05:00
79a0fa32ee
Remove tracing-error workaround
2021-09-18 16:34:23 -05:00
5e9d923d03
Instrument for OpenTelemetry
2021-09-18 16:29:30 -05:00
06e402ec72
Don't enter across await points
2021-09-16 17:51:20 -05:00
acba660c37
Update to latest actix-form-data
2021-09-13 20:50:51 -05:00
5d3e6f50b3
Instrument better with Tracing
2021-09-13 20:22:42 -05:00
79bd562d8e
Clippy lints
2021-09-12 10:42:44 -05:00
68e4f1f4c8
Make uploads cancel-safe
2021-09-11 19:53:26 -05:00
bf1a16d7d3
Abort process writer task if reader is dropped
2021-09-11 16:35:38 -05:00
0ffd66c74e
Add and document request deadlines
2021-09-11 15:31:00 -05:00
c1b2c7706a
Add back range header support for thumbnail on generation
2021-09-09 16:35:07 -05:00
45606f4579
Add application-level dimension limiting, bail on failed processes
2021-09-09 14:16:12 -05:00
a0f7148924
Cargo fmt
2021-09-06 12:09:25 -05:00
0d5ce07b20
Convert OnceCell to Lazy, fmt
2021-09-06 12:08:13 -05:00
ac79a9d5cd
Use futures-util instead of hand-implemented types
2021-09-05 20:00:31 -05:00
80044616f9
Make CancelSafeProcessor impl more concise, format code
2021-09-05 19:05:58 -05:00
810831ca73
Don't process images that are already being processed
2021-09-05 17:15:30 -05:00
e88b9a024a
Add semaphore around process operations
2021-09-04 16:01:48 -05:00