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
e21fd29c09
Drop unneeded dependencies
2021-09-04 14:20:31 -05:00
08c3169d3f
Fewer streams
2021-09-04 12:42:40 -05:00
1119ed740e
WIP: Try to pass AsyncRead types around instead of Streams
2021-09-03 19:53:53 -05:00
43f94a3d5d
Fix imagemagick policy for gifs
2021-08-31 12:14:23 -05:00
ee215bfa5e
Version v0.3.0-alpha.21-in-mem
2021-08-31 11:02:30 -05:00
a6f2082b37
Spawn new task to avoid complexity/bugs
2021-08-31 10:17:08 -05:00
c1d4e3b87e
Start work on piping bytes around from memory instead of going to disk and back
2021-08-30 21:19:47 -05:00
3578303104
Version v0.3.0-alpha.19
2021-08-29 14:56:28 -05:00
18c6481fff
Print outfile when converting / processing
2021-08-29 14:16:55 -05:00
3066e4d350
Use safe_move_file to create thumbnail image
2021-08-29 12:12:22 -05:00
98ec2c5a90
Magick on tmp files, allow tmp files in policy
2021-08-29 11:51:56 -05:00
91207e1a6f
Version v0.3.0-alpha.15
2021-08-29 00:05:02 -05:00
7c371c182a
Version v0.3.0-alpha.14
2021-08-28 23:15:29 -05:00
db95c85bdf
Version v0.3.0-alpha.13-shell-out-r4
2021-08-28 22:05:49 -05:00
d4733321ed
Version v0.3.0-alpha.13-shell-out-r3
2021-08-28 20:37:53 -05:00
edd6bb4a60
Replace all bindings with calls to external binaries
2021-08-28 17:15:14 -05:00
7fd707c8df
Begin work on spawning processes rather than binding to c libs
2021-08-25 21:46:11 -05:00
a2c17a950b
Update actix deps
2021-06-26 13:10:28 -05:00
120184dd0c
Update dependencies
2021-06-19 14:39:41 -05:00
5e452ef27e
Update actix deps
2021-04-17 14:59:42 -05:00
7aa32b9b3b
Update actix deps
2021-03-09 20:51:03 -06:00
79b26a1dda
Update to actix-web 4.0.0-beta.3
2021-02-10 16:57:42 -06:00
9797e2e3fc
Go back to actix-fs
2021-01-18 19:54:39 -06:00
8c1f60101b
Add module for Range Header operations
...
Switch from actix-fs to async-fs
2021-01-18 17:11:32 -06:00
John Doe
da237eacae
fmt
2021-01-14 11:26:17 -05:00
John Doe
c663337bcd
ranged support for process endpoint, bugfixes
2021-01-14 08:52:11 -05:00
John Doe
61061f0451
range header support
2021-01-13 20:08:04 -05:00
c0520d181b
Randomize tmp folder name, clean tmp folder on exit
2021-01-05 11:51:13 -06:00
2e9fb2a830
Update download route to return 'details'
2021-01-05 00:28:17 -06:00
0acdfffe08
Return details in upload method, clippy nits
2020-12-25 20:39:19 -06:00
a750364e27
Expose cropping
2020-12-16 18:20:06 -06:00
c0a20588d3
Add content type, width, height to Details, add details endpoints
2020-12-10 12:49:10 -06:00
0bf7e0f688
Add initial details implementation
...
Details is an object generated for each image, containing
it's created_at date to properly set response headers. It
also can be expanding in the future to include an image's
dimensions, which we can expose via an API endpoint.
In addition to this, Details allows us the ability to
re-generate processed images. For now, all images which
do not yet have an associated Details will be
re-generated upon access. Details is set for each
thumbnail on generation, so this will only happen once
for each image.
2020-12-09 23:05:07 -06:00
4bd99431e2
Generate image bytes based on request format
2020-11-01 14:25:21 -06:00
4ce7b79b86
Safely create parent tmp dir when needed
2020-10-16 17:48:42 -05:00
b64e3615be
Switch many migration logs to debug, flush changes to new db
2020-10-16 16:02:48 -05:00
577d358da1
Enhance migrations to be more resilient to panics
2020-10-16 15:28:45 -05:00
f4f1ae6939
Update migration string
2020-10-10 19:38:07 -05:00
04e5d45679
Add Last-Modified header, extend MaxAge cache
2020-10-02 15:38:52 -05:00
6de19d17b6
Clean migration, don't use db tree
2020-09-14 16:42:31 -05:00
2515de00c2
Stable actix
2020-09-14 10:52:18 -05:00
4a3bd42c14
ffmpeg features, sled 034
2020-09-10 11:12:42 -05:00
7c0a407568
Add privileged purging, alias <-> filename relation queries
2020-07-11 17:22:45 -05:00
fd809e4a0b
Make 'import' a protected method
2020-07-11 16:28:49 -05:00
de3e04a411
Support mp4
2020-07-11 16:01:09 -05:00
d28d56fb9a
Fix odd-pixeled gif conversion
2020-07-11 15:49:33 -05:00
510f955cc0
Migrate from 0.32.0-rc1
2020-07-11 15:40:40 -05:00
cc37f0dd8a
Remove redundant default info, update readme help, add 'check' helper
2020-06-25 18:17:05 -05:00
a746793187
Enable mp4 with ffmpeg
2020-06-24 11:58:46 -05:00
eb685f99e7
Use sample for thumbnail generation
2020-06-16 21:05:06 -05:00
6dab3b30e8
Purge image
2020-06-16 18:13:22 -05:00
0fef7abc67
Validate with magickwand
2020-06-16 16:34:37 -05:00
df85faff8b
Start work on webp support
2020-06-16 15:55:24 -05:00
0801c1141f
dev build works with imagemagick
2020-06-15 14:20:25 -05:00
84c10edd0e
Improve bounds check, don't save variant unless it's been changed
2020-06-14 23:10:30 -05:00
928fb8f277
Replace 'move' with 'copy+delete'
2020-06-14 22:35:00 -05:00
154914e61a
Use rexiv2 for metadata removal
2020-06-14 21:41:45 -05:00
24f09408fb
Further clean tracing logs
2020-06-14 13:56:42 -05:00
3b4c5b646a
Do better logging
2020-06-14 10:07:31 -05:00
68721fb269
Replace log with tracing, only hardcode 'info' if RUST_LOG is empty
2020-06-13 21:28:06 -05:00