[INFO] cloning repository https://github.com/blckdfly/fortro-engine [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/blckdfly/fortro-engine" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fblckdfly%2Ffortro-engine", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fblckdfly%2Ffortro-engine'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] da5625307247b5152e2d0438f421a00903ae52a7 [INFO] testing blckdfly/fortro-engine against master#cdb45c87e2cd43495379f7e867e3cc15dcee9f93 for pr-145838-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fblckdfly%2Ffortro-engine" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/blckdfly/fortro-engine [INFO] finished tweaking git repo https://github.com/blckdfly/fortro-engine [INFO] tweaked toml for git repo https://github.com/blckdfly/fortro-engine written to /workspace/builds/worker-4-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/blckdfly/fortro-engine on toolchain cdb45c87e2cd43495379f7e867e3cc15dcee9f93 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/blckdfly/fortro-engine 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" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded scale-info-derive v2.11.6 [INFO] [stderr] Downloaded gloo-timers v0.2.6 [INFO] [stderr] Downloaded send_wrapper v0.4.0 [INFO] [stderr] Downloaded hyper-rustls v0.24.2 [INFO] [stderr] Downloaded common-multipart-rfc7578 v0.6.0 [INFO] [stderr] Downloaded libsecp256k1-gen-ecmult v0.3.0 [INFO] [stderr] Downloaded multihash-derive v0.8.1 [INFO] [stderr] Downloaded lalrpop-util v0.20.2 [INFO] [stderr] Downloaded http-range-header v0.3.1 [INFO] [stderr] Downloaded aead v0.5.2 [INFO] [stderr] Downloaded pharos v0.5.3 [INFO] [stderr] Downloaded camino v1.1.10 [INFO] [stderr] Downloaded ascii-canvas v3.0.0 [INFO] [stderr] Downloaded tower-http v0.4.4 [INFO] [stderr] Downloaded axum v0.6.20 [INFO] [stderr] Downloaded bech32 v0.9.1 [INFO] [stderr] Downloaded hash32 v0.2.1 [INFO] [stderr] Downloaded polyval v0.6.2 [INFO] [stderr] Downloaded universal-hash v0.5.1 [INFO] [stderr] Downloaded libsecp256k1-core v0.3.0 [INFO] [stderr] Downloaded ethers-contract v2.0.14 [INFO] [stderr] Downloaded simple_asn1 v0.6.3 [INFO] [stderr] Downloaded axum-core v0.3.4 [INFO] [stderr] Downloaded ethers-solc v2.0.14 [INFO] [stderr] Downloaded ethers-core v2.0.14 [INFO] [stderr] Downloaded ipconfig v0.3.2 [INFO] [stderr] Downloaded trust-dns-proto v0.21.2 [INFO] [stderr] Downloaded libsecp256k1 v0.7.2 [INFO] [stderr] Downloaded ethers-contract-abigen v2.0.14 [INFO] [stderr] Downloaded multiaddr v0.17.1 [INFO] [stderr] Downloaded ghash v0.5.1 [INFO] [stderr] Downloaded clear_on_drop v0.2.5 [INFO] [stderr] Downloaded subtle-ng v2.5.0 [INFO] [stderr] Downloaded atomic-polyfill v1.0.3 [INFO] [stderr] Downloaded pairing v0.22.0 [INFO] [stderr] Downloaded json-patch v0.2.7 [INFO] [stderr] Downloaded futures-locks v0.7.1 [INFO] [stderr] Downloaded secp256k1-sys v0.8.2 [INFO] [stderr] Downloaded mongodb v2.8.2 [INFO] [stderr] Downloaded x25519-dalek v1.1.1 [INFO] [stderr] Downloaded hkdf v0.11.0 [INFO] [stderr] Downloaded ethers-providers v2.0.14 [INFO] [stderr] Downloaded lalrpop v0.20.2 [INFO] [stderr] Downloaded did_url v0.1.0 [INFO] [stderr] Downloaded treediff v3.0.2 [INFO] [stderr] Downloaded heapless v0.7.17 [INFO] [stderr] Downloaded did-key v0.2.1 [INFO] [stderr] Downloaded ethers-addressbook v2.0.14 [INFO] [stderr] Downloaded aes-gcm v0.10.3 [INFO] [stderr] Downloaded ethers-contract-derive v2.0.14 [INFO] [stderr] Downloaded ethers-etherscan v2.0.14 [INFO] [stderr] Downloaded curve25519-dalek-ng v4.1.1 [INFO] [stderr] Downloaded ethers-middleware v2.0.14 [INFO] [stderr] Downloaded enr v0.10.0 [INFO] [stderr] Downloaded ws_stream_wasm v0.7.5 [INFO] [stderr] Downloaded coins-bip39 v0.8.7 [INFO] [stderr] Downloaded multibase v0.9.1 [INFO] [stderr] Downloaded bson v2.15.0 [INFO] [stderr] Downloaded libsecp256k1-gen-genmult v0.3.0 [INFO] [stderr] Downloaded hashers v1.0.1 [INFO] [stderr] Downloaded async_io_stream v0.3.3 [INFO] [stderr] Downloaded ripemd v0.1.3 [INFO] [stderr] Downloaded eth-keystore v0.5.0 [INFO] [stderr] Downloaded cargo_metadata v0.18.1 [INFO] [stderr] Downloaded ena v0.14.3 [INFO] [stderr] Downloaded solang-parser v0.3.3 [INFO] [stderr] Downloaded hyper-multipart-rfc7578 v0.8.0 [INFO] [stderr] Downloaded data-encoding-macro-internal v0.1.16 [INFO] [stderr] Downloaded ipfs-api-prelude v0.6.0 [INFO] [stderr] Downloaded enum-as-inner v0.4.0 [INFO] [stderr] Downloaded trust-dns-resolver v0.21.2 [INFO] [stderr] Downloaded coins-core v0.8.7 [INFO] [stderr] Downloaded open-fastrlp-derive v0.1.1 [INFO] [stderr] Downloaded open-fastrlp v0.1.4 [INFO] [stderr] Downloaded bls12_381_plus v0.7.0 [INFO] [stderr] Downloaded path-slash v0.2.1 [INFO] [stderr] Downloaded svm-rs v0.3.5 [INFO] [stderr] Downloaded ethers v2.0.14 [INFO] [stderr] Downloaded core2 v0.4.0 [INFO] [stderr] Downloaded proc-macro-crate v1.1.3 [INFO] [stderr] Downloaded multihash v0.17.0 [INFO] [stderr] Downloaded unsigned-varint v0.7.2 [INFO] [stderr] Downloaded ipfs-api-backend-hyper v0.6.0 [INFO] [stderr] Downloaded rustc_version_runtime v0.2.1 [INFO] [stderr] Downloaded resolv-conf v0.7.4 [INFO] [stderr] Downloaded typed-builder v0.10.0 [INFO] [stderr] Downloaded coins-bip32 v0.8.7 [INFO] [stderr] Downloaded ethers-signers v2.0.14 [INFO] [stderr] Downloaded h2 v0.3.27 [INFO] [stderr] Downloaded data-encoding-macro v0.1.18 [INFO] [stderr] Downloaded scale-info v2.11.6 [INFO] [stderr] Downloaded bulletproofs v4.0.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] bbf5ee9d9572263359295fd308e9e34421b2357a7b4bddfa2612f3aba0246245 [INFO] running `Command { std: "docker" "start" "-a" "bbf5ee9d9572263359295fd308e9e34421b2357a7b4bddfa2612f3aba0246245", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "bbf5ee9d9572263359295fd308e9e34421b2357a7b4bddfa2612f3aba0246245", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "bbf5ee9d9572263359295fd308e9e34421b2357a7b4bddfa2612f3aba0246245", kill_on_drop: false }` [INFO] [stdout] bbf5ee9d9572263359295fd308e9e34421b2357a7b4bddfa2612f3aba0246245 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] c5993a6a9857e18e7930d5344391a8ee6f7e145ed828f064b6cf09e513a06b94 [INFO] running `Command { std: "docker" "start" "-a" "c5993a6a9857e18e7930d5344391a8ee6f7e145ed828f064b6cf09e513a06b94", kill_on_drop: false }` [INFO] [stderr] Compiling unicode-ident v1.0.18 [INFO] [stderr] Compiling subtle v2.4.1 [INFO] [stderr] Compiling const-oid v0.9.6 [INFO] [stderr] Compiling serde v1.0.219 [INFO] [stderr] Compiling generic-array v0.14.7 [INFO] [stderr] Compiling hashbrown v0.15.4 [INFO] [stderr] Compiling getrandom v0.2.16 [INFO] [stderr] Compiling zerocopy v0.8.26 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling proc-macro2 v1.0.95 [INFO] [stderr] Compiling rustversion v1.0.21 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling cc v1.2.29 [INFO] [stderr] Compiling unicode-xid v0.2.6 [INFO] [stderr] Compiling winnow v0.7.12 [INFO] [stderr] Compiling crunchy v0.2.4 [INFO] [stderr] Compiling toml_write v0.1.2 [INFO] [stderr] Compiling quote v1.0.40 [INFO] [stderr] Compiling syn v2.0.104 [INFO] [stderr] Compiling indexmap v2.10.0 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling futures-core v0.3.31 [INFO] [stderr] Compiling byteorder v1.5.0 [INFO] [stderr] Compiling zeroize v1.8.1 [INFO] [stderr] Compiling futures-channel v0.3.31 [INFO] [stderr] Compiling parity-scale-codec v3.7.5 [INFO] [stderr] Compiling const_format_proc_macros v0.2.34 [INFO] [stderr] Compiling futures-io v0.3.31 [INFO] [stderr] Compiling futures-task v0.3.31 [INFO] [stderr] Compiling byte-slice-cast v1.2.3 [INFO] [stderr] Compiling slab v0.4.10 [INFO] [stderr] Compiling rustc-hex v2.1.0 [INFO] [stderr] Compiling parking_lot_core v0.9.11 [INFO] [stderr] Compiling libc v0.2.174 [INFO] [stderr] Compiling socket2 v0.5.10 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling parking_lot v0.12.4 [INFO] [stderr] Compiling signal-hook-registry v1.4.5 [INFO] [stderr] Compiling const_format v0.2.34 [INFO] [stderr] Compiling serde_json v1.0.140 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling bitflags v2.9.1 [INFO] [stderr] Compiling tiny-keccak v2.0.2 [INFO] [stderr] Compiling base16ct v0.2.0 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling semver v1.0.26 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling getrandom v0.3.3 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling radium v0.7.0 [INFO] [stderr] Compiling openssl-sys v0.9.109 [INFO] [stderr] Compiling block-buffer v0.10.4 [INFO] [stderr] Compiling crypto-common v0.1.6 [INFO] [stderr] Compiling ff v0.13.1 [INFO] [stderr] Compiling untrusted v0.9.0 [INFO] [stderr] Compiling camino v1.1.10 [INFO] [stderr] Compiling tap v1.0.1 [INFO] [stderr] Compiling group v0.13.0 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling wyz v0.5.1 [INFO] [stderr] Compiling fixed-hash v0.8.0 [INFO] [stderr] Compiling aho-corasick v1.1.3 [INFO] [stderr] Compiling funty v2.0.0 [INFO] [stderr] Compiling mime v0.3.17 [INFO] [stderr] Compiling rustix v1.0.7 [INFO] [stderr] Compiling uint v0.9.5 [INFO] [stderr] Compiling rustls v0.21.12 [INFO] [stderr] Compiling bitvec v1.0.1 [INFO] [stderr] Compiling arrayvec v0.7.6 [INFO] [stderr] Compiling data-encoding v2.9.0 [INFO] [stderr] Compiling httpdate v1.0.3 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling regex-automata v0.4.9 [INFO] [stderr] Compiling memchr v2.7.5 [INFO] [stderr] Compiling openssl v0.10.73 [INFO] [stderr] Compiling foreign-types-shared v0.1.1 [INFO] [stderr] Compiling rlp-derive v0.1.0 [INFO] [stderr] Compiling foreign-types v0.3.2 [INFO] [stderr] Compiling wasm-bindgen-shared v0.2.100 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling zeroize_derive v1.4.2 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.0 [INFO] [stderr] Compiling impl-trait-for-tuples v0.2.3 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling zerovec-derive v0.11.1 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling derive_more-impl v1.0.0 [INFO] [stderr] Compiling tokio-macros v2.5.0 [INFO] [stderr] Compiling yoke v0.8.0 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling hmac v0.12.1 [INFO] [stderr] Compiling tracing-attributes v0.1.30 [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling zerovec v0.11.2 [INFO] [stderr] Compiling derive_more v1.0.0 [INFO] [stderr] Compiling digest v0.9.0 [INFO] [stderr] Compiling zerotrie v0.2.2 [INFO] [stderr] Compiling der v0.7.10 [INFO] [stderr] Compiling sha3 v0.10.8 [INFO] [stderr] Compiling crypto-bigint v0.5.5 [INFO] [stderr] Compiling rfc6979 v0.4.0 [INFO] [stderr] Compiling signature v2.2.0 [INFO] [stderr] Compiling tinystr v0.8.1 [INFO] [stderr] Compiling potential_utf v0.1.2 [INFO] [stderr] Compiling icu_locale_core v2.0.0 [INFO] [stderr] Compiling icu_collections v2.0.0 [INFO] [stderr] Compiling tracing v0.1.41 [INFO] [stderr] Compiling auto_impl v1.3.0 [INFO] [stderr] Compiling spki v0.7.3 [INFO] [stderr] Compiling sec1 v0.7.3 [INFO] [stderr] Compiling pkcs8 v0.10.2 [INFO] [stderr] Compiling icu_provider v2.0.0 [INFO] [stderr] Compiling regex v1.11.1 [INFO] [stderr] Compiling rustls-webpki v0.101.7 [INFO] [stderr] Compiling sct v0.7.1 [INFO] [stderr] Compiling icu_properties v2.0.1 [INFO] [stderr] Compiling icu_normalizer v2.0.0 [INFO] [stderr] Compiling strum_macros v0.26.4 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling elliptic-curve v0.13.8 [INFO] [stderr] Compiling ecdsa v0.16.9 [INFO] [stderr] Compiling async-trait v0.1.88 [INFO] [stderr] Compiling hex v0.4.3 [INFO] [stderr] Compiling k256 v0.13.4 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling log v0.4.27 [INFO] [stderr] Compiling wasm-bindgen-backend v0.2.100 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.0.3 [INFO] [stderr] Compiling strum v0.26.3 [INFO] [stderr] Compiling base64 v0.13.1 [INFO] [stderr] Compiling url v2.5.4 [INFO] [stderr] Compiling bytes v1.10.1 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling toml_edit v0.22.27 [INFO] [stderr] Compiling impl-serde v0.4.0 [INFO] [stderr] Compiling rlp v0.5.2 [INFO] [stderr] Compiling tokio v1.46.1 [INFO] [stderr] Compiling impl-rlp v0.3.0 [INFO] [stderr] Compiling http v0.2.12 [INFO] [stderr] Compiling open-fastrlp-derive v0.1.1 [INFO] [stderr] Compiling cargo-platform v0.1.9 [INFO] [stderr] Compiling openssl-probe v0.1.6 [INFO] [stderr] Compiling chrono v0.4.41 [INFO] [stderr] Compiling http-body v0.4.6 [INFO] [stderr] Compiling wasm-bindgen-macro-support v0.2.100 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling inout v0.1.4 [INFO] [stderr] Compiling proc-macro-crate v3.3.0 [INFO] [stderr] Compiling time-core v0.1.4 [INFO] [stderr] Compiling time-macros v0.2.22 [INFO] [stderr] Compiling wasm-bindgen-macro v0.2.100 [INFO] [stderr] Compiling block-buffer v0.9.0 [INFO] [stderr] Compiling deranged v0.4.0 [INFO] [stderr] Compiling cipher v0.4.4 [INFO] [stderr] Compiling cargo_metadata v0.18.1 [INFO] [stderr] Compiling pin-project-internal v1.1.10 [INFO] [stderr] Compiling parity-scale-codec-derive v3.7.5 [INFO] [stderr] Compiling scale-info-derive v2.11.6 [INFO] [stderr] Compiling num_enum_derive v0.7.4 [INFO] [stderr] Compiling tokio-util v0.7.15 [INFO] [stderr] Compiling tokio-rustls v0.24.1 [INFO] [stderr] Compiling tempfile v3.20.0 [INFO] [stderr] Compiling h2 v0.3.27 [INFO] [stderr] Compiling num_enum v0.7.4 [INFO] [stderr] Compiling const-hex v1.14.1 [INFO] [stderr] Compiling prettyplease v0.2.35 [INFO] [stderr] Compiling webpki-roots v0.25.4 [INFO] [stderr] Compiling tinyvec v1.9.0 [INFO] [stderr] Compiling impl-codec v0.6.0 [INFO] [stderr] Compiling scale-info v2.11.6 [INFO] [stderr] Compiling pin-project v1.1.10 [INFO] [stderr] Compiling ethbloom v0.13.0 [INFO] [stderr] Compiling primitive-types v0.12.2 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling time v0.3.41 [INFO] [stderr] Compiling wasm-bindgen v0.2.100 [INFO] [stderr] Compiling sha1 v0.10.6 [INFO] [stderr] Compiling rustls-pemfile v1.0.4 [INFO] [stderr] Compiling thiserror v2.0.12 [INFO] [stderr] Compiling sync_wrapper v0.1.2 [INFO] [stderr] Compiling ethereum-types v0.14.1 [INFO] [stderr] Compiling js-sys v0.3.77 [INFO] [stderr] Compiling unicode-normalization v0.1.24 [INFO] [stderr] Compiling ethabi v18.0.0 [INFO] [stderr] Compiling hyper v0.14.32 [INFO] [stderr] Compiling open-fastrlp v0.1.4 [INFO] [stderr] Compiling getrandom v0.1.16 [INFO] [stderr] Compiling futures-executor v0.3.31 [INFO] [stderr] Compiling der v0.6.1 [INFO] [stderr] Compiling ff v0.12.1 [INFO] [stderr] Compiling thiserror-impl v2.0.12 [INFO] [stderr] Compiling num-integer v0.1.46 [INFO] [stderr] Compiling ethers-core v2.0.14 [INFO] [stderr] Compiling ring v0.16.20 [INFO] [stderr] Compiling encoding_rs v0.8.35 [INFO] [stderr] Compiling base64ct v1.8.0 [INFO] [stderr] Compiling unicase v2.8.1 [INFO] [stderr] Compiling unicode-bidi v0.3.18 [INFO] [stderr] Compiling indenter v0.3.3 [INFO] [stderr] Compiling eyre v0.6.12 [INFO] [stderr] Compiling spki v0.6.0 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Compiling gloo-timers v0.2.6 [INFO] [stderr] Compiling libsecp256k1-core v0.3.0 [INFO] [stderr] Compiling num-bigint v0.4.6 [INFO] [stderr] Compiling group v0.12.1 [INFO] [stderr] Compiling rand_core v0.5.1 [INFO] [stderr] Compiling proc-macro-error-attr v1.0.4 [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling hyper-rustls v0.24.2 [INFO] [stderr] Compiling hyper-tls v0.5.0 [INFO] [stderr] Compiling toml v0.5.11 [INFO] [stderr] Compiling reqwest v0.11.27 [INFO] [stderr] Compiling bs58 v0.5.1 [INFO] [stderr] Compiling ripemd v0.1.3 [INFO] [stderr] Compiling pbkdf2 v0.11.0 [INFO] [stderr] Compiling untrusted v0.7.1 [INFO] [stderr] Compiling bech32 v0.9.1 [INFO] [stderr] Compiling send_wrapper v0.4.0 [INFO] [stderr] Compiling semver-parser v0.7.0 [INFO] [stderr] Compiling spin v0.5.2 [INFO] [stderr] Compiling darling_core v0.13.4 [INFO] [stderr] Compiling data-encoding-macro-internal v0.1.16 [INFO] [stderr] Compiling semver v0.9.0 [INFO] [stderr] Compiling proc-macro-crate v1.1.3 [INFO] [stderr] Compiling futures-timer v3.0.3 [INFO] [stderr] Compiling coins-core v0.8.7 [INFO] [stderr] Compiling tungstenite v0.20.1 [INFO] [stderr] Compiling proc-macro-error v1.0.4 [INFO] [stderr] Compiling simple_asn1 v0.6.3 [INFO] [stderr] Compiling pkcs8 v0.9.0 [INFO] [stderr] Compiling futures v0.3.31 [INFO] [stderr] Compiling Inflector v0.11.4 [INFO] [stderr] Compiling salsa20 v0.10.2 [INFO] [stderr] Compiling aes v0.8.4 [INFO] [stderr] Compiling ctr v0.9.2 [INFO] [stderr] Compiling rustc_version v0.4.1 [INFO] [stderr] Compiling pem v1.1.1 [INFO] [stderr] Compiling signature v1.6.4 [INFO] [stderr] Compiling crypto-bigint v0.4.9 [INFO] [stderr] Compiling synstructure v0.12.6 [INFO] [stderr] Compiling fxhash v0.2.1 [INFO] [stderr] Compiling base16ct v0.1.1 [INFO] [stderr] Compiling darling_macro v0.13.4 [INFO] [stderr] Compiling sec1 v0.3.0 [INFO] [stderr] Compiling hashers v1.0.1 [INFO] [stderr] Compiling multihash-derive v0.8.1 [INFO] [stderr] Compiling heapless v0.7.17 [INFO] [stderr] Compiling jsonwebtoken v8.3.0 [INFO] [stderr] Compiling scrypt v0.10.0 [INFO] [stderr] Compiling tokio-tungstenite v0.20.1 [INFO] [stderr] Compiling coins-bip32 v0.8.7 [INFO] [stderr] Compiling rustc_version v0.2.3 [INFO] [stderr] Compiling data-encoding-macro v0.1.18 [INFO] [stderr] Compiling libsecp256k1-gen-ecmult v0.3.0 [INFO] [stderr] Compiling libsecp256k1-gen-genmult v0.3.0 [INFO] [stderr] Compiling tracing-futures v0.2.5 [INFO] [stderr] Compiling enr v0.10.0 [INFO] [stderr] Compiling uuid v0.8.2 [INFO] [stderr] Compiling pbkdf2 v0.12.2 [INFO] [stderr] Compiling hkdf v0.12.4 [INFO] [stderr] Compiling crypto-mac v0.8.0 [INFO] [stderr] Compiling rand_core v0.9.3 [INFO] [stderr] Compiling secp256k1-sys v0.8.2 [INFO] [stderr] Compiling core2 v0.4.0 [INFO] [stderr] Compiling instant v0.1.13 [INFO] [stderr] Compiling ahash v0.8.12 [INFO] [stderr] Compiling unsigned-varint v0.7.2 [INFO] [stderr] Compiling base-x v0.2.11 [INFO] [stderr] Compiling enum-as-inner v0.4.0 [INFO] [stderr] Compiling idna v0.2.3 [INFO] [stderr] Compiling multibase v0.9.1 [INFO] [stderr] Compiling multihash v0.17.0 [INFO] [stderr] Compiling ethers-contract-abigen v2.0.14 [INFO] [stderr] Compiling ethers-providers v2.0.14 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling hmac v0.8.1 [INFO] [stderr] Compiling elliptic-curve v0.12.3 [INFO] [stderr] Compiling coins-bip39 v0.8.7 [INFO] [stderr] Compiling eth-keystore v0.5.0 [INFO] [stderr] Compiling libsecp256k1 v0.7.2 [INFO] [stderr] Compiling rustc_version_runtime v0.2.1 [INFO] [stderr] Compiling common-multipart-rfc7578 v0.6.0 [INFO] [stderr] Compiling rfc6979 v0.3.1 [INFO] [stderr] Compiling darling v0.13.4 [INFO] [stderr] Compiling rand_chacha v0.2.2 [INFO] [stderr] Compiling curve25519-dalek v3.2.0 [INFO] [stderr] Compiling sha2 v0.9.9 [INFO] [stderr] Compiling universal-hash v0.5.1 [INFO] [stderr] Compiling crypto-mac v0.11.1 [INFO] [stderr] Compiling clear_on_drop v0.2.5 [INFO] [stderr] Compiling spin v0.9.8 [INFO] [stderr] Compiling hash32 v0.2.1 [INFO] [stderr] Compiling axum-core v0.3.4 [INFO] [stderr] Compiling dirs-sys v0.3.7 [INFO] [stderr] Compiling linked-hash-map v0.5.6 [INFO] [stderr] Compiling derive_more v0.99.20 [INFO] [stderr] Compiling lru-cache v0.1.2 [INFO] [stderr] Compiling dirs v4.0.0 [INFO] [stderr] Compiling hmac v0.11.0 [INFO] [stderr] Compiling polyval v0.6.2 [INFO] [stderr] Compiling rand v0.7.3 [INFO] [stderr] Compiling serde_with_macros v1.5.2 [INFO] [stderr] Compiling ecdsa v0.14.8 [INFO] [stderr] Compiling ethers-signers v2.0.14 [INFO] [stderr] Compiling hmac-drbg v0.3.0 [INFO] [stderr] Compiling rand v0.9.1 [INFO] [stderr] Compiling trust-dns-proto v0.21.2 [INFO] [stderr] Compiling multiaddr v0.17.1 [INFO] [stderr] Compiling ed25519 v1.5.3 [INFO] [stderr] Compiling ethers-etherscan v2.0.14 [INFO] [stderr] Compiling pairing v0.22.0 [INFO] [stderr] Compiling sha-1 v0.9.8 [INFO] [stderr] Compiling ethers-contract-derive v2.0.14 [INFO] [stderr] Compiling headers-core v0.2.0 [INFO] [stderr] Compiling treediff v3.0.2 [INFO] [stderr] Compiling uuid v1.17.0 [INFO] [stderr] Compiling serde_bytes v0.11.17 [INFO] [stderr] Compiling futures-locks v0.7.1 [INFO] [stderr] Compiling axum v0.6.20 [INFO] [stderr] Compiling subtle-ng v2.5.0 [INFO] [stderr] Compiling unicode-properties v0.1.3 [INFO] [stderr] Compiling resolv-conf v0.7.4 [INFO] [stderr] Compiling bson v2.15.0 [INFO] [stderr] Compiling curve25519-dalek-ng v4.1.1 [INFO] [stderr] Compiling stringprep v0.1.5 [INFO] [stderr] Compiling json-patch v0.2.7 [INFO] [stderr] Compiling trust-dns-resolver v0.21.2 [INFO] [stderr] Compiling headers v0.3.9 [INFO] [stderr] Compiling ethers-contract v2.0.14 [INFO] [stderr] Compiling soketto v0.7.1 [INFO] [stderr] Compiling bls12_381_plus v0.7.0 [INFO] [stderr] Compiling ed25519-dalek v1.0.1 [INFO] [stderr] Compiling ipfs-api-prelude v0.6.0 [INFO] [stderr] Compiling serde_with v1.14.0 [INFO] [stderr] Compiling p256 v0.11.1 [INFO] [stderr] Compiling secp256k1 v0.27.0 [INFO] [stderr] Compiling ghash v0.5.1 [INFO] [stderr] Compiling hkdf v0.11.0 [INFO] [stderr] Compiling x25519-dalek v1.1.1 [INFO] [stderr] Compiling hyper-multipart-rfc7578 v0.8.0 [INFO] [stderr] Compiling tower v0.4.13 [INFO] [stderr] Compiling ethers-addressbook v2.0.14 [INFO] [stderr] Compiling jsonrpc-core v18.0.0 [INFO] [stderr] Compiling ethers-middleware v2.0.14 [INFO] [stderr] Compiling idna v0.4.0 [INFO] [stderr] Compiling tokio-stream v0.1.17 [INFO] [stderr] Compiling web3-async-native-tls v0.4.0 [INFO] [stderr] Compiling sha3 v0.9.1 [INFO] [stderr] Compiling serde_path_to_error v0.1.17 [INFO] [stderr] Compiling sha-1 v0.10.1 [INFO] [stderr] Compiling md-5 v0.10.6 [INFO] [stderr] Compiling aead v0.5.2 [INFO] [stderr] Compiling merlin v3.0.0 [INFO] [stderr] Compiling derivative v2.2.0 [INFO] [stderr] Compiling typed-builder v0.10.0 [INFO] [stderr] Compiling did_url v0.1.0 [INFO] [stderr] Compiling socket2 v0.4.10 [INFO] [stderr] Compiling matchit v0.7.3 [INFO] [stderr] Compiling take_mut v0.2.2 [INFO] [stderr] Compiling http-range-header v0.3.1 [INFO] [stderr] Compiling tracing-subscriber v0.3.19 [INFO] [stderr] Compiling did-key v0.2.1 [INFO] [stderr] Compiling tower-http v0.4.4 [INFO] [stderr] Compiling bulletproofs v4.0.0 [INFO] [stderr] Compiling ipfs-api-backend-hyper v0.6.0 [INFO] [stderr] Compiling aes-gcm v0.10.3 [INFO] [stderr] Compiling web3 v0.19.0 [INFO] [stderr] Compiling dotenv v0.15.0 [INFO] [stderr] Compiling mongodb v2.8.2 [INFO] [stderr] Compiling ethers v2.0.14 [INFO] [stderr] Compiling fortro-engine v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `generic_array::ArrayLength` [INFO] [stdout] --> src/blockchain.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use generic_array::ArrayLength; [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: `Duration` [INFO] [stdout] --> src/services/credential.rs:7:24 [INFO] [stdout] | [INFO] [stdout] 7 | use chrono::{DateTime, Duration, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `uuid::Uuid` [INFO] [stdout] --> src/services/credential.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use uuid::Uuid; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Credential` [INFO] [stdout] --> src/services/presentation.rs:3:21 [INFO] [stdout] | [INFO] [stdout] 3 | use crate::models::{Credential, CredentialRequirement, Presentation, PresentationRequest, PresentationStatus}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `crypto` and `did` [INFO] [stdout] --> src/services/presentation.rs:5:20 [INFO] [stdout] | [INFO] [stdout] 5 | use crate::utils::{crypto, did, jwt, qr, zk_proofs}; [INFO] [stdout] | ^^^^^^ ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Duration` [INFO] [stdout] --> src/services/presentation.rs:6:24 [INFO] [stdout] | [INFO] [stdout] 6 | use chrono::{DateTime, Duration, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `json` [INFO] [stdout] --> src/utils/qr.rs:4:18 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_json::{json, Value}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode [INFO] [stdout] --> src/services/auth.rs:27:22 [INFO] [stdout] | [INFO] [stdout] 27 | &base64::decode(signature) [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode [INFO] [stdout] --> src/services/auth.rs:131:22 [INFO] [stdout] | [INFO] [stdout] 131 | &base64::decode(&request.signature) [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode [INFO] [stdout] --> src/services/wallet.rs:405:37 [INFO] [stdout] | [INFO] [stdout] 405 | let backup_base64 = base64::encode(&encrypted_backup); [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode [INFO] [stdout] --> src/services/wallet.rs:413:40 [INFO] [stdout] | [INFO] [stdout] 413 | let encrypted_backup = base64::decode(backup_data) [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:105:23 [INFO] [stdout] | [INFO] [stdout] 105 | .map_err(|e| AppError::BlockchainError("Failed to deploy contract".to_string()))? [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:108:23 [INFO] [stdout] | [INFO] [stdout] 108 | .map_err(|e| AppError::BlockchainError("Failed to send deployment transaction:".to_string()))?; [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:253:23 [INFO] [stdout] | [INFO] [stdout] 253 | .map_err(|e| AppError::BlockchainError("Failed to send transaction".to_string()))? [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:270:23 [INFO] [stdout] | [INFO] [stdout] 270 | .map_err(|e| AppError::BlockchainError("Failed to get balance".to_string()))?; [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:283:23 [INFO] [stdout] | [INFO] [stdout] 283 | .map_err(|e| AppError::BlockchainError("Failed to get block number".to_string()))?; [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:293:23 [INFO] [stdout] | [INFO] [stdout] 293 | .map_err(|e| AppError::BlockchainError("Failed to get transaction receipt".to_string()))?; [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `issuer_private_key` [INFO] [stdout] --> src/services/credential.rs:299:13 [INFO] [stdout] | [INFO] [stdout] 299 | let issuer_private_key = "dummy_private_key"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_issuer_private_key` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `request` [INFO] [stdout] --> src/services/credential.rs:302:13 [INFO] [stdout] | [INFO] [stdout] 302 | let request = RevokeCredentialRequest { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ChallengeResponse` is never constructed [INFO] [stdout] --> src/api/auth.rs:69:12 [INFO] [stdout] | [INFO] [stdout] 69 | pub struct ChallengeResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `jwt_expiration`, `issuer_did`, `issuer_private_key`, and `jwt_secret` are never read [INFO] [stdout] --> src/config.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 6 | pub struct Config { [INFO] [stdout] | ------ fields in this struct [INFO] [stdout] ... [INFO] [stdout] 11 | pub jwt_expiration: u64, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 12 | pub issuer_did: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 13 | pub issuer_private_key: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 14 | pub jwt_secret: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Config` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `client` is never read [INFO] [stdout] --> src/db.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 14 | pub struct Database { [INFO] [stdout] | -------- field in this struct [INFO] [stdout] 15 | client: Client, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Database` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `update_user`, `find_credential_requests_by_user`, `update_credential_request_status`, `find_short_url_qr_codes_by_issuer_verifier`, and `delete_short_url_qr_code` are never used [INFO] [stdout] --> src/db.rs:50:18 [INFO] [stdout] | [INFO] [stdout] 19 | impl Database { [INFO] [stdout] | ------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 50 | pub async fn update_user(&self, user: &User) -> Result<(), AppError> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 111 | pub async fn find_credential_requests_by_user(&self, user_did: &str) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 131 | pub async fn update_credential_request_status(&self, id: &str, status: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 290 | pub async fn find_short_url_qr_codes_by_issuer_verifier(&self, did: &str) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 300 | pub async fn delete_short_url_qr_code(&self, short_id: &str, did: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/blockchain.rs:55:12 [INFO] [stdout] | [INFO] [stdout] 38 | impl EthereumClient { [INFO] [stdout] | ------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 55 | pub fn with_wallet(mut self, private_key: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 69 | pub fn with_registry_address(mut self, address: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 80 | pub async fn deploy_registry(&mut self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 151 | pub async fn revoke_credential(&self, did: &str, credential_hash: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 175 | pub async fn is_credential_registered(&self, did: &str, credential_hash: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 225 | pub async fn get_schema_hash(&self, schema_id: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 238 | pub async fn send_ether(&self, to: &str, amount: f64) -> Result { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 262 | pub async fn get_balance(&self, address: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 279 | pub async fn get_block_number(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 289 | pub async fn wait_for_transaction(&self, tx_hash: H256) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/ipfs.rs:44:18 [INFO] [stdout] | [INFO] [stdout] 11 | impl IpfsClient { [INFO] [stdout] | --------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 44 | pub async fn upload_json(&self, data: &T) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 51 | pub async fn get(&self, cid: &str) -> Result, AppError> { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 80 | pub async fn get_json(&self, cid: &str) -> Result { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 89 | pub async fn exists(&self, cid: &str) -> Result { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 121 | pub async fn pin(&self, cid: &str) -> Result<(), AppError> { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 147 | pub async fn unpin(&self, cid: &str) -> Result<(), AppError> { [INFO] [stdout] | ^^^^^ [INFO] [stdout] ... [INFO] [stdout] 183 | pub async fn get_encrypted(&self, cid: &str, encryption_key: &[u8]) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 207 | pub async fn get_credential_data( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/models.rs:106:12 [INFO] [stdout] | [INFO] [stdout] 105 | impl CredentialRequest { [INFO] [stdout] | ---------------------- associated function in this implementation [INFO] [stdout] 106 | pub fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `to_qr_data` is never used [INFO] [stdout] --> src/models.rs:231:12 [INFO] [stdout] | [INFO] [stdout] 208 | impl PresentationRequest { [INFO] [stdout] | ------------------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 231 | pub fn to_qr_data(&self) -> String { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new` and `to_qr_data` are never used [INFO] [stdout] --> src/models.rs:282:12 [INFO] [stdout] | [INFO] [stdout] 281 | impl CredentialOffer { [INFO] [stdout] | -------------------- associated items in this implementation [INFO] [stdout] 282 | pub fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 302 | pub fn to_qr_data(&self) -> String { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `QrCodeData` is never constructed [INFO] [stdout] --> src/models.rs:309:12 [INFO] [stdout] | [INFO] [stdout] 309 | pub struct QrCodeData { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new` and `is_expired` are never used [INFO] [stdout] --> src/models.rs:318:12 [INFO] [stdout] | [INFO] [stdout] 317 | impl QrCodeData { [INFO] [stdout] | --------------- associated items in this implementation [INFO] [stdout] 318 | pub fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 332 | pub fn is_expired(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ApiResponse` is never constructed [INFO] [stdout] --> src/models.rs:500:12 [INFO] [stdout] | [INFO] [stdout] 500 | pub struct ApiResponse { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated functions `success` and `error` are never used [INFO] [stdout] --> src/models.rs:507:12 [INFO] [stdout] | [INFO] [stdout] 506 | impl ApiResponse { [INFO] [stdout] | ---------------------- associated functions in this implementation [INFO] [stdout] 507 | pub fn success(data: T) -> Self { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 515 | pub fn error(error: String) -> Self { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `user_service` is never used [INFO] [stdout] --> src/services/mod.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 35 | impl AppState { [INFO] [stdout] | ------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 51 | pub fn user_service(&self) -> UserService { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `verify_token`, `get_user_from_token`, and `generate_did_key_pair` are never used [INFO] [stdout] --> src/services/auth.rs:178:12 [INFO] [stdout] | [INFO] [stdout] 74 | impl AuthService { [INFO] [stdout] | ---------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 178 | pub fn verify_token(&self, token: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 186 | pub async fn get_user_from_token(&self, token: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 197 | pub fn generate_did_key_pair(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `credential_id` and `reason` are never read [INFO] [stdout] --> src/services/credential.rs:40:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub struct RevokeCredentialRequest { [INFO] [stdout] | ----------------------- fields in this struct [INFO] [stdout] 40 | pub credential_id: String, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 41 | pub reason: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `RevokeCredentialRequest` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `revoke_credential_with_key` and `create_predicate_proof` are never used [INFO] [stdout] --> src/services/credential.rs:322:18 [INFO] [stdout] | [INFO] [stdout] 65 | impl CredentialService { [INFO] [stdout] | ---------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 322 | pub async fn revoke_credential_with_key( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 434 | pub async fn create_predicate_proof( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `reason` is never read [INFO] [stdout] --> src/services/issuer.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 44 | pub struct ProcessCredentialRequestRequest { [INFO] [stdout] | ------------------------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 47 | pub reason: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ProcessCredentialRequestRequest` 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 `CreateCredentialOfferRequest` is never constructed [INFO] [stdout] --> src/services/issuer.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 51 | pub struct CreateCredentialOfferRequest { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CredentialRequestResponse` is never constructed [INFO] [stdout] --> src/services/issuer.rs:60:12 [INFO] [stdout] | [INFO] [stdout] 60 | pub struct CredentialRequestResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CredentialOfferResponse` is never constructed [INFO] [stdout] --> src/services/issuer.rs:66:12 [INFO] [stdout] | [INFO] [stdout] 66 | pub struct CredentialOfferResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `get_credential_requests_for_user`, `create_credential_offer`, `count_pending_requests`, and `get_recent_requests` are never used [INFO] [stdout] --> src/services/issuer.rs:326:18 [INFO] [stdout] | [INFO] [stdout] 71 | impl IssuerService { [INFO] [stdout] | ------------------ methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 326 | pub async fn get_credential_requests_for_user( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 467 | pub async fn create_credential_offer( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 520 | pub async fn count_pending_requests(&self, issuer_did: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 539 | pub async fn get_recent_requests( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ValidateCredentialRequest` is never constructed [INFO] [stdout] --> src/services/schema.rs:44:12 [INFO] [stdout] | [INFO] [stdout] 44 | pub struct ValidateCredentialRequest { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ValidationResult` is never constructed [INFO] [stdout] --> src/services/schema.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 51 | pub struct ValidationResult { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `validate_credential`, `search_schemas`, and `verify_schema_on_blockchain` are never used [INFO] [stdout] --> src/services/schema.rs:139:18 [INFO] [stdout] | [INFO] [stdout] 56 | impl SchemaService { [INFO] [stdout] | ------------------ methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 139 | pub async fn validate_credential( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 325 | pub async fn search_schemas(&self, query: &str) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 341 | pub async fn verify_schema_on_blockchain(&self, schema_id: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `UserService` is never constructed [INFO] [stdout] --> src/services/user.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct UserService { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `UpdateProfileRequest` is never constructed [INFO] [stdout] --> src/services/user.rs:15:12 [INFO] [stdout] | [INFO] [stdout] 15 | pub struct UpdateProfileRequest { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `UserProfileResponse` is never constructed [INFO] [stdout] --> src/services/user.rs:22:12 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct UserProfileResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/services/user.rs:28:12 [INFO] [stdout] | [INFO] [stdout] 26 | impl UserService { [INFO] [stdout] | ---------------- associated items in this implementation [INFO] [stdout] 27 | /// Create a new user service [INFO] [stdout] 28 | pub fn new(db: Arc) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 33 | pub async fn get_user_by_did(&self, did: &str) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 38 | pub async fn update_profile(&self, did: &str, request: UpdateProfileRequest) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 62 | pub async fn create_user(&self, user: &User) -> Result<(), AppError> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 82 | pub async fn get_all_users(&self) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 89 | pub async fn delete_user(&self, did: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 102 | pub async fn search_users(&self, query: &str) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 117 | pub async fn user_exists(&self, did: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 123 | pub async fn count_users(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `create_range_proof` is never used [INFO] [stdout] --> src/utils/zk_proofs.rs:32:8 [INFO] [stdout] | [INFO] [stdout] 32 | pub fn create_range_proof( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `create_predicate_proof` is never used [INFO] [stdout] --> src/utils/zk_proofs.rs:89:8 [INFO] [stdout] | [INFO] [stdout] 89 | pub fn create_predicate_proof( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `verify_selective_disclosure` is never used [INFO] [stdout] --> src/utils/zk_proofs.rs:262:8 [INFO] [stdout] | [INFO] [stdout] 262 | pub fn verify_selective_disclosure( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 7m 47s [INFO] running `Command { std: "docker" "inspect" "c5993a6a9857e18e7930d5344391a8ee6f7e145ed828f064b6cf09e513a06b94", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c5993a6a9857e18e7930d5344391a8ee6f7e145ed828f064b6cf09e513a06b94", kill_on_drop: false }` [INFO] [stdout] c5993a6a9857e18e7930d5344391a8ee6f7e145ed828f064b6cf09e513a06b94 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 8e2bc042f70db56458ec2cfc7e96b8a8f62f84269b5997f5e05bf56370d522fa [INFO] running `Command { std: "docker" "start" "-a" "8e2bc042f70db56458ec2cfc7e96b8a8f62f84269b5997f5e05bf56370d522fa", kill_on_drop: false }` [INFO] [stderr] Compiling fortro-engine v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `generic_array::ArrayLength` [INFO] [stdout] --> src/blockchain.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use generic_array::ArrayLength; [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: `Duration` [INFO] [stdout] --> src/services/credential.rs:7:24 [INFO] [stdout] | [INFO] [stdout] 7 | use chrono::{DateTime, Duration, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `uuid::Uuid` [INFO] [stdout] --> src/services/credential.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use uuid::Uuid; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Credential` [INFO] [stdout] --> src/services/presentation.rs:3:21 [INFO] [stdout] | [INFO] [stdout] 3 | use crate::models::{Credential, CredentialRequirement, Presentation, PresentationRequest, PresentationStatus}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `crypto` and `did` [INFO] [stdout] --> src/services/presentation.rs:5:20 [INFO] [stdout] | [INFO] [stdout] 5 | use crate::utils::{crypto, did, jwt, qr, zk_proofs}; [INFO] [stdout] | ^^^^^^ ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Duration` [INFO] [stdout] --> src/services/presentation.rs:6:24 [INFO] [stdout] | [INFO] [stdout] 6 | use chrono::{DateTime, Duration, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `json` [INFO] [stdout] --> src/utils/qr.rs:4:18 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_json::{json, Value}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode [INFO] [stdout] --> src/services/auth.rs:27:22 [INFO] [stdout] | [INFO] [stdout] 27 | &base64::decode(signature) [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode [INFO] [stdout] --> src/services/auth.rs:131:22 [INFO] [stdout] | [INFO] [stdout] 131 | &base64::decode(&request.signature) [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode [INFO] [stdout] --> src/services/wallet.rs:405:37 [INFO] [stdout] | [INFO] [stdout] 405 | let backup_base64 = base64::encode(&encrypted_backup); [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `base64::decode`: Use Engine::decode [INFO] [stdout] --> src/services/wallet.rs:413:40 [INFO] [stdout] | [INFO] [stdout] 413 | let encrypted_backup = base64::decode(backup_data) [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:105:23 [INFO] [stdout] | [INFO] [stdout] 105 | .map_err(|e| AppError::BlockchainError("Failed to deploy contract".to_string()))? [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:108:23 [INFO] [stdout] | [INFO] [stdout] 108 | .map_err(|e| AppError::BlockchainError("Failed to send deployment transaction:".to_string()))?; [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:253:23 [INFO] [stdout] | [INFO] [stdout] 253 | .map_err(|e| AppError::BlockchainError("Failed to send transaction".to_string()))? [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:270:23 [INFO] [stdout] | [INFO] [stdout] 270 | .map_err(|e| AppError::BlockchainError("Failed to get balance".to_string()))?; [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:283:23 [INFO] [stdout] | [INFO] [stdout] 283 | .map_err(|e| AppError::BlockchainError("Failed to get block number".to_string()))?; [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/blockchain.rs:293:23 [INFO] [stdout] | [INFO] [stdout] 293 | .map_err(|e| AppError::BlockchainError("Failed to get transaction receipt".to_string()))?; [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `issuer_private_key` [INFO] [stdout] --> src/services/credential.rs:299:13 [INFO] [stdout] | [INFO] [stdout] 299 | let issuer_private_key = "dummy_private_key"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_issuer_private_key` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `request` [INFO] [stdout] --> src/services/credential.rs:302:13 [INFO] [stdout] | [INFO] [stdout] 302 | let request = RevokeCredentialRequest { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ChallengeResponse` is never constructed [INFO] [stdout] --> src/api/auth.rs:69:12 [INFO] [stdout] | [INFO] [stdout] 69 | pub struct ChallengeResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `jwt_expiration`, `issuer_did`, `issuer_private_key`, and `jwt_secret` are never read [INFO] [stdout] --> src/config.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 6 | pub struct Config { [INFO] [stdout] | ------ fields in this struct [INFO] [stdout] ... [INFO] [stdout] 11 | pub jwt_expiration: u64, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 12 | pub issuer_did: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 13 | pub issuer_private_key: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 14 | pub jwt_secret: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Config` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `client` is never read [INFO] [stdout] --> src/db.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 14 | pub struct Database { [INFO] [stdout] | -------- field in this struct [INFO] [stdout] 15 | client: Client, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Database` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `update_user`, `find_credential_requests_by_user`, `update_credential_request_status`, `find_short_url_qr_codes_by_issuer_verifier`, and `delete_short_url_qr_code` are never used [INFO] [stdout] --> src/db.rs:50:18 [INFO] [stdout] | [INFO] [stdout] 19 | impl Database { [INFO] [stdout] | ------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 50 | pub async fn update_user(&self, user: &User) -> Result<(), AppError> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 111 | pub async fn find_credential_requests_by_user(&self, user_did: &str) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 131 | pub async fn update_credential_request_status(&self, id: &str, status: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 290 | pub async fn find_short_url_qr_codes_by_issuer_verifier(&self, did: &str) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 300 | pub async fn delete_short_url_qr_code(&self, short_id: &str, did: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/blockchain.rs:55:12 [INFO] [stdout] | [INFO] [stdout] 38 | impl EthereumClient { [INFO] [stdout] | ------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 55 | pub fn with_wallet(mut self, private_key: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 69 | pub fn with_registry_address(mut self, address: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 80 | pub async fn deploy_registry(&mut self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 151 | pub async fn revoke_credential(&self, did: &str, credential_hash: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 175 | pub async fn is_credential_registered(&self, did: &str, credential_hash: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 225 | pub async fn get_schema_hash(&self, schema_id: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 238 | pub async fn send_ether(&self, to: &str, amount: f64) -> Result { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 262 | pub async fn get_balance(&self, address: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 279 | pub async fn get_block_number(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 289 | pub async fn wait_for_transaction(&self, tx_hash: H256) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/ipfs.rs:44:18 [INFO] [stdout] | [INFO] [stdout] 11 | impl IpfsClient { [INFO] [stdout] | --------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 44 | pub async fn upload_json(&self, data: &T) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 51 | pub async fn get(&self, cid: &str) -> Result, AppError> { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 80 | pub async fn get_json(&self, cid: &str) -> Result { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 89 | pub async fn exists(&self, cid: &str) -> Result { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 121 | pub async fn pin(&self, cid: &str) -> Result<(), AppError> { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 147 | pub async fn unpin(&self, cid: &str) -> Result<(), AppError> { [INFO] [stdout] | ^^^^^ [INFO] [stdout] ... [INFO] [stdout] 183 | pub async fn get_encrypted(&self, cid: &str, encryption_key: &[u8]) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 207 | pub async fn get_credential_data( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/models.rs:106:12 [INFO] [stdout] | [INFO] [stdout] 105 | impl CredentialRequest { [INFO] [stdout] | ---------------------- associated function in this implementation [INFO] [stdout] 106 | pub fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `to_qr_data` is never used [INFO] [stdout] --> src/models.rs:231:12 [INFO] [stdout] | [INFO] [stdout] 208 | impl PresentationRequest { [INFO] [stdout] | ------------------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 231 | pub fn to_qr_data(&self) -> String { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new` and `to_qr_data` are never used [INFO] [stdout] --> src/models.rs:282:12 [INFO] [stdout] | [INFO] [stdout] 281 | impl CredentialOffer { [INFO] [stdout] | -------------------- associated items in this implementation [INFO] [stdout] 282 | pub fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 302 | pub fn to_qr_data(&self) -> String { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `QrCodeData` is never constructed [INFO] [stdout] --> src/models.rs:309:12 [INFO] [stdout] | [INFO] [stdout] 309 | pub struct QrCodeData { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new` and `is_expired` are never used [INFO] [stdout] --> src/models.rs:318:12 [INFO] [stdout] | [INFO] [stdout] 317 | impl QrCodeData { [INFO] [stdout] | --------------- associated items in this implementation [INFO] [stdout] 318 | pub fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 332 | pub fn is_expired(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ApiResponse` is never constructed [INFO] [stdout] --> src/models.rs:500:12 [INFO] [stdout] | [INFO] [stdout] 500 | pub struct ApiResponse { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated functions `success` and `error` are never used [INFO] [stdout] --> src/models.rs:507:12 [INFO] [stdout] | [INFO] [stdout] 506 | impl ApiResponse { [INFO] [stdout] | ---------------------- associated functions in this implementation [INFO] [stdout] 507 | pub fn success(data: T) -> Self { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 515 | pub fn error(error: String) -> Self { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `user_service` is never used [INFO] [stdout] --> src/services/mod.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 35 | impl AppState { [INFO] [stdout] | ------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 51 | pub fn user_service(&self) -> UserService { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `verify_token`, `get_user_from_token`, and `generate_did_key_pair` are never used [INFO] [stdout] --> src/services/auth.rs:178:12 [INFO] [stdout] | [INFO] [stdout] 74 | impl AuthService { [INFO] [stdout] | ---------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 178 | pub fn verify_token(&self, token: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 186 | pub async fn get_user_from_token(&self, token: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 197 | pub fn generate_did_key_pair(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `credential_id` and `reason` are never read [INFO] [stdout] --> src/services/credential.rs:40:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub struct RevokeCredentialRequest { [INFO] [stdout] | ----------------------- fields in this struct [INFO] [stdout] 40 | pub credential_id: String, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 41 | pub reason: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `RevokeCredentialRequest` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `revoke_credential_with_key` and `create_predicate_proof` are never used [INFO] [stdout] --> src/services/credential.rs:322:18 [INFO] [stdout] | [INFO] [stdout] 65 | impl CredentialService { [INFO] [stdout] | ---------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 322 | pub async fn revoke_credential_with_key( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 434 | pub async fn create_predicate_proof( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `reason` is never read [INFO] [stdout] --> src/services/issuer.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 44 | pub struct ProcessCredentialRequestRequest { [INFO] [stdout] | ------------------------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 47 | pub reason: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ProcessCredentialRequestRequest` 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 `CreateCredentialOfferRequest` is never constructed [INFO] [stdout] --> src/services/issuer.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 51 | pub struct CreateCredentialOfferRequest { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CredentialRequestResponse` is never constructed [INFO] [stdout] --> src/services/issuer.rs:60:12 [INFO] [stdout] | [INFO] [stdout] 60 | pub struct CredentialRequestResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CredentialOfferResponse` is never constructed [INFO] [stdout] --> src/services/issuer.rs:66:12 [INFO] [stdout] | [INFO] [stdout] 66 | pub struct CredentialOfferResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `get_credential_requests_for_user`, `create_credential_offer`, `count_pending_requests`, and `get_recent_requests` are never used [INFO] [stdout] --> src/services/issuer.rs:326:18 [INFO] [stdout] | [INFO] [stdout] 71 | impl IssuerService { [INFO] [stdout] | ------------------ methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 326 | pub async fn get_credential_requests_for_user( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 467 | pub async fn create_credential_offer( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 520 | pub async fn count_pending_requests(&self, issuer_did: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 539 | pub async fn get_recent_requests( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ValidateCredentialRequest` is never constructed [INFO] [stdout] --> src/services/schema.rs:44:12 [INFO] [stdout] | [INFO] [stdout] 44 | pub struct ValidateCredentialRequest { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ValidationResult` is never constructed [INFO] [stdout] --> src/services/schema.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 51 | pub struct ValidationResult { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `validate_credential`, `search_schemas`, and `verify_schema_on_blockchain` are never used [INFO] [stdout] --> src/services/schema.rs:139:18 [INFO] [stdout] | [INFO] [stdout] 56 | impl SchemaService { [INFO] [stdout] | ------------------ methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 139 | pub async fn validate_credential( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 325 | pub async fn search_schemas(&self, query: &str) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 341 | pub async fn verify_schema_on_blockchain(&self, schema_id: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `UserService` is never constructed [INFO] [stdout] --> src/services/user.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct UserService { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `UpdateProfileRequest` is never constructed [INFO] [stdout] --> src/services/user.rs:15:12 [INFO] [stdout] | [INFO] [stdout] 15 | pub struct UpdateProfileRequest { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `UserProfileResponse` is never constructed [INFO] [stdout] --> src/services/user.rs:22:12 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct UserProfileResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/services/user.rs:28:12 [INFO] [stdout] | [INFO] [stdout] 26 | impl UserService { [INFO] [stdout] | ---------------- associated items in this implementation [INFO] [stdout] 27 | /// Create a new user service [INFO] [stdout] 28 | pub fn new(db: Arc) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 33 | pub async fn get_user_by_did(&self, did: &str) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 38 | pub async fn update_profile(&self, did: &str, request: UpdateProfileRequest) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 62 | pub async fn create_user(&self, user: &User) -> Result<(), AppError> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 82 | pub async fn get_all_users(&self) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 89 | pub async fn delete_user(&self, did: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 102 | pub async fn search_users(&self, query: &str) -> Result, AppError> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 117 | pub async fn user_exists(&self, did: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 123 | pub async fn count_users(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `create_range_proof` is never used [INFO] [stdout] --> src/utils/zk_proofs.rs:32:8 [INFO] [stdout] | [INFO] [stdout] 32 | pub fn create_range_proof( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `create_predicate_proof` is never used [INFO] [stdout] --> src/utils/zk_proofs.rs:89:8 [INFO] [stdout] | [INFO] [stdout] 89 | pub fn create_predicate_proof( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `verify_selective_disclosure` is never used [INFO] [stdout] --> src/utils/zk_proofs.rs:262:8 [INFO] [stdout] | [INFO] [stdout] 262 | pub fn verify_selective_disclosure( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 12.13s [INFO] running `Command { std: "docker" "inspect" "8e2bc042f70db56458ec2cfc7e96b8a8f62f84269b5997f5e05bf56370d522fa", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8e2bc042f70db56458ec2cfc7e96b8a8f62f84269b5997f5e05bf56370d522fa", kill_on_drop: false }` [INFO] [stdout] 8e2bc042f70db56458ec2cfc7e96b8a8f62f84269b5997f5e05bf56370d522fa [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 44e5e18d2be84d0f9147a4bc256bb59c6cc2c6c2ddbf9c9c42622b01d28c61c5 [INFO] running `Command { std: "docker" "start" "-a" "44e5e18d2be84d0f9147a4bc256bb59c6cc2c6c2ddbf9c9c42622b01d28c61c5", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `generic_array::ArrayLength` [INFO] [stderr] --> src/blockchain.rs:12:5 [INFO] [stderr] | [INFO] [stderr] 12 | use generic_array::ArrayLength; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `Duration` [INFO] [stderr] --> src/services/credential.rs:7:24 [INFO] [stderr] | [INFO] [stderr] 7 | use chrono::{DateTime, Duration, Utc}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `uuid::Uuid` [INFO] [stderr] --> src/services/credential.rs:12:5 [INFO] [stderr] | [INFO] [stderr] 12 | use uuid::Uuid; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Credential` [INFO] [stderr] --> src/services/presentation.rs:3:21 [INFO] [stderr] | [INFO] [stderr] 3 | use crate::models::{Credential, CredentialRequirement, Presentation, PresentationRequest, PresentationStatus}; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `crypto` and `did` [INFO] [stderr] --> src/services/presentation.rs:5:20 [INFO] [stderr] | [INFO] [stderr] 5 | use crate::utils::{crypto, did, jwt, qr, zk_proofs}; [INFO] [stderr] | ^^^^^^ ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Duration` [INFO] [stderr] --> src/services/presentation.rs:6:24 [INFO] [stderr] | [INFO] [stderr] 6 | use chrono::{DateTime, Duration, Utc}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `json` [INFO] [stderr] --> src/utils/qr.rs:4:18 [INFO] [stderr] | [INFO] [stderr] 4 | use serde_json::{json, Value}; [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated function `base64::decode`: Use Engine::decode [INFO] [stderr] --> src/services/auth.rs:27:22 [INFO] [stderr] | [INFO] [stderr] 27 | &base64::decode(signature) [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated function `base64::decode`: Use Engine::decode [INFO] [stderr] --> src/services/auth.rs:131:22 [INFO] [stderr] | [INFO] [stderr] 131 | &base64::decode(&request.signature) [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated function `base64::encode`: Use Engine::encode [INFO] [stderr] --> src/services/wallet.rs:405:37 [INFO] [stderr] | [INFO] [stderr] 405 | let backup_base64 = base64::encode(&encrypted_backup); [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated function `base64::decode`: Use Engine::decode [INFO] [stderr] --> src/services/wallet.rs:413:40 [INFO] [stderr] | [INFO] [stderr] 413 | let encrypted_backup = base64::decode(backup_data) [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/blockchain.rs:105:23 [INFO] [stderr] | [INFO] [stderr] 105 | .map_err(|e| AppError::BlockchainError("Failed to deploy contract".to_string()))? [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/blockchain.rs:108:23 [INFO] [stderr] | [INFO] [stderr] 108 | .map_err(|e| AppError::BlockchainError("Failed to send deployment transaction:".to_string()))?; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/blockchain.rs:253:23 [INFO] [stderr] | [INFO] [stderr] 253 | .map_err(|e| AppError::BlockchainError("Failed to send transaction".to_string()))? [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/blockchain.rs:270:23 [INFO] [stderr] | [INFO] [stderr] 270 | .map_err(|e| AppError::BlockchainError("Failed to get balance".to_string()))?; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/blockchain.rs:283:23 [INFO] [stderr] | [INFO] [stderr] 283 | .map_err(|e| AppError::BlockchainError("Failed to get block number".to_string()))?; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `e` [INFO] [stderr] --> src/blockchain.rs:293:23 [INFO] [stderr] | [INFO] [stderr] 293 | .map_err(|e| AppError::BlockchainError("Failed to get transaction receipt".to_string()))?; [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `issuer_private_key` [INFO] [stderr] --> src/services/credential.rs:299:13 [INFO] [stderr] | [INFO] [stderr] 299 | let issuer_private_key = "dummy_private_key"; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_issuer_private_key` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `request` [INFO] [stderr] --> src/services/credential.rs:302:13 [INFO] [stderr] | [INFO] [stderr] 302 | let request = RevokeCredentialRequest { [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_request` [INFO] [stderr] [INFO] [stderr] warning: struct `ChallengeResponse` is never constructed [INFO] [stderr] --> src/api/auth.rs:69:12 [INFO] [stderr] | [INFO] [stderr] 69 | pub struct ChallengeResponse { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: fields `jwt_expiration`, `issuer_did`, `issuer_private_key`, and `jwt_secret` are never read [INFO] [stderr] --> src/config.rs:11:9 [INFO] [stderr] | [INFO] [stderr] 6 | pub struct Config { [INFO] [stderr] | ------ fields in this struct [INFO] [stderr] ... [INFO] [stderr] 11 | pub jwt_expiration: u64, [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] 12 | pub issuer_did: String, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] 13 | pub issuer_private_key: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 14 | pub jwt_secret: String, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `Config` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: field `client` is never read [INFO] [stderr] --> src/db.rs:15:5 [INFO] [stderr] | [INFO] [stderr] 14 | pub struct Database { [INFO] [stderr] | -------- field in this struct [INFO] [stderr] 15 | client: Client, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `Database` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: methods `update_user`, `find_credential_requests_by_user`, `update_credential_request_status`, `find_short_url_qr_codes_by_issuer_verifier`, and `delete_short_url_qr_code` are never used [INFO] [stderr] --> src/db.rs:50:18 [INFO] [stderr] | [INFO] [stderr] 19 | impl Database { [INFO] [stderr] | ------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 50 | pub async fn update_user(&self, user: &User) -> Result<(), AppError> { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 111 | pub async fn find_credential_requests_by_user(&self, user_did: &str) -> Result, AppError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 131 | pub async fn update_credential_request_status(&self, id: &str, status: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 290 | pub async fn find_short_url_qr_codes_by_issuer_verifier(&self, did: &str) -> Result, AppError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 300 | pub async fn delete_short_url_qr_code(&self, short_id: &str, did: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: multiple methods are never used [INFO] [stderr] --> src/blockchain.rs:55:12 [INFO] [stderr] | [INFO] [stderr] 38 | impl EthereumClient { [INFO] [stderr] | ------------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 55 | pub fn with_wallet(mut self, private_key: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 69 | pub fn with_registry_address(mut self, address: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 80 | pub async fn deploy_registry(&mut self) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 151 | pub async fn revoke_credential(&self, did: &str, credential_hash: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 175 | pub async fn is_credential_registered(&self, did: &str, credential_hash: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 225 | pub async fn get_schema_hash(&self, schema_id: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 238 | pub async fn send_ether(&self, to: &str, amount: f64) -> Result { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 262 | pub async fn get_balance(&self, address: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 279 | pub async fn get_block_number(&self) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 289 | pub async fn wait_for_transaction(&self, tx_hash: H256) -> Result, AppError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: multiple methods are never used [INFO] [stderr] --> src/ipfs.rs:44:18 [INFO] [stderr] | [INFO] [stderr] 11 | impl IpfsClient { [INFO] [stderr] | --------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 44 | pub async fn upload_json(&self, data: &T) -> Result { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 51 | pub async fn get(&self, cid: &str) -> Result, AppError> { [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 80 | pub async fn get_json(&self, cid: &str) -> Result { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 89 | pub async fn exists(&self, cid: &str) -> Result { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 121 | pub async fn pin(&self, cid: &str) -> Result<(), AppError> { [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 147 | pub async fn unpin(&self, cid: &str) -> Result<(), AppError> { [INFO] [stderr] | ^^^^^ [INFO] [stderr] ... [INFO] [stderr] 183 | pub async fn get_encrypted(&self, cid: &str, encryption_key: &[u8]) -> Result, AppError> { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 207 | pub async fn get_credential_data( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `new` is never used [INFO] [stderr] --> src/models.rs:106:12 [INFO] [stderr] | [INFO] [stderr] 105 | impl CredentialRequest { [INFO] [stderr] | ---------------------- associated function in this implementation [INFO] [stderr] 106 | pub fn new( [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: method `to_qr_data` is never used [INFO] [stderr] --> src/models.rs:231:12 [INFO] [stderr] | [INFO] [stderr] 208 | impl PresentationRequest { [INFO] [stderr] | ------------------------ method in this implementation [INFO] [stderr] ... [INFO] [stderr] 231 | pub fn to_qr_data(&self) -> String { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated items `new` and `to_qr_data` are never used [INFO] [stderr] --> src/models.rs:282:12 [INFO] [stderr] | [INFO] [stderr] 281 | impl CredentialOffer { [INFO] [stderr] | -------------------- associated items in this implementation [INFO] [stderr] 282 | pub fn new( [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 302 | pub fn to_qr_data(&self) -> String { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `QrCodeData` is never constructed [INFO] [stderr] --> src/models.rs:309:12 [INFO] [stderr] | [INFO] [stderr] 309 | pub struct QrCodeData { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated items `new` and `is_expired` are never used [INFO] [stderr] --> src/models.rs:318:12 [INFO] [stderr] | [INFO] [stderr] 317 | impl QrCodeData { [INFO] [stderr] | --------------- associated items in this implementation [INFO] [stderr] 318 | pub fn new( [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 332 | pub fn is_expired(&self) -> bool { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `ApiResponse` is never constructed [INFO] [stderr] --> src/models.rs:500:12 [INFO] [stderr] | [INFO] [stderr] 500 | pub struct ApiResponse { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated functions `success` and `error` are never used [INFO] [stderr] --> src/models.rs:507:12 [INFO] [stderr] | [INFO] [stderr] 506 | impl ApiResponse { [INFO] [stderr] | ---------------------- associated functions in this implementation [INFO] [stderr] 507 | pub fn success(data: T) -> Self { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 515 | pub fn error(error: String) -> Self { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method `user_service` is never used [INFO] [stderr] --> src/services/mod.rs:51:12 [INFO] [stderr] | [INFO] [stderr] 35 | impl AppState { [INFO] [stderr] | ------------- method in this implementation [INFO] [stderr] ... [INFO] [stderr] 51 | pub fn user_service(&self) -> UserService { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `verify_token`, `get_user_from_token`, and `generate_did_key_pair` are never used [INFO] [stderr] --> src/services/auth.rs:178:12 [INFO] [stderr] | [INFO] [stderr] 74 | impl AuthService { [INFO] [stderr] | ---------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 178 | pub fn verify_token(&self, token: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 186 | pub async fn get_user_from_token(&self, token: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 197 | pub fn generate_did_key_pair(&self) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `credential_id` and `reason` are never read [INFO] [stderr] --> src/services/credential.rs:40:9 [INFO] [stderr] | [INFO] [stderr] 39 | pub struct RevokeCredentialRequest { [INFO] [stderr] | ----------------------- fields in this struct [INFO] [stderr] 40 | pub credential_id: String, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] 41 | pub reason: Option, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `RevokeCredentialRequest` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: methods `revoke_credential_with_key` and `create_predicate_proof` are never used [INFO] [stderr] --> src/services/credential.rs:322:18 [INFO] [stderr] | [INFO] [stderr] 65 | impl CredentialService { [INFO] [stderr] | ---------------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 322 | pub async fn revoke_credential_with_key( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 434 | pub async fn create_predicate_proof( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `reason` is never read [INFO] [stderr] --> src/services/issuer.rs:47:9 [INFO] [stderr] | [INFO] [stderr] 44 | pub struct ProcessCredentialRequestRequest { [INFO] [stderr] | ------------------------------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 47 | pub reason: Option, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `ProcessCredentialRequestRequest` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: struct `CreateCredentialOfferRequest` is never constructed [INFO] [stderr] --> src/services/issuer.rs:51:12 [INFO] [stderr] | [INFO] [stderr] 51 | pub struct CreateCredentialOfferRequest { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `CredentialRequestResponse` is never constructed [INFO] [stderr] --> src/services/issuer.rs:60:12 [INFO] [stderr] | [INFO] [stderr] 60 | pub struct CredentialRequestResponse { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `CredentialOfferResponse` is never constructed [INFO] [stderr] --> src/services/issuer.rs:66:12 [INFO] [stderr] | [INFO] [stderr] 66 | pub struct CredentialOfferResponse { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `get_credential_requests_for_user`, `create_credential_offer`, `count_pending_requests`, and `get_recent_requests` are never used [INFO] [stderr] --> src/services/issuer.rs:326:18 [INFO] [stderr] | [INFO] [stderr] 71 | impl IssuerService { [INFO] [stderr] | ------------------ methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 326 | pub async fn get_credential_requests_for_user( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 467 | pub async fn create_credential_offer( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 520 | pub async fn count_pending_requests(&self, issuer_did: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 539 | pub async fn get_recent_requests( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `ValidateCredentialRequest` is never constructed [INFO] [stderr] --> src/services/schema.rs:44:12 [INFO] [stderr] | [INFO] [stderr] 44 | pub struct ValidateCredentialRequest { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `ValidationResult` is never constructed [INFO] [stderr] --> src/services/schema.rs:51:12 [INFO] [stderr] | [INFO] [stderr] 51 | pub struct ValidationResult { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `validate_credential`, `search_schemas`, and `verify_schema_on_blockchain` are never used [INFO] [stderr] --> src/services/schema.rs:139:18 [INFO] [stderr] | [INFO] [stderr] 56 | impl SchemaService { [INFO] [stderr] | ------------------ methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 139 | pub async fn validate_credential( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 325 | pub async fn search_schemas(&self, query: &str) -> Result, AppError> { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 341 | pub async fn verify_schema_on_blockchain(&self, schema_id: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `UserService` is never constructed [INFO] [stderr] --> src/services/user.rs:9:12 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct UserService { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `UpdateProfileRequest` is never constructed [INFO] [stderr] --> src/services/user.rs:15:12 [INFO] [stderr] | [INFO] [stderr] 15 | pub struct UpdateProfileRequest { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `UserProfileResponse` is never constructed [INFO] [stderr] --> src/services/user.rs:22:12 [INFO] [stderr] | [INFO] [stderr] 22 | pub struct UserProfileResponse { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: multiple associated items are never used [INFO] [stderr] --> src/services/user.rs:28:12 [INFO] [stderr] | [INFO] [stderr] 26 | impl UserService { [INFO] [stderr] | ---------------- associated items in this implementation [INFO] [stderr] 27 | /// Create a new user service [INFO] [stderr] 28 | pub fn new(db: Arc) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 33 | pub async fn get_user_by_did(&self, did: &str) -> Result, AppError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 38 | pub async fn update_profile(&self, did: &str, request: UpdateProfileRequest) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 62 | pub async fn create_user(&self, user: &User) -> Result<(), AppError> { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 82 | pub async fn get_all_users(&self) -> Result, AppError> { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 89 | pub async fn delete_user(&self, did: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 102 | pub async fn search_users(&self, query: &str) -> Result, AppError> { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 117 | pub async fn user_exists(&self, did: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 123 | pub async fn count_users(&self) -> Result { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `create_range_proof` is never used [INFO] [stderr] --> src/utils/zk_proofs.rs:32:8 [INFO] [stderr] | [INFO] [stderr] 32 | pub fn create_range_proof( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `create_predicate_proof` is never used [INFO] [stderr] --> src/utils/zk_proofs.rs:89:8 [INFO] [stderr] | [INFO] [stderr] 89 | pub fn create_predicate_proof( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `verify_selective_disclosure` is never used [INFO] [stderr] --> src/utils/zk_proofs.rs:262:8 [INFO] [stderr] | [INFO] [stderr] 262 | pub fn verify_selective_disclosure( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `fortro-engine` (bin "fortro-engine" test) generated 51 warnings (run `cargo fix --bin "fortro-engine" --tests` to apply 7 suggestions) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 1.01s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/fortro_engine-885409c138effd7d) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "44e5e18d2be84d0f9147a4bc256bb59c6cc2c6c2ddbf9c9c42622b01d28c61c5", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "44e5e18d2be84d0f9147a4bc256bb59c6cc2c6c2ddbf9c9c42622b01d28c61c5", kill_on_drop: false }` [INFO] [stdout] 44e5e18d2be84d0f9147a4bc256bb59c6cc2c6c2ddbf9c9c42622b01d28c61c5