[INFO] cloning repository https://github.com/ArseniLaputska/rust_db
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/ArseniLaputska/rust_db" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArseniLaputska%2Frust_db", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArseniLaputska%2Frust_db'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] fb8e919a027b82570f2d646f9fdff9d9eddb7fa3
[INFO] checking ArseniLaputska/rust_db against try#44f3504e96c944ae54fc72b5f5008f53f7eda001 for pr-136776
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArseniLaputska%2Frust_db" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/ArseniLaputska/rust_db on toolchain 44f3504e96c944ae54fc72b5f5008f53f7eda001
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/ArseniLaputska/rust_db
[INFO] finished tweaking git repo https://github.com/ArseniLaputska/rust_db
[INFO] tweaked toml for git repo https://github.com/ArseniLaputska/rust_db written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] crate git repo https://github.com/ArseniLaputska/rust_db 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" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[ERROR] error running command: no output for 300 seconds
[INFO] checking ArseniLaputska/rust_db against try#44f3504e96c944ae54fc72b5f5008f53f7eda001 for pr-136776
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArseniLaputska%2Frust_db" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/ArseniLaputska/rust_db on toolchain 44f3504e96c944ae54fc72b5f5008f53f7eda001
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/ArseniLaputska/rust_db
[INFO] finished tweaking git repo https://github.com/ArseniLaputska/rust_db
[INFO] tweaked toml for git repo https://github.com/ArseniLaputska/rust_db written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] crate git repo https://github.com/ArseniLaputska/rust_db 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" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[ERROR] error running command: no output for 300 seconds
[INFO] checking ArseniLaputska/rust_db against try#44f3504e96c944ae54fc72b5f5008f53f7eda001 for pr-136776
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArseniLaputska%2Frust_db" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/ArseniLaputska/rust_db on toolchain 44f3504e96c944ae54fc72b5f5008f53f7eda001
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/ArseniLaputska/rust_db
[INFO] finished tweaking git repo https://github.com/ArseniLaputska/rust_db
[INFO] tweaked toml for git repo https://github.com/ArseniLaputska/rust_db written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] crate git repo https://github.com/ArseniLaputska/rust_db 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" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[ERROR] error running command: no output for 300 seconds
[INFO] checking ArseniLaputska/rust_db against try#44f3504e96c944ae54fc72b5f5008f53f7eda001 for pr-136776
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArseniLaputska%2Frust_db" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/ArseniLaputska/rust_db on toolchain 44f3504e96c944ae54fc72b5f5008f53f7eda001
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/ArseniLaputska/rust_db
[INFO] finished tweaking git repo https://github.com/ArseniLaputska/rust_db
[INFO] tweaked toml for git repo https://github.com/ArseniLaputska/rust_db written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] crate git repo https://github.com/ArseniLaputska/rust_db 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" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded zerocopy-derive v0.8.14
[INFO] [stderr]   Downloaded bincode_derive v2.0.0-rc.3
[INFO] [stderr]   Downloaded rand_chacha v0.9.0-beta.1
[INFO] [stderr]   Downloaded virtue v0.0.13
[INFO] [stderr]   Downloaded rand_core v0.9.0-beta.1
[INFO] [stderr]   Downloaded bincode v2.0.0-rc.3
[INFO] [stderr]   Downloaded rand v0.9.0-beta.3
[INFO] [stderr]   Downloaded cc v1.2.7
[INFO] [stderr]   Downloaded rusqlite v0.33.0
[INFO] [stderr]   Downloaded getrandom v0.3.0-rc.0
[INFO] [stderr]   Downloaded uuid v1.12.1
[INFO] [stderr]   Downloaded zerocopy v0.8.14
[INFO] [stderr]   Downloaded bindgen v0.71.1
[INFO] [stderr]   Downloaded libsqlite3-sys v0.31.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:3959728d45483eb673ba100a951a6b9f5012970368db2a9e08e0ac9b67c8a5ad" "/opt/rustwide/cargo-home/bin/cargo" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 34eef3dbdee4b7b14920d2284da4e3ae68dc75e3d65e0924a3ccec54d45e1602
[INFO] running `Command { std: "docker" "start" "-a" "34eef3dbdee4b7b14920d2284da4e3ae68dc75e3d65e0924a3ccec54d45e1602", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "34eef3dbdee4b7b14920d2284da4e3ae68dc75e3d65e0924a3ccec54d45e1602", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "34eef3dbdee4b7b14920d2284da4e3ae68dc75e3d65e0924a3ccec54d45e1602", kill_on_drop: false }`
[INFO] [stdout] 34eef3dbdee4b7b14920d2284da4e3ae68dc75e3d65e0924a3ccec54d45e1602
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:3959728d45483eb673ba100a951a6b9f5012970368db2a9e08e0ac9b67c8a5ad" "/opt/rustwide/cargo-home/bin/cargo" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] df0d0e855d19a13029a1fac411d711a878173b563e0e4a8c9799c24ad72fa690
[INFO] running `Command { std: "docker" "start" "-a" "df0d0e855d19a13029a1fac411d711a878173b563e0e4a8c9799c24ad72fa690", kill_on_drop: false }`
[INFO] [stderr]    Compiling unicode-ident v1.0.14
[INFO] [stderr]    Compiling libc v0.2.169
[INFO] [stderr]    Compiling glob v0.3.2
[INFO] [stderr]    Compiling regex-syntax v0.8.5
[INFO] [stderr]    Compiling either v1.13.0
[INFO] [stderr]    Compiling bindgen v0.71.1
[INFO] [stderr]    Compiling serde v1.0.217
[INFO] [stderr]    Compiling zerocopy v0.8.14
[INFO] [stderr]    Compiling rustc-hash v2.1.0
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling libloading v0.8.6
[INFO] [stderr]    Compiling bitflags v2.8.0
[INFO] [stderr]    Compiling cc v1.2.7
[INFO] [stderr]     Checking foldhash v0.1.4
[INFO] [stderr]    Compiling serde_json v1.0.137
[INFO] [stderr]    Compiling virtue v0.0.13
[INFO] [stderr]    Compiling proc-macro2 v1.0.93
[INFO] [stderr]     Checking hashbrown v0.15.2
[INFO] [stderr]     Checking fallible-iterator v0.3.0
[INFO] [stderr]     Checking fallible-streaming-iterator v0.1.9
[INFO] [stderr]    Compiling itertools v0.12.1
[INFO] [stderr]     Checking once_cell v1.20.2
[INFO] [stderr]    Compiling clang-sys v1.8.1
[INFO] [stderr]    Compiling bincode_derive v2.0.0-rc.3
[INFO] [stderr]    Compiling quote v1.0.38
[INFO] [stderr]    Compiling syn v2.0.96
[INFO] [stderr]     Checking bincode v2.0.0-rc.3
[INFO] [stderr]     Checking hashlink v0.10.0
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]     Checking getrandom v0.3.0-rc.0
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]    Compiling cexpr v0.6.0
[INFO] [stderr]     Checking rand_core v0.9.0-beta.1
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling serde_derive v1.0.217
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]     Checking zerocopy v0.7.35
[INFO] [stderr]     Checking ppv-lite86 v0.2.20
[INFO] [stderr]     Checking rand_chacha v0.9.0-beta.1
[INFO] [stderr]     Checking rand v0.9.0-beta.3
[INFO] [stderr]    Compiling libsqlite3-sys v0.31.0
[INFO] [stderr]     Checking chrono v0.4.39
[INFO] [stderr]     Checking uuid v1.12.1
[INFO] [stderr]     Checking rusqlite v0.33.0
[INFO] [stderr]     Checking rust_sqlite v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/db/message.rs:8:15
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::{self, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Arc`
[INFO] [stdout]   --> src/db/monitor.rs:25:17
[INFO] [stdout]    |
[INFO] [stdout] 25 | use std::sync::{Arc, Mutex};
[INFO] [stdout]    |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CStr`
[INFO] [stdout]   --> src/db/monitor.rs:28:25
[INFO] [stdout]    |
[INFO] [stdout] 28 | use std::ffi::{CString, CStr};
[INFO] [stdout]    |                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Result`
[INFO] [stdout]   --> src/db/monitor.rs:35:17
[INFO] [stdout]    |
[INFO] [stdout] 35 |     Connection, Result,
[INFO] [stdout]    |                 ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AuthAction`, `AuthContext`, `Authorization`, and `TransactionOperation`
[INFO] [stdout]   --> src/db/mod.rs:19:21
[INFO] [stdout]    |
[INFO] [stdout] 19 |     hooks::{Action, AuthAction, AuthContext, Authorization, TransactionOperation},
[INFO] [stdout]    |                     ^^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `uuid::Uuid`
[INFO] [stdout]   --> src/db/mod.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use uuid::Uuid;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]   --> src/db/mod.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 | use chrono::{DateTime, Utc};
[INFO] [stdout]    |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: renamed to `rng`
[INFO] [stdout]    --> src/db/message.rs:815:20
[INFO] [stdout]     |
[INFO] [stdout] 815 |         use rand::{thread_rng, Rng};
[INFO] [stdout]     |                    ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: renamed to `rng`
[INFO] [stdout]    --> src/db/message.rs:817:19
[INFO] [stdout]     |
[INFO] [stdout] 817 |         let rng = thread_rng();
[INFO] [stdout]     |                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]    --> src/db/contact_book.rs:458:72
[INFO] [stdout]     |
[INFO] [stdout] 458 |         picture_data_base64: c.picture_data.as_ref().map(|bin| base64::encode(bin)),
[INFO] [stdout]     |                                                                        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode
[INFO] [stdout]    --> src/db/contact_book.rs:202:42
[INFO] [stdout]     |
[INFO] [stdout] 202 |                 if let Ok(bin) = base64::decode(b64) {
[INFO] [stdout]     |                                          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode
[INFO] [stdout]    --> src/db/contact_book.rs:221:29
[INFO] [stdout]     |
[INFO] [stdout] 221 |                     base64::decode(b64).ok()
[INFO] [stdout]     |                             ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode
[INFO] [stdout]    --> src/db/contact_book.rs:314:38
[INFO] [stdout]     |
[INFO] [stdout] 314 |             if let Ok(bin) = base64::decode(b64) {
[INFO] [stdout]     |                                      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]    --> src/db/monitor.rs:254:38
[INFO] [stdout]     |
[INFO] [stdout] 254 |         ValueRef::Blob(b) => base64::encode(b),
[INFO] [stdout]     |                                      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/db/message.rs:8:15
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::{self, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Result`
[INFO] [stdout]     --> src/db/message.rs:1011:32
[INFO] [stdout]      |
[INFO] [stdout] 1011 |     use rusqlite::{Connection, Result};
[INFO] [stdout]      |                                ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `uuid::Timestamp`
[INFO] [stdout]     --> src/db/message.rs:1012:9
[INFO] [stdout]      |
[INFO] [stdout] 1012 |     use uuid::Timestamp;
[INFO] [stdout]      |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Arc`
[INFO] [stdout]   --> src/db/monitor.rs:25:17
[INFO] [stdout]    |
[INFO] [stdout] 25 | use std::sync::{Arc, Mutex};
[INFO] [stdout]    |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AuthAction`, `AuthContext`, `Authorization`, and `TransactionOperation`
[INFO] [stdout]   --> src/db/mod.rs:19:21
[INFO] [stdout]    |
[INFO] [stdout] 19 |     hooks::{Action, AuthAction, AuthContext, Authorization, TransactionOperation},
[INFO] [stdout]    |                     ^^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]   --> src/db/mod.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 | use chrono::{DateTime, Utc};
[INFO] [stdout]    |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: renamed to `rng`
[INFO] [stdout]    --> src/db/message.rs:815:20
[INFO] [stdout]     |
[INFO] [stdout] 815 |         use rand::{thread_rng, Rng};
[INFO] [stdout]     |                    ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: renamed to `rng`
[INFO] [stdout]    --> src/db/message.rs:817:19
[INFO] [stdout]     |
[INFO] [stdout] 817 |         let rng = thread_rng();
[INFO] [stdout]     |                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]    --> src/db/contact_book.rs:458:72
[INFO] [stdout]     |
[INFO] [stdout] 458 |         picture_data_base64: c.picture_data.as_ref().map(|bin| base64::encode(bin)),
[INFO] [stdout]     |                                                                        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode
[INFO] [stdout]    --> src/db/contact_book.rs:202:42
[INFO] [stdout]     |
[INFO] [stdout] 202 |                 if let Ok(bin) = base64::decode(b64) {
[INFO] [stdout]     |                                          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode
[INFO] [stdout]    --> src/db/contact_book.rs:221:29
[INFO] [stdout]     |
[INFO] [stdout] 221 |                     base64::decode(b64).ok()
[INFO] [stdout]     |                             ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode
[INFO] [stdout]    --> src/db/contact_book.rs:314:38
[INFO] [stdout]     |
[INFO] [stdout] 314 |             if let Ok(bin) = base64::decode(b64) {
[INFO] [stdout]     |                                      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]    --> src/db/monitor.rs:254:38
[INFO] [stdout]     |
[INFO] [stdout] 254 |         ValueRef::Blob(b) => base64::encode(b),
[INFO] [stdout]     |                                      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Write`
[INFO] [stdout]  --> src/db/message.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::{self, Write};
[INFO] [stdout]   |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Write`
[INFO] [stdout]  --> src/db/message.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::{self, Write};
[INFO] [stdout]   |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `send`
[INFO] [stdout]    --> src/db/message.rs:351:56
[INFO] [stdout]     |
[INFO] [stdout] 351 |     pub fn add_message_struct(&self, json_input: &str, send: bool) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |                                                        ^^^^ help: if this is intentional, prefix it with an underscore: `_send`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `force`
[INFO] [stdout]    --> src/db/message.rs:609:47
[INFO] [stdout]     |
[INFO] [stdout] 609 |     pub fn retry_message(&self, id_str: &str, force: bool) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |                                               ^^^^^ help: if this is intentional, prefix it with an underscore: `_force`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `send`
[INFO] [stdout]    --> src/db/message.rs:351:56
[INFO] [stdout]     |
[INFO] [stdout] 351 |     pub fn add_message_struct(&self, json_input: &str, send: bool) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |                                                        ^^^^ help: if this is intentional, prefix it with an underscore: `_send`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `force`
[INFO] [stdout]    --> src/db/message.rs:609:47
[INFO] [stdout]     |
[INFO] [stdout] 609 |     pub fn retry_message(&self, id_str: &str, force: bool) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |                                               ^^^^^ help: if this is intentional, prefix it with an underscore: `_force`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `col_count`
[INFO] [stdout]    --> src/db/monitor.rs:169:22
[INFO] [stdout]     |
[INFO] [stdout] 169 |                 let (col_count, new_list) = collect_new_values(new_acc);
[INFO] [stdout]     |                      ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_col_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `col_count`
[INFO] [stdout]    --> src/db/monitor.rs:174:22
[INFO] [stdout]     |
[INFO] [stdout] 174 |                 let (col_count, old_list) = collect_old_values(old_acc);
[INFO] [stdout]     |                      ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_col_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `init_db` is never used
[INFO] [stdout]   --> src/db/mod.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub fn init_db(conn: &Connection) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `register_hooks` is never used
[INFO] [stdout]   --> src/db/mod.rs:42:8
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub fn register_hooks(conn: &Connection) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_contact_table` is never used
[INFO] [stdout]   --> src/db/contact.rs:50:8
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub fn create_contact_table(conn: &Connection) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ContactRepo` is never constructed
[INFO] [stdout]   --> src/db/contact.rs:73:12
[INFO] [stdout]    |
[INFO] [stdout] 73 | pub struct ContactRepo<'a> {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `NoContact`, `InvalidUuid`, and `Other` are never constructed
[INFO] [stdout]   --> src/db/contact.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub enum ContactError {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] 79 |     NoContact(Uuid),
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 80 |     InvalidUuid,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 81 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ContactError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_i64` is never used
[INFO] [stdout]    --> src/db/contact.rs:109:12
[INFO] [stdout]     |
[INFO] [stdout] 108 | impl ContactRelationship {
[INFO] [stdout]     | ------------------------ method in this implementation
[INFO] [stdout] 109 |     pub fn to_i64(&self) -> i64 {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/db/contact.rs:133:12
[INFO] [stdout]     |
[INFO] [stdout] 132 | impl<'a> ContactRepo<'a> {
[INFO] [stdout]     | ------------------------ associated items in this implementation
[INFO] [stdout] 133 |     pub fn new(conn: &'a Connection) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub fn add_contact_pb_json(&self, json_input: &str) -> Result<(), ContactError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 146 |     pub fn add_contact_struct_json(&self, json_input: &str) -> Result<(), ContactError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 154 |     pub fn add_contact_pb(&self, input: ContactInput) -> Result<(), ContactError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     fn insert_contact(&self, input: ContactInput) -> Result<(), ContactError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 199 |     fn update_contact(&self, input: ContactInput) -> Result<(), ContactError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub fn delete_contact(&self, id: Uuid) -> Result<(), ContactError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 243 |     pub fn update_contact_relationship(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 274 |     pub fn add_contact_struct(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 299 |     pub fn get_image_data(&self, id: Uuid) -> Result<Option<Vec<u8>>, ContactError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 315 |     pub fn get_contact(&self, id: Uuid) -> Result<Option<String>, ContactError> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `SqlError`, `JsonError`, `InvalidUuid`, and `Other` are never constructed
[INFO] [stdout]   --> src/db/message.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum MessageRepoError {
[INFO] [stdout]    |          ---------------- variants in this enum
[INFO] [stdout] 13 |     SqlError(String),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 14 |     JsonError(String),
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 15 |     InvalidUuid(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 16 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MessageRepoError` 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 `Logger` is never constructed
[INFO] [stdout]   --> src/db/message.rs:31:8
[INFO] [stdout]    |
[INFO] [stdout] 31 | struct Logger {}
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `debug`, `error`, `warning`, `info`, and `trace` are never used
[INFO] [stdout]   --> src/db/message.rs:33:8
[INFO] [stdout]    |
[INFO] [stdout] 32 | impl Logger {
[INFO] [stdout]    | ----------- associated functions in this implementation
[INFO] [stdout] 33 |     fn debug(msg: &str) {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     fn error(msg: &str) {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39 |     fn warning(msg: &str) {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     fn info(msg: &str) {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     fn trace(msg: &str) {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/db/message.rs:92:12
[INFO] [stdout]     |
[INFO] [stdout] 90  | impl MessageProtobuf {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] 91  |     // Возвращает true, если `from` задано.
[INFO] [stdout] 92  |     pub fn has_from(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 97  |     pub fn clear_from(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn has_to(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub fn clear_to(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub fn has_contact_id(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn clear_contact_id(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 122 |     pub fn has_audio_data(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 127 |     pub fn clear_audio_data(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn has_text(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub fn clear_text(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn has_client_text(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub fn clear_client_text(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 152 |     pub fn has_server_text(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub fn clear_server_text(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 162 |     pub fn has_gpt_text(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn clear_gpt_text(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 172 |     pub fn has_language(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn clear_language(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 182 |     pub fn has_audio_url(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 187 |     pub fn clear_audio_url(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 192 |     pub fn has_duration(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn clear_duration(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 202 |     pub fn has_created_at(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |     pub fn clear_created_at(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub fn has_updated_at(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 217 |     pub fn clear_updated_at(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_message_table` is never used
[INFO] [stdout]    --> src/db/message.rs:294:8
[INFO] [stdout]     |
[INFO] [stdout] 294 | pub fn create_message_table(conn: &Connection) -> Result<()> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MessageRepo` is never constructed
[INFO] [stdout]    --> src/db/message.rs:323:12
[INFO] [stdout]     |
[INFO] [stdout] 323 | pub struct MessageRepo<'a> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/db/message.rs:328:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | impl<'a> MessageRepo<'a> {
[INFO] [stdout]     | ------------------------ associated items in this implementation
[INFO] [stdout] 328 |     pub fn new(conn: &'a Connection) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 332 |     pub fn delete_message(&self, id: Uuid) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 351 |     pub fn add_message_struct(&self, json_input: &str, send: bool) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 409 |     pub fn add_incomming_message(&self, json_input: &str) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 440 |     pub fn add_message_payload(&self, payload: &HashMap<String, String>) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 487 |     pub fn add_message_pb(&self, json_input: &str) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 537 |     pub fn update_message_client_text(&self, id_str: &str, client_text: &str) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 564 |     pub fn update_message_status(&self, id_str: &str, status: i64) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 587 |     pub fn update_message_status_with_date(&self, id_str: &str, status: i64, updated_at: i64) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 609 |     pub fn retry_message(&self, id_str: &str, force: bool) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 642 |     pub fn update_message_error(&self, id_str: &str, err: &str) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 664 |     pub fn update_message_with_description(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 721 |     pub fn update_messages_status(&self, contact_id_str: &str, id_str: &str, last_seen_at: f64) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 762 |     pub fn get_unread_messages(&self, id_str: &str) -> Result<i64, MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 786 |     pub fn add_messages_for_contact(&self, contact_id_str: &str, count: i64) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 814 |     pub fn random_string(&self, length: usize) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 824 |     fn insert_message_inner(&self, tx: &Transaction, msg: &Message) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 865 |     fn update_message_inner(&self, tx: &Transaction, msg: &Message) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 928 |     fn get_message_inner(&self, tx: &Transaction, id: Uuid) -> Result<Option<Message>, MessageRepoError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 999 |     fn to_uuid(bytes: Vec<u8>) -> Uuid {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/db/contact_book.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct ContactBookData {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 12 |     pub id: Uuid,
[INFO] [stdout]    |         ^^
[INFO] [stdout] 13 |     pub first_name: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 14 |     pub last_name: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 15 |     pub nick_name: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 16 |     pub phone_number: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 17 |     pub email: Option<String>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 18 |     pub picture_url: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 19 |     pub picture_data: Option<Vec<u8>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 20 |     pub created_at: f64, // Swift uses Double
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 21 |     pub updated_at: f64,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ContactBookData` 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: function `create_contact_book_table` is never used
[INFO] [stdout]   --> src/db/contact_book.rs:53:8
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub fn create_contact_book_table(conn: &Connection) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Sql`, `Json`, `InvalidUuid`, and `Other` are never constructed
[INFO] [stdout]    --> src/db/contact_book.rs:128:5
[INFO] [stdout]     |
[INFO] [stdout] 127 | pub enum ContactBookError {
[INFO] [stdout]     |          ---------------- variants in this enum
[INFO] [stdout] 128 |     Sql(String),
[INFO] [stdout]     |     ^^^
[INFO] [stdout] 129 |     Json(String),
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 130 |     InvalidUuid(String),
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 131 |     Other(String),
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ContactBookError` 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 `ContactBookRepo` is never constructed
[INFO] [stdout]    --> src/db/contact_book.rs:150:12
[INFO] [stdout]     |
[INFO] [stdout] 150 | pub struct ContactBookRepo<'a> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/db/contact_book.rs:155:12
[INFO] [stdout]     |
[INFO] [stdout] 154 | impl<'a> ContactBookRepo<'a> {
[INFO] [stdout]     | ---------------------------- associated items in this implementation
[INFO] [stdout] 155 |     pub fn new(conn: &'a Connection) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 171 |     pub fn add_contact_book_json(&self, json_input: &str) -> Result<String, ContactBookError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 247 |     pub fn delete_contact_book_json(&self, id_str: &str) -> Result<String, ContactBookError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 270 |     pub fn get_contact_book_json(&self, id_str: &str) -> Result<String, ContactBookError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 288 |     pub fn update_contact_book_json(&self, id_str: &str, json_input: &str) -> Result<String, ContactBookError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 339 |     fn insert_inner_tx(&self, tx: &Transaction, cbd: &ContactBookData) -> Result<(), ContactBookError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 367 |     fn update_inner_tx(&self, tx: &Transaction, cbd: &ContactBookData) -> Result<(), ContactBookError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 398 |     fn select_inner_tx(&self, tx: &Transaction, id: Uuid) -> Result<Option<ContactBookData>, ContactBookError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 439 |     fn select_inner(&self, id: Uuid) -> Result<Option<ContactBookData>, ContactBookError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `contact_book_data_to_json_out` is never used
[INFO] [stdout]    --> src/db/contact_book.rs:449:4
[INFO] [stdout]     |
[INFO] [stdout] 449 | fn contact_book_data_to_json_out(c: &ContactBookData) -> ContactBookDataJsonOut {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ContactStatusData` is never constructed
[INFO] [stdout]  --> src/db/contact_status.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct ContactStatusData {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `ContactStatusData` 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: function `create_contact_status_table` is never used
[INFO] [stdout]   --> src/db/contact_status.rs:14:8
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn create_contact_status_table(conn: &Connection) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Sql`, `Json`, `InvalidUuid`, and `Other` are never constructed
[INFO] [stdout]   --> src/db/contact_status.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub enum ContactStatusError {
[INFO] [stdout]    |          ------------------ variants in this enum
[INFO] [stdout] 30 |     Sql(String),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 31 |     Json(String),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 32 |     InvalidUuid(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 33 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ContactStatusError` 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 `ContactStatusRepo` is never constructed
[INFO] [stdout]   --> src/db/contact_status.rs:60:12
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct ContactStatusRepo<'a> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/db/contact_status.rs:65:12
[INFO] [stdout]     |
[INFO] [stdout] 64  | impl<'a> ContactStatusRepo<'a> {
[INFO] [stdout]     | ------------------------------ associated items in this implementation
[INFO] [stdout] 65  |     pub fn new(conn: &'a Connection) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 73  |     pub fn add_status_json(&self, json_input: &str) -> Result<String, ContactStatusError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 118 |     pub fn all_contacts_status_json(&self) -> Result<String, ContactStatusError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 151 |     fn select_inner_tx(&self, tx: &Transaction, id: Uuid) -> Result<Option<ContactStatusData>, ContactStatusError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 165 |     fn select_inner(&self, id: Uuid) -> Result<Option<ContactStatusData>, ContactStatusError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     fn insert_inner_tx(&self, tx: &Transaction, data: &ContactStatusData) -> Result<(), ContactStatusError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 181 |     fn update_inner_tx(&self, tx: &Transaction, data: &ContactStatusData) -> Result<(), ContactStatusError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ContactSeenAtData` is never constructed
[INFO] [stdout]  --> src/db/contact_seen_at.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct ContactSeenAtData {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `ContactSeenAtData` 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: function `create_contact_seen_at_table` is never used
[INFO] [stdout]   --> src/db/contact_seen_at.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub fn create_contact_seen_at_table(conn: &Connection) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ContactSeenAtRepo` is never constructed
[INFO] [stdout]   --> src/db/contact_seen_at.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct ContactSeenAtRepo<'a> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Sql`, `Json`, `InvalidUuid`, and `Other` are never constructed
[INFO] [stdout]   --> src/db/contact_seen_at.rs:50:5
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub enum ContactSeenAtError {
[INFO] [stdout]    |          ------------------ variants in this enum
[INFO] [stdout] 50 |     Sql(String),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 51 |     Json(String),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 52 |     InvalidUuid(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 53 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ContactSeenAtError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/db/contact_seen_at.rs:68:12
[INFO] [stdout]     |
[INFO] [stdout] 67  | impl<'a> ContactSeenAtRepo<'a> {
[INFO] [stdout]     | ------------------------------ associated items in this implementation
[INFO] [stdout] 68  |     pub fn new(conn: &'a Connection) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 74  |     pub fn add_seen_json(&self, json_input: &str) -> Result<String, ContactSeenAtError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 143 |     pub fn all_seen_json(&self) -> Result<String, ContactSeenAtError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 178 |     fn select_inner_tx(&self, tx: &Transaction, id: Uuid) -> Result<Option<ContactSeenAtData>, ContactSeenAtError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 192 |     fn select_inner(&self, id: Uuid) -> Result<Option<ContactSeenAtData>, ContactSeenAtError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 200 |     fn insert_inner_tx(&self, tx: &Transaction, data: &ContactSeenAtData) -> Result<(), ContactSeenAtError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 208 |     fn update_inner_tx(&self, tx: &Transaction, data: &ContactSeenAtData) -> Result<(), ContactSeenAtError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `merge_date_json` is never used
[INFO] [stdout]    --> src/db/contact_seen_at.rs:218:4
[INFO] [stdout]     |
[INFO] [stdout] 218 | fn merge_date_json(old: &Option<String>, new_s: &str) -> Result<String, ContactSeenAtError> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `EVENT_CHANNEL` is never used
[INFO] [stdout]   --> src/db/monitor.rs:82:8
[INFO] [stdout]    |
[INFO] [stdout] 82 | static EVENT_CHANNEL: Lazy<(Sender<PreUpdateEvent>, Mutex<Receiver<PreUpdateEvent>>)> = Lazy::new(|| {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `start_event_dispatcher` is never used
[INFO] [stdout]    --> src/db/monitor.rs:107:8
[INFO] [stdout]     |
[INFO] [stdout] 107 | pub fn start_event_dispatcher() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `register_preupdate_hook` is never used
[INFO] [stdout]    --> src/db/monitor.rs:150:8
[INFO] [stdout]     |
[INFO] [stdout] 150 | pub fn register_preupdate_hook(conn: &Connection) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `collect_old_values` is never used
[INFO] [stdout]    --> src/db/monitor.rs:210:4
[INFO] [stdout]     |
[INFO] [stdout] 210 | fn collect_old_values(acc: &PreUpdateOldValueAccessor) -> (i32, Vec<(String, String)>) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `collect_new_values` is never used
[INFO] [stdout]    --> src/db/monitor.rs:232:4
[INFO] [stdout]     |
[INFO] [stdout] 232 | fn collect_new_values(acc: &PreUpdateNewValueAccessor) -> (i32, Vec<(String, String)>) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `value_to_string` is never used
[INFO] [stdout]    --> src/db/monitor.rs:248:4
[INFO] [stdout]     |
[INFO] [stdout] 248 | fn value_to_string(v: &ValueRef) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `userId` should have a snake case name
[INFO] [stdout]    --> src/db/message.rs:722:13
[INFO] [stdout]     |
[INFO] [stdout] 722 |         let userId = Uuid::from_str(id_str).unwrap();
[INFO] [stdout]     |             ^^^^^^ help: convert the identifier to snake case: `user_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `contact_id`
[INFO] [stdout]     --> src/db/message.rs:1117:13
[INFO] [stdout]      |
[INFO] [stdout] 1117 |         let contact_id = Uuid::now_v7();
[INFO] [stdout]      |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_contact_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `col_count`
[INFO] [stdout]    --> src/db/monitor.rs:169:22
[INFO] [stdout]     |
[INFO] [stdout] 169 |                 let (col_count, new_list) = collect_new_values(new_acc);
[INFO] [stdout]     |                      ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_col_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `col_count`
[INFO] [stdout]    --> src/db/monitor.rs:174:22
[INFO] [stdout]     |
[INFO] [stdout] 174 |                 let (col_count, old_list) = collect_old_values(old_acc);
[INFO] [stdout]     |                      ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_col_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/db/monitor.rs:300:13
[INFO] [stdout]     |
[INFO] [stdout] 300 |         let data = vec![1, 2, 3];
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `NoContact` and `InvalidUuid` are never constructed
[INFO] [stdout]   --> src/db/contact.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub enum ContactError {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] 79 |     NoContact(Uuid),
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 80 |     InvalidUuid,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ContactError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `add_contact_struct_json` and `add_contact_struct` are never used
[INFO] [stdout]    --> src/db/contact.rs:146:12
[INFO] [stdout]     |
[INFO] [stdout] 132 | impl<'a> ContactRepo<'a> {
[INFO] [stdout]     | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 146 |     pub fn add_contact_struct_json(&self, json_input: &str) -> Result<(), ContactError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 274 |     pub fn add_contact_struct(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `InvalidUuid` and `Other` are never constructed
[INFO] [stdout]   --> src/db/message.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum MessageRepoError {
[INFO] [stdout]    |          ---------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 15 |     InvalidUuid(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 16 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MessageRepoError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `error`, `warning`, and `info` are never used
[INFO] [stdout]   --> src/db/message.rs:36:8
[INFO] [stdout]    |
[INFO] [stdout] 32 | impl Logger {
[INFO] [stdout]    | ----------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 36 |     fn error(msg: &str) {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39 |     fn warning(msg: &str) {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     fn info(msg: &str) {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/db/message.rs:92:12
[INFO] [stdout]     |
[INFO] [stdout] 90  | impl MessageProtobuf {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] 91  |     // Возвращает true, если `from` задано.
[INFO] [stdout] 92  |     pub fn has_from(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 97  |     pub fn clear_from(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn has_to(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub fn clear_to(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub fn has_contact_id(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn clear_contact_id(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 122 |     pub fn has_audio_data(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 127 |     pub fn clear_audio_data(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn has_text(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub fn clear_text(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn has_client_text(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub fn clear_client_text(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 152 |     pub fn has_server_text(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub fn clear_server_text(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 162 |     pub fn has_gpt_text(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn clear_gpt_text(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 172 |     pub fn has_language(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn clear_language(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 182 |     pub fn has_audio_url(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 187 |     pub fn clear_audio_url(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 192 |     pub fn has_duration(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn clear_duration(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 202 |     pub fn has_created_at(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |     pub fn clear_created_at(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub fn has_updated_at(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 217 |     pub fn clear_updated_at(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/db/message.rs:440:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | impl<'a> MessageRepo<'a> {
[INFO] [stdout]     | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 440 |     pub fn add_message_payload(&self, payload: &HashMap<String, String>) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 487 |     pub fn add_message_pb(&self, json_input: &str) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 537 |     pub fn update_message_client_text(&self, id_str: &str, client_text: &str) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 587 |     pub fn update_message_status_with_date(&self, id_str: &str, status: i64, updated_at: i64) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 609 |     pub fn retry_message(&self, id_str: &str, force: bool) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 642 |     pub fn update_message_error(&self, id_str: &str, err: &str) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 664 |     pub fn update_message_with_description(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 721 |     pub fn update_messages_status(&self, contact_id_str: &str, id_str: &str, last_seen_at: f64) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 786 |     pub fn add_messages_for_contact(&self, contact_id_str: &str, count: i64) -> Result<(), MessageRepoError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 814 |     pub fn random_string(&self, length: usize) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Other` is never constructed
[INFO] [stdout]    --> src/db/contact_book.rs:131:5
[INFO] [stdout]     |
[INFO] [stdout] 127 | pub enum ContactBookError {
[INFO] [stdout]     |          ---------------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 131 |     Other(String),
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ContactBookError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Other` is never constructed
[INFO] [stdout]   --> src/db/contact_status.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub enum ContactStatusError {
[INFO] [stdout]    |          ------------------ variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 33 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ContactStatusError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Other` is never constructed
[INFO] [stdout]   --> src/db/contact_seen_at.rs:53:5
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub enum ContactSeenAtError {
[INFO] [stdout]    |          ------------------ variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 53 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ContactSeenAtError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `userId` should have a snake case name
[INFO] [stdout]    --> src/db/message.rs:722:13
[INFO] [stdout]     |
[INFO] [stdout] 722 |         let userId = Uuid::from_str(id_str).unwrap();
[INFO] [stdout]     |             ^^^^^^ help: convert the identifier to snake case: `user_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 41.46s
[INFO] running `Command { std: "docker" "inspect" "df0d0e855d19a13029a1fac411d711a878173b563e0e4a8c9799c24ad72fa690", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "df0d0e855d19a13029a1fac411d711a878173b563e0e4a8c9799c24ad72fa690", kill_on_drop: false }`
[INFO] [stdout] df0d0e855d19a13029a1fac411d711a878173b563e0e4a8c9799c24ad72fa690
