[INFO] cloning repository https://github.com/meghsamedr/SolanaArbitrageBot
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/meghsamedr/SolanaArbitrageBot" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmeghsamedr%2FSolanaArbitrageBot", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmeghsamedr%2FSolanaArbitrageBot'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] e313590be90f3ac4abe2390fda437ddc1e8ddee1
[INFO] checking meghsamedr/SolanaArbitrageBot against master#c9af9c1dc85a55e309345030ff9cb7ea247953fa for pr-151146-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmeghsamedr%2FSolanaArbitrageBot" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/meghsamedr/SolanaArbitrageBot
[INFO] finished tweaking git repo https://github.com/meghsamedr/SolanaArbitrageBot
[INFO] tweaked toml for git repo https://github.com/meghsamedr/SolanaArbitrageBot written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/meghsamedr/SolanaArbitrageBot on toolchain c9af9c1dc85a55e309345030ff9cb7ea247953fa
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c9af9c1dc85a55e309345030ff9cb7ea247953fa" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/meghsamedr/SolanaArbitrageBot 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" "+c9af9c1dc85a55e309345030ff9cb7ea247953fa" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded solana-hash v4.0.1
[INFO] [stderr]   Downloaded tokio-test v0.4.4
[INFO] [stderr]   Downloaded solana-account-info v3.1.0
[INFO] [stderr]   Downloaded solana-cpi v3.1.0
[INFO] [stderr]   Downloaded solana-transaction-status-client-types v3.1.4
[INFO] [stderr]   Downloaded solana-address v2.0.0
[INFO] [stderr]   Downloaded serde_bytes v0.11.19
[INFO] [stderr]   Downloaded solana-instruction v3.1.0
[INFO] [stderr]   Downloaded unit-prefix v0.5.2
[INFO] [stderr]   Downloaded bytecheck v0.6.12
[INFO] [stderr]   Downloaded ptr_meta v0.1.4
[INFO] [stderr]   Downloaded ptr_meta_derive v0.1.4
[INFO] [stderr]   Downloaded solana-short-vec v3.1.0
[INFO] [stderr]   Downloaded solana-keccak-hasher v3.1.0
[INFO] [stderr]   Downloaded solana-epoch-rewards-hasher v3.1.0
[INFO] [stderr]   Downloaded mio v1.1.0
[INFO] [stderr]   Downloaded bytecheck_derive v0.6.12
[INFO] [stderr]   Downloaded compression-codecs v0.4.33
[INFO] [stderr]   Downloaded solana-rpc-client-types v3.1.4
[INFO] [stderr]   Downloaded password-hash v0.5.0
[INFO] [stderr]   Downloaded solana-vote-interface v4.0.4
[INFO] [stderr]   Downloaded jiff-static v0.2.16
[INFO] [stderr]   Downloaded solana-rpc-client v3.1.4
[INFO] [stderr]   Downloaded rkyv v0.7.45
[INFO] [stderr]   Downloaded spl-token-2022-interface v2.1.0
[INFO] [stderr]   Downloaded tower-http v0.6.7
[INFO] [stderr]   Downloaded rust_decimal v1.39.0
[INFO] [stderr]   Downloaded reqwest v0.12.24
[INFO] [stderr]   Downloaded solana-sbpf v0.13.1
[INFO] [stderr]   Downloaded async-compression v0.4.34
[INFO] [stderr]   Downloaded borsh v1.6.0
[INFO] [stderr]   Downloaded tracing v0.1.43
[INFO] [stderr]   Downloaded indicatif v0.18.3
[INFO] [stderr]   Downloaded solana-transaction-status v3.1.4
[INFO] [stderr]   Downloaded tracing-core v0.1.35
[INFO] [stderr]   Downloaded solana-instruction-error v2.1.0
[INFO] [stderr]   Downloaded console v0.16.1
[INFO] [stderr]   Downloaded solana-stake-interface v2.0.2
[INFO] [stderr]   Downloaded solana-rpc-client-api v3.1.4
[INFO] [stderr]   Downloaded agave-feature-set v3.1.4
[INFO] [stderr]   Downloaded solana-account-decoder v3.1.4
[INFO] [stderr]   Downloaded solana-transaction v3.0.2
[INFO] [stderr]   Downloaded solana-sysvar v3.1.1
[INFO] [stderr]   Downloaded solana-transaction-context v3.1.4
[INFO] [stderr]   Downloaded curve25519-dalek v3.2.0
[INFO] [stderr]   Downloaded spl-token-confidential-transfer-proof-extraction v0.5.1
[INFO] [stderr]   Downloaded spl-token-confidential-transfer-proof-generation v0.5.1
[INFO] [stderr]   Downloaded solana-pubkey v4.0.0
[INFO] [stderr]   Downloaded borsh-derive v1.6.0
[INFO] [stderr]   Downloaded five8 v1.0.0
[INFO] [stderr]   Downloaded rend v0.4.2
[INFO] [stderr]   Downloaded rkyv_derive v0.7.45
[INFO] [stderr]   Downloaded seahash v4.1.0
[INFO] [stderr]   Downloaded solana-secp256k1-recover v3.1.0
[INFO] [stderr]   Downloaded agave-reserved-account-keys v3.1.4
[INFO] [stderr]   Downloaded solana-program-entrypoint v3.1.1
[INFO] [stderr]   Downloaded solana-svm-feature-set v3.1.4
[INFO] [stderr]   Downloaded jiff v0.2.16
[INFO] [stderr]   Downloaded solana-curve25519 v3.1.4
[INFO] [stderr]   Downloaded five8_const v1.0.0
[INFO] [stderr]   Downloaded solana-serialize-utils v3.1.0
[INFO] [stderr]   Downloaded solana-define-syscall v4.0.1
[INFO] [stderr]   Downloaded solana-epoch-info v3.1.0
[INFO] [stderr]   Downloaded solana-blake3-hasher v3.1.0
[INFO] [stderr]   Downloaded solana-account-decoder-client-types v3.1.4
[INFO] [stderr]   Downloaded solana-commitment-config v3.1.0
[INFO] [stderr]   Downloaded solana-account v3.2.0
[INFO] [stderr]   Downloaded solana-hash v3.1.0
[INFO] [stderr]   Downloaded solana-program-memory v3.1.0
[INFO] [stderr]   Downloaded solana-version v3.1.4
[INFO] [stderr]   Downloaded solana-address v1.1.0
[INFO] [stderr]   Downloaded solana-sdk-ids v3.1.0
[INFO] [stderr]   Downloaded solana-keypair v3.1.0
[INFO] [stderr]   Downloaded solana-sysvar-id v3.1.0
[INFO] [stderr]   Downloaded solana-sha256-hasher v3.1.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+c9af9c1dc85a55e309345030ff9cb7ea247953fa" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] f871251141c91778c49f96b80022127f2eaa4720a1c483305463a00118b2fba3
[INFO] running `Command { std: "docker" "start" "-a" "f871251141c91778c49f96b80022127f2eaa4720a1c483305463a00118b2fba3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "f871251141c91778c49f96b80022127f2eaa4720a1c483305463a00118b2fba3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f871251141c91778c49f96b80022127f2eaa4720a1c483305463a00118b2fba3", kill_on_drop: false }`
[INFO] [stdout] f871251141c91778c49f96b80022127f2eaa4720a1c483305463a00118b2fba3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+c9af9c1dc85a55e309345030ff9cb7ea247953fa" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 807db44a352fa9d5d668e0e3e06e2b82c4c2f84f971372891f9d0d3a4283933d
[INFO] running `Command { std: "docker" "start" "-a" "807db44a352fa9d5d668e0e3e06e2b82c4c2f84f971372891f9d0d3a4283933d", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.178
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling zeroize_derive v1.4.2
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling toml_datetime v0.7.3
[INFO] [stderr]    Compiling zerocopy v0.8.31
[INFO] [stderr]    Compiling borsh v1.6.0
[INFO] [stderr]     Checking five8_core v0.1.2
[INFO] [stderr]    Compiling bytemuck_derive v1.10.2
[INFO] [stderr]    Compiling semver v1.0.27
[INFO] [stderr]    Compiling indexmap v2.12.1
[INFO] [stderr]     Checking zeroize v1.8.2
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]     Checking generic-array v0.14.7
[INFO] [stderr]     Checking five8 v1.0.0
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]    Compiling curve25519-dalek v4.1.3
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling curve25519-dalek-derive v0.1.1
[INFO] [stderr]     Checking five8_const v1.0.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking memchr v2.7.6
[INFO] [stderr]     Checking crypto-common v0.1.7
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking bytemuck v1.24.0
[INFO] [stderr]     Checking sha2 v0.10.9
[INFO] [stderr]     Checking signature v2.2.0
[INFO] [stderr]    Compiling solana-sdk-macro v3.0.0
[INFO] [stderr]     Checking ed25519 v2.2.3
[INFO] [stderr]     Checking solana-program-memory v3.1.0
[INFO] [stderr]     Checking hmac v0.12.1
[INFO] [stderr]     Checking five8 v0.2.1
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking socket2 v0.6.1
[INFO] [stderr]     Checking mio v1.1.0
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]     Checking signal-hook-registry v1.4.7
[INFO] [stderr]    Compiling toml_parser v1.0.4
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking bitflags v2.10.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]    Compiling cc v1.2.48
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]     Checking sha3 v0.10.8
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling toml_edit v0.23.7
[INFO] [stderr]     Checking qstring v0.7.2
[INFO] [stderr]     Checking tokio v1.48.0
[INFO] [stderr]     Checking inout v0.1.4
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking serde-big-array v0.5.1
[INFO] [stderr]    Compiling proc-macro-crate v3.4.0
[INFO] [stderr]     Checking solana-fee-calculator v3.0.0
[INFO] [stderr]     Checking bv v0.11.1
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]     Checking slab v0.4.11
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]     Checking solana-define-syscall v4.0.1
[INFO] [stderr]    Compiling borsh-derive v1.6.0
[INFO] [stderr]     Checking cipher v0.4.4
[INFO] [stderr]     Checking solana-derivation-path v3.0.0
[INFO] [stderr]     Checking pbkdf2 v0.11.0
[INFO] [stderr]     Checking solana-seed-derivable v3.0.0
[INFO] [stderr]     Checking solana-seed-phrase v3.0.0
[INFO] [stderr]    Compiling blake3 v1.8.2
[INFO] [stderr]    Compiling num_enum_derive v0.7.5
[INFO] [stderr]     Checking solana-short-vec v3.1.0
[INFO] [stderr]     Checking serde_bytes v0.11.19
[INFO] [stderr]     Checking universal-hash v0.5.1
[INFO] [stderr]     Checking ed25519-dalek v2.2.0
[INFO] [stderr]     Checking solana-signature v3.1.0
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]     Checking arrayvec v0.7.6
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]     Checking polyval v0.6.2
[INFO] [stderr]     Checking num_enum v0.7.5
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]    Compiling zstd-sys v2.0.16+zstd.1.5.7
[INFO] [stderr]     Checking ctr v0.9.2
[INFO] [stderr]     Checking aes v0.8.4
[INFO] [stderr]     Checking http v1.4.0
[INFO] [stderr]     Checking tracing-core v0.1.35
[INFO] [stderr]     Checking aead v0.5.2
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]     Checking aes-gcm-siv v0.11.1
[INFO] [stderr]     Checking merlin v3.0.0
[INFO] [stderr]     Checking tracing v0.1.43
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]     Checking aho-corasick v1.1.4
[INFO] [stderr]    Compiling icu_properties_data v2.1.1
[INFO] [stderr]    Compiling zstd-safe v7.2.4
[INFO] [stderr]    Compiling spl-discriminator-syn v0.2.1
[INFO] [stderr]     Checking solana-serde-varint v3.0.0
[INFO] [stderr]     Checking der v0.7.10
[INFO] [stderr]     Checking solana-hash v4.0.1
[INFO] [stderr]     Checking solana-program-error v3.0.0
[INFO] [stderr]     Checking solana-sha256-hasher v3.1.0
[INFO] [stderr]     Checking solana-hash v3.1.0
[INFO] [stderr]     Checking solana-address v2.0.0
[INFO] [stderr]     Checking solana-instruction-error v2.1.0
[INFO] [stderr]     Checking solana-transaction-error v3.0.0
[INFO] [stderr]     Checking solana-address v1.1.0
[INFO] [stderr]     Checking solana-pubkey v3.0.0
[INFO] [stderr]     Checking solana-sdk-ids v3.1.0
[INFO] [stderr]     Checking solana-pubkey v4.0.0
[INFO] [stderr]     Checking solana-instruction v3.1.0
[INFO] [stderr]     Checking solana-sysvar-id v3.1.0
[INFO] [stderr]     Checking solana-account-info v3.1.0
[INFO] [stderr]     Checking solana-signer v3.0.0
[INFO] [stderr]     Checking solana-epoch-schedule v3.0.0
[INFO] [stderr]     Checking solana-clock v3.0.0
[INFO] [stderr]     Checking solana-slot-hashes v3.0.0
[INFO] [stderr]     Checking solana-rent v3.0.0
[INFO] [stderr]     Checking solana-program-entrypoint v3.1.1
[INFO] [stderr]     Checking solana-slot-history v3.0.0
[INFO] [stderr]     Checking solana-last-restart-slot v3.0.0
[INFO] [stderr]     Checking solana-epoch-rewards v3.0.0
[INFO] [stderr]     Checking solana-serialize-utils v3.1.0
[INFO] [stderr]     Checking solana-zk-sdk v4.0.0
[INFO] [stderr]     Checking solana-system-interface v2.0.0
[INFO] [stderr]     Checking tokio-util v0.7.17
[INFO] [stderr]     Checking solana-instructions-sysvar v3.0.0
[INFO] [stderr]     Checking solana-sysvar v3.1.1
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]     Checking solana-message v3.0.1
[INFO] [stderr]     Checking solana-account v3.2.0
[INFO] [stderr]     Checking rustls-pki-types v1.13.1
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling crunchy v0.2.4
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]     Checking h2 v0.4.12
[INFO] [stderr]    Compiling spl-discriminator-derive v0.2.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]     Checking spl-pod v0.7.1
[INFO] [stderr]     Checking adler2 v2.0.1
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]     Checking simd-adler32 v0.3.7
[INFO] [stderr]    Compiling rustls v0.23.35
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking combine v3.8.1
[INFO] [stderr]     Checking spl-discriminator v0.5.1
[INFO] [stderr]     Checking icu_properties v2.1.1
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking rustls-webpki v0.103.8
[INFO] [stderr]     Checking hyper v1.8.1
[INFO] [stderr]     Checking brotli-decompressor v5.0.0
[INFO] [stderr]     Checking spki v0.7.3
[INFO] [stderr]     Checking solana-program-pack v3.0.0
[INFO] [stderr]     Checking solana-borsh v3.0.0
[INFO] [stderr]     Checking hash32 v0.3.1
[INFO] [stderr]     Checking ff v0.13.1
[INFO] [stderr]     Checking solana-svm-feature-set v3.1.4
[INFO] [stderr]     Checking rustc-demangle v0.1.26
[INFO] [stderr]     Checking agave-feature-set v3.1.4
[INFO] [stderr]     Checking group v0.13.0
[INFO] [stderr]     Checking brotli v8.0.2
[INFO] [stderr]     Checking sec1 v0.7.3
[INFO] [stderr]     Checking hyper-util v0.1.19
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]     Checking pkcs8 v0.10.2
[INFO] [stderr]     Checking flate2 v1.1.5
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking regex v1.12.2
[INFO] [stderr]     Checking solana-transaction v3.0.2
[INFO] [stderr]     Checking solana-address-lookup-table-interface v3.0.0
[INFO] [stderr]     Checking solana-cpi v3.1.0
[INFO] [stderr]     Checking solana-nonce v3.0.0
[INFO] [stderr]     Checking solana-sbpf v0.13.1
[INFO] [stderr]     Checking form_urlencoded v1.2.2
[INFO] [stderr]     Checking crypto-bigint v0.5.5
[INFO] [stderr]     Checking compression-core v0.4.31
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]    Compiling const-random-macro v0.1.16
[INFO] [stderr]    Compiling serde_with_macros v3.16.1
[INFO] [stderr]     Checking getrandom v0.1.16
[INFO] [stderr]     Checking spl-type-length-value v0.9.0
[INFO] [stderr]     Checking webpki-roots v1.0.4
[INFO] [stderr]     Checking spl-generic-token v2.0.1
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]     Checking solana-curve25519 v3.1.4
[INFO] [stderr]     Checking solana-commitment-config v3.1.0
[INFO] [stderr]     Checking solana-transaction-context v3.1.4
[INFO] [stderr]     Checking solana-reward-info v3.0.0
[INFO] [stderr]     Checking elliptic-curve v0.13.8
[INFO] [stderr]     Checking rfc6979 v0.4.0
[INFO] [stderr]    Compiling solana-version v3.1.4
[INFO] [stderr]     Checking iri-string v0.7.9
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking spl-token-confidential-transfer-proof-extraction v0.5.1
[INFO] [stderr]     Checking compression-codecs v0.4.33
[INFO] [stderr]     Checking spl-token-metadata-interface v0.8.0
[INFO] [stderr]     Checking ecdsa v0.16.9
[INFO] [stderr]     Checking serde_with v3.16.1
[INFO] [stderr]     Checking async-compression v0.4.34
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]     Checking url v2.5.7
[INFO] [stderr]     Checking const-random v0.1.18
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking tokio-rustls v0.26.4
[INFO] [stderr]     Checking spl-token-group-interface v0.7.1
[INFO] [stderr]     Checking spl-token-confidential-transfer-proof-generation v0.5.1
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking hyper-rustls v0.27.7
[INFO] [stderr]     Checking solana-inflation v3.0.0
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]    Compiling memoffset v0.9.1
[INFO] [stderr]    Compiling cfg_eval v0.1.2
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking spl-token-2022-interface v2.1.0
[INFO] [stderr]     Checking solana-vote-interface v4.0.4
[INFO] [stderr]     Checking tower-http v0.6.7
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking k256 v0.13.4
[INFO] [stderr]     Checking dlv-list v0.5.2
[INFO] [stderr]     Checking reqwest v0.12.24
[INFO] [stderr]     Checking solana-stake-interface v2.0.2
[INFO] [stderr]     Checking Inflector v0.11.4
[INFO] [stderr]     Checking spl-token-interface v2.0.0
[INFO] [stderr]     Checking solana-config-interface v2.0.0
[INFO] [stderr]     Checking solana-loader-v3-interface v6.1.0
[INFO] [stderr]     Checking solana-keccak-hasher v3.1.0
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]     Checking digest v0.9.0
[INFO] [stderr]     Checking toml_write v0.1.2
[INFO] [stderr]     Checking console v0.16.1
[INFO] [stderr]     Checking pest v2.8.4
[INFO] [stderr]     Checking solana-big-mod-exp v3.0.0
[INFO] [stderr]     Checking solana-example-mocks v3.0.0
[INFO] [stderr]     Checking solana-secp256k1-recover v3.1.0
[INFO] [stderr]     Checking ordered-multimap v0.7.3
[INFO] [stderr]     Checking jsonrpc-core v18.0.0
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking hashlink v0.8.4
[INFO] [stderr]     Checking reqwest-middleware v0.4.2
[INFO] [stderr]     Checking solana-stable-layout v3.0.0
[INFO] [stderr]     Checking solana-epoch-stake v3.0.0
[INFO] [stderr]     Checking solana-blake3-hasher v3.1.0
[INFO] [stderr]     Checking ed25519-dalek-bip32 v0.3.0
[INFO] [stderr]     Checking solana-epoch-info v3.1.0
[INFO] [stderr]     Checking solana-packet v3.0.0
[INFO] [stderr]     Checking block-buffer v0.9.0
[INFO] [stderr]     Checking unit-prefix v0.5.2
[INFO] [stderr]     Checking arraydeque v0.5.1
[INFO] [stderr]     Checking signature v1.6.4
[INFO] [stderr]     Checking base64ct v1.8.0
[INFO] [stderr]    Compiling heck v0.5.0
[INFO] [stderr]    Compiling rust_decimal v1.39.0
[INFO] [stderr]     Checking base64 v0.21.7
[INFO] [stderr]     Checking yaml-rust2 v0.8.1
[INFO] [stderr]     Checking password-hash v0.5.0
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]     Checking ed25519 v1.5.3
[INFO] [stderr]     Checking ron v0.8.1
[INFO] [stderr]     Checking solana-offchain-message v3.0.0
[INFO] [stderr]     Checking clap_builder v4.5.53
[INFO] [stderr]     Checking solana-epoch-rewards-hasher v3.1.0
[INFO] [stderr]     Checking solana-program v3.0.0
[INFO] [stderr]     Checking indicatif v0.18.3
[INFO] [stderr]     Checking convert_case v0.6.0
[INFO] [stderr]     Checking json5 v0.4.1
[INFO] [stderr]     Checking sha2 v0.9.9
[INFO] [stderr]     Checking solana-shred-version v3.0.0
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]     Checking solana-keypair v3.1.0
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking rust-ini v0.20.0
[INFO] [stderr]     Checking curve25519-dalek v3.2.0
[INFO] [stderr]     Checking env_filter v0.1.4
[INFO] [stderr]     Checking agave-reserved-account-keys v3.1.4
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking solana-presigner v3.0.0
[INFO] [stderr]     Checking solana-loader-v2-interface v3.0.0
[INFO] [stderr]     Checking spl-associated-token-account-interface v2.0.0
[INFO] [stderr]     Checking spl-memo-interface v2.0.0
[INFO] [stderr]     Checking solana-feature-gate-interface v3.0.0
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking solana-fee-structure v3.0.0
[INFO] [stderr]     Checking solana-serde v3.0.0
[INFO] [stderr]     Checking jiff v0.2.16
[INFO] [stderr]     Checking iana-time-zone v0.1.64
[INFO] [stderr]     Checking solana-sdk v3.0.0
[INFO] [stderr]     Checking tracing-subscriber v0.3.22
[INFO] [stderr]     Checking ed25519-dalek v1.0.1
[INFO] [stderr]     Checking chrono v0.4.42
[INFO] [stderr]     Checking clap v4.5.53
[INFO] [stderr]     Checking pbkdf2 v0.12.2
[INFO] [stderr]     Checking uuid v1.19.0
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]     Checking zstd v0.13.3
[INFO] [stderr]     Checking tokio-stream v0.1.17
[INFO] [stderr]     Checking solana-account-decoder-client-types v3.1.4
[INFO] [stderr]     Checking async-stream v0.3.6
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking tokio-test v0.4.4
[INFO] [stderr]     Checking config v0.14.1
[INFO] [stderr]     Checking solana-transaction-status-client-types v3.1.4
[INFO] [stderr]     Checking solana-account-decoder v3.1.4
[INFO] [stderr]     Checking solana-rpc-client-types v3.1.4
[INFO] [stderr]     Checking solana-transaction-status v3.1.4
[INFO] [stderr]     Checking env_logger v0.11.8
[INFO] [stderr]     Checking solana-rpc-client-api v3.1.4
[INFO] [stderr]     Checking solana-rpc-client v3.1.4
[INFO] [stderr]     Checking offchain-bot v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/config/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::time::Duration;
[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 imports: `Config`, `Environment`, and `File`
[INFO] [stdout]  --> src/config/mod.rs:4:14
[INFO] [stdout]   |
[INFO] [stdout] 4 | use config::{Config, Environment, File};
[INFO] [stdout]   |              ^^^^^^  ^^^^^^^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/models/pool.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `solana_program::pubkey::Pubkey`
[INFO] [stdout]  --> src/models/arbitrage.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use solana_program::pubkey::Pubkey;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `transaction::Transaction`
[INFO] [stdout]  --> src/models/transaction.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 |     transaction::Transaction,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: ambiguous glob re-exports
[INFO] [stdout]  --> src/models/mod.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub use token::*;
[INFO] [stdout]   |         ^^^^^^^^ the name `TokenBalance` in the type namespace is first re-exported here
[INFO] [stdout] ...
[INFO] [stdout] 9 | pub use transaction::*;
[INFO] [stdout]   |         -------------- but the name `TokenBalance` in the type namespace is also re-exported here
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(ambiguous_glob_reexports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/raydium.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/dex/raydium.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/raydium.rs:11:86
[INFO] [stdout]    |
[INFO] [stdout] 11 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/meteora.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/meteora.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/whirlpool.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/whirlpool.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/pump.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/pump.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Pool`, `StorageUsage`, and `Token`
[INFO] [stdout]   --> src/arbitrage/engine.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 |         ArbitrageMetrics, Token, Pool, RiskScore, ExecutionStatus
[INFO] [stdout]    |                           ^^^^^  ^^^^
[INFO] [stdout] 15 |     },
[INFO] [stdout] 16 |     services::{database::DatabaseService, memory_store::{MemoryStore, StorageUsage}},
[INFO] [stdout]    |                                                                       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/services/database.rs:4:14
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `pubkey::Pubkey`
[INFO] [stdout]  --> src/services/jito.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     pubkey::Pubkey,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `uuid::Uuid`
[INFO] [stdout]  --> src/services/memory_store.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use uuid::Uuid;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::Ordering`
[INFO] [stdout]  --> src/utils/math.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::cmp::Ordering;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Block`
[INFO] [stdout]  --> src/utils/crypto.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 | use aes::{Aes256, Block};
[INFO] [stdout]   |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Pbkdf2`
[INFO] [stdout]    --> src/utils/crypto.rs:106:30
[INFO] [stdout]     |
[INFO] [stdout] 106 |         use pbkdf2::{pbkdf2, Pbkdf2};
[INFO] [stdout]     |                              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Pbkdf2`
[INFO] [stdout]    --> src/utils/crypto.rs:242:30
[INFO] [stdout]     |
[INFO] [stdout] 242 |         use pbkdf2::{pbkdf2, Pbkdf2};
[INFO] [stdout]     |                              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Ipv6Addr`
[INFO] [stdout]  --> src/utils/network.rs:1:34
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::{IpAddr, Ipv4Addr, Ipv6Addr, SocketAddr};
[INFO] [stdout]   |                                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]   --> src/services/jito.rs:92:40
[INFO] [stdout]    |
[INFO] [stdout] 92 |         let transaction_data = base64::encode(&bincode::serialize(transaction)?);
[INFO] [stdout]    |                                        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/config/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::time::Duration;
[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 imports: `Config`, `Environment`, and `File`
[INFO] [stdout]  --> src/config/mod.rs:4:14
[INFO] [stdout]   |
[INFO] [stdout] 4 | use config::{Config, Environment, File};
[INFO] [stdout]   |              ^^^^^^  ^^^^^^^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/models/pool.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `solana_program::pubkey::Pubkey`
[INFO] [stdout]  --> src/models/arbitrage.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use solana_program::pubkey::Pubkey;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `transaction::Transaction`
[INFO] [stdout]  --> src/models/transaction.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 |     transaction::Transaction,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: ambiguous glob re-exports
[INFO] [stdout]  --> src/models/mod.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub use token::*;
[INFO] [stdout]   |         ^^^^^^^^ the name `TokenBalance` in the type namespace is first re-exported here
[INFO] [stdout] ...
[INFO] [stdout] 9 | pub use transaction::*;
[INFO] [stdout]   |         -------------- but the name `TokenBalance` in the type namespace is also re-exported here
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(ambiguous_glob_reexports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/raydium.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/dex/raydium.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/raydium.rs:11:86
[INFO] [stdout]    |
[INFO] [stdout] 11 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/meteora.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/meteora.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/whirlpool.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/whirlpool.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/pump.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/pump.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Pool`, `StorageUsage`, and `Token`
[INFO] [stdout]   --> src/arbitrage/engine.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 |         ArbitrageMetrics, Token, Pool, RiskScore, ExecutionStatus
[INFO] [stdout]    |                           ^^^^^  ^^^^
[INFO] [stdout] 15 |     },
[INFO] [stdout] 16 |     services::{database::DatabaseService, memory_store::{MemoryStore, StorageUsage}},
[INFO] [stdout]    |                                                                       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/services/database.rs:4:14
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `pubkey::Pubkey`
[INFO] [stdout]  --> src/services/jito.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     pubkey::Pubkey,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `uuid::Uuid`
[INFO] [stdout]  --> src/services/memory_store.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use uuid::Uuid;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::Ordering`
[INFO] [stdout]  --> src/utils/math.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::cmp::Ordering;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Block`
[INFO] [stdout]  --> src/utils/crypto.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 | use aes::{Aes256, Block};
[INFO] [stdout]   |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Pbkdf2`
[INFO] [stdout]    --> src/utils/crypto.rs:106:30
[INFO] [stdout]     |
[INFO] [stdout] 106 |         use pbkdf2::{pbkdf2, Pbkdf2};
[INFO] [stdout]     |                              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Pbkdf2`
[INFO] [stdout]    --> src/utils/crypto.rs:242:30
[INFO] [stdout]     |
[INFO] [stdout] 242 |         use pbkdf2::{pbkdf2, Pbkdf2};
[INFO] [stdout]     |                              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Ipv6Addr`
[INFO] [stdout]  --> src/utils/network.rs:1:34
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::{IpAddr, Ipv4Addr, Ipv6Addr, SocketAddr};
[INFO] [stdout]   |                                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]   --> src/services/jito.rs:92:40
[INFO] [stdout]    |
[INFO] [stdout] 92 |         let transaction_data = base64::encode(&bincode::serialize(transaction)?);
[INFO] [stdout]    |                                        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:225:38
[INFO] [stdout]     |
[INFO] [stdout] 225 |         let mut current = start_time.date();
[INFO] [stdout]     |                                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:226:28
[INFO] [stdout]     |
[INFO] [stdout] 226 |         let end = end_time.date();
[INFO] [stdout]     |                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:229:46
[INFO] [stdout]     |
[INFO] [stdout] 229 |             if Self::is_business_day(current.and_hms(0, 0, 0)) {
[INFO] [stdout]     |                                              ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::succ`: Use succ_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:232:31
[INFO] [stdout]     |
[INFO] [stdout] 232 |             current = current.succ();
[INFO] [stdout]     |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:244:38
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut current = start_time.date();
[INFO] [stdout]     |                                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:245:28
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let end = end_time.date();
[INFO] [stdout]     |                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:248:46
[INFO] [stdout]     |
[INFO] [stdout] 248 |             if Self::is_business_day(current.and_hms(0, 0, 0)) {
[INFO] [stdout]     |                                              ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:249:44
[INFO] [stdout]     |
[INFO] [stdout] 249 |                 business_days.push(current.and_hms(9, 0, 0)); // 9:00 AM
[INFO] [stdout]     |                                            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::succ`: Use succ_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:251:31
[INFO] [stdout]     |
[INFO] [stdout] 251 |             current = current.succ();
[INFO] [stdout]     |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:314:18
[INFO] [stdout]     |
[INFO] [stdout] 314 |         if start.date() == end.date() {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:314:32
[INFO] [stdout]     |
[INFO] [stdout] 314 |         if start.date() == end.date() {
[INFO] [stdout]     |                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]    --> src/utils/time.rs:364:26
[INFO] [stdout]     |
[INFO] [stdout] 364 |         let monday = Utc.ymd(2024, 1, 1).and_hms(10, 0, 0); // Monday
[INFO] [stdout]     |                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:364:42
[INFO] [stdout]     |
[INFO] [stdout] 364 |         let monday = Utc.ymd(2024, 1, 1).and_hms(10, 0, 0); // Monday
[INFO] [stdout]     |                                          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]    --> src/utils/time.rs:365:28
[INFO] [stdout]     |
[INFO] [stdout] 365 |         let saturday = Utc.ymd(2024, 1, 6).and_hms(10, 0, 0); // Saturday
[INFO] [stdout]     |                            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:365:44
[INFO] [stdout]     |
[INFO] [stdout] 365 |         let saturday = Utc.ymd(2024, 1, 6).and_hms(10, 0, 0); // Saturday
[INFO] [stdout]     |                                            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:225:38
[INFO] [stdout]     |
[INFO] [stdout] 225 |         let mut current = start_time.date();
[INFO] [stdout]     |                                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:226:28
[INFO] [stdout]     |
[INFO] [stdout] 226 |         let end = end_time.date();
[INFO] [stdout]     |                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:229:46
[INFO] [stdout]     |
[INFO] [stdout] 229 |             if Self::is_business_day(current.and_hms(0, 0, 0)) {
[INFO] [stdout]     |                                              ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::succ`: Use succ_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:232:31
[INFO] [stdout]     |
[INFO] [stdout] 232 |             current = current.succ();
[INFO] [stdout]     |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:244:38
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut current = start_time.date();
[INFO] [stdout]     |                                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:245:28
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let end = end_time.date();
[INFO] [stdout]     |                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:248:46
[INFO] [stdout]     |
[INFO] [stdout] 248 |             if Self::is_business_day(current.and_hms(0, 0, 0)) {
[INFO] [stdout]     |                                              ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:249:44
[INFO] [stdout]     |
[INFO] [stdout] 249 |                 business_days.push(current.and_hms(9, 0, 0)); // 9:00 AM
[INFO] [stdout]     |                                            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::succ`: Use succ_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:251:31
[INFO] [stdout]     |
[INFO] [stdout] 251 |             current = current.succ();
[INFO] [stdout]     |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:314:18
[INFO] [stdout]     |
[INFO] [stdout] 314 |         if start.date() == end.date() {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:314:32
[INFO] [stdout]     |
[INFO] [stdout] 314 |         if start.date() == end.date() {
[INFO] [stdout]     |                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output_amount`
[INFO] [stdout]    --> src/dex/interface.rs:192:13
[INFO] [stdout]     |
[INFO] [stdout] 192 |         let output_amount = numerator / denominator;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_output_amount`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `input_amount`
[INFO] [stdout]    --> src/dex/interface.rs:217:9
[INFO] [stdout]     |
[INFO] [stdout] 217 |         input_amount: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_input_amount`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output_amount`
[INFO] [stdout]    --> src/dex/interface.rs:192:13
[INFO] [stdout]     |
[INFO] [stdout] 192 |         let output_amount = numerator / denominator;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_output_amount`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `input_amount`
[INFO] [stdout]    --> src/dex/interface.rs:217:9
[INFO] [stdout]     |
[INFO] [stdout] 217 |         input_amount: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_input_amount`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/raydium.rs:245:9
[INFO] [stdout]     |
[INFO] [stdout] 245 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/raydium.rs:243:9
[INFO] [stdout]     |
[INFO] [stdout] 243 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/raydium.rs:299:42
[INFO] [stdout]     |
[INFO] [stdout] 299 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/raydium.rs:245:9
[INFO] [stdout]     |
[INFO] [stdout] 245 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/raydium.rs:243:9
[INFO] [stdout]     |
[INFO] [stdout] 243 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/raydium.rs:299:42
[INFO] [stdout]     |
[INFO] [stdout] 299 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/meteora.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/meteora.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/meteora.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/meteora.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/meteora.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/meteora.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/whirlpool.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/whirlpool.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/whirlpool.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/whirlpool.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/whirlpool.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/pump.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/pump.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/whirlpool.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/pump.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token_b`
[INFO] [stdout]    --> src/arbitrage/scanner.rs:163:9
[INFO] [stdout]     |
[INFO] [stdout] 163 |         token_b: &Token,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `opportunity`
[INFO] [stdout]    --> src/arbitrage/executor.rs:247:34
[INFO] [stdout]     |
[INFO] [stdout] 247 |     pub fn should_execute(&self, opportunity: &ArbitrageOpportunity) -> bool {
[INFO] [stdout]     |                                  ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_opportunity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_profit`
[INFO] [stdout]    --> src/arbitrage/executor.rs:251:43
[INFO] [stdout]     |
[INFO] [stdout] 251 |             ExecutionCondition::MinProfit(min_profit) => {
[INFO] [stdout]     |                                           ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_min_profit`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `risk_score`
[INFO] [stdout]    --> src/arbitrage/executor.rs:257:41
[INFO] [stdout]     |
[INFO] [stdout] 257 |             ExecutionCondition::MaxRisk(risk_score) => {
[INFO] [stdout]     |                                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_risk_score`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `status`
[INFO] [stdout]   --> src/services/solana.rs:57:13
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let status = self.rpc_client.get_transaction(signature, UiTransactionEncoding::Json)?;
[INFO] [stdout]    |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_status`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction`
[INFO] [stdout]    --> src/services/solana.rs:304:44
[INFO] [stdout]     |
[INFO] [stdout] 304 |     pub async fn verify_transaction(&self, transaction: &Transaction) -> Result<bool> {
[INFO] [stdout]     |                                            ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `host`
[INFO] [stdout]    --> src/utils/network.rs:377:9
[INFO] [stdout]     |
[INFO] [stdout] 377 |         host: &str,
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_host`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `StoreMetrics` is more private than the item `memory_store::MemoryStore::get_metrics`
[INFO] [stdout]    --> src/services/memory_store.rs:228:5
[INFO] [stdout]     |
[INFO] [stdout] 228 |     pub async fn get_metrics(&self) -> StoreMetrics {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `memory_store::MemoryStore::get_metrics` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `StoreMetrics` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/services/memory_store.rs:33:1
[INFO] [stdout]     |
[INFO] [stdout]  33 | struct StoreMetrics {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `base_price`, `quote_price`, and `volume_7d` are never read
[INFO] [stdout]   --> src/dex/raydium.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | struct RaydiumPool {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 30 |     base_price: String,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 31 |     quote_price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 32 |     volume_24h: String,
[INFO] [stdout] 33 |     volume_7d: String,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RaydiumPool` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RaydiumQuote` is never constructed
[INFO] [stdout]   --> src/dex/raydium.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | struct RaydiumQuote {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `validate_opportunity` and `calculate_optimal_amount` are never used
[INFO] [stdout]    --> src/arbitrage/scanner.rs:206:8
[INFO] [stdout]     |
[INFO] [stdout]  22 | impl OpportunityScanner {
[INFO] [stdout]     | ----------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 206 |     fn validate_opportunity(&self, opportunity: &ArbitrageOpportunity) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 231 |     fn calculate_optimal_amount(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `dex_instances` and `config` are never read
[INFO] [stdout]   --> src/arbitrage/executor.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct ArbitrageExecutor {
[INFO] [stdout]    |            ----------------- fields in this struct
[INFO] [stdout] 23 |     dex_instances: Arc<HashMap<DexType, Box<dyn DexInterface>>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 24 |     execution_sender: mpsc::Sender<ArbitrageExecution>,
[INFO] [stdout] 25 |     config: AppConfig,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `check_execution_status` is never used
[INFO] [stdout]    --> src/arbitrage/executor.rs:137:14
[INFO] [stdout]     |
[INFO] [stdout]  30 | impl ArbitrageExecutor {
[INFO] [stdout]     | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 137 |     async fn check_execution_status(&self, execution: &mut ArbitrageExecution) -> Result<()> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/utils/crypto.rs:110:9
[INFO] [stdout]     |
[INFO] [stdout] 110 |         pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, 10000, &mut hash);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 110 |         let _ = pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, 10000, &mut hash);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/utils/crypto.rs:246:9
[INFO] [stdout]     |
[INFO] [stdout] 246 |         pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, iterations, &mut key);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 246 |         let _ = pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, iterations, &mut key);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]    --> src/utils/network.rs:107:21
[INFO] [stdout]     |
[INFO] [stdout] 107 |         port > 0 && port <= 65535
[INFO] [stdout]     |                     ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/pump.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/pump.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/pump.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token_b`
[INFO] [stdout]    --> src/arbitrage/scanner.rs:163:9
[INFO] [stdout]     |
[INFO] [stdout] 163 |         token_b: &Token,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `opportunity`
[INFO] [stdout]    --> src/arbitrage/executor.rs:247:34
[INFO] [stdout]     |
[INFO] [stdout] 247 |     pub fn should_execute(&self, opportunity: &ArbitrageOpportunity) -> bool {
[INFO] [stdout]     |                                  ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_opportunity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_profit`
[INFO] [stdout]    --> src/arbitrage/executor.rs:251:43
[INFO] [stdout]     |
[INFO] [stdout] 251 |             ExecutionCondition::MinProfit(min_profit) => {
[INFO] [stdout]     |                                           ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_min_profit`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `risk_score`
[INFO] [stdout]    --> src/arbitrage/executor.rs:257:41
[INFO] [stdout]     |
[INFO] [stdout] 257 |             ExecutionCondition::MaxRisk(risk_score) => {
[INFO] [stdout]     |                                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_risk_score`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `status`
[INFO] [stdout]   --> src/services/solana.rs:57:13
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let status = self.rpc_client.get_transaction(signature, UiTransactionEncoding::Json)?;
[INFO] [stdout]    |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_status`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction`
[INFO] [stdout]    --> src/services/solana.rs:304:44
[INFO] [stdout]     |
[INFO] [stdout] 304 |     pub async fn verify_transaction(&self, transaction: &Transaction) -> Result<bool> {
[INFO] [stdout]     |                                            ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `host`
[INFO] [stdout]    --> src/utils/network.rs:377:9
[INFO] [stdout]     |
[INFO] [stdout] 377 |         host: &str,
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_host`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `StoreMetrics` is more private than the item `MemoryStore::get_metrics`
[INFO] [stdout]    --> src/services/memory_store.rs:228:5
[INFO] [stdout]     |
[INFO] [stdout] 228 |     pub async fn get_metrics(&self) -> StoreMetrics {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `MemoryStore::get_metrics` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `StoreMetrics` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/services/memory_store.rs:33:1
[INFO] [stdout]     |
[INFO] [stdout]  33 | struct StoreMetrics {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `base_price`, `quote_price`, and `volume_7d` are never read
[INFO] [stdout]   --> src/dex/raydium.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | struct RaydiumPool {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 30 |     base_price: String,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 31 |     quote_price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 32 |     volume_24h: String,
[INFO] [stdout] 33 |     volume_7d: String,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RaydiumPool` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RaydiumQuote` is never constructed
[INFO] [stdout]   --> src/dex/raydium.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | struct RaydiumQuote {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `validate_opportunity` and `calculate_optimal_amount` are never used
[INFO] [stdout]    --> src/arbitrage/scanner.rs:206:8
[INFO] [stdout]     |
[INFO] [stdout]  22 | impl OpportunityScanner {
[INFO] [stdout]     | ----------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 206 |     fn validate_opportunity(&self, opportunity: &ArbitrageOpportunity) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 231 |     fn calculate_optimal_amount(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `dex_instances` and `config` are never read
[INFO] [stdout]   --> src/arbitrage/executor.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct ArbitrageExecutor {
[INFO] [stdout]    |            ----------------- fields in this struct
[INFO] [stdout] 23 |     dex_instances: Arc<HashMap<DexType, Box<dyn DexInterface>>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 24 |     execution_sender: mpsc::Sender<ArbitrageExecution>,
[INFO] [stdout] 25 |     config: AppConfig,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `check_execution_status` is never used
[INFO] [stdout]    --> src/arbitrage/executor.rs:137:14
[INFO] [stdout]     |
[INFO] [stdout]  30 | impl ArbitrageExecutor {
[INFO] [stdout]     | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 137 |     async fn check_execution_status(&self, execution: &mut ArbitrageExecution) -> Result<()> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/utils/crypto.rs:110:9
[INFO] [stdout]     |
[INFO] [stdout] 110 |         pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, 10000, &mut hash);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 110 |         let _ = pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, 10000, &mut hash);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/utils/crypto.rs:246:9
[INFO] [stdout]     |
[INFO] [stdout] 246 |         pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, iterations, &mut key);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 246 |         let _ = pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, iterations, &mut key);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]    --> src/utils/network.rs:107:21
[INFO] [stdout]     |
[INFO] [stdout] 107 |         port > 0 && port <= 65535
[INFO] [stdout]     |                     ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 3m 06s
[INFO] running `Command { std: "docker" "inspect" "807db44a352fa9d5d668e0e3e06e2b82c4c2f84f971372891f9d0d3a4283933d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "807db44a352fa9d5d668e0e3e06e2b82c4c2f84f971372891f9d0d3a4283933d", kill_on_drop: false }`
[INFO] [stdout] 807db44a352fa9d5d668e0e3e06e2b82c4c2f84f971372891f9d0d3a4283933d
