Mubashir R
319ba50a44
fix: validate client-supplied image _endpoint to prevent SSRF (gallery proxies) ( #1718 )
...
POST /api/image/harmonize and POST /api/image/inpaint read an `_endpoint` from
the request body and issue server-side httpx POSTs to it with no validation. A
caller can set `_endpoint` to http://169.254.169.254/ (cloud instance metadata)
or any internal/loopback address the server can reach, turning these routes into
an SSRF primitive.
routes/embedding_routes.py already runs its user-supplied endpoint through
src.url_safety.check_outbound_url; these two routes were missing the same guard.
Validate `_endpoint` the same way before any outbound request: non-HTTP(S)
schemes and the link-local metadata range are always rejected, and
IMAGE_BLOCK_PRIVATE_IPS=true blocks private/loopback for full lockdown (the
local-first default still allows LAN diffusion servers).
Co-authored-by: Claude Opus 4.8 <noreply@anthropic.com >
2026-06-03 13:34:17 +09:00
..
2026-05-31 23:58:26 +09:00
2026-05-31 23:58:26 +09:00
2026-06-03 13:25:26 +09:00
2026-06-01 14:32:41 +09:00
2026-06-03 01:47:13 +09:00
2026-06-02 20:35:57 +09:00
2026-06-02 13:06:09 +09:00
2026-06-03 08:56:48 +09:00
2026-06-03 00:57:20 +09:00
2026-06-03 08:11:37 +09:00
2026-06-02 20:28:26 +09:00
2026-06-02 20:42:32 +09:00
2026-06-02 01:32:00 +02:00
2026-06-01 02:22:17 +00:00
2026-06-02 05:48:59 +09:00
2026-06-02 20:42:10 +09:00
2026-06-02 06:02:49 +09:00
2026-06-03 08:38:27 +09:00
2026-06-03 13:29:14 +09:00
2026-06-03 08:59:16 +09:00
2026-06-02 12:40:28 +09:00
2026-06-03 02:50:02 +09:00
2026-06-03 08:35:16 +09:00
2026-06-03 01:44:02 +09:00
2026-06-03 08:57:15 +09:00
2026-06-02 23:14:52 +09:00
2026-06-02 20:42:37 +09:00
2026-06-01 13:42:44 +09:00
2026-06-03 02:37:45 +09:00
2026-06-02 20:55:30 +09:00
2026-06-02 21:00:58 +09:00
2026-06-02 20:52:03 +09:00
2026-06-02 20:52:08 +09:00
2026-06-01 22:33:35 +09:00
2026-06-03 08:59:49 +09:00
2026-06-01 22:22:41 +09:00
2026-06-02 20:42:21 +09:00
2026-06-02 20:29:37 +09:00
2026-06-02 13:15:22 +09:00
2026-06-01 22:24:27 +09:00
2026-06-03 01:36:57 +09:00
2026-06-03 13:25:33 +09:00
2026-06-03 04:26:15 +09:00
2026-06-02 12:59:29 +09:00
2026-06-03 03:48:25 +09:00
2026-06-03 00:09:48 +09:00
2026-06-03 13:28:19 +09:00
2026-06-02 22:52:37 +09:00
2026-06-03 13:23:35 +09:00
2026-06-02 12:25:56 +09:00
2026-06-03 03:00:52 +09:00
2026-06-02 11:50:03 +09:00
2026-06-02 20:34:25 +09:00
2026-06-03 08:11:44 +09:00
2026-06-03 04:20:48 +09:00
2026-06-02 23:52:22 +09:00
2026-06-03 13:25:41 +09:00
2026-06-02 12:41:25 +09:00
2026-06-03 01:03:58 +09:00
2026-06-03 13:28:31 +09:00
2026-06-03 03:31:09 +09:00
2026-06-03 08:59:55 +09:00
2026-06-03 01:47:13 +09:00
2026-06-02 11:48:54 +09:00
2026-06-03 13:28:38 +09:00
2026-06-02 20:35:27 +09:00
2026-06-03 13:23:01 +09:00
2026-06-02 06:00:02 +09:00
2026-06-03 13:28:53 +09:00
2026-06-02 23:11:04 +09:00
2026-06-02 20:28:01 +09:00
2026-06-03 02:21:02 +09:00
2026-06-03 04:13:52 +09:00
2026-06-02 13:15:06 +09:00
2026-06-02 23:28:24 +09:00
2026-06-03 02:08:09 +09:00
2026-06-02 11:10:43 +09:00
2026-06-01 14:23:22 -04:00
2026-06-02 22:34:52 +09:00
2026-06-03 08:59:36 +09:00
2026-06-02 22:35:30 +09:00
2026-06-02 20:32:56 +09:00
2026-06-03 08:36:51 +09:00
2026-06-02 20:34:05 +09:00
2026-06-03 13:34:17 +09:00
2026-06-01 22:35:24 +09:00
2026-06-03 13:23:08 +09:00
2026-06-03 04:05:40 +09:00
2026-06-03 00:30:03 +09:00
2026-06-03 13:30:11 +09:00
2026-06-02 11:36:01 +09:00
2026-06-02 21:01:42 +09:00
2026-06-01 22:47:47 +09:00
2026-06-02 23:12:34 +09:00
2026-06-02 13:07:20 +09:00
2026-06-03 03:19:39 +09:00
2026-06-02 22:36:12 +09:00
2026-06-02 23:02:28 +09:00
2026-06-03 09:00:04 +09:00
2026-06-03 13:24:24 +09:00
2026-06-03 13:24:33 +09:00
2026-06-02 11:12:54 +09:00
2026-06-03 13:29:21 +09:00
2026-06-02 11:14:31 +09:00
2026-06-03 13:29:36 +09:00
2026-06-02 05:54:23 +09:00
2026-06-03 13:33:50 +09:00
2026-06-02 20:27:24 +09:00
2026-06-03 01:41:24 +09:00
2026-06-02 11:48:17 +09:00
2026-06-02 20:44:13 +09:00
2026-06-02 11:39:40 +09:00
2026-06-02 20:58:33 +09:00
2026-06-02 23:04:58 +09:00
2026-06-02 23:01:04 +09:00
2026-06-02 20:36:54 +09:00
2026-06-02 11:47:58 +09:00
2026-06-03 08:59:30 +09:00
2026-06-03 13:31:10 +09:00
2026-06-03 08:57:23 +09:00
2026-06-03 01:53:47 +09:00
2026-06-03 01:59:05 +09:00
2026-06-02 22:41:27 +09:00
2026-06-03 09:00:10 +09:00
2026-06-02 11:28:52 +09:00
2026-06-03 00:49:29 +09:00
2026-06-03 08:35:09 +09:00
2026-06-03 08:35:54 +09:00
2026-06-02 11:50:17 +09:00
2026-06-03 03:46:07 +09:00
2026-06-02 11:46:06 +09:00
2026-06-03 13:25:48 +09:00
2026-06-02 11:27:31 +09:00
2026-06-02 23:31:09 +09:00
2026-06-02 20:33:09 +09:00
2026-06-02 23:41:04 +09:00
2026-06-03 04:07:31 +09:00
2026-06-02 21:00:50 +09:00
2026-06-02 20:51:16 +09:00
2026-06-02 20:31:35 +09:00
2026-06-03 08:56:56 +09:00
2026-06-02 11:41:33 +09:00
2026-06-02 12:24:18 +09:00
2026-06-03 08:57:47 +09:00
2026-06-03 01:20:43 +09:00
2026-06-01 18:27:17 +09:00
2026-06-03 13:29:57 +09:00
2026-06-02 20:35:44 +09:00
2026-06-03 08:37:29 +09:00
2026-06-02 11:28:52 +09:00
2026-06-01 22:33:35 +09:00
2026-06-03 04:02:16 +09:00
2026-06-01 22:36:53 +09:00
2026-06-02 20:45:48 +09:00
2026-06-03 13:23:50 +09:00
2026-06-03 08:57:35 +09:00
2026-06-03 03:59:05 +09:00
2026-06-02 20:32:08 +09:00
2026-06-03 04:09:28 +09:00
2026-06-02 23:43:53 +09:00
2026-06-02 20:42:43 +09:00
2026-06-02 11:11:17 +09:00
2026-06-02 12:53:50 +09:00
2026-06-03 01:10:06 +09:00
2026-06-03 13:31:33 +09:00
2026-06-03 13:29:51 +09:00
2026-06-03 08:36:45 +09:00
2026-06-02 22:42:23 +09:00
2026-05-31 23:58:26 +09:00
2026-06-02 23:33:22 +09:00
2026-06-03 03:42:01 +09:00
2026-06-02 23:18:15 +09:00
2026-06-02 11:42:20 +09:00
2026-06-03 02:32:38 +09:00
2026-06-03 08:36:57 +09:00
2026-06-03 13:29:29 +09:00
2026-06-02 20:42:15 +09:00
2026-06-02 22:51:25 +09:00
2026-06-02 11:30:53 +09:00
2026-06-03 03:24:09 +09:00
2026-06-03 08:57:09 +09:00
2026-06-01 23:25:38 +01:00
2026-06-01 22:26:37 +09:00
2026-06-02 05:58:58 +09:00
2026-06-02 12:24:50 +09:00
2026-06-02 20:37:14 +09:00
2026-06-03 13:31:19 +09:00
2026-06-03 01:21:57 +09:00
2026-06-02 11:43:30 +09:00
2026-06-03 00:26:37 +09:00
2026-06-02 10:53:33 +09:00
2026-06-03 13:24:17 +09:00
2026-06-02 23:37:15 +09:00
2026-06-02 20:53:07 +09:00
2026-06-02 21:02:26 +09:00
2026-06-03 13:30:28 +09:00
2026-06-03 08:36:01 +09:00
2026-06-01 23:09:41 +09:00
2026-06-03 00:18:15 +09:00
2026-05-31 23:58:26 +09:00
2026-06-03 13:30:19 +09:00
2026-06-03 13:33:56 +09:00
2026-06-03 03:56:54 +09:00
2026-06-02 20:29:56 +09:00
2026-06-02 23:09:15 +09:00
2026-06-03 13:22:52 +09:00
2026-06-02 12:34:42 +09:00
2026-06-02 21:02:26 +09:00
2026-06-03 02:40:22 +09:00
2026-06-03 08:35:47 +09:00
2026-06-02 20:51:26 +09:00
2026-06-01 16:55:09 +09:00
2026-06-02 11:39:01 +09:00
2026-06-03 08:57:41 +09:00
2026-06-01 23:11:50 +09:00
2026-06-03 03:53:05 +09:00
2026-06-01 22:38:56 +09:00
2026-06-02 23:20:00 +09:00
2026-06-03 08:57:28 +09:00
2026-06-03 13:22:46 +09:00
2026-06-02 11:15:45 +09:00
2026-06-03 03:16:11 +09:00
2026-06-03 08:37:05 +09:00
2026-06-02 20:28:36 +09:00
2026-06-03 02:27:43 +09:00
2026-06-03 08:59:24 +09:00
2026-06-03 00:42:56 +09:00
2026-06-02 10:44:39 +09:00
2026-06-03 08:57:54 +09:00
2026-06-02 20:36:13 +09:00
2026-06-02 20:36:37 +09:00
2026-06-02 20:43:24 +09:00
2026-06-02 20:51:21 +09:00
2026-06-02 11:29:29 +09:00
2026-06-03 13:31:26 +09:00
2026-06-02 20:32:20 +09:00
2026-06-03 08:59:42 +09:00
2026-06-02 23:13:30 +09:00
2026-06-03 13:33:43 +09:00
2026-06-02 23:22:57 +09:00
2026-06-02 20:44:27 +09:00
2026-06-03 01:26:47 +09:00
2026-06-02 20:43:29 +09:00
2026-06-03 13:24:00 +09:00
2026-06-02 12:57:45 +09:00
2026-06-03 08:57:03 +09:00
2026-06-03 04:12:23 +09:00
2026-06-03 00:59:01 +09:00
2026-06-03 13:28:45 +09:00
2026-06-03 01:16:30 +09:00
2026-06-03 04:04:19 +09:00
2026-06-02 20:42:26 +09:00
2026-06-02 23:46:33 +09:00
2026-06-03 02:13:51 +09:00
2026-06-02 23:03:46 +09:00
2026-06-03 04:17:40 +09:00
2026-06-01 22:26:13 +09:00
2026-06-02 20:28:12 +09:00
2026-06-02 11:23:40 +09:00
2026-06-02 20:45:32 +09:00
2026-06-02 20:44:24 +09:00
2026-06-03 13:29:01 +09:00
2026-06-03 13:29:08 +09:00