[INFO] cloning repository https://github.com/maisonlam90/axum
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/maisonlam90/axum" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmaisonlam90%2Faxum", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmaisonlam90%2Faxum'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 44f9d5243edb0d5f737d042d5228a56aa4e76351
[INFO] checking maisonlam90/axum against try#84addd32a13fa2d3f62fe5d99031611147b7fb13 for pr-147565
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmaisonlam90%2Faxum" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'...
[INFO] [stderr] done.
[INFO] [stderr] Updating files:  48% (7705/16033)
Updating files:  49% (7857/16033)
Updating files:  50% (8017/16033)
Updating files:  51% (8177/16033)
Updating files:  52% (8338/16033)
Updating files:  53% (8498/16033)
Updating files:  54% (8658/16033)
Updating files:  55% (8819/16033)
Updating files:  56% (8979/16033)
Updating files:  57% (9139/16033)
Updating files:  58% (9300/16033)
Updating files:  59% (9460/16033)
Updating files:  60% (9620/16033)
Updating files:  61% (9781/16033)
Updating files:  62% (9941/16033)
Updating files:  63% (10101/16033)
Updating files:  64% (10262/16033)
Updating files:  65% (10422/16033)
Updating files:  66% (10582/16033)
Updating files:  67% (10743/16033)
Updating files:  68% (10903/16033)
Updating files:  69% (11063/16033)
Updating files:  70% (11224/16033)
Updating files:  71% (11384/16033)
Updating files:  72% (11544/16033)
Updating files:  73% (11705/16033)
Updating files:  74% (11865/16033)
Updating files:  75% (12025/16033)
Updating files:  76% (12186/16033)
Updating files:  77% (12346/16033)
Updating files:  78% (12506/16033)
Updating files:  79% (12667/16033)
Updating files:  80% (12827/16033)
Updating files:  81% (12987/16033)
Updating files:  82% (13148/16033)
Updating files:  83% (13308/16033)
Updating files:  84% (13468/16033)
Updating files:  85% (13629/16033)
Updating files:  86% (13789/16033)
Updating files:  87% (13949/16033)
Updating files:  88% (14110/16033)
Updating files:  89% (14270/16033)
Updating files:  90% (14430/16033)
Updating files:  91% (14591/16033)
Updating files:  92% (14751/16033)
Updating files:  93% (14911/16033)
Updating files:  94% (15072/16033)
Updating files:  95% (15232/16033)
Updating files:  96% (15392/16033)
Updating files:  97% (15553/16033)
Updating files:  98% (15713/16033)
Updating files:  99% (15873/16033)
Updating files: 100% (16033/16033)
Updating files: 100% (16033/16033), done.
[INFO] removed /workspace/builds/worker-5-tc2/source/rust-toolchain.toml
[INFO] started tweaking git repo https://github.com/maisonlam90/axum
[INFO] finished tweaking git repo https://github.com/maisonlam90/axum
[INFO] tweaked toml for git repo https://github.com/maisonlam90/axum written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/maisonlam90/axum on toolchain 84addd32a13fa2d3f62fe5d99031611147b7fb13
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+84addd32a13fa2d3f62fe5d99031611147b7fb13" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+84addd32a13fa2d3f62fe5d99031611147b7fb13" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 338 packages to latest compatible versions
[INFO] [stderr]       Adding axum v0.7.9 (available: v0.8.6)
[INFO] [stderr]       Adding bcrypt v0.15.1 (available: v0.17.1)
[INFO] [stderr]       Adding bigdecimal v0.3.1 (available: v0.4.9)
[INFO] [stderr]       Adding chrono-tz v0.8.6 (available: v0.10.4)
[INFO] [stderr]       Adding convert_case v0.5.0 (available: v0.8.0)
[INFO] [stderr]       Adding jsonwebtoken v9.3.1 (available: v10.1.0)
[INFO] [stderr]       Adding redis v0.24.0 (available: v0.32.7)
[INFO] [stderr]       Adding sqlx v0.7.4 (available: v0.8.6)
[INFO] [stderr]       Adding tokio-tungstenite v0.20.1 (available: v0.28.0)
[INFO] [stderr]       Adding tower v0.4.13 (available: v0.5.2)
[INFO] [stderr]       Adding tower-http v0.5.2 (available: v0.6.6)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+84addd32a13fa2d3f62fe5d99031611147b7fb13" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+84addd32a13fa2d3f62fe5d99031611147b7fb13" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] eb0fb89c4da9fe8b407bf86a06e59370a63e0f031a5e78f6857b7ec33fc1f2f7
[INFO] running `Command { std: "docker" "start" "-a" "eb0fb89c4da9fe8b407bf86a06e59370a63e0f031a5e78f6857b7ec33fc1f2f7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "eb0fb89c4da9fe8b407bf86a06e59370a63e0f031a5e78f6857b7ec33fc1f2f7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "eb0fb89c4da9fe8b407bf86a06e59370a63e0f031a5e78f6857b7ec33fc1f2f7", kill_on_drop: false }`
[INFO] [stdout] eb0fb89c4da9fe8b407bf86a06e59370a63e0f031a5e78f6857b7ec33fc1f2f7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+84addd32a13fa2d3f62fe5d99031611147b7fb13" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 4797fa6071c7aabfec4c47789496f977531f86819d0c767f0192e325670ec4b1
[INFO] running `Command { std: "docker" "start" "-a" "4797fa6071c7aabfec4c47789496f977531f86819d0c767f0192e325670ec4b1", kill_on_drop: false }`
[INFO] [stderr]    Compiling find-msvc-tools v0.1.4
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]    Compiling icu_normalizer_data v2.1.1
[INFO] [stderr]    Compiling icu_properties_data v2.1.1
[INFO] [stderr]    Compiling libc v0.2.177
[INFO] [stderr]     Checking stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling syn v2.0.108
[INFO] [stderr]     Checking memchr v2.7.6
[INFO] [stderr]     Checking lock_api v0.4.14
[INFO] [stderr]     Checking socket2 v0.6.1
[INFO] [stderr]     Checking signal-hook-registry v1.4.6
[INFO] [stderr]     Checking mio v1.1.0
[INFO] [stderr]     Checking log v0.4.28
[INFO] [stderr]     Checking crypto-common v0.1.6
[INFO] [stderr]     Checking litemap v0.8.1
[INFO] [stderr]     Checking writeable v0.6.2
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling cc v1.2.44
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]     Checking slab v0.4.11
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking form_urlencoded v1.2.2
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling rustls v0.21.12
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]    Compiling bytes v1.10.1
[INFO] [stderr]    Compiling regex-syntax v0.8.8
[INFO] [stderr]    Compiling tinyvec v1.10.0
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling rustix v1.1.2
[INFO] [stderr]    Compiling base64 v0.21.7
[INFO] [stderr]    Compiling iana-time-zone v0.1.64
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling atoi v2.0.0
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling rustls-pemfile v1.0.4
[INFO] [stderr]    Compiling tokio v1.48.0
[INFO] [stderr]    Compiling futures-intrusive v0.5.0
[INFO] [stderr]    Compiling unicode-normalization v0.1.25
[INFO] [stderr]    Compiling crc v3.3.0
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling webpki-roots v0.25.4
[INFO] [stderr]    Compiling uuid v1.18.1
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling hashlink v0.8.4
[INFO] [stderr]    Compiling phf_generator v0.11.3
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling time-core v0.1.6
[INFO] [stderr]    Compiling unicode-properties v0.1.4
[INFO] [stderr]    Compiling linux-raw-sys v0.11.0
[INFO] [stderr]    Compiling time-macros v0.2.24
[INFO] [stderr]    Compiling bigdecimal v0.3.1
[INFO] [stderr]    Compiling stringprep v0.1.5
[INFO] [stderr]    Compiling phf_codegen v0.11.3
[INFO] [stderr]     Checking deranged v0.5.5
[INFO] [stderr]    Compiling sqlformat v0.2.6
[INFO] [stderr]    Compiling hkdf v0.12.4
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling phf v0.11.3
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling whoami v1.6.1
[INFO] [stderr]    Compiling home v0.5.12
[INFO] [stderr]     Checking hashbrown v0.16.0
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling heck v0.4.1
[INFO] [stderr]     Checking indexmap v2.12.0
[INFO] [stderr]    Compiling parse-zoneinfo v0.3.1
[INFO] [stderr]     Checking time v0.3.44
[INFO] [stderr]    Compiling chrono-tz-build v0.2.1
[INFO] [stderr]     Checking inout v0.1.4
[INFO] [stderr]     Checking phf_shared v0.11.3
[INFO] [stderr]     Checking cipher v0.4.4
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking http v0.2.12
[INFO] [stderr]    Compiling tempfile v3.23.0
[INFO] [stderr]     Checking thread_local v1.1.9
[INFO] [stderr]    Compiling rust_decimal v1.39.0
[INFO] [stderr]     Checking nu-ansi-term v0.50.3
[INFO] [stderr]    Compiling chrono-tz v0.8.6
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]     Checking blowfish v0.9.1
[INFO] [stderr]     Checking pem v3.0.6
[INFO] [stderr]     Checking socket2 v0.4.10
[INFO] [stderr]     Checking serde_path_to_error v0.1.20
[INFO] [stderr]     Checking zeroize v1.8.2
[INFO] [stderr]     Checking arrayvec v0.7.6
[INFO] [stderr]     Checking arc-swap v1.7.1
[INFO] [stderr]     Checking sha1_smol v1.0.1
[INFO] [stderr]     Checking bcrypt v0.15.1
[INFO] [stderr]     Checking tower-http v0.5.2
[INFO] [stderr]     Checking convert_case v0.5.0
[INFO] [stderr]     Checking rustls-webpki v0.101.7
[INFO] [stderr]     Checking sct v0.7.1
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[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.30
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]    Compiling axum-macros v0.4.2
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking simple_asn1 v0.6.3
[INFO] [stderr]     Checking yoke v0.8.1
[INFO] [stderr]     Checking tracing-subscriber v0.3.20
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]     Checking pin-project v1.1.10
[INFO] [stderr]     Checking tinystr v0.8.2
[INFO] [stderr]     Checking potential_utf v0.1.4
[INFO] [stderr]     Checking icu_collections v2.1.1
[INFO] [stderr]     Checking icu_locale_core v2.1.1
[INFO] [stderr]     Checking tracing-appender v0.2.3
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking icu_properties v2.1.1
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking axum-core v0.4.5
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking jsonwebtoken v9.3.1
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling url v2.5.7
[INFO] [stderr]    Compiling sqlx-core v0.7.4
[INFO] [stderr]     Checking hyper v1.7.0
[INFO] [stderr]     Checking tokio-util v0.7.16
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking tokio-rustls v0.24.1
[INFO] [stderr]     Checking tokio-retry v0.3.0
[INFO] [stderr]     Checking combine v4.6.7
[INFO] [stderr]     Checking tungstenite v0.20.1
[INFO] [stderr]     Checking hyper-util v0.1.17
[INFO] [stderr]     Checking axum v0.7.9
[INFO] [stderr]     Checking tokio-tungstenite v0.20.1
[INFO] [stderr]     Checking sqlx-postgres v0.7.4
[INFO] [stderr]     Checking redis v0.24.0
[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 milan v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `serde_json::json`
[INFO] [stdout]  --> src/module/loan/handler/dashboard.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use serde_json::json;
[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: `model::AccountMove`
[INFO] [stdout]   --> src/module/invoice/handler/invoice.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     model::AccountMove
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sqlx::types::BigDecimal`
[INFO] [stdout]  --> src/module/invoice/query.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use sqlx::types::BigDecimal;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::json`
[INFO] [stdout]  --> src/module/loan/handler/dashboard.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use serde_json::json;
[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: `model::AccountMove`
[INFO] [stdout]   --> src/module/invoice/handler/invoice.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     model::AccountMove
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sqlx::types::BigDecimal`
[INFO] [stdout]  --> src/module/invoice/query.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use sqlx::types::BigDecimal;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `current_principal` is assigned to, but never used
[INFO] [stdout]     --> src/module/loan/handler/dashboard.rs:1097:13
[INFO] [stdout]      |
[INFO] [stdout] 1097 |         let mut current_principal = contract.current_principal;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: consider using `_current_principal` instead
[INFO] [stdout]      = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `current_principal` is never read
[INFO] [stdout]     --> src/module/loan/handler/dashboard.rs:1102:21
[INFO] [stdout]      |
[INFO] [stdout] 1102 |                     current_principal -= tx.amount;
[INFO] [stdout]      |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `current_principal` is never read
[INFO] [stdout]     --> src/module/loan/handler/dashboard.rs:1105:21
[INFO] [stdout]      |
[INFO] [stdout] 1105 |                     current_principal -= tx.amount - tx.interest_applied;
[INFO] [stdout]      |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `current_principal` is assigned to, but never used
[INFO] [stdout]     --> src/module/loan/handler/dashboard.rs:1097:13
[INFO] [stdout]      |
[INFO] [stdout] 1097 |         let mut current_principal = contract.current_principal;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: consider using `_current_principal` instead
[INFO] [stdout]      = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `current_principal` is never read
[INFO] [stdout]     --> src/module/loan/handler/dashboard.rs:1102:21
[INFO] [stdout]      |
[INFO] [stdout] 1102 |                     current_principal -= tx.amount;
[INFO] [stdout]      |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `current_principal` is never read
[INFO] [stdout]     --> src/module/loan/handler/dashboard.rs:1105:21
[INFO] [stdout]      |
[INFO] [stdout] 1105 |                     current_principal -= tx.amount - tx.interest_applied;
[INFO] [stdout]      |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `telemetry` and `event_publisher` are never read
[INFO] [stdout]   --> src/core/state.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub struct AppState {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout]  8 |     pub shard: Arc<ShardManager>, // chỉ còn ShardManager
[INFO] [stdout]  9 |     pub telemetry: Arc<Telemetry>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 10 |     pub event_publisher: Arc<dyn EventPublisher + Send + Sync>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AppState` 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: function `is_sys_admin` is never used
[INFO] [stdout]  --> src/core/iam.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub fn is_sys_admin(user: &AuthUser) -> bool {
[INFO] [stdout]   |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `log_and_respond` is never used
[INFO] [stdout]  --> src/core/log.rs:5:14
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub async fn log_and_respond<E: std::error::Error>(err: E) -> impl IntoResponse {
[INFO] [stdout]   |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `L1CacheEntry` is never constructed
[INFO] [stdout]   --> src/core/cache.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 19 | struct L1CacheEntry {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/core/cache.rs:109:18
[INFO] [stdout]     |
[INFO] [stdout]  25 | impl CacheService {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub async fn del(&self, key: &str) -> RedisResult<()> {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 122 |     pub async fn exists(&self, key: &str) -> RedisResult<bool> {
[INFO] [stdout]     |                  ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub async fn get_monthly_interest(&self, tenant_id: &str, month: u32, year: i32) -> RedisResult<Option<serde_json::Value>> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 158 |     pub async fn set_monthly_interest(&self, tenant_id: &str, month: u32, year: i32, data: &serde_json::Value) -> RedisResult<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 163 |     pub async fn get_loan_activity(&self, tenant_id: &str, month: u32, year: i32) -> RedisResult<Option<serde_json::Value>> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub async fn set_loan_activity(&self, tenant_id: &str, month: u32, year: i32, data: &serde_json::Value) -> RedisResult<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 174 |     pub async fn clear_tenant_cache(&self, tenant_id: &str) -> RedisResult<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 189 |     pub async fn cleanup_l1_cache(&self) {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub async fn get_cache_stats(&self) -> RedisResult<serde_json::Value> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `start_cache_cleanup_task` is never used
[INFO] [stdout]    --> src/core/cache.rs:266:14
[INFO] [stdout]     |
[INFO] [stdout] 266 | pub async fn start_cache_cleanup_task() {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `publish` is never used
[INFO] [stdout]  --> src/infra/event_bus.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub trait EventPublisher: Send + Sync {
[INFO] [stdout]   |           -------------- method in this trait
[INFO] [stdout] 4 |     /// Gửi message tới topic tương ứng
[INFO] [stdout] 5 |     fn publish(&self, topic: &str, payload: &[u8]);
[INFO] [stdout]   |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `routes` is never used
[INFO] [stdout]  --> src/module/user/router.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn routes() -> Router<Arc<AppState>> {
[INFO] [stdout]   |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_users` is never used
[INFO] [stdout]  --> src/module/user/query.rs:6:14
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub async fn find_users(pool: &PgPool, tenant_id: Uuid) -> sqlx::Result<Vec<User>> {
[INFO] [stdout]   |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_user_by_id` is never used
[INFO] [stdout]   --> src/module/user/query.rs:28:14
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub async fn find_user_by_id(pool: &PgPool, tenant_id: Uuid, user_id: Uuid) -> sqlx::Result<User> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `clean` and `validate` are never used
[INFO] [stdout]   --> src/module/user/dto.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl RegisterDto {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub fn clean(self) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn validate(&self) -> Result<(), String> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `clean` and `validate` are never used
[INFO] [stdout]   --> src/module/user/dto.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout] 61 | impl LoginDto {
[INFO] [stdout]    | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn clean(self) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 79 |     pub fn validate(&self) -> Result<(), String> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ModuleMetadata` is never constructed
[INFO] [stdout]  --> src/module/user/metadata.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ModuleMetadata {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `metadata` is never used
[INFO] [stdout]   --> src/module/user/metadata.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn metadata() -> ModuleMetadata {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TenantModule` is never constructed
[INFO] [stdout]   --> src/module/tenant/model.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct TenantModule {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetTenantQuery` is never constructed
[INFO] [stdout]  --> src/module/tenant/query.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct GetTenantQuery {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ListTenantByEnterpriseQuery` is never constructed
[INFO] [stdout]  --> src/module/tenant/query.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ListTenantByEnterpriseQuery {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ListTenantByCompanyQuery` is never constructed
[INFO] [stdout]   --> src/module/tenant/query.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct ListTenantByCompanyQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `enterprise_form_schema` is never used
[INFO] [stdout]  --> src/module/tenant/metadata.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn enterprise_form_schema() -> serde_json::Value {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `enterprise_form_ui` is never used
[INFO] [stdout]   --> src/module/tenant/metadata.rs:17:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub fn enterprise_form_ui() -> serde_json::Value {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `company_form_schema` is never used
[INFO] [stdout]   --> src/module/tenant/metadata.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub fn company_form_schema() -> serde_json::Value {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `company_form_ui` is never used
[INFO] [stdout]   --> src/module/tenant/metadata.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub fn company_form_ui() -> serde_json::Value {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tenant_form_schema` is never used
[INFO] [stdout]   --> src/module/tenant/metadata.rs:49:8
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub fn tenant_form_schema() -> serde_json::Value {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateTenantInput` is never constructed
[INFO] [stdout]  --> src/module/tenant/dto.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct CreateTenantInput {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TenantDto` is never constructed
[INFO] [stdout]   --> src/module/tenant/dto.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct TenantDto {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `EnableModuleInput` is never constructed
[INFO] [stdout]   --> src/module/tenant/dto.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub struct EnableModuleInput {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TenantModuleDto` is never constructed
[INFO] [stdout]   --> src/module/tenant/dto.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct TenantModuleDto {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RolePermission` is never constructed
[INFO] [stdout]   --> src/module/iam/model.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct RolePermission {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UserRole` is never constructed
[INFO] [stdout]   --> src/module/iam/model.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct UserRole {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `use_report` is never read
[INFO] [stdout]   --> src/module/loan/handler/dashboard.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub struct StatsParams {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     pub use_report: Option<bool>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_collateral` is never used
[INFO] [stdout]    --> src/module/loan/command.rs:402:14
[INFO] [stdout]     |
[INFO] [stdout] 402 | pub async fn create_collateral(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ContractDetail` is never constructed
[INFO] [stdout]    --> src/module/loan/query.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct ContractDetail {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_contract_detail` is never used
[INFO] [stdout]    --> src/module/loan/query.rs:112:14
[INFO] [stdout]     |
[INFO] [stdout] 112 | pub async fn get_contract_detail(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LoanStats` is never constructed
[INFO] [stdout]    --> src/module/loan/query.rs:125:12
[INFO] [stdout]     |
[INFO] [stdout] 125 | pub struct LoanStats {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `aggregate_by_month` is never used
[INFO] [stdout]    --> src/module/loan/query.rs:131:14
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub async fn aggregate_by_month(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `aggregate_by_day` is never used
[INFO] [stdout]    --> src/module/loan/query.rs:158:14
[INFO] [stdout]     |
[INFO] [stdout] 158 | pub async fn aggregate_by_day(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `aggregate_by_year` is never used
[INFO] [stdout]    --> src/module/loan/query.rs:188:14
[INFO] [stdout]     |
[INFO] [stdout] 188 | pub async fn aggregate_by_year(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CollateralAsset` is never constructed
[INFO] [stdout]   --> src/module/loan/model.rs:83:12
[INFO] [stdout]    |
[INFO] [stdout] 83 | pub struct CollateralAsset {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `principal`, `state`, and `collateral_asset_ids` are never read
[INFO] [stdout]   --> src/module/loan/dto.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct CreateContractInput {
[INFO] [stdout]    |            ------------------- fields in this struct
[INFO] [stdout] 10 |     pub contact_id: Uuid,
[INFO] [stdout] 11 |     pub principal: i64,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub state: String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub collateral_asset_ids: Option<Vec<Uuid>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CreateContractInput` 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 `days_from_prev`, `interest_for_period`, `accumulated_interest`, and `principal_balance` are never read
[INFO] [stdout]   --> src/module/loan/dto.rs:41:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct TransactionInput {
[INFO] [stdout]    |            ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub days_from_prev: Option<i32>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 42 |     #[serde(skip_deserializing, default)]
[INFO] [stdout] 43 |     pub interest_for_period: Option<i64>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 44 |     #[serde(skip_deserializing, default)]
[INFO] [stdout] 45 |     pub accumulated_interest: Option<i64>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 46 |     #[serde(skip_deserializing, default)]
[INFO] [stdout] 47 |     pub principal_balance: Option<i64>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TransactionInput` 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: struct `ContractView` is never constructed
[INFO] [stdout]   --> src/module/loan/dto.rs:52:12
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub struct ContractView {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TransactionView` is never constructed
[INFO] [stdout]   --> src/module/loan/dto.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub struct TransactionView {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_collateral_status` is never used
[INFO] [stdout]   --> src/module/loan/dto.rs:85:4
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn default_collateral_status() -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `LoanEvent` is never used
[INFO] [stdout]  --> src/module/loan/event.rs:2:10
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub enum LoanEvent {
[INFO] [stdout]   |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DISPLAY_NAME` is never used
[INFO] [stdout]  --> src/module/loan/metadata.rs:2:11
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub const DISPLAY_NAME: &str = "Loan";
[INFO] [stdout]   |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DESCRIPTION` is never used
[INFO] [stdout]  --> src/module/loan/metadata.rs:3:11
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub const DESCRIPTION: &str = "Quản lí cho vay";
[INFO] [stdout]   |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `principal_paid_as_of` is never used
[INFO] [stdout]    --> src/module/loan/calculator.rs:146:8
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub fn principal_paid_as_of(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Contact` is never constructed
[INFO] [stdout]  --> src/module/contact/model.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Contact {
[INFO] [stdout]   |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DISPLAY_NAME` is never used
[INFO] [stdout]  --> src/module/contact/metadata.rs:2:11
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub const DISPLAY_NAME: &str = "Contact";
[INFO] [stdout]   |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DESCRIPTION` is never used
[INFO] [stdout]  --> src/module/contact/metadata.rs:3:11
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub const DESCRIPTION: &str = "Quản lí liên hệ";
[INFO] [stdout]   |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ContactEvent` is never used
[INFO] [stdout]   --> src/module/contact/mod.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub enum ContactEvent {
[INFO] [stdout]    |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `year` and `month` are never read
[INFO] [stdout]    --> src/module/invoice/handler/stats.rs:119:9
[INFO] [stdout]     |
[INFO] [stdout] 118 | pub struct MonthlyStatsQuery {
[INFO] [stdout]     |            ----------------- fields in this struct
[INFO] [stdout] 119 |     pub year: Option<i32>,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 120 |     pub month: Option<u32>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `date_from`, `date_to`, `partner_id`, and `move_type` are never read
[INFO] [stdout]    --> src/module/invoice/handler/stats.rs:125:9
[INFO] [stdout]     |
[INFO] [stdout] 124 | pub struct ReportQuery {
[INFO] [stdout]     |            ----------- fields in this struct
[INFO] [stdout] 125 |     pub date_from: Option<NaiveDate>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 126 |     pub date_to: Option<NaiveDate>,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout] 127 |     pub partner_id: Option<uuid::Uuid>,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 128 |     pub move_type: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateInvoiceCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct CreateInvoiceCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateInvoiceLineCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct CreateInvoiceLineCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UpdateInvoiceCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:39:12
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct UpdateInvoiceCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UpdateInvoiceLineCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:54:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub struct UpdateInvoiceLineCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PostInvoiceCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:67:12
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub struct PostInvoiceCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ResetToDraftCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:75:12
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub struct ResetToDraftCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CancelInvoiceCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:82:12
[INFO] [stdout]    |
[INFO] [stdout] 82 | pub struct CancelInvoiceCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ReverseInvoiceCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:89:12
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub struct ReverseInvoiceCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreatePaymentCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:96:12
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub struct CreatePaymentCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UpdatePaymentCommand` is never constructed
[INFO] [stdout]    --> src/module/invoice/command.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub struct UpdatePaymentCommand {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DeletePaymentCommand` is never constructed
[INFO] [stdout]    --> src/module/invoice/command.rs:126:12
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub struct DeletePaymentCommand {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetInvoiceQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct GetInvoiceQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ListInvoicesQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct ListInvoicesQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetInvoiceStatsQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct GetInvoiceStatsQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetInvoicePaymentsQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct GetInvoicePaymentsQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetPaymentQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct GetPaymentQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetOverdueInvoicesQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub struct GetOverdueInvoicesQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetMonthlyStatsQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct GetMonthlyStatsQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetAgingReportQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:70:12
[INFO] [stdout]    |
[INFO] [stdout] 70 | pub struct GetAgingReportQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetTaxReportQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:78:12
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub struct GetTaxReportQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountMove` is never constructed
[INFO] [stdout]  --> src/module/invoice/model.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct AccountMove {
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountMoveLine` is never constructed
[INFO] [stdout]   --> src/module/invoice/model.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub struct AccountMoveLine {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountTax` is never constructed
[INFO] [stdout]   --> src/module/invoice/model.rs:66:12
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct AccountTax {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountPayment` is never constructed
[INFO] [stdout]   --> src/module/invoice/model.rs:80:12
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub struct AccountPayment {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountPaymentTerm` is never constructed
[INFO] [stdout]    --> src/module/invoice/model.rs:100:12
[INFO] [stdout]     |
[INFO] [stdout] 100 | pub struct AccountPaymentTerm {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountJournal` is never constructed
[INFO] [stdout]    --> src/module/invoice/model.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub struct AccountJournal {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountPaymentMethod` is never constructed
[INFO] [stdout]    --> src/module/invoice/model.rs:124:12
[INFO] [stdout]     |
[INFO] [stdout] 124 | pub struct AccountPaymentMethod {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountFiscalPosition` is never constructed
[INFO] [stdout]    --> src/module/invoice/model.rs:136:12
[INFO] [stdout]     |
[INFO] [stdout] 136 | pub struct AccountFiscalPosition {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceCreatedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct InvoiceCreatedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceUpdatedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct InvoiceUpdatedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoicePostedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct InvoicePostedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceResetToDraftEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct InvoiceResetToDraftEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceCancelledEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub struct InvoiceCancelledEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceReversedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:57:12
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub struct InvoiceReversedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentCreatedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:66:12
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct PaymentCreatedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentUpdatedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:77:12
[INFO] [stdout]    |
[INFO] [stdout] 77 | pub struct PaymentUpdatedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentDeletedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub struct PaymentDeletedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceOverdueEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:95:12
[INFO] [stdout]    |
[INFO] [stdout] 95 | pub struct InvoiceOverdueEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoicePaidEvent` is never constructed
[INFO] [stdout]    --> src/module/invoice/event.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct InvoicePaidEvent {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceMetadata` is never constructed
[INFO] [stdout]  --> src/module/invoice/metadata.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct InvoiceMetadata {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MoveTypeOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct MoveTypeOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `StateOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct StateOption {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentStateOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct PaymentStateOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `JournalOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct JournalOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentTermOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub struct PaymentTermOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentMethodOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:56:12
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub struct PaymentMethodOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FiscalPositionOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:64:12
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub struct FiscalPositionOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `default` is never used
[INFO] [stdout]   --> src/module/invoice/metadata.rs:75:12
[INFO] [stdout]    |
[INFO] [stdout] 74 | impl InvoiceMetadata {
[INFO] [stdout]    | -------------------- associated function in this implementation
[INFO] [stdout] 75 |     pub fn default() -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `telemetry` and `event_publisher` are never read
[INFO] [stdout]   --> src/core/state.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub struct AppState {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout]  8 |     pub shard: Arc<ShardManager>, // chỉ còn ShardManager
[INFO] [stdout]  9 |     pub telemetry: Arc<Telemetry>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 10 |     pub event_publisher: Arc<dyn EventPublisher + Send + Sync>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AppState` 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: function `is_sys_admin` is never used
[INFO] [stdout]  --> src/core/iam.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub fn is_sys_admin(user: &AuthUser) -> bool {
[INFO] [stdout]   |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `log_and_respond` is never used
[INFO] [stdout]  --> src/core/log.rs:5:14
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub async fn log_and_respond<E: std::error::Error>(err: E) -> impl IntoResponse {
[INFO] [stdout]   |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `L1CacheEntry` is never constructed
[INFO] [stdout]   --> src/core/cache.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 19 | struct L1CacheEntry {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/core/cache.rs:109:18
[INFO] [stdout]     |
[INFO] [stdout]  25 | impl CacheService {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub async fn del(&self, key: &str) -> RedisResult<()> {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 122 |     pub async fn exists(&self, key: &str) -> RedisResult<bool> {
[INFO] [stdout]     |                  ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub async fn get_monthly_interest(&self, tenant_id: &str, month: u32, year: i32) -> RedisResult<Option<serde_json::Value>> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 158 |     pub async fn set_monthly_interest(&self, tenant_id: &str, month: u32, year: i32, data: &serde_json::Value) -> RedisResult<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 163 |     pub async fn get_loan_activity(&self, tenant_id: &str, month: u32, year: i32) -> RedisResult<Option<serde_json::Value>> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub async fn set_loan_activity(&self, tenant_id: &str, month: u32, year: i32, data: &serde_json::Value) -> RedisResult<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 174 |     pub async fn clear_tenant_cache(&self, tenant_id: &str) -> RedisResult<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 189 |     pub async fn cleanup_l1_cache(&self) {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub async fn get_cache_stats(&self) -> RedisResult<serde_json::Value> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `start_cache_cleanup_task` is never used
[INFO] [stdout]    --> src/core/cache.rs:266:14
[INFO] [stdout]     |
[INFO] [stdout] 266 | pub async fn start_cache_cleanup_task() {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `publish` is never used
[INFO] [stdout]  --> src/infra/event_bus.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub trait EventPublisher: Send + Sync {
[INFO] [stdout]   |           -------------- method in this trait
[INFO] [stdout] 4 |     /// Gửi message tới topic tương ứng
[INFO] [stdout] 5 |     fn publish(&self, topic: &str, payload: &[u8]);
[INFO] [stdout]   |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `routes` is never used
[INFO] [stdout]  --> src/module/user/router.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn routes() -> Router<Arc<AppState>> {
[INFO] [stdout]   |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_users` is never used
[INFO] [stdout]  --> src/module/user/query.rs:6:14
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub async fn find_users(pool: &PgPool, tenant_id: Uuid) -> sqlx::Result<Vec<User>> {
[INFO] [stdout]   |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_user_by_id` is never used
[INFO] [stdout]   --> src/module/user/query.rs:28:14
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub async fn find_user_by_id(pool: &PgPool, tenant_id: Uuid, user_id: Uuid) -> sqlx::Result<User> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `clean` and `validate` are never used
[INFO] [stdout]   --> src/module/user/dto.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl RegisterDto {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub fn clean(self) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn validate(&self) -> Result<(), String> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `clean` and `validate` are never used
[INFO] [stdout]   --> src/module/user/dto.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout] 61 | impl LoginDto {
[INFO] [stdout]    | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn clean(self) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 79 |     pub fn validate(&self) -> Result<(), String> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ModuleMetadata` is never constructed
[INFO] [stdout]  --> src/module/user/metadata.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ModuleMetadata {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `metadata` is never used
[INFO] [stdout]   --> src/module/user/metadata.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn metadata() -> ModuleMetadata {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TenantModule` is never constructed
[INFO] [stdout]   --> src/module/tenant/model.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct TenantModule {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetTenantQuery` is never constructed
[INFO] [stdout]  --> src/module/tenant/query.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct GetTenantQuery {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ListTenantByEnterpriseQuery` is never constructed
[INFO] [stdout]  --> src/module/tenant/query.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ListTenantByEnterpriseQuery {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ListTenantByCompanyQuery` is never constructed
[INFO] [stdout]   --> src/module/tenant/query.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct ListTenantByCompanyQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `enterprise_form_schema` is never used
[INFO] [stdout]  --> src/module/tenant/metadata.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn enterprise_form_schema() -> serde_json::Value {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `enterprise_form_ui` is never used
[INFO] [stdout]   --> src/module/tenant/metadata.rs:17:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub fn enterprise_form_ui() -> serde_json::Value {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `company_form_schema` is never used
[INFO] [stdout]   --> src/module/tenant/metadata.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub fn company_form_schema() -> serde_json::Value {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `company_form_ui` is never used
[INFO] [stdout]   --> src/module/tenant/metadata.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub fn company_form_ui() -> serde_json::Value {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tenant_form_schema` is never used
[INFO] [stdout]   --> src/module/tenant/metadata.rs:49:8
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub fn tenant_form_schema() -> serde_json::Value {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateTenantInput` is never constructed
[INFO] [stdout]  --> src/module/tenant/dto.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct CreateTenantInput {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TenantDto` is never constructed
[INFO] [stdout]   --> src/module/tenant/dto.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct TenantDto {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `EnableModuleInput` is never constructed
[INFO] [stdout]   --> src/module/tenant/dto.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub struct EnableModuleInput {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TenantModuleDto` is never constructed
[INFO] [stdout]   --> src/module/tenant/dto.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct TenantModuleDto {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RolePermission` is never constructed
[INFO] [stdout]   --> src/module/iam/model.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct RolePermission {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UserRole` is never constructed
[INFO] [stdout]   --> src/module/iam/model.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct UserRole {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `use_report` is never read
[INFO] [stdout]   --> src/module/loan/handler/dashboard.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub struct StatsParams {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     pub use_report: Option<bool>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_collateral` is never used
[INFO] [stdout]    --> src/module/loan/command.rs:402:14
[INFO] [stdout]     |
[INFO] [stdout] 402 | pub async fn create_collateral(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ContractDetail` is never constructed
[INFO] [stdout]    --> src/module/loan/query.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct ContractDetail {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_contract_detail` is never used
[INFO] [stdout]    --> src/module/loan/query.rs:112:14
[INFO] [stdout]     |
[INFO] [stdout] 112 | pub async fn get_contract_detail(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LoanStats` is never constructed
[INFO] [stdout]    --> src/module/loan/query.rs:125:12
[INFO] [stdout]     |
[INFO] [stdout] 125 | pub struct LoanStats {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `aggregate_by_month` is never used
[INFO] [stdout]    --> src/module/loan/query.rs:131:14
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub async fn aggregate_by_month(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `aggregate_by_day` is never used
[INFO] [stdout]    --> src/module/loan/query.rs:158:14
[INFO] [stdout]     |
[INFO] [stdout] 158 | pub async fn aggregate_by_day(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `aggregate_by_year` is never used
[INFO] [stdout]    --> src/module/loan/query.rs:188:14
[INFO] [stdout]     |
[INFO] [stdout] 188 | pub async fn aggregate_by_year(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CollateralAsset` is never constructed
[INFO] [stdout]   --> src/module/loan/model.rs:83:12
[INFO] [stdout]    |
[INFO] [stdout] 83 | pub struct CollateralAsset {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `principal`, `state`, and `collateral_asset_ids` are never read
[INFO] [stdout]   --> src/module/loan/dto.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct CreateContractInput {
[INFO] [stdout]    |            ------------------- fields in this struct
[INFO] [stdout] 10 |     pub contact_id: Uuid,
[INFO] [stdout] 11 |     pub principal: i64,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub state: String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub collateral_asset_ids: Option<Vec<Uuid>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CreateContractInput` 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 `days_from_prev`, `interest_for_period`, `accumulated_interest`, and `principal_balance` are never read
[INFO] [stdout]   --> src/module/loan/dto.rs:41:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct TransactionInput {
[INFO] [stdout]    |            ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub days_from_prev: Option<i32>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 42 |     #[serde(skip_deserializing, default)]
[INFO] [stdout] 43 |     pub interest_for_period: Option<i64>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 44 |     #[serde(skip_deserializing, default)]
[INFO] [stdout] 45 |     pub accumulated_interest: Option<i64>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 46 |     #[serde(skip_deserializing, default)]
[INFO] [stdout] 47 |     pub principal_balance: Option<i64>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TransactionInput` 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: struct `ContractView` is never constructed
[INFO] [stdout]   --> src/module/loan/dto.rs:52:12
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub struct ContractView {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TransactionView` is never constructed
[INFO] [stdout]   --> src/module/loan/dto.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub struct TransactionView {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_collateral_status` is never used
[INFO] [stdout]   --> src/module/loan/dto.rs:85:4
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn default_collateral_status() -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `LoanEvent` is never used
[INFO] [stdout]  --> src/module/loan/event.rs:2:10
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub enum LoanEvent {
[INFO] [stdout]   |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DISPLAY_NAME` is never used
[INFO] [stdout]  --> src/module/loan/metadata.rs:2:11
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub const DISPLAY_NAME: &str = "Loan";
[INFO] [stdout]   |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DESCRIPTION` is never used
[INFO] [stdout]  --> src/module/loan/metadata.rs:3:11
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub const DESCRIPTION: &str = "Quản lí cho vay";
[INFO] [stdout]   |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `principal_paid_as_of` is never used
[INFO] [stdout]    --> src/module/loan/calculator.rs:146:8
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub fn principal_paid_as_of(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Contact` is never constructed
[INFO] [stdout]  --> src/module/contact/model.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Contact {
[INFO] [stdout]   |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DISPLAY_NAME` is never used
[INFO] [stdout]  --> src/module/contact/metadata.rs:2:11
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub const DISPLAY_NAME: &str = "Contact";
[INFO] [stdout]   |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DESCRIPTION` is never used
[INFO] [stdout]  --> src/module/contact/metadata.rs:3:11
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub const DESCRIPTION: &str = "Quản lí liên hệ";
[INFO] [stdout]   |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ContactEvent` is never used
[INFO] [stdout]   --> src/module/contact/mod.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub enum ContactEvent {
[INFO] [stdout]    |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `year` and `month` are never read
[INFO] [stdout]    --> src/module/invoice/handler/stats.rs:119:9
[INFO] [stdout]     |
[INFO] [stdout] 118 | pub struct MonthlyStatsQuery {
[INFO] [stdout]     |            ----------------- fields in this struct
[INFO] [stdout] 119 |     pub year: Option<i32>,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 120 |     pub month: Option<u32>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `date_from`, `date_to`, `partner_id`, and `move_type` are never read
[INFO] [stdout]    --> src/module/invoice/handler/stats.rs:125:9
[INFO] [stdout]     |
[INFO] [stdout] 124 | pub struct ReportQuery {
[INFO] [stdout]     |            ----------- fields in this struct
[INFO] [stdout] 125 |     pub date_from: Option<NaiveDate>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 126 |     pub date_to: Option<NaiveDate>,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout] 127 |     pub partner_id: Option<uuid::Uuid>,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 128 |     pub move_type: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateInvoiceCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct CreateInvoiceCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateInvoiceLineCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct CreateInvoiceLineCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UpdateInvoiceCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:39:12
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct UpdateInvoiceCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UpdateInvoiceLineCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:54:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub struct UpdateInvoiceLineCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PostInvoiceCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:67:12
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub struct PostInvoiceCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ResetToDraftCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:75:12
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub struct ResetToDraftCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CancelInvoiceCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:82:12
[INFO] [stdout]    |
[INFO] [stdout] 82 | pub struct CancelInvoiceCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ReverseInvoiceCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:89:12
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub struct ReverseInvoiceCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreatePaymentCommand` is never constructed
[INFO] [stdout]   --> src/module/invoice/command.rs:96:12
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub struct CreatePaymentCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UpdatePaymentCommand` is never constructed
[INFO] [stdout]    --> src/module/invoice/command.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub struct UpdatePaymentCommand {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DeletePaymentCommand` is never constructed
[INFO] [stdout]    --> src/module/invoice/command.rs:126:12
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub struct DeletePaymentCommand {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetInvoiceQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct GetInvoiceQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ListInvoicesQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct ListInvoicesQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetInvoiceStatsQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct GetInvoiceStatsQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetInvoicePaymentsQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct GetInvoicePaymentsQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetPaymentQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct GetPaymentQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetOverdueInvoicesQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub struct GetOverdueInvoicesQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetMonthlyStatsQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct GetMonthlyStatsQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetAgingReportQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:70:12
[INFO] [stdout]    |
[INFO] [stdout] 70 | pub struct GetAgingReportQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GetTaxReportQuery` is never constructed
[INFO] [stdout]   --> src/module/invoice/query.rs:78:12
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub struct GetTaxReportQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountMove` is never constructed
[INFO] [stdout]  --> src/module/invoice/model.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct AccountMove {
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountMoveLine` is never constructed
[INFO] [stdout]   --> src/module/invoice/model.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub struct AccountMoveLine {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountTax` is never constructed
[INFO] [stdout]   --> src/module/invoice/model.rs:66:12
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct AccountTax {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountPayment` is never constructed
[INFO] [stdout]   --> src/module/invoice/model.rs:80:12
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub struct AccountPayment {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountPaymentTerm` is never constructed
[INFO] [stdout]    --> src/module/invoice/model.rs:100:12
[INFO] [stdout]     |
[INFO] [stdout] 100 | pub struct AccountPaymentTerm {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountJournal` is never constructed
[INFO] [stdout]    --> src/module/invoice/model.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub struct AccountJournal {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountPaymentMethod` is never constructed
[INFO] [stdout]    --> src/module/invoice/model.rs:124:12
[INFO] [stdout]     |
[INFO] [stdout] 124 | pub struct AccountPaymentMethod {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountFiscalPosition` is never constructed
[INFO] [stdout]    --> src/module/invoice/model.rs:136:12
[INFO] [stdout]     |
[INFO] [stdout] 136 | pub struct AccountFiscalPosition {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceCreatedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct InvoiceCreatedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceUpdatedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct InvoiceUpdatedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoicePostedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct InvoicePostedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceResetToDraftEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct InvoiceResetToDraftEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceCancelledEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub struct InvoiceCancelledEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceReversedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:57:12
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub struct InvoiceReversedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentCreatedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:66:12
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct PaymentCreatedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentUpdatedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:77:12
[INFO] [stdout]    |
[INFO] [stdout] 77 | pub struct PaymentUpdatedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentDeletedEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub struct PaymentDeletedEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceOverdueEvent` is never constructed
[INFO] [stdout]   --> src/module/invoice/event.rs:95:12
[INFO] [stdout]    |
[INFO] [stdout] 95 | pub struct InvoiceOverdueEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoicePaidEvent` is never constructed
[INFO] [stdout]    --> src/module/invoice/event.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct InvoicePaidEvent {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InvoiceMetadata` is never constructed
[INFO] [stdout]  --> src/module/invoice/metadata.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct InvoiceMetadata {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MoveTypeOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct MoveTypeOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `StateOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct StateOption {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentStateOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct PaymentStateOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `JournalOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct JournalOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentTermOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub struct PaymentTermOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PaymentMethodOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:56:12
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub struct PaymentMethodOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FiscalPositionOption` is never constructed
[INFO] [stdout]   --> src/module/invoice/metadata.rs:64:12
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub struct FiscalPositionOption {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `default` is never used
[INFO] [stdout]   --> src/module/invoice/metadata.rs:75:12
[INFO] [stdout]    |
[INFO] [stdout] 74 | impl InvoiceMetadata {
[INFO] [stdout]    | -------------------- associated function in this implementation
[INFO] [stdout] 75 |     pub fn default() -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 54s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: redis v0.24.0, 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 3`
[INFO] running `Command { std: "docker" "inspect" "4797fa6071c7aabfec4c47789496f977531f86819d0c767f0192e325670ec4b1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4797fa6071c7aabfec4c47789496f977531f86819d0c767f0192e325670ec4b1", kill_on_drop: false }`
[INFO] [stdout] 4797fa6071c7aabfec4c47789496f977531f86819d0c767f0192e325670ec4b1
