[INFO] cloning repository https://github.com/Bliod-Cook/rota-rust
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Bliod-Cook/rota-rust" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBliod-Cook%2Frota-rust", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBliod-Cook%2Frota-rust'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 23b2687fc09a09b516d4c0ef7775f6d5e62084a8
[INFO] checking Bliod-Cook/rota-rust against try#fa4dd1f19bfeb3fd235dc7f1406c42404436bef5 for pr-145108-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBliod-Cook%2Frota-rust" "/workspace/builds/worker-0-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Bliod-Cook/rota-rust
[INFO] finished tweaking git repo https://github.com/Bliod-Cook/rota-rust
[INFO] tweaked toml for git repo https://github.com/Bliod-Cook/rota-rust written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Bliod-Cook/rota-rust on toolchain fa4dd1f19bfeb3fd235dc7f1406c42404436bef5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Bliod-Cook/rota-rust already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:61361fe0aef631f17e9d025a70c5a647956f8c671dd02950a60ad3f5cc5526d7" "/opt/rustwide/cargo-home/bin/cargo" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 663d54c40756555763750e7ebc8bc7821feaf86cc27b46f9d6027154ced07e6b
[INFO] running `Command { std: "docker" "start" "-a" "663d54c40756555763750e7ebc8bc7821feaf86cc27b46f9d6027154ced07e6b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "663d54c40756555763750e7ebc8bc7821feaf86cc27b46f9d6027154ced07e6b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "663d54c40756555763750e7ebc8bc7821feaf86cc27b46f9d6027154ced07e6b", kill_on_drop: false }`
[INFO] [stdout] 663d54c40756555763750e7ebc8bc7821feaf86cc27b46f9d6027154ced07e6b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:61361fe0aef631f17e9d025a70c5a647956f8c671dd02950a60ad3f5cc5526d7" "/opt/rustwide/cargo-home/bin/cargo" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] e300b3704a00a87ddfe6e0181ea82f6da1fd1b473de759201caa3a39639c2dfa
[INFO] running `Command { std: "docker" "start" "-a" "e300b3704a00a87ddfe6e0181ea82f6da1fd1b473de759201caa3a39639c2dfa", kill_on_drop: false }`
[INFO] [stderr]    Compiling zerocopy v0.8.33
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling libc v0.2.180
[INFO] [stderr]    Compiling stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking tracing-core v0.1.36
[INFO] [stderr]    Compiling zmij v1.0.16
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]     Checking getrandom v0.2.17
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling litemap v0.8.1
[INFO] [stderr]    Compiling writeable v0.6.2
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking http v1.4.0
[INFO] [stderr]    Compiling icu_normalizer_data v2.1.1
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking getrandom v0.3.4
[INFO] [stderr]    Compiling icu_properties_data v2.1.2
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling memchr v2.7.6
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling lock_api v0.4.14
[INFO] [stderr]    Compiling percent-encoding v2.3.2
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling bytes v1.11.0
[INFO] [stderr]    Compiling tinyvec v1.10.0
[INFO] [stderr]    Compiling socket2 v0.6.1
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling form_urlencoded v1.2.2
[INFO] [stderr]    Compiling crypto-common v0.1.7
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling slab v0.4.11
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]    Compiling unicode_categories v0.1.1
[INFO] [stderr]    Compiling iana-time-zone v0.1.64
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling crc v3.4.0
[INFO] [stderr]    Compiling atoi v2.0.0
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling chrono v0.4.43
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking ahash v0.8.12
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling futures-intrusive v0.5.0
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling unicode-normalization v0.1.25
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]    Compiling find-msvc-tools v0.1.8
[INFO] [stderr]    Compiling uuid v1.19.0
[INFO] [stderr]    Compiling unicode-properties v0.1.4
[INFO] [stderr]    Compiling event-listener v2.5.3
[INFO] [stderr]    Compiling linux-raw-sys v0.11.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]    Compiling stringprep v0.1.5
[INFO] [stderr]    Compiling cc v1.2.53
[INFO] [stderr]    Compiling hkdf v0.12.4
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling home v0.5.12
[INFO] [stderr]    Compiling time-core v0.1.7
[INFO] [stderr]    Compiling whoami v1.6.1
[INFO] [stderr]    Compiling base64 v0.21.7
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling sqlformat v0.2.6
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling time-macros v0.2.25
[INFO] [stderr]    Compiling heck v0.4.1
[INFO] [stderr]     Checking hashlink v0.8.4
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]     Checking serde_json v1.0.149
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]    Compiling tempfile v3.24.0
[INFO] [stderr]     Checking regex-syntax v0.8.8
[INFO] [stderr]     Checking data-encoding v2.10.0
[INFO] [stderr]    Compiling portable-atomic v1.13.0
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking raw-cpuid v11.6.0
[INFO] [stderr]     Checking ryu v1.0.22
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]     Checking serde_path_to_error v0.1.20
[INFO] [stderr]     Checking pem v3.0.6
[INFO] [stderr]     Checking dashmap v5.5.3
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking hdrhistogram v7.5.4
[INFO] [stderr]     Checking thread_local v1.1.9
[INFO] [stderr]     Checking nu-ansi-term v0.50.3
[INFO] [stderr]     Checking time v0.3.45
[INFO] [stderr]     Checking arc-swap v1.8.0
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking quanta v0.12.6
[INFO] [stderr]    Compiling axum-macros v0.4.2
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking tungstenite v0.24.0
[INFO] [stderr]     Checking pin-project v1.1.10
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]     Checking simple_asn1 v0.6.3
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking icu_properties v2.1.2
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking tracing-serde v0.2.0
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking jsonwebtoken v9.3.1
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking axum-core v0.4.5
[INFO] [stderr]     Checking tracing-subscriber v0.3.22
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking governor v0.6.3
[INFO] [stderr]     Checking rayon v1.11.0
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking tokio-util v0.7.18
[INFO] [stderr]     Checking tower v0.5.3
[INFO] [stderr]     Checking tokio-tungstenite v0.24.0
[INFO] [stderr]     Checking tokio-socks v0.5.2
[INFO] [stderr]     Checking tower-http v0.5.2
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking url v2.5.8
[INFO] [stderr]     Checking h2 v0.4.13
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking sqlx-core v0.7.4
[INFO] [stderr]     Checking tokio-test v0.4.5
[INFO] [stderr]     Checking sysinfo v0.30.13
[INFO] [stderr]     Checking sqlx-postgres v0.7.4
[INFO] [stderr]     Checking hyper v1.8.1
[INFO] [stderr]     Checking hyper-util v0.1.19
[INFO] [stderr]     Checking axum v0.7.9
[INFO] [stderr]    Compiling sqlx-macros-core v0.7.4
[INFO] [stderr]    Compiling sqlx-macros v0.7.4
[INFO] [stderr]     Checking sqlx v0.7.4
[INFO] [stderr]     Checking rota v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `AuthenticatedUser` and `Claims`
[INFO] [stdout]  --> src/api/middleware/mod.rs:8:26
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub use jwt::{AuthError, AuthenticatedUser, Claims, JwtAuth};
[INFO] [stdout]   |                          ^^^^^^^^^^^^^^^^^  ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `logging::RequestLogging`
[INFO] [stdout]  --> src/api/middleware/mod.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use logging::RequestLogging;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `handler::ProxyHandler`
[INFO] [stdout]   --> src/proxy/mod.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub use handler::ProxyHandler;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `health::HealthChecker`
[INFO] [stdout]   --> src/proxy/mod.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub use health::HealthChecker;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ProxySelector`, `RotationStrategy`, and `create_selector`
[INFO] [stdout]   --> src/proxy/mod.rs:21:20
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub use rotation::{create_selector, ProxySelector, RotationStrategy};
[INFO] [stdout]    |                    ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `server::ProxyServer`
[INFO] [stdout]   --> src/proxy/mod.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub use server::ProxyServer;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `transport::ProxyTransport`
[INFO] [stdout]   --> src/proxy/mod.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub use transport::ProxyTransport;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tunnel::TunnelHandler`
[INFO] [stdout]   --> src/proxy/mod.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub use tunnel::TunnelHandler;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AuthenticatedUser` and `Claims`
[INFO] [stdout]  --> src/api/middleware/mod.rs:8:26
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub use jwt::{AuthError, AuthenticatedUser, Claims, JwtAuth};
[INFO] [stdout]   |                          ^^^^^^^^^^^^^^^^^  ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `logging::RequestLogging`
[INFO] [stdout]  --> src/api/middleware/mod.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use logging::RequestLogging;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `handler::ProxyHandler`
[INFO] [stdout]   --> src/proxy/mod.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub use handler::ProxyHandler;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `health::HealthChecker`
[INFO] [stdout]   --> src/proxy/mod.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub use health::HealthChecker;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ProxySelector`, `RotationStrategy`, and `create_selector`
[INFO] [stdout]   --> src/proxy/mod.rs:21:20
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub use rotation::{create_selector, ProxySelector, RotationStrategy};
[INFO] [stdout]    |                    ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `server::ProxyServer`
[INFO] [stdout]   --> src/proxy/mod.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub use server::ProxyServer;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `transport::ProxyTransport`
[INFO] [stdout]   --> src/proxy/mod.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub use transport::ProxyTransport;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tunnel::TunnelHandler`
[INFO] [stdout]   --> src/proxy/mod.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub use tunnel::TunnelHandler;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `decoding_key` is never read
[INFO] [stdout]   --> src/api/middleware/jwt.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub struct JwtAuth {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] 44 |     encoding_key: EncodingKey,
[INFO] [stdout] 45 |     decoding_key: DecodingKey,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `JwtAuth` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `validate_token` and `extract_token` are never used
[INFO] [stdout]   --> src/api/middleware/jwt.rs:84:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | impl JwtAuth {
[INFO] [stdout]    | ------------ associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 84 |     pub fn validate_token(&self, token: &str) -> Result<Claims, AuthError> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub fn extract_token(authorization: &str) -> Option<&str> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `InvalidToken` and `MissingToken` are never constructed
[INFO] [stdout]    --> src/api/middleware/jwt.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 107 | pub enum AuthError {
[INFO] [stdout]     |          --------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 110 |     InvalidToken,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 111 |     MissingToken,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AuthError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AuthenticatedUser` is never constructed
[INFO] [stdout]    --> src/api/middleware/jwt.rs:131:12
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub struct AuthenticatedUser {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RequestLogging` is never constructed
[INFO] [stdout]   --> src/api/middleware/logging.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct RequestLogging;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `log_request` is never used
[INFO] [stdout]   --> src/api/middleware/logging.rs:15:18
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl RequestLogging {
[INFO] [stdout]    | ------------------- associated function in this implementation
[INFO] [stdout] 14 |     /// Log request details
[INFO] [stdout] 15 |     pub async fn log_request(req: Request<Body>, next: Next) -> Response {
[INFO] [stdout]    |                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ApiServerBuilder` is never constructed
[INFO] [stdout]    --> src/api/server.rs:108:12
[INFO] [stdout]     |
[INFO] [stdout] 108 | pub struct ApiServerBuilder {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `config`, `database`, `selector`, `log_sender`, and `build` are never used
[INFO] [stdout]    --> src/api/server.rs:117:12
[INFO] [stdout]     |
[INFO] [stdout] 116 | impl ApiServerBuilder {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 117 |     pub fn new(api_config: ApiServerConfig) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 127 |     pub fn config(mut self, config: Config) -> Self {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn database(mut self, db: Database) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub fn selector(mut self, selector: Arc<DynamicProxySelector>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn log_sender(mut self, sender: broadcast::Sender<RequestRecord>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub fn build(self) -> ApiServer {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `log` is never read
[INFO] [stdout]   --> src/config.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub struct Config {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 17 |     pub log: LogConfig,
[INFO] [stdout]    |         ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Config` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `rate_limit_enabled`, `rate_limit_per_second`, `rate_limit_burst`, and `rotation_strategy` are never read
[INFO] [stdout]   --> src/config.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct ProxyServerConfig {
[INFO] [stdout]    |            ----------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     pub rate_limit_enabled: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 40 |     /// Rate limit requests per second
[INFO] [stdout] 41 |     pub rate_limit_per_second: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 42 |     /// Rate limit burst size
[INFO] [stdout] 43 |     pub rate_limit_burst: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 44 |     /// Rotation strategy (random, round_robin, least_connections, time_based)
[INFO] [stdout] 45 |     pub rotation_strategy: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyServerConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `level` and `format` are never read
[INFO] [stdout]    --> src/config.rs:108:9
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct LogConfig {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 107 |     /// Log level (debug, info, warn, error)
[INFO] [stdout] 108 |     pub level: String,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 109 |     /// Output format (json, pretty)
[INFO] [stdout] 110 |     pub format: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `LogConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `proxy_addr` and `api_addr` are never used
[INFO] [stdout]    --> src/config.rs:201:12
[INFO] [stdout]     |
[INFO] [stdout] 113 | impl Config {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 201 |     pub fn proxy_addr(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 206 |     pub fn api_addr(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `from_pool`, `health_check`, `pool_stats`, and `close` are never used
[INFO] [stdout]   --> src/database/pool.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl Database {
[INFO] [stdout]    | ------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn from_pool(pool: PgPool) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub async fn health_check(&self) -> Result<Duration> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub fn pool_stats(&self) -> PoolStats {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 81 |     pub async fn close(&self) {
[INFO] [stdout]    |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PoolStats` is never constructed
[INFO] [stdout]   --> src/database/pool.rs:89:12
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub struct PoolStats {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_retention_policy` is never used
[INFO] [stdout]   --> src/database/timescale.rs:95:14
[INFO] [stdout]    |
[INFO] [stdout] 95 | pub async fn add_retention_policy(
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_compression_policy` is never used
[INFO] [stdout]    --> src/database/timescale.rs:143:14
[INFO] [stdout]     |
[INFO] [stdout] 143 | pub async fn add_compression_policy(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/error.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum RotaError {
[INFO] [stdout]    |          --------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 27 |     AllProxiesExhausted { attempts: u32 },
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     ProxyNotFound { id: i32 },
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 43 |     TunnelError(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     ConnectFailed(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     InvalidCredentials,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     MissingAuthHeader,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     InvalidAuthHeader,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     MissingEnvVar(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 80 |     RequestTimeout,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 95 |     SettingsNotFound { key: String },
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RotaError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `is_client_error` and `is_server_error` are never used
[INFO] [stdout]    --> src/error.rs:157:12
[INFO] [stdout]     |
[INFO] [stdout] 105 | impl RotaError {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub fn is_client_error(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 162 |     pub fn is_server_error(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DatabaseHealth` is never constructed
[INFO] [stdout]    --> src/models/dashboard.rs:109:12
[INFO] [stdout]     |
[INFO] [stdout] 109 | pub struct DatabaseHealth {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HealthStatus` is never constructed
[INFO] [stdout]    --> src/models/dashboard.rs:118:12
[INFO] [stdout]     |
[INFO] [stdout] 118 | pub struct HealthStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `LogLevel` is never used
[INFO] [stdout]  --> src/models/log.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub enum LogLevel {
[INFO] [stdout]   |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `as_str` and `from_str` are never used
[INFO] [stdout]   --> src/models/log.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl LogLevel {
[INFO] [stdout]    | ------------- associated items in this implementation
[INFO] [stdout] 18 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn from_str(s: &str) -> Option<Self> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `level_enum` is never used
[INFO] [stdout]   --> src/models/log.rs:59:12
[INFO] [stdout]    |
[INFO] [stdout] 57 | impl Log {
[INFO] [stdout]    | -------- method in this implementation
[INFO] [stdout] 58 |     /// Get the log level enum
[INFO] [stdout] 59 |     pub fn level_enum(&self) -> Option<LogLevel> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateLogRequest` is never constructed
[INFO] [stdout]   --> src/models/log.rs:66:12
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct CreateLogRequest {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `info`, `error`, `warning`, `success`, `with_details`, and `with_metadata` are never used
[INFO] [stdout]    --> src/models/log.rs:74:12
[INFO] [stdout]     |
[INFO] [stdout]  73 | impl CreateLogRequest {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout]  74 |     pub fn info(message: impl Into<String>) -> Self {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  83 |     pub fn error(message: impl Into<String>) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  92 |     pub fn warning(message: impl Into<String>) -> Self {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn success(message: impl Into<String>) -> Self {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub fn with_details(mut self, details: impl Into<String>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn with_metadata(mut self, key: impl Into<String>, value: serde_json::Value) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ProxyProtocol` is never used
[INFO] [stdout]   --> src/models/proxy.rs:10:10
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum ProxyProtocol {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `as_str`, `from_str`, `is_socks`, and `is_http` are never used
[INFO] [stdout]   --> src/models/proxy.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl ProxyProtocol {
[INFO] [stdout]    | ------------------ associated items in this implementation
[INFO] [stdout] 19 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |     pub fn from_str(s: &str) -> Option<Self> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub fn is_socks(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn is_http(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ProxyStatus` is never used
[INFO] [stdout]   --> src/models/proxy.rs:62:10
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub enum ProxyStatus {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `as_str`, `from_str`, and `is_usable` are never used
[INFO] [stdout]   --> src/models/proxy.rs:70:12
[INFO] [stdout]    |
[INFO] [stdout] 69 | impl ProxyStatus {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] 70 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 78 |     pub fn from_str(s: &str) -> Option<Self> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 87 |     pub fn is_usable(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `protocol_enum`, `status_enum`, `is_usable`, `matches_filter`, and `url` are never used
[INFO] [stdout]    --> src/models/proxy.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 120 | impl Proxy {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] 121 |     /// Get the protocol enum
[INFO] [stdout] 122 |     pub fn protocol_enum(&self) -> Option<ProxyProtocol> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 127 |     pub fn status_enum(&self) -> Option<ProxyStatus> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 141 |     pub fn is_usable(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 146 |     pub fn matches_filter(&self, settings: &super::RotationSettings) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn url(&self) -> String {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BulkDeleteProxiesRequest` is never constructed
[INFO] [stdout]    --> src/models/proxy.rs:276:12
[INFO] [stdout]     |
[INFO] [stdout] 276 | pub struct BulkDeleteProxiesRequest {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `password` is never read
[INFO] [stdout]   --> src/models/settings.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct AuthenticationSettings {
[INFO] [stdout]    |            ---------------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub password: String,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AuthenticationSettings` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_enabled` is never used
[INFO] [stdout]   --> src/proxy/middleware/auth.rs:43:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl ProxyAuth {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 43 |     pub fn is_enabled(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `is_enabled` and `client_count` are never used
[INFO] [stdout]    --> src/proxy/middleware/rate_limit.rs:80:12
[INFO] [stdout]     |
[INFO] [stdout]  58 | impl RateLimiter {
[INFO] [stdout]     | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  80 |     pub fn is_enabled(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 169 |     pub fn client_count(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `strategy_name` is never used
[INFO] [stdout]   --> src/proxy/rotation/mod.rs:75:8
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub trait ProxySelector: Send + Sync {
[INFO] [stdout]    |           ------------- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 75 |     fn strategy_name(&self) -> &'static str;
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `clear` is never used
[INFO] [stdout]    --> src/proxy/rotation/mod.rs:118:12
[INFO] [stdout]     |
[INFO] [stdout]  92 | impl ConnectionTracker {
[INFO] [stdout]     | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 118 |     pub fn clear(&self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_interval` and `get_interval` are never used
[INFO] [stdout]   --> src/proxy/rotation/time_based.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl TimeBasedSelector {
[INFO] [stdout]    | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn set_interval(&self, interval: Duration) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn get_interval(&self) -> Duration {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ProxyServerBuilder` is never constructed
[INFO] [stdout]    --> src/proxy/server.rs:195:12
[INFO] [stdout]     |
[INFO] [stdout] 195 | pub struct ProxyServerBuilder {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `selector`, `database`, `log_sender`, `rate_limiter`, and `build` are never used
[INFO] [stdout]    --> src/proxy/server.rs:204:12
[INFO] [stdout]     |
[INFO] [stdout] 203 | impl ProxyServerBuilder {
[INFO] [stdout]     | ----------------------- associated items in this implementation
[INFO] [stdout] 204 |     pub fn new(config: ProxyServerConfig) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 214 |     pub fn selector(mut self, selector: Arc<dyn ProxySelector>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 219 |     pub fn database(mut self, db_pool: PgPool) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 224 |     pub fn log_sender(mut self, sender: broadcast::Sender<RequestRecord>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 229 |     pub fn rate_limiter(mut self, rate_limiter: RateLimiter) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub fn build(self) -> ProxyServer {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `tunnel_through_proxy`, `tunnel_direct`, `handle_upgraded`, and `handle_upgraded_direct` are never used
[INFO] [stdout]    --> src/proxy/tunnel.rs:24:18
[INFO] [stdout]     |
[INFO] [stdout]  21 | impl TunnelHandler {
[INFO] [stdout]     | ------------------ associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  24 |     pub async fn tunnel_through_proxy(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     pub async fn tunnel_direct(target_host: &str, target_port: u16) -> Result<TcpStream> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  90 |     pub async fn handle_upgraded(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub async fn handle_upgraded_direct(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_success_rate_chart` and `get_response_time_chart` are never used
[INFO] [stdout]    --> src/repository/dashboard.rs:160:18
[INFO] [stdout]     |
[INFO] [stdout]  12 | impl DashboardRepository {
[INFO] [stdout]     | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 160 |     pub async fn get_success_rate_chart(&self, range: &ChartTimeRange) -> Result<ChartData> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 227 |     pub async fn get_response_time_chart(&self, range: &ChartTimeRange) -> Result<ChartData> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_by_id` is never used
[INFO] [stdout]   --> src/repository/deleted_proxy.rs:53:18
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl DeletedProxyRepository {
[INFO] [stdout]    | --------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub async fn get_by_id(&self, id: i32) -> Result<Option<DeletedProxy>> {
[INFO] [stdout]    |                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `create` and `get_since` are never used
[INFO] [stdout]    --> src/repository/log.rs:17:18
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl LogRepository {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  17 |     pub async fn create(&self, req: &CreateLogRequest) -> Result<Log> {
[INFO] [stdout]     |                  ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub async fn get_since(&self, last_id: i64, limit: i64) -> Result<Vec<Log>> {
[INFO] [stdout]     |                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `bulk_delete`, `count_by_status`, and `count_total` are never used
[INFO] [stdout]    --> src/repository/proxy.rs:310:18
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl ProxyRepository {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 310 |     pub async fn bulk_delete(&self, ids: &[i32]) -> Result<u64> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 491 |     pub async fn count_by_status(&self, status: &str) -> Result<i64> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 501 |     pub async fn count_total(&self) -> Result<i64> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/repository/settings.rs:64:18
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl SettingsRepository {
[INFO] [stdout]     | ----------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  64 |     pub async fn get<T: serde::de::DeserializeOwned>(&self, key: &str) -> Result<T> {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout]  83 |     pub async fn get_authentication(&self) -> Result<AuthenticationSettings> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  88 |     pub async fn get_rotation(&self) -> Result<RotationSettings> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub async fn get_rate_limit(&self) -> Result<RateLimitSettings> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  98 |     pub async fn get_healthcheck(&self) -> Result<HealthCheckSettings> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     pub async fn get_log_retention(&self) -> Result<LogRetentionSettings> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 143 |     pub async fn reset(&self) -> Result<Settings> {
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `MissingToken` is never constructed
[INFO] [stdout]    --> src/api/middleware/jwt.rs:111:5
[INFO] [stdout]     |
[INFO] [stdout] 107 | pub enum AuthError {
[INFO] [stdout]     |          --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 111 |     MissingToken,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AuthError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AuthenticatedUser` is never constructed
[INFO] [stdout]    --> src/api/middleware/jwt.rs:131:12
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub struct AuthenticatedUser {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RequestLogging` is never constructed
[INFO] [stdout]   --> src/api/middleware/logging.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct RequestLogging;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `log_request` is never used
[INFO] [stdout]   --> src/api/middleware/logging.rs:15:18
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl RequestLogging {
[INFO] [stdout]    | ------------------- associated function in this implementation
[INFO] [stdout] 14 |     /// Log request details
[INFO] [stdout] 15 |     pub async fn log_request(req: Request<Body>, next: Next) -> Response {
[INFO] [stdout]    |                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ApiServerBuilder` is never constructed
[INFO] [stdout]    --> src/api/server.rs:108:12
[INFO] [stdout]     |
[INFO] [stdout] 108 | pub struct ApiServerBuilder {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `config`, `database`, `selector`, `log_sender`, and `build` are never used
[INFO] [stdout]    --> src/api/server.rs:117:12
[INFO] [stdout]     |
[INFO] [stdout] 116 | impl ApiServerBuilder {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 117 |     pub fn new(api_config: ApiServerConfig) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 127 |     pub fn config(mut self, config: Config) -> Self {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn database(mut self, db: Database) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub fn selector(mut self, selector: Arc<DynamicProxySelector>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn log_sender(mut self, sender: broadcast::Sender<RequestRecord>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub fn build(self) -> ApiServer {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `log` is never read
[INFO] [stdout]   --> src/config.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub struct Config {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 17 |     pub log: LogConfig,
[INFO] [stdout]    |         ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Config` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `rate_limit_enabled`, `rate_limit_per_second`, and `rate_limit_burst` are never read
[INFO] [stdout]   --> src/config.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct ProxyServerConfig {
[INFO] [stdout]    |            ----------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     pub rate_limit_enabled: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 40 |     /// Rate limit requests per second
[INFO] [stdout] 41 |     pub rate_limit_per_second: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 42 |     /// Rate limit burst size
[INFO] [stdout] 43 |     pub rate_limit_burst: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProxyServerConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `level` and `format` are never read
[INFO] [stdout]    --> src/config.rs:108:9
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct LogConfig {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 107 |     /// Log level (debug, info, warn, error)
[INFO] [stdout] 108 |     pub level: String,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 109 |     /// Output format (json, pretty)
[INFO] [stdout] 110 |     pub format: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `LogConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `health_check`, `pool_stats`, and `close` are never used
[INFO] [stdout]   --> src/database/pool.rs:51:18
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl Database {
[INFO] [stdout]    | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub async fn health_check(&self) -> Result<Duration> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub fn pool_stats(&self) -> PoolStats {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 81 |     pub async fn close(&self) {
[INFO] [stdout]    |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PoolStats` is never constructed
[INFO] [stdout]   --> src/database/pool.rs:89:12
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub struct PoolStats {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/error.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum RotaError {
[INFO] [stdout]    |          --------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 27 |     AllProxiesExhausted { attempts: u32 },
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 43 |     TunnelError(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     ConnectFailed(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     InvalidCredentials,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     MissingAuthHeader,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     InvalidAuthHeader,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     MissingEnvVar(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 80 |     RequestTimeout,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 95 |     SettingsNotFound { key: String },
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RotaError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DatabaseHealth` is never constructed
[INFO] [stdout]    --> src/models/dashboard.rs:109:12
[INFO] [stdout]     |
[INFO] [stdout] 109 | pub struct DatabaseHealth {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HealthStatus` is never constructed
[INFO] [stdout]    --> src/models/dashboard.rs:118:12
[INFO] [stdout]     |
[INFO] [stdout] 118 | pub struct HealthStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `warning` is never used
[INFO] [stdout]   --> src/models/log.rs:92:12
[INFO] [stdout]    |
[INFO] [stdout] 73 | impl CreateLogRequest {
[INFO] [stdout]    | --------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 92 |     pub fn warning(message: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BulkDeleteProxiesRequest` is never constructed
[INFO] [stdout]    --> src/models/proxy.rs:276:12
[INFO] [stdout]     |
[INFO] [stdout] 276 | pub struct BulkDeleteProxiesRequest {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_enabled` is never used
[INFO] [stdout]   --> src/proxy/middleware/auth.rs:43:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl ProxyAuth {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 43 |     pub fn is_enabled(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_enabled` is never used
[INFO] [stdout]   --> src/proxy/middleware/rate_limit.rs:80:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl RateLimiter {
[INFO] [stdout]    | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 80 |     pub fn is_enabled(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ProxyServerBuilder` is never constructed
[INFO] [stdout]    --> src/proxy/server.rs:195:12
[INFO] [stdout]     |
[INFO] [stdout] 195 | pub struct ProxyServerBuilder {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `selector`, `database`, `log_sender`, `rate_limiter`, and `build` are never used
[INFO] [stdout]    --> src/proxy/server.rs:204:12
[INFO] [stdout]     |
[INFO] [stdout] 203 | impl ProxyServerBuilder {
[INFO] [stdout]     | ----------------------- associated items in this implementation
[INFO] [stdout] 204 |     pub fn new(config: ProxyServerConfig) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 214 |     pub fn selector(mut self, selector: Arc<dyn ProxySelector>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 219 |     pub fn database(mut self, db_pool: PgPool) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 224 |     pub fn log_sender(mut self, sender: broadcast::Sender<RequestRecord>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 229 |     pub fn rate_limiter(mut self, rate_limiter: RateLimiter) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub fn build(self) -> ProxyServer {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `tunnel_through_proxy`, `tunnel_direct`, `handle_upgraded`, and `handle_upgraded_direct` are never used
[INFO] [stdout]    --> src/proxy/tunnel.rs:24:18
[INFO] [stdout]     |
[INFO] [stdout]  21 | impl TunnelHandler {
[INFO] [stdout]     | ------------------ associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  24 |     pub async fn tunnel_through_proxy(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     pub async fn tunnel_direct(target_host: &str, target_port: u16) -> Result<TcpStream> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  90 |     pub async fn handle_upgraded(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub async fn handle_upgraded_direct(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_success_rate_chart` and `get_response_time_chart` are never used
[INFO] [stdout]    --> src/repository/dashboard.rs:160:18
[INFO] [stdout]     |
[INFO] [stdout]  12 | impl DashboardRepository {
[INFO] [stdout]     | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 160 |     pub async fn get_success_rate_chart(&self, range: &ChartTimeRange) -> Result<ChartData> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 227 |     pub async fn get_response_time_chart(&self, range: &ChartTimeRange) -> Result<ChartData> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_by_id` is never used
[INFO] [stdout]   --> src/repository/deleted_proxy.rs:53:18
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl DeletedProxyRepository {
[INFO] [stdout]    | --------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub async fn get_by_id(&self, id: i32) -> Result<Option<DeletedProxy>> {
[INFO] [stdout]    |                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `create` and `get_since` are never used
[INFO] [stdout]    --> src/repository/log.rs:17:18
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl LogRepository {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  17 |     pub async fn create(&self, req: &CreateLogRequest) -> Result<Log> {
[INFO] [stdout]     |                  ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub async fn get_since(&self, last_id: i64, limit: i64) -> Result<Vec<Log>> {
[INFO] [stdout]     |                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `bulk_delete`, `count_by_status`, and `count_total` are never used
[INFO] [stdout]    --> src/repository/proxy.rs:310:18
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl ProxyRepository {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 310 |     pub async fn bulk_delete(&self, ids: &[i32]) -> Result<u64> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 491 |     pub async fn count_by_status(&self, status: &str) -> Result<i64> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 501 |     pub async fn count_total(&self) -> Result<i64> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/repository/settings.rs:64:18
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl SettingsRepository {
[INFO] [stdout]     | ----------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  64 |     pub async fn get<T: serde::de::DeserializeOwned>(&self, key: &str) -> Result<T> {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout]  83 |     pub async fn get_authentication(&self) -> Result<AuthenticationSettings> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  88 |     pub async fn get_rotation(&self) -> Result<RotationSettings> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub async fn get_rate_limit(&self) -> Result<RateLimitSettings> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  98 |     pub async fn get_healthcheck(&self) -> Result<HealthCheckSettings> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     pub async fn get_log_retention(&self) -> Result<LogRetentionSettings> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 143 |     pub async fn reset(&self) -> Result<Settings> {
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 00s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: sqlx-postgres v0.7.4
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] running `Command { std: "docker" "inspect" "e300b3704a00a87ddfe6e0181ea82f6da1fd1b473de759201caa3a39639c2dfa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e300b3704a00a87ddfe6e0181ea82f6da1fd1b473de759201caa3a39639c2dfa", kill_on_drop: false }`
[INFO] [stdout] e300b3704a00a87ddfe6e0181ea82f6da1fd1b473de759201caa3a39639c2dfa
