[INFO] cloning repository https://github.com/stslex/AtTenR [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/stslex/AtTenR" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fstslex%2FAtTenR", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fstslex%2FAtTenR'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 20caaacf0fd07018acf13fb5522fe130f9d54bbc [INFO] checking stslex/AtTenR against master#642c19bfc3a5c1de985bf5d0cc8207ac9d22708a for pr-148577 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fstslex%2FAtTenR" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/stslex/AtTenR [INFO] finished tweaking git repo https://github.com/stslex/AtTenR [INFO] tweaked toml for git repo https://github.com/stslex/AtTenR written to /workspace/builds/worker-0-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/stslex/AtTenR on toolchain 642c19bfc3a5c1de985bf5d0cc8207ac9d22708a [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+642c19bfc3a5c1de985bf5d0cc8207ac9d22708a" "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" "+642c19bfc3a5c1de985bf5d0cc8207ac9d22708a" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 310 packages to latest compatible versions [INFO] [stderr] Adding generic-array v0.14.7 (available: v0.14.9) [INFO] [stderr] Adding jsonwebtoken v9.3.1 (available: v10.2.0) [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+642c19bfc3a5c1de985bf5d0cc8207ac9d22708a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded env_filter v0.1.4 [INFO] [stderr] Downloaded migrations_internals v2.3.0 [INFO] [stderr] Downloaded tokio-openssl v0.6.5 [INFO] [stderr] Downloaded diesel_migrations v2.3.0 [INFO] [stderr] Downloaded migrations_macros v2.3.0 [INFO] [stderr] Downloaded jiff-static v0.2.16 [INFO] [stderr] Downloaded webpki-roots v1.0.4 [INFO] [stderr] Downloaded jiff v0.2.16 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+642c19bfc3a5c1de985bf5d0cc8207ac9d22708a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] cb13d34874970e5d07ec76923c9db53bb49d043039164f3f96f38c80c497f684 [INFO] running `Command { std: "docker" "start" "-a" "cb13d34874970e5d07ec76923c9db53bb49d043039164f3f96f38c80c497f684", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "cb13d34874970e5d07ec76923c9db53bb49d043039164f3f96f38c80c497f684", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cb13d34874970e5d07ec76923c9db53bb49d043039164f3f96f38c80c497f684", kill_on_drop: false }` [INFO] [stdout] cb13d34874970e5d07ec76923c9db53bb49d043039164f3f96f38c80c497f684 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+642c19bfc3a5c1de985bf5d0cc8207ac9d22708a" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] e19a4119c5a95377cc56188528b6aa9e557dd92c88c8c15d12788ada6c589e7b [INFO] running `Command { std: "docker" "start" "-a" "e19a4119c5a95377cc56188528b6aa9e557dd92c88c8c15d12788ada6c589e7b", kill_on_drop: false }` [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling cc v1.2.45 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling tracing-attributes v0.1.30 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Checking generic-array v0.14.7 [INFO] [stderr] Checking getrandom v0.2.16 [INFO] [stderr] Compiling darling_core v0.21.3 [INFO] [stderr] Checking rustls-pki-types v1.13.0 [INFO] [stderr] Checking aho-corasick v1.1.4 [INFO] [stderr] Compiling serde_json v1.0.145 [INFO] [stderr] Compiling tokio-openssl v0.6.5 [INFO] [stderr] Compiling winnow v0.7.13 [INFO] [stderr] Compiling rustls v0.23.35 [INFO] [stderr] Checking time v0.3.44 [INFO] [stderr] Compiling serde_spanned v1.0.3 [INFO] [stderr] Checking crypto-common v0.1.7 [INFO] [stderr] Checking block-buffer v0.10.4 [INFO] [stderr] Compiling toml_datetime v0.7.3 [INFO] [stderr] Compiling pq-sys v0.7.5 [INFO] [stderr] Compiling diesel_derives v2.3.4 [INFO] [stderr] Checking digest v0.10.7 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Checking tokio v1.48.0 [INFO] [stderr] Compiling thiserror v2.0.17 [INFO] [stderr] Compiling log v0.4.28 [INFO] [stderr] Compiling tracing v0.1.41 [INFO] [stderr] Checking num-integer v0.1.46 [INFO] [stderr] Compiling bytestring v1.5.0 [INFO] [stderr] Compiling derive_more-impl v2.0.1 [INFO] [stderr] Checking scheduled-thread-pool v0.2.7 [INFO] [stderr] Compiling diesel_table_macro_syntax v0.3.0 [INFO] [stderr] Compiling thiserror-impl v2.0.17 [INFO] [stderr] Checking regex-automata v0.4.13 [INFO] [stderr] Compiling regex-lite v0.1.8 [INFO] [stderr] Checking chrono v0.4.42 [INFO] [stderr] Checking r2d2 v0.8.10 [INFO] [stderr] Checking num-bigint v0.4.6 [INFO] [stderr] Checking sha1 v0.10.6 [INFO] [stderr] Checking webpki-roots v1.0.4 [INFO] [stderr] Compiling async-stream-impl v0.3.6 [INFO] [stderr] Checking socket2 v0.5.10 [INFO] [stderr] Checking downcast-rs v2.0.2 [INFO] [stderr] Compiling toml_parser v1.0.4 [INFO] [stderr] Checking iri-string v0.7.9 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling zstd-sys v2.0.16+zstd.1.5.7 [INFO] [stderr] Checking zerofrom v0.1.6 [INFO] [stderr] Checking yoke v0.8.1 [INFO] [stderr] Checking zerovec v0.11.5 [INFO] [stderr] Checking zerotrie v0.2.3 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling toml v0.9.8 [INFO] [stderr] Checking anstream v0.6.21 [INFO] [stderr] Checking async-stream v0.3.6 [INFO] [stderr] Checking cookie v0.16.2 [INFO] [stderr] Checking hmac v0.12.1 [INFO] [stderr] Checking sha2 v0.10.9 [INFO] [stderr] Checking simple_asn1 v0.6.3 [INFO] [stderr] Checking pem v3.0.6 [INFO] [stderr] Compiling actix-macros v0.2.4 [INFO] [stderr] Checking jiff v0.2.16 [INFO] [stderr] Checking tinystr v0.8.2 [INFO] [stderr] Checking potential_utf v0.1.4 [INFO] [stderr] Checking regex v1.12.2 [INFO] [stderr] Checking icu_collections v2.1.1 [INFO] [stderr] Checking icu_locale_core v2.1.1 [INFO] [stderr] Compiling darling_macro v0.21.3 [INFO] [stderr] Checking derive_more v2.0.1 [INFO] [stderr] Checking env_filter v0.1.4 [INFO] [stderr] Compiling darling v0.21.3 [INFO] [stderr] Compiling dsl_auto_type v0.2.0 [INFO] [stderr] Checking icu_provider v2.1.1 [INFO] [stderr] Checking icu_normalizer v2.1.1 [INFO] [stderr] Checking icu_properties v2.1.1 [INFO] [stderr] Compiling actix-router v0.5.3 [INFO] [stderr] Compiling migrations_internals v2.3.0 [INFO] [stderr] Checking uuid v1.18.1 [INFO] [stderr] Checking serde_urlencoded v0.7.1 [INFO] [stderr] Compiling migrations_macros v2.3.0 [INFO] [stderr] Checking jwt v0.16.0 [INFO] [stderr] Compiling actix-web-codegen v4.3.0 [INFO] [stderr] Checking tokio-util v0.7.17 [INFO] [stderr] Checking actix-rt v2.11.0 [INFO] [stderr] Checking tower v0.5.2 [INFO] [stderr] Checking tokio-stream v0.1.17 [INFO] [stderr] Checking idna_adapter v1.2.1 [INFO] [stderr] Checking idna v1.1.0 [INFO] [stderr] Checking actix-server v2.6.0 [INFO] [stderr] Checking h2 v0.4.12 [INFO] [stderr] Checking actix-codec v0.5.2 [INFO] [stderr] Checking h2 v0.3.27 [INFO] [stderr] Checking url v2.5.7 [INFO] [stderr] Checking tower-http v0.6.6 [INFO] [stderr] Checking tokio-test v0.4.4 [INFO] [stderr] Checking rustls-webpki v0.103.8 [INFO] [stderr] Checking jsonwebtoken v9.3.1 [INFO] [stderr] Checking env_logger v0.11.8 [INFO] [stderr] Checking actix-tls v3.5.0 [INFO] [stderr] Checking tokio-native-tls v0.3.1 [INFO] [stderr] Compiling zstd-safe v7.2.4 [INFO] [stderr] Checking zstd v0.13.3 [INFO] [stderr] Checking hyper v1.8.0 [INFO] [stderr] Checking diesel v2.3.3 [INFO] [stderr] Checking hyper-util v0.1.17 [INFO] [stderr] Checking tokio-rustls v0.26.4 [INFO] [stderr] Checking actix-http v3.11.2 [INFO] [stderr] Checking hyper-tls v0.6.0 [INFO] [stderr] Checking hyper-rustls v0.27.7 [INFO] [stderr] Checking reqwest v0.12.24 [INFO] [stderr] Checking actix-web v4.11.0 [INFO] [stderr] Checking diesel_migrations v2.3.0 [INFO] [stderr] Checking atten_r v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `std::io::Error` [INFO] [stdout] --> src/database/user/mod.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::io::Error; [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: `std::io::Error` [INFO] [stdout] --> src/database/user/mod.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::io::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `bind_server_ssl` is never used [INFO] [stdout] --> src/config/mod.rs:16:8 [INFO] [stdout] | [INFO] [stdout] 15 | pub trait ServiceSertConfig { [INFO] [stdout] | ----------------- method in this trait [INFO] [stdout] 16 | fn bind_server_ssl(self) -> Self; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `JWT_ACCESS_SECRET` is never used [INFO] [stdout] --> src/config/mod.rs:20:11 [INFO] [stdout] | [INFO] [stdout] 20 | pub const JWT_ACCESS_SECRET: &'static str = "JWT_ACCESS_SECRET"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `JWT_REFRESH_SECRET` is never used [INFO] [stdout] --> src/config/mod.rs:21:11 [INFO] [stdout] | [INFO] [stdout] 21 | pub const JWT_REFRESH_SECRET: &'static str = "JWT_REFRESH_SECRET"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `JWT_PROPERY_UUID` is never used [INFO] [stdout] --> src/config/mod.rs:23:11 [INFO] [stdout] | [INFO] [stdout] 23 | pub const JWT_PROPERY_UUID: &'static str = "uuid"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `JWT_PROPERY_EXP` is never used [INFO] [stdout] --> src/config/mod.rs:24:11 [INFO] [stdout] | [INFO] [stdout] 24 | pub const JWT_PROPERY_EXP: &'static str = "exp_time"; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `JWT_PROPERY_USERNAME` is never used [INFO] [stdout] --> src/config/mod.rs:25:11 [INFO] [stdout] | [INFO] [stdout] 25 | pub const JWT_PROPERY_USERNAME: &'static str = "username"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `aud`, `iss`, and `exp` are never read [INFO] [stdout] --> src/routes/auth/google_verifier.rs:48:5 [INFO] [stdout] | [INFO] [stdout] 44 | struct Claims { [INFO] [stdout] | ------ fields in this struct [INFO] [stdout] ... [INFO] [stdout] 48 | aud: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 49 | iss: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 50 | exp: usize, [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Claims` 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 `kty`, `alg`, and `use_` are never read [INFO] [stdout] --> src/routes/auth/google_verifier.rs:63:5 [INFO] [stdout] | [INFO] [stdout] 59 | struct Jwk { [INFO] [stdout] | --- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 63 | kty: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 64 | alg: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 65 | #[serde(rename = "use")] [INFO] [stdout] 66 | use_: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Jwk` 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 `LoginRequest` is never constructed [INFO] [stdout] --> src/routes/auth/models.rs:7:12 [INFO] [stdout] | [INFO] [stdout] 7 | pub struct LoginRequest { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RegistrationRequest` is never constructed [INFO] [stdout] --> src/routes/auth/models.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 21 | pub struct RegistrationRequest { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AuthResponse` is never constructed [INFO] [stdout] --> src/routes/auth/models.rs:31:12 [INFO] [stdout] | [INFO] [stdout] 31 | pub struct AuthResponse { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `FieldValidator` is never used [INFO] [stdout] --> src/routes/auth/validator/mod.rs:5:11 [INFO] [stdout] | [INFO] [stdout] 5 | pub trait FieldValidator { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `PasswordValidatorObject` is never constructed [INFO] [stdout] --> src/routes/auth/validator/mod.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct PasswordValidatorObject<'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `PasswordValidatorError` is never used [INFO] [stdout] --> src/routes/auth/validator/mod.rs:14:10 [INFO] [stdout] | [INFO] [stdout] 14 | pub enum PasswordValidatorError { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `LoginValidatorObject` is never constructed [INFO] [stdout] --> src/routes/auth/validator/mod.rs:22:12 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct LoginValidatorObject<'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `LoginValidatorError` is never used [INFO] [stdout] --> src/routes/auth/validator/mod.rs:27:10 [INFO] [stdout] | [INFO] [stdout] 27 | pub enum LoginValidatorError { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `ModelValidator` is never used [INFO] [stdout] --> src/routes/models/mod.rs:9:11 [INFO] [stdout] | [INFO] [stdout] 9 | pub trait ModelValidator<'a, D>: Validator<'a, D, ErrorResponse<'static>> [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `UserResponse` is never constructed [INFO] [stdout] --> src/routes/models/response.rs:4:12 [INFO] [stdout] | [INFO] [stdout] 4 | pub struct UserResponse { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `API_KEY_HEADER` is never used [INFO] [stdout] --> src/service/guard/mod.rs:6:7 [INFO] [stdout] | [INFO] [stdout] 6 | const API_KEY_HEADER: &str = "X-Api-Key"; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `API_KEY_ENV_VAR` is never used [INFO] [stdout] --> src/service/guard/mod.rs:7:7 [INFO] [stdout] | [INFO] [stdout] 7 | const API_KEY_ENV_VAR: &str = "API_KEY"; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static `API_KEY` is never used [INFO] [stdout] --> src/service/guard/mod.rs:9:8 [INFO] [stdout] | [INFO] [stdout] 9 | static API_KEY: Lazy = [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `api_key_guard` is never used [INFO] [stdout] --> src/service/guard/mod.rs:12:8 [INFO] [stdout] | [INFO] [stdout] 12 | pub fn api_key_guard() -> impl Guard { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `AppHasher` is never used [INFO] [stdout] --> src/utils/mod.rs:6:11 [INFO] [stdout] | [INFO] [stdout] 6 | pub trait AppHasher { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `AsyncInto` is never used [INFO] [stdout] --> src/utils/mod.rs:10:11 [INFO] [stdout] | [INFO] [stdout] 10 | pub trait AsyncInto { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `Validator` is never used [INFO] [stdout] --> src/utils/mod.rs:14:11 [INFO] [stdout] | [INFO] [stdout] 14 | pub trait Validator<'a, D, E> [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified [INFO] [stdout] --> src/repository/auth/mod.rs:14:5 [INFO] [stdout] | [INFO] [stdout] 14 | async fn auth(self, info: GoogleTokenInfo) -> Result; [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future` [INFO] [stdout] = note: `#[warn(async_fn_in_trait)]` on by default [INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change [INFO] [stdout] | [INFO] [stdout] 14 - async fn auth(self, info: GoogleTokenInfo) -> Result; [INFO] [stdout] 14 + fn auth(self, info: GoogleTokenInfo) -> impl std::future::Future> + Send; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `bind_app_state_for_tests` is never used [INFO] [stdout] --> src/config/mod.rs:12:8 [INFO] [stdout] | [INFO] [stdout] 9 | pub trait AppStateConfig { [INFO] [stdout] | -------------- method in this trait [INFO] [stdout] ... [INFO] [stdout] 12 | fn bind_app_state_for_tests(self) -> Self; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `bind_server_ssl` is never used [INFO] [stdout] --> src/config/mod.rs:16:8 [INFO] [stdout] | [INFO] [stdout] 15 | pub trait ServiceSertConfig { [INFO] [stdout] | ----------------- method in this trait [INFO] [stdout] 16 | fn bind_server_ssl(self) -> Self; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `JWT_ACCESS_SECRET` is never used [INFO] [stdout] --> src/config/mod.rs:20:11 [INFO] [stdout] | [INFO] [stdout] 20 | pub const JWT_ACCESS_SECRET: &'static str = "JWT_ACCESS_SECRET"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `JWT_REFRESH_SECRET` is never used [INFO] [stdout] --> src/config/mod.rs:21:11 [INFO] [stdout] | [INFO] [stdout] 21 | pub const JWT_REFRESH_SECRET: &'static str = "JWT_REFRESH_SECRET"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `JWT_PROPERY_UUID` is never used [INFO] [stdout] --> src/config/mod.rs:23:11 [INFO] [stdout] | [INFO] [stdout] 23 | pub const JWT_PROPERY_UUID: &'static str = "uuid"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `JWT_PROPERY_EXP` is never used [INFO] [stdout] --> src/config/mod.rs:24:11 [INFO] [stdout] | [INFO] [stdout] 24 | pub const JWT_PROPERY_EXP: &'static str = "exp_time"; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `JWT_PROPERY_USERNAME` is never used [INFO] [stdout] --> src/config/mod.rs:25:11 [INFO] [stdout] | [INFO] [stdout] 25 | pub const JWT_PROPERY_USERNAME: &'static str = "username"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `create_test_db_pool` is never used [INFO] [stdout] --> src/config/database/pool.rs:18:8 [INFO] [stdout] | [INFO] [stdout] 18 | pub fn create_test_db_pool() -> DbPool { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `aud`, `iss`, and `exp` are never read [INFO] [stdout] --> src/routes/auth/google_verifier.rs:48:5 [INFO] [stdout] | [INFO] [stdout] 44 | struct Claims { [INFO] [stdout] | ------ fields in this struct [INFO] [stdout] ... [INFO] [stdout] 48 | aud: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 49 | iss: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 50 | exp: usize, [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Claims` 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 `kty`, `alg`, and `use_` are never read [INFO] [stdout] --> src/routes/auth/google_verifier.rs:63:5 [INFO] [stdout] | [INFO] [stdout] 59 | struct Jwk { [INFO] [stdout] | --- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 63 | kty: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 64 | alg: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 65 | #[serde(rename = "use")] [INFO] [stdout] 66 | use_: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Jwk` 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 `LoginRequest` is never constructed [INFO] [stdout] --> src/routes/auth/models.rs:7:12 [INFO] [stdout] | [INFO] [stdout] 7 | pub struct LoginRequest { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RegistrationRequest` is never constructed [INFO] [stdout] --> src/routes/auth/models.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 21 | pub struct RegistrationRequest { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AuthResponse` is never constructed [INFO] [stdout] --> src/routes/auth/models.rs:31:12 [INFO] [stdout] | [INFO] [stdout] 31 | pub struct AuthResponse { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `ModelValidator` is never used [INFO] [stdout] --> src/routes/models/mod.rs:9:11 [INFO] [stdout] | [INFO] [stdout] 9 | pub trait ModelValidator<'a, D>: Validator<'a, D, ErrorResponse<'static>> [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `UserResponse` is never constructed [INFO] [stdout] --> src/routes/models/response.rs:4:12 [INFO] [stdout] | [INFO] [stdout] 4 | pub struct UserResponse { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `API_KEY_HEADER` is never used [INFO] [stdout] --> src/service/guard/mod.rs:6:7 [INFO] [stdout] | [INFO] [stdout] 6 | const API_KEY_HEADER: &str = "X-Api-Key"; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `API_KEY_ENV_VAR` is never used [INFO] [stdout] --> src/service/guard/mod.rs:7:7 [INFO] [stdout] | [INFO] [stdout] 7 | const API_KEY_ENV_VAR: &str = "API_KEY"; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static `API_KEY` is never used [INFO] [stdout] --> src/service/guard/mod.rs:9:8 [INFO] [stdout] | [INFO] [stdout] 9 | static API_KEY: Lazy = [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `api_key_guard` is never used [INFO] [stdout] --> src/service/guard/mod.rs:12:8 [INFO] [stdout] | [INFO] [stdout] 12 | pub fn api_key_guard() -> impl Guard { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `AsyncInto` is never used [INFO] [stdout] --> src/utils/mod.rs:10:11 [INFO] [stdout] | [INFO] [stdout] 10 | pub trait AsyncInto { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `Validator` is never used [INFO] [stdout] --> src/utils/mod.rs:14:11 [INFO] [stdout] | [INFO] [stdout] 14 | pub trait Validator<'a, D, E> [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of `async fn` in public traits is discouraged as auto trait bounds cannot be specified [INFO] [stdout] --> src/repository/auth/mod.rs:14:5 [INFO] [stdout] | [INFO] [stdout] 14 | async fn auth(self, info: GoogleTokenInfo) -> Result; [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: you can suppress this lint if you plan to use the trait only in your own code, or do not care about auto traits like `Send` on the `Future` [INFO] [stdout] = note: `#[warn(async_fn_in_trait)]` on by default [INFO] [stdout] help: you can alternatively desugar to a normal `fn` that returns `impl Future` and add any desired bounds such as `Send`, but these cannot be relaxed without a breaking API change [INFO] [stdout] | [INFO] [stdout] 14 - async fn auth(self, info: GoogleTokenInfo) -> Result; [INFO] [stdout] 14 + fn auth(self, info: GoogleTokenInfo) -> impl std::future::Future> + Send; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 13s [INFO] running `Command { std: "docker" "inspect" "e19a4119c5a95377cc56188528b6aa9e557dd92c88c8c15d12788ada6c589e7b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e19a4119c5a95377cc56188528b6aa9e557dd92c88c8c15d12788ada6c589e7b", kill_on_drop: false }` [INFO] [stdout] e19a4119c5a95377cc56188528b6aa9e557dd92c88c8c15d12788ada6c589e7b