[INFO] cloning repository https://github.com/Arekkusul/ExploitAtlas
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Arekkusul/ExploitAtlas" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArekkusul%2FExploitAtlas", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArekkusul%2FExploitAtlas'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 755e4fa28490f8947e5aa2a766c5314b85fddf54
[INFO] checking Arekkusul/ExploitAtlas against master#59fd4ef94daa991e6797b5aa6127e824f3067def for pr-145108-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArekkusul%2FExploitAtlas" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Arekkusul/ExploitAtlas
[INFO] finished tweaking git repo https://github.com/Arekkusul/ExploitAtlas
[INFO] tweaked toml for git repo https://github.com/Arekkusul/ExploitAtlas written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Arekkusul/ExploitAtlas on toolchain 59fd4ef94daa991e6797b5aa6127e824f3067def
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+59fd4ef94daa991e6797b5aa6127e824f3067def" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Arekkusul/ExploitAtlas 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" "+59fd4ef94daa991e6797b5aa6127e824f3067def" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded route-recognizer v0.3.1
[INFO] [stderr]   Downloaded tower_governor v0.4.3
[INFO] [stderr]   Downloaded yew-router v0.18.0
[INFO] [stderr]   Downloaded ordered-float v1.1.1
[INFO] [stderr]   Downloaded implicit-clone-derive v0.1.2
[INFO] [stderr]   Downloaded yew-router-macro v0.18.0
[INFO] [stderr]   Downloaded genpdf v0.2.0
[INFO] [stderr]   Downloaded printpdf v0.3.4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/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" "+59fd4ef94daa991e6797b5aa6127e824f3067def" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 902e72d15dd5bf23ee5a9f916f6fa6b3f84093db98ca3d1afd4d36dcc6a241b1
[INFO] running `Command { std: "docker" "start" "-a" "902e72d15dd5bf23ee5a9f916f6fa6b3f84093db98ca3d1afd4d36dcc6a241b1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "902e72d15dd5bf23ee5a9f916f6fa6b3f84093db98ca3d1afd4d36dcc6a241b1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "902e72d15dd5bf23ee5a9f916f6fa6b3f84093db98ca3d1afd4d36dcc6a241b1", kill_on_drop: false }`
[INFO] [stdout] 902e72d15dd5bf23ee5a9f916f6fa6b3f84093db98ca3d1afd4d36dcc6a241b1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/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" "+59fd4ef94daa991e6797b5aa6127e824f3067def" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 58b13f07ae1803b404a2bb9748eb29352d51f0e7c98305c6b2430d806b41f764
[INFO] running `Command { std: "docker" "start" "-a" "58b13f07ae1803b404a2bb9748eb29352d51f0e7c98305c6b2430d806b41f764", kill_on_drop: false }`
[INFO] [stderr]    Compiling zmij v1.0.19
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling wasm-bindgen-shared v0.2.108
[INFO] [stderr]    Compiling bumpalo v3.19.1
[INFO] [stderr]     Checking unicode-ident v1.0.22
[INFO] [stderr]     Checking log v0.4.29
[INFO] [stderr]     Checking tracing-core v0.1.36
[INFO] [stderr]    Compiling wasm-bindgen v0.2.108
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling cc v1.2.55
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]     Checking http v1.4.0
[INFO] [stderr]     Checking getrandom v0.2.17
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking crypto-common v0.1.7
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling zerocopy v0.8.37
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling winnow v0.5.40
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking simd-adler32 v0.3.8
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]     Checking crc32fast v1.5.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling socket2 v0.6.2
[INFO] [stderr]    Compiling slab v0.4.12
[INFO] [stderr]     Checking http v0.2.12
[INFO] [stderr]     Checking flate2 v1.1.8
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling futures-intrusive v0.5.0
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling event-listener v5.4.1
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling rustls v0.23.36
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]    Compiling prettyplease v0.2.37
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]    Compiling unicase v2.9.0
[INFO] [stderr]     Checking data-encoding v2.10.0
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]     Checking iana-time-zone v0.1.65
[INFO] [stderr]    Compiling portable-atomic v1.13.1
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]     Checking raw-cpuid v11.6.0
[INFO] [stderr]     Checking bstr v1.12.1
[INFO] [stderr]    Compiling time-macros-impl v0.1.2
[INFO] [stderr]     Checking sha2 v0.10.9
[INFO] [stderr]     Checking stb_truetype v0.3.1
[INFO] [stderr]    Compiling libsqlite3-sys v0.30.1
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]     Checking ordered-float v1.1.1
[INFO] [stderr]     Checking approx v0.3.2
[INFO] [stderr]     Checking num_cpus v1.17.0
[INFO] [stderr]     Checking lzw v0.10.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking compression-core v0.4.31
[INFO] [stderr]     Checking rusttype v0.8.3
[INFO] [stderr]     Checking compression-codecs v0.4.36
[INFO] [stderr]     Checking pom v3.4.0
[INFO] [stderr]     Checking webpki-roots v1.0.5
[INFO] [stderr]     Checking time-macros v0.1.1
[INFO] [stderr]     Checking spinning_top v0.3.0
[INFO] [stderr]     Checking time v0.2.27
[INFO] [stderr]     Checking serde_path_to_error v0.1.20
[INFO] [stderr]     Checking nonzero_ext v0.3.0
[INFO] [stderr]     Checking futures-timer v3.0.3
[INFO] [stderr]     Checking no-std-compat v0.4.1
[INFO] [stderr]    Compiling anyhow v1.0.100
[INFO] [stderr]     Checking nonempty v0.7.0
[INFO] [stderr]     Checking dashmap v5.5.3
[INFO] [stderr]     Checking sharded-slab v0.1.7
[INFO] [stderr]     Checking uuid v1.20.0
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking thread_local v1.1.9
[INFO] [stderr]     Checking http-range-header v0.4.2
[INFO] [stderr]    Compiling toml_edit v0.19.15
[INFO] [stderr]     Checking route-recognizer v0.3.1
[INFO] [stderr]     Checking nu-ansi-term v0.50.3
[INFO] [stderr]     Checking lru v0.12.5
[INFO] [stderr]     Checking dotenvy v0.15.7
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]     Checking quanta v0.12.6
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling wasm-bindgen-macro-support v0.2.108
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling proc-macro-crate v1.3.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]     Checking rustls-webpki v0.103.9
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling implicit-clone-derive v0.1.2
[INFO] [stderr]    Compiling yew-macro v0.21.0
[INFO] [stderr]     Checking forwarded-header-value v0.1.1
[INFO] [stderr]     Checking implicit-clone v0.4.9
[INFO] [stderr]    Compiling gloo-worker-macros v0.1.0
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]     Checking pin-project v1.1.10
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]     Checking tungstenite v0.24.0
[INFO] [stderr]    Compiling yew-router-macro v0.18.0
[INFO] [stderr]    Compiling derive_more v0.99.20
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling wasm-bindgen-macro v0.2.108
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking js-sys v0.3.85
[INFO] [stderr]     Checking console_error_panic_hook v0.1.7
[INFO] [stderr]     Checking axum-core v0.4.5
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking chrono v0.4.43
[INFO] [stderr]     Checking shared v0.1.0 (/opt/rustwide/workdir/shared)
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking pinned v0.1.0
[INFO] [stderr]     Checking governor v0.6.3
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]     Checking hyper v1.8.1
[INFO] [stderr]     Checking tower v0.5.3
[INFO] [stderr]     Checking tokio-tungstenite v0.24.0
[INFO] [stderr]     Checking tokio-util v0.7.18
[INFO] [stderr]     Checking async-compression v0.4.37
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]     Checking tokio-rustls v0.26.4
[INFO] [stderr]     Checking prokio v0.1.0
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]     Checking tower-http v0.5.2
[INFO] [stderr]     Checking tower-http v0.6.8
[INFO] [stderr]     Checking lopdf v0.26.0
[INFO] [stderr]     Checking hyper-util v0.1.19
[INFO] [stderr]    Compiling sqlx-core v0.8.6
[INFO] [stderr]     Checking printpdf v0.3.4
[INFO] [stderr]     Checking hyper-rustls v0.27.7
[INFO] [stderr]     Checking axum v0.7.9
[INFO] [stderr]     Checking genpdf v0.2.0
[INFO] [stderr]     Checking web-sys v0.3.85
[INFO] [stderr]     Checking wasm-bindgen-futures v0.4.58
[INFO] [stderr]     Checking serde-wasm-bindgen v0.6.5
[INFO] [stderr]     Checking gloo-timers v0.3.0
[INFO] [stderr]     Checking reqwest v0.12.28
[INFO] [stderr]     Checking sqlx-sqlite v0.8.6
[INFO] [stderr]     Checking tower_governor v0.4.3
[INFO] [stderr]    Compiling sqlx-macros-core v0.8.6
[INFO] [stderr]    Compiling sqlx-macros v0.8.6
[INFO] [stderr]     Checking sqlx v0.8.6
[INFO] [stderr]     Checking backend v0.1.0 (/opt/rustwide/workdir/backend)
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> backend/src/services/greynoise.rs:104:9
[INFO] [stdout]     |
[INFO] [stdout] 104 |     let mut countries: std::collections::HashMap<String, u32> = std::collections::HashMap::new();
[INFO] [stdout]     |         ----^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> backend/src/services/greynoise.rs:104:9
[INFO] [stdout]     |
[INFO] [stdout] 104 |     let mut countries: std::collections::HashMap<String, u32> = std::collections::HashMap::new();
[INFO] [stdout]     |         ----^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking gloo-utils v0.2.0
[INFO] [stderr]     Checking gloo-events v0.2.0
[INFO] [stderr]     Checking gloo-render v0.2.0
[INFO] [stderr]     Checking gloo-dialogs v0.2.0
[INFO] [stderr]     Checking gloo-storage v0.3.0
[INFO] [stderr]     Checking gloo-console v0.3.0
[INFO] [stderr]     Checking gloo-net v0.4.0
[INFO] [stderr]     Checking gloo-worker v0.4.0
[INFO] [stderr]     Checking gloo-net v0.5.0
[INFO] [stderr]     Checking gloo-worker v0.5.0
[INFO] [stderr]     Checking gloo-net v0.6.0
[INFO] [stderr]     Checking gloo-history v0.2.2
[INFO] [stderr]     Checking gloo-file v0.3.0
[INFO] [stderr]     Checking gloo v0.11.0
[INFO] [stderr]     Checking gloo v0.10.0
[INFO] [stderr]     Checking yew v0.21.0
[INFO] [stdout] warning: constant `MITRE_EXECUTION` is never used
[INFO] [stdout]  --> backend/src/services/attack_path.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | const MITRE_EXECUTION: &str = "TA0002";
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MITRE_PERSISTENCE` is never used
[INFO] [stdout]   --> backend/src/services/attack_path.rs:10:7
[INFO] [stdout]    |
[INFO] [stdout] 10 | const MITRE_PERSISTENCE: &str = "TA0003";
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MITRE_PRIV_ESC` is never used
[INFO] [stdout]   --> backend/src/services/attack_path.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const MITRE_PRIV_ESC: &str = "TA0004";
[INFO] [stdout]    |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MITRE_DEFENSE_EVASION` is never used
[INFO] [stdout]   --> backend/src/services/attack_path.rs:12:7
[INFO] [stdout]    |
[INFO] [stdout] 12 | const MITRE_DEFENSE_EVASION: &str = "TA0005";
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MITRE_CREDENTIAL_ACCESS` is never used
[INFO] [stdout]   --> backend/src/services/attack_path.rs:13:7
[INFO] [stdout]    |
[INFO] [stdout] 13 | const MITRE_CREDENTIAL_ACCESS: &str = "TA0006";
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `should_update_epss` is never used
[INFO] [stdout]    --> backend/src/services/epss_tracker.rs:165:14
[INFO] [stdout]     |
[INFO] [stdout] 165 | pub async fn should_update_epss(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `id` is never read
[INFO] [stdout]   --> backend/src/services/virustotal.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | struct VtSearchItem {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] 19 |     #[serde(default)]
[INFO] [stdout] 20 |     id: String,
[INFO] [stdout]    |     ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `VtSearchItem` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `md5` is never read
[INFO] [stdout]   --> backend/src/services/virustotal.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | struct VtAttributes {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 36 |     md5: Option<String>,
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `VtAttributes` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `count` is never read
[INFO] [stdout]   --> backend/src/services/virustotal.rs:62:5
[INFO] [stdout]    |
[INFO] [stdout] 58 | struct VtThreatName {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 62 |     count: u32,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `VtThreatName` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `vector` and `authentication` are never read
[INFO] [stdout]   --> backend/src/services/circl.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | struct CirclAccess {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 38 |     vector: String,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 39 |     #[serde(default)]
[INFO] [stdout] 40 |     authentication: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CirclAccess` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `search_related_cves` is never used
[INFO] [stdout]    --> backend/src/services/circl.rs:133:14
[INFO] [stdout]     |
[INFO] [stdout] 133 | pub async fn search_related_cves(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GREYNOISE_RIOT_API` is never used
[INFO] [stdout]   --> backend/src/services/greynoise.rs:13:7
[INFO] [stdout]    |
[INFO] [stdout] 13 | const GREYNOISE_RIOT_API: &str = "https://api.greynoise.io/v2/riot/";
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `message` is never read
[INFO] [stdout]   --> backend/src/services/greynoise.rs:72:5
[INFO] [stdout]    |
[INFO] [stdout] 61 | struct CommunityResponse {
[INFO] [stdout]    |        ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 72 |     message: Option<String>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CommunityResponse` 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 `RiotResponse` is never constructed
[INFO] [stdout]   --> backend/src/services/greynoise.rs:77:8
[INFO] [stdout]    |
[INFO] [stdout] 77 | struct RiotResponse {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `catalog_version`, `date_released`, and `count` are never read
[INFO] [stdout]   --> backend/src/services/cisa.rs:58:5
[INFO] [stdout]    |
[INFO] [stdout] 56 | struct KevCatalog {
[INFO] [stdout]    |        ---------- fields in this struct
[INFO] [stdout] 57 |     #[serde(rename = "catalogVersion")]
[INFO] [stdout] 58 |     catalog_version: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 59 |     #[serde(rename = "dateReleased")]
[INFO] [stdout] 60 |     date_released: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 61 |     count: u32,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `KevCatalog` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `vendor_project`, `product`, `vulnerability_name`, `date_added`, and `short_description` are never read
[INFO] [stdout]   --> backend/src/services/cisa.rs:70:5
[INFO] [stdout]    |
[INFO] [stdout] 66 | struct KevVulnerability {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 70 |     vendor_project: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 71 |     product: String,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 72 |     #[serde(rename = "vulnerabilityName")]
[INFO] [stdout] 73 |     vulnerability_name: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 74 |     #[serde(rename = "dateAdded")]
[INFO] [stdout] 75 |     date_added: String,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 76 |     #[serde(rename = "shortDescription")]
[INFO] [stdout] 77 |     short_description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `KevVulnerability` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `retry_with_backoff` is never used
[INFO] [stdout]    --> backend/src/services/resilience.rs:276:14
[INFO] [stdout]     |
[INFO] [stdout] 276 | pub async fn retry_with_backoff<F, Fut, T, E>(f: F) -> Result<T, E>
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `shared_circuit_breaker` is never used
[INFO] [stdout]    --> backend/src/services/resilience.rs:372:8
[INFO] [stdout]     |
[INFO] [stdout] 372 | pub fn shared_circuit_breaker(name: impl Into<String>) -> SharedCircuitBreaker {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `attacks` is never read
[INFO] [stdout]    --> backend/src/services/attack_feed.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 152 | struct DShieldIpEntry {
[INFO] [stdout]     |        -------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 158 |     attacks: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `DShieldIpEntry` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `targets` and `sources` are never read
[INFO] [stdout]    --> backend/src/services/attack_feed.rs:178:5
[INFO] [stdout]     |
[INFO] [stdout] 172 | struct DShieldPortEntry {
[INFO] [stdout]     |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 178 |     targets: u64,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 179 |     #[serde(default)]
[INFO] [stdout] 180 |     sources: u64,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `DShieldPortEntry` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MITRE_EXECUTION` is never used
[INFO] [stdout]  --> backend/src/services/attack_path.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | const MITRE_EXECUTION: &str = "TA0002";
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MITRE_PERSISTENCE` is never used
[INFO] [stdout]   --> backend/src/services/attack_path.rs:10:7
[INFO] [stdout]    |
[INFO] [stdout] 10 | const MITRE_PERSISTENCE: &str = "TA0003";
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MITRE_PRIV_ESC` is never used
[INFO] [stdout]   --> backend/src/services/attack_path.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const MITRE_PRIV_ESC: &str = "TA0004";
[INFO] [stdout]    |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MITRE_DEFENSE_EVASION` is never used
[INFO] [stdout]   --> backend/src/services/attack_path.rs:12:7
[INFO] [stdout]    |
[INFO] [stdout] 12 | const MITRE_DEFENSE_EVASION: &str = "TA0005";
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MITRE_CREDENTIAL_ACCESS` is never used
[INFO] [stdout]   --> backend/src/services/attack_path.rs:13:7
[INFO] [stdout]    |
[INFO] [stdout] 13 | const MITRE_CREDENTIAL_ACCESS: &str = "TA0006";
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `should_update_epss` is never used
[INFO] [stdout]    --> backend/src/services/epss_tracker.rs:165:14
[INFO] [stdout]     |
[INFO] [stdout] 165 | pub async fn should_update_epss(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `id` is never read
[INFO] [stdout]   --> backend/src/services/virustotal.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | struct VtSearchItem {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] 19 |     #[serde(default)]
[INFO] [stdout] 20 |     id: String,
[INFO] [stdout]    |     ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `VtSearchItem` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `md5` is never read
[INFO] [stdout]   --> backend/src/services/virustotal.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | struct VtAttributes {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 36 |     md5: Option<String>,
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `VtAttributes` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `count` is never read
[INFO] [stdout]   --> backend/src/services/virustotal.rs:62:5
[INFO] [stdout]    |
[INFO] [stdout] 58 | struct VtThreatName {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 62 |     count: u32,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `VtThreatName` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `vector` and `authentication` are never read
[INFO] [stdout]   --> backend/src/services/circl.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | struct CirclAccess {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 38 |     vector: String,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 39 |     #[serde(default)]
[INFO] [stdout] 40 |     authentication: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CirclAccess` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `search_related_cves` is never used
[INFO] [stdout]    --> backend/src/services/circl.rs:133:14
[INFO] [stdout]     |
[INFO] [stdout] 133 | pub async fn search_related_cves(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GREYNOISE_RIOT_API` is never used
[INFO] [stdout]   --> backend/src/services/greynoise.rs:13:7
[INFO] [stdout]    |
[INFO] [stdout] 13 | const GREYNOISE_RIOT_API: &str = "https://api.greynoise.io/v2/riot/";
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `message` is never read
[INFO] [stdout]   --> backend/src/services/greynoise.rs:72:5
[INFO] [stdout]    |
[INFO] [stdout] 61 | struct CommunityResponse {
[INFO] [stdout]    |        ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 72 |     message: Option<String>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CommunityResponse` 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 `RiotResponse` is never constructed
[INFO] [stdout]   --> backend/src/services/greynoise.rs:77:8
[INFO] [stdout]    |
[INFO] [stdout] 77 | struct RiotResponse {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_ip` is never used
[INFO] [stdout]    --> backend/src/services/greynoise.rs:185:14
[INFO] [stdout]     |
[INFO] [stdout] 185 | pub async fn check_ip(
[INFO] [stdout]     |              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `catalog_version`, `date_released`, and `count` are never read
[INFO] [stdout]   --> backend/src/services/cisa.rs:58:5
[INFO] [stdout]    |
[INFO] [stdout] 56 | struct KevCatalog {
[INFO] [stdout]    |        ---------- fields in this struct
[INFO] [stdout] 57 |     #[serde(rename = "catalogVersion")]
[INFO] [stdout] 58 |     catalog_version: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 59 |     #[serde(rename = "dateReleased")]
[INFO] [stdout] 60 |     date_released: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 61 |     count: u32,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `KevCatalog` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `vendor_project`, `product`, `vulnerability_name`, `date_added`, and `short_description` are never read
[INFO] [stdout]   --> backend/src/services/cisa.rs:70:5
[INFO] [stdout]    |
[INFO] [stdout] 66 | struct KevVulnerability {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 70 |     vendor_project: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 71 |     product: String,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 72 |     #[serde(rename = "vulnerabilityName")]
[INFO] [stdout] 73 |     vulnerability_name: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 74 |     #[serde(rename = "dateAdded")]
[INFO] [stdout] 75 |     date_added: String,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 76 |     #[serde(rename = "shortDescription")]
[INFO] [stdout] 77 |     short_description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `KevVulnerability` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `retry_with_backoff` is never used
[INFO] [stdout]    --> backend/src/services/resilience.rs:276:14
[INFO] [stdout]     |
[INFO] [stdout] 276 | pub async fn retry_with_backoff<F, Fut, T, E>(f: F) -> Result<T, E>
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `shared_circuit_breaker` is never used
[INFO] [stdout]    --> backend/src/services/resilience.rs:372:8
[INFO] [stdout]     |
[INFO] [stdout] 372 | pub fn shared_circuit_breaker(name: impl Into<String>) -> SharedCircuitBreaker {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `attacks` is never read
[INFO] [stdout]    --> backend/src/services/attack_feed.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 152 | struct DShieldIpEntry {
[INFO] [stdout]     |        -------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 158 |     attacks: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `DShieldIpEntry` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `targets` and `sources` are never read
[INFO] [stdout]    --> backend/src/services/attack_feed.rs:178:5
[INFO] [stdout]     |
[INFO] [stdout] 172 | struct DShieldPortEntry {
[INFO] [stdout]     |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 178 |     targets: u64,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 179 |     #[serde(default)]
[INFO] [stdout] 180 |     sources: u64,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `DShieldPortEntry` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking yew-router v0.18.0
[INFO] [stderr]     Checking frontend v0.1.0 (/opt/rustwide/workdir/frontend)
[INFO] [stdout] warning: function `update_heatmap` is never used
[INFO] [stdout]    --> frontend/src/bindings/leaflet.rs:117:8
[INFO] [stdout]     |
[INFO] [stdout] 117 | pub fn update_heatmap(map: &JsValue, points_json: &str) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_epss_history` is never used
[INFO] [stdout]    --> frontend/src/services/api.rs:214:14
[INFO] [stdout]     |
[INFO] [stdout] 214 | pub async fn get_epss_history(cve_id: &str) -> Result<shared::EpssHistoryResponse, String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_source_health` is never used
[INFO] [stdout]    --> frontend/src/services/api.rs:231:14
[INFO] [stdout]     |
[INFO] [stdout] 231 | pub async fn get_source_health() -> Result<shared::SourceHealthResponse, String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_cache_stats` is never used
[INFO] [stdout]    --> frontend/src/services/api.rs:246:14
[INFO] [stdout]     |
[INFO] [stdout] 246 | pub async fn get_cache_stats() -> Result<serde_json::Value, String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `bulk_analyze` is never used
[INFO] [stdout]    --> frontend/src/services/api.rs:263:14
[INFO] [stdout]     |
[INFO] [stdout] 263 | pub async fn bulk_analyze(cve_ids: Vec<String>) -> Result<shared::BulkJob, String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_bulk_job` is never used
[INFO] [stdout]    --> frontend/src/services/api.rs:282:14
[INFO] [stdout]     |
[INFO] [stdout] 282 | pub async fn get_bulk_job(job_id: &str) -> Result<shared::BulkJobResponse, String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `update_heatmap` is never used
[INFO] [stdout]    --> frontend/src/bindings/leaflet.rs:117:8
[INFO] [stdout]     |
[INFO] [stdout] 117 | pub fn update_heatmap(map: &JsValue, points_json: &str) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_epss_history` is never used
[INFO] [stdout]    --> frontend/src/services/api.rs:214:14
[INFO] [stdout]     |
[INFO] [stdout] 214 | pub async fn get_epss_history(cve_id: &str) -> Result<shared::EpssHistoryResponse, String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_source_health` is never used
[INFO] [stdout]    --> frontend/src/services/api.rs:231:14
[INFO] [stdout]     |
[INFO] [stdout] 231 | pub async fn get_source_health() -> Result<shared::SourceHealthResponse, String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_cache_stats` is never used
[INFO] [stdout]    --> frontend/src/services/api.rs:246:14
[INFO] [stdout]     |
[INFO] [stdout] 246 | pub async fn get_cache_stats() -> Result<serde_json::Value, String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `bulk_analyze` is never used
[INFO] [stdout]    --> frontend/src/services/api.rs:263:14
[INFO] [stdout]     |
[INFO] [stdout] 263 | pub async fn bulk_analyze(cve_ids: Vec<String>) -> Result<shared::BulkJob, String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_bulk_job` is never used
[INFO] [stdout]    --> frontend/src/services/api.rs:282:14
[INFO] [stdout]     |
[INFO] [stdout] 282 | pub async fn get_bulk_job(job_id: &str) -> Result<shared::BulkJobResponse, String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 41s
[INFO] running `Command { std: "docker" "inspect" "58b13f07ae1803b404a2bb9748eb29352d51f0e7c98305c6b2430d806b41f764", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "58b13f07ae1803b404a2bb9748eb29352d51f0e7c98305c6b2430d806b41f764", kill_on_drop: false }`
[INFO] [stdout] 58b13f07ae1803b404a2bb9748eb29352d51f0e7c98305c6b2430d806b41f764
