[INFO] cloning repository https://github.com/enigmarikki/orderflow-aggregator
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/enigmarikki/orderflow-aggregator" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fenigmarikki%2Forderflow-aggregator", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fenigmarikki%2Forderflow-aggregator'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 20eb72e9a299458fb9c1d34c16fd921326a42905
[INFO] checking enigmarikki/orderflow-aggregator/20eb72e9a299458fb9c1d34c16fd921326a42905 against master#c871d09d1cc32a649f4c5177bb819646260ed120 for pr-149291-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fenigmarikki%2Forderflow-aggregator" "/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/enigmarikki/orderflow-aggregator
[INFO] finished tweaking git repo https://github.com/enigmarikki/orderflow-aggregator
[INFO] tweaked toml for git repo https://github.com/enigmarikki/orderflow-aggregator written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/enigmarikki/orderflow-aggregator on toolchain c871d09d1cc32a649f4c5177bb819646260ed120
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c871d09d1cc32a649f4c5177bb819646260ed120" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/enigmarikki/orderflow-aggregator 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" "+c871d09d1cc32a649f4c5177bb819646260ed120" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded asynchronous-codec v0.7.0
[INFO] [stderr]   Downloaded zeromq v0.4.1
[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:94a0c148923f5b2b52a63ef0eeb1882ad339ab61bce784c8077cbe41c61feb6c" "/opt/rustwide/cargo-home/bin/cargo" "+c871d09d1cc32a649f4c5177bb819646260ed120" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] edc852061b53b928e19fe39b58456e590fef3223dcd9dcb497199f508f545919
[INFO] running `Command { std: "docker" "start" "-a" "edc852061b53b928e19fe39b58456e590fef3223dcd9dcb497199f508f545919", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "edc852061b53b928e19fe39b58456e590fef3223dcd9dcb497199f508f545919", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "edc852061b53b928e19fe39b58456e590fef3223dcd9dcb497199f508f545919", kill_on_drop: false }`
[INFO] [stdout] edc852061b53b928e19fe39b58456e590fef3223dcd9dcb497199f508f545919
[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:94a0c148923f5b2b52a63ef0eeb1882ad339ab61bce784c8077cbe41c61feb6c" "/opt/rustwide/cargo-home/bin/cargo" "+c871d09d1cc32a649f4c5177bb819646260ed120" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f6a6d4520abeec44b73554bd35d4bd60bcc9e2b369c7e42735636a573d6d4e89
[INFO] running `Command { std: "docker" "start" "-a" "f6a6d4520abeec44b73554bd35d4bd60bcc9e2b369c7e42735636a573d6d4e89", kill_on_drop: false }`
[INFO] [stderr]    Compiling unicode-ident v1.0.19
[INFO] [stderr]    Compiling libc v0.2.176
[INFO] [stderr]     Checking memchr v2.7.6
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking ahash v0.8.12
[INFO] [stderr]     Checking futures-task v0.3.31
[INFO] [stderr]    Compiling ref-cast v1.0.25
[INFO] [stderr]     Checking simdutf8 v0.1.5
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]     Checking regex-syntax v0.8.8
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling proc-macro2 v1.0.101
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking serde_json v1.0.145
[INFO] [stderr]    Compiling quote v1.0.41
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking signal-hook-registry v1.4.6
[INFO] [stderr]     Checking mio v1.0.4
[INFO] [stderr]     Checking socket2 v0.6.0
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking uuid v1.18.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking dashmap v5.5.3
[INFO] [stderr]     Checking float-cmp v0.10.0
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking regex v1.12.2
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling ref-cast-impl v1.0.25
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]     Checking tokio v1.47.1
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking tungstenite v0.24.0
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking asynchronous-codec v0.7.0
[INFO] [stderr]     Checking halfbrown v0.2.5
[INFO] [stderr]     Checking value-trait v0.10.1
[INFO] [stderr]     Checking simd-json v0.14.3
[INFO] [stderr]     Checking tokio-tungstenite v0.24.0
[INFO] [stderr]     Checking tokio-util v0.7.16
[INFO] [stderr]     Checking db v0.1.0 (/opt/rustwide/workdir/db)
[INFO] [stderr]     Checking zeromq v0.4.1
[INFO] [stderr]     Checking binance_api v0.1.0 (/opt/rustwide/workdir/binance_api)
[INFO] [stderr]     Checking bybit_api v0.1.0 (/opt/rustwide/workdir/bybit_api)
[INFO] [stderr]     Checking hyperliquid_api v0.1.0 (/opt/rustwide/workdir/hyperliquid_api)
[INFO] [stderr]     Checking okx_api v0.1.0 (/opt/rustwide/workdir/okx_api)
[INFO] [stderr]     Checking cb_api v0.1.0 (/opt/rustwide/workdir/cb_api)
[INFO] [stderr]     Checking mexc_api v0.1.0 (/opt/rustwide/workdir/mexc_api)
[INFO] [stderr]     Checking producer v0.1.0 (/opt/rustwide/workdir/producer)
[INFO] [stdout] error[E0609]: no field `event_time` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:65:37
[INFO] [stdout]    |
[INFO] [stdout] 65 |             timestamp_exchange: bbo.event_time,
[INFO] [stdout]    |                                     ^^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `symbol` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:67:30
[INFO] [stdout]    |
[INFO] [stdout] 67 |             symbol_hash: bbo.symbol,
[INFO] [stdout]    |                              ^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `bid_price` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:68:28
[INFO] [stdout]    |
[INFO] [stdout] 68 |             bid_price: bbo.bid_price,
[INFO] [stdout]    |                            ^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `bid_qty` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:69:27
[INFO] [stdout]    |
[INFO] [stdout] 69 |             bid_size: bbo.bid_qty,
[INFO] [stdout]    |                           ^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `ask_price` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:70:28
[INFO] [stdout]    |
[INFO] [stdout] 70 |             ask_price: bbo.ask_price,
[INFO] [stdout]    |                            ^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `ask_qty` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:71:27
[INFO] [stdout]    |
[INFO] [stdout] 71 |             ask_size: bbo.ask_qty,
[INFO] [stdout]    |                           ^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `update_id` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:72:26
[INFO] [stdout]    |
[INFO] [stdout] 72 |             seq_num: bbo.update_id,
[INFO] [stdout]    |                          ^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `event_time` on type `binance_api::CompactTrade`
[INFO] [stdout]   --> producer/src/adapters.rs:84:39
[INFO] [stdout]    |
[INFO] [stdout] 84 |             timestamp_exchange: trade.event_time,
[INFO] [stdout]    |                                       ^^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `et`, `tid`, `price`, `quantity`, `ftid` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `symbol` on type `binance_api::CompactTrade`
[INFO] [stdout]   --> producer/src/adapters.rs:86:32
[INFO] [stdout]    |
[INFO] [stdout] 86 |             symbol_hash: trade.symbol,
[INFO] [stdout]    |                                ^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `et`, `tid`, `price`, `quantity`, `ftid` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `trade_id` on type `binance_api::CompactTrade`
[INFO] [stdout]   --> producer/src/adapters.rs:87:29
[INFO] [stdout]    |
[INFO] [stdout] 87 |             trade_id: trade.trade_id,
[INFO] [stdout]    |                             ^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `et`, `tid`, `price`, `quantity`, `ftid` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `is_buyer_maker` on type `binance_api::CompactTrade`
[INFO] [stdout]   --> producer/src/adapters.rs:90:28
[INFO] [stdout]    |
[INFO] [stdout] 90 |             side: if trade.is_buyer_maker { TradeSide::Buy } else { TradeSide::Sell },
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `et`, `tid`, `price`, `quantity`, `ftid` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `is_buyer_maker` on type `binance_api::CompactTrade`
[INFO] [stdout]   --> producer/src/adapters.rs:91:35
[INFO] [stdout]    |
[INFO] [stdout] 91 |             is_buyer_maker: trade.is_buyer_maker,
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `et`, `tid`, `price`, `quantity`, `ftid` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `time` on type `binance_api::CompactLiquidation`
[INFO] [stdout]    --> producer/src/adapters.rs:103:37
[INFO] [stdout]     |
[INFO] [stdout] 103 |             timestamp_exchange: liq.time,
[INFO] [stdout]     |                                     ^^^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `event_time`, `trade_time`, `symbol`, `price`, `average_price` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `parse` found for type `u64` in the current scope
[INFO] [stdout]    --> producer/src/adapters.rs:293:38
[INFO] [stdout]     |
[INFO] [stdout] 293 |             trade_id: trade.trade_id.parse().unwrap_or(0),
[INFO] [stdout]     |                                      ^^^^^ method not found in `u64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `timestamp` on type `hyperliquid_api::CompactBbo`
[INFO] [stdout]    --> producer/src/adapters.rs:677:37
[INFO] [stdout]     |
[INFO] [stdout] 677 |             timestamp_exchange: bbo.timestamp,
[INFO] [stdout]     |                                     ^^^^^^^^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `time`, `coin`, `bid_price`, `bid_size`, `ask_price`, `ask_size`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `coin_hash` on type `hyperliquid_api::CompactBbo`
[INFO] [stdout]    --> producer/src/adapters.rs:679:30
[INFO] [stdout]     |
[INFO] [stdout] 679 |             symbol_hash: bbo.coin_hash,
[INFO] [stdout]     |                              ^^^^^^^^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `time`, `coin`, `bid_price`, `bid_size`, `ask_price`, `ask_size`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `coin_hash` on type `hyperliquid_api::CompactTrade`
[INFO] [stdout]    --> producer/src/adapters.rs:698:32
[INFO] [stdout]     |
[INFO] [stdout] 698 |             symbol_hash: trade.coin_hash,
[INFO] [stdout]     |                                ^^^^^^^^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `time`, `tid`, `price`, `size`, `coin` ... and 2 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `px` on type `hyperliquid_api::CompactTrade`
[INFO] [stdout]    --> producer/src/adapters.rs:700:26
[INFO] [stdout]     |
[INFO] [stdout] 700 |             price: trade.px,
[INFO] [stdout]     |                          ^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `time`, `tid`, `price`, `size`, `coin` ... and 2 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `sz` on type `hyperliquid_api::CompactTrade`
[INFO] [stdout]    --> producer/src/adapters.rs:701:25
[INFO] [stdout]     |
[INFO] [stdout] 701 |             size: trade.sz,
[INFO] [stdout]     |                         ^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `time`, `tid`, `price`, `size`, `coin` ... and 2 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `event_time` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:65:37
[INFO] [stdout]    |
[INFO] [stdout] 65 |             timestamp_exchange: bbo.event_time,
[INFO] [stdout]    |                                     ^^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `symbol` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:67:30
[INFO] [stdout]    |
[INFO] [stdout] 67 |             symbol_hash: bbo.symbol,
[INFO] [stdout]    |                              ^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `bid_price` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:68:28
[INFO] [stdout]    |
[INFO] [stdout] 68 |             bid_price: bbo.bid_price,
[INFO] [stdout]    |                            ^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `bid_qty` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:69:27
[INFO] [stdout]    |
[INFO] [stdout] 69 |             bid_size: bbo.bid_qty,
[INFO] [stdout]    |                           ^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `ask_price` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:70:28
[INFO] [stdout]    |
[INFO] [stdout] 70 |             ask_price: bbo.ask_price,
[INFO] [stdout]    |                            ^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `ask_qty` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:71:27
[INFO] [stdout]    |
[INFO] [stdout] 71 |             ask_size: bbo.ask_qty,
[INFO] [stdout]    |                           ^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `update_id` on type `binance_api::CompactBbo`
[INFO] [stdout]   --> producer/src/adapters.rs:72:26
[INFO] [stdout]    |
[INFO] [stdout] 72 |             seq_num: bbo.update_id,
[INFO] [stdout]    |                          ^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `uid`, `sym`, `bp`, `bq`, `ap`, `aq`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `event_time` on type `binance_api::CompactTrade`
[INFO] [stdout]   --> producer/src/adapters.rs:84:39
[INFO] [stdout]    |
[INFO] [stdout] 84 |             timestamp_exchange: trade.event_time,
[INFO] [stdout]    |                                       ^^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `et`, `tid`, `price`, `quantity`, `ftid` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `symbol` on type `binance_api::CompactTrade`
[INFO] [stdout]   --> producer/src/adapters.rs:86:32
[INFO] [stdout]    |
[INFO] [stdout] 86 |             symbol_hash: trade.symbol,
[INFO] [stdout]    |                                ^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `et`, `tid`, `price`, `quantity`, `ftid` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `trade_id` on type `binance_api::CompactTrade`
[INFO] [stdout]   --> producer/src/adapters.rs:87:29
[INFO] [stdout]    |
[INFO] [stdout] 87 |             trade_id: trade.trade_id,
[INFO] [stdout]    |                             ^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `et`, `tid`, `price`, `quantity`, `ftid` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `is_buyer_maker` on type `binance_api::CompactTrade`
[INFO] [stdout]   --> producer/src/adapters.rs:90:28
[INFO] [stdout]    |
[INFO] [stdout] 90 |             side: if trade.is_buyer_maker { TradeSide::Buy } else { TradeSide::Sell },
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `et`, `tid`, `price`, `quantity`, `ftid` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `is_buyer_maker` on type `binance_api::CompactTrade`
[INFO] [stdout]   --> producer/src/adapters.rs:91:35
[INFO] [stdout]    |
[INFO] [stdout] 91 |             is_buyer_maker: trade.is_buyer_maker,
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout]    = note: available fields are: `et`, `tid`, `price`, `quantity`, `ftid` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `time` on type `binance_api::CompactLiquidation`
[INFO] [stdout]    --> producer/src/adapters.rs:103:37
[INFO] [stdout]     |
[INFO] [stdout] 103 |             timestamp_exchange: liq.time,
[INFO] [stdout]     |                                     ^^^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `event_time`, `trade_time`, `symbol`, `price`, `average_price` ... and 5 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `parse` found for type `u64` in the current scope
[INFO] [stdout]    --> producer/src/adapters.rs:293:38
[INFO] [stdout]     |
[INFO] [stdout] 293 |             trade_id: trade.trade_id.parse().unwrap_or(0),
[INFO] [stdout]     |                                      ^^^^^ method not found in `u64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:144:29
[INFO] [stdout]     |
[INFO] [stdout] 144 |                         let mut client = binance_api::BinanceWsClient::new(self.config.clone());
[INFO] [stdout]     |                             ----^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:153:33
[INFO] [stdout]     |
[INFO] [stdout] 153 | ...                   let mut client = binance_api::BinanceWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:163:33
[INFO] [stdout]     |
[INFO] [stdout] 163 | ...                   let mut client = binance_api::BinanceWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:147:25
[INFO] [stdout]     |
[INFO] [stdout] 147 |                         client.connect().await?;
[INFO] [stdout]     |                         ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 145 |                         let (mut client, rx) = client.with_bbo_handler();
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:156:29
[INFO] [stdout]     |
[INFO] [stdout] 156 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 154 |                             let (mut client, rx) = client.with_trade_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:166:29
[INFO] [stdout]     |
[INFO] [stdout] 166 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 164 |                             let (mut client, rx) = client.with_liquidation_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `timestamp` on type `hyperliquid_api::CompactBbo`
[INFO] [stdout]    --> producer/src/adapters.rs:677:37
[INFO] [stdout]     |
[INFO] [stdout] 677 |             timestamp_exchange: bbo.timestamp,
[INFO] [stdout]     |                                     ^^^^^^^^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `time`, `coin`, `bid_price`, `bid_size`, `ask_price`, `ask_size`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `coin_hash` on type `hyperliquid_api::CompactBbo`
[INFO] [stdout]    --> producer/src/adapters.rs:679:30
[INFO] [stdout]     |
[INFO] [stdout] 679 |             symbol_hash: bbo.coin_hash,
[INFO] [stdout]     |                              ^^^^^^^^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `time`, `coin`, `bid_price`, `bid_size`, `ask_price`, `ask_size`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `coin_hash` on type `hyperliquid_api::CompactTrade`
[INFO] [stdout]    --> producer/src/adapters.rs:698:32
[INFO] [stdout]     |
[INFO] [stdout] 698 |             symbol_hash: trade.coin_hash,
[INFO] [stdout]     |                                ^^^^^^^^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `time`, `tid`, `price`, `size`, `coin` ... and 2 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `px` on type `hyperliquid_api::CompactTrade`
[INFO] [stdout]    --> producer/src/adapters.rs:700:26
[INFO] [stdout]     |
[INFO] [stdout] 700 |             price: trade.px,
[INFO] [stdout]     |                          ^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `time`, `tid`, `price`, `size`, `coin` ... and 2 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `sz` on type `hyperliquid_api::CompactTrade`
[INFO] [stdout]    --> producer/src/adapters.rs:701:25
[INFO] [stdout]     |
[INFO] [stdout] 701 |             size: trade.sz,
[INFO] [stdout]     |                         ^^ unknown field
[INFO] [stdout]     |
[INFO] [stdout]     = note: available fields are: `time`, `tid`, `price`, `size`, `coin` ... and 2 others
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:348:29
[INFO] [stdout]     |
[INFO] [stdout] 348 |                         let mut client = okx_api::OkxWsClient::new(self.config.clone());
[INFO] [stdout]     |                             ----^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:357:33
[INFO] [stdout]     |
[INFO] [stdout] 357 | ...                   let mut client = okx_api::OkxWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:367:33
[INFO] [stdout]     |
[INFO] [stdout] 367 | ...                   let mut client = okx_api::OkxWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:351:25
[INFO] [stdout]     |
[INFO] [stdout] 351 |                         client.connect().await?;
[INFO] [stdout]     |                         ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 349 |                         let (mut client, rx) = client.with_bbo_handler();
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:360:29
[INFO] [stdout]     |
[INFO] [stdout] 360 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 358 |                             let (mut client, rx) = client.with_trade_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:370:29
[INFO] [stdout]     |
[INFO] [stdout] 370 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 368 |                             let (mut client, rx) = client.with_liquidation_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:552:29
[INFO] [stdout]     |
[INFO] [stdout] 552 |                         let mut client = bybit_api::BybitWsClient::new(self.config.clone());
[INFO] [stdout]     |                             ----^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:561:33
[INFO] [stdout]     |
[INFO] [stdout] 561 | ...                   let mut client = bybit_api::BybitWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:571:33
[INFO] [stdout]     |
[INFO] [stdout] 571 | ...                   let mut client = bybit_api::BybitWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:555:25
[INFO] [stdout]     |
[INFO] [stdout] 555 |                         client.connect().await?;
[INFO] [stdout]     |                         ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 553 |                         let (mut client, rx) = client.with_orderbook_handler();
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:564:29
[INFO] [stdout]     |
[INFO] [stdout] 564 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 562 |                             let (mut client, rx) = client.with_trade_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:574:29
[INFO] [stdout]     |
[INFO] [stdout] 574 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 572 |                             let (mut client, rx) = client.with_liquidation_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:735:25
[INFO] [stdout]     |
[INFO] [stdout] 735 |                     let mut client = hyperliquid_api::HyperliquidWsClient::new(self.config.clone());
[INFO] [stdout]     |                         ----^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:744:29
[INFO] [stdout]     |
[INFO] [stdout] 744 |                         let mut client = hyperliquid_api::HyperliquidWsClient::new(self.config.clone());
[INFO] [stdout]     |                             ----^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:738:21
[INFO] [stdout]     |
[INFO] [stdout] 738 |                     client.connect().await?;
[INFO] [stdout]     |                     ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 736 |                     let (mut client, rx) = client.with_bbo_handler();
[INFO] [stdout]     |                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:747:25
[INFO] [stdout]     |
[INFO] [stdout] 747 |                         client.connect().await?;
[INFO] [stdout]     |                         ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 745 |                         let (mut client, rx) = client.with_trade_handler();
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:144:29
[INFO] [stdout]     |
[INFO] [stdout] 144 |                         let mut client = binance_api::BinanceWsClient::new(self.config.clone());
[INFO] [stdout]     |                             ----^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:153:33
[INFO] [stdout]     |
[INFO] [stdout] 153 | ...                   let mut client = binance_api::BinanceWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:163:33
[INFO] [stdout]     |
[INFO] [stdout] 163 | ...                   let mut client = binance_api::BinanceWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:147:25
[INFO] [stdout]     |
[INFO] [stdout] 147 |                         client.connect().await?;
[INFO] [stdout]     |                         ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 145 |                         let (mut client, rx) = client.with_bbo_handler();
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:156:29
[INFO] [stdout]     |
[INFO] [stdout] 156 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 154 |                             let (mut client, rx) = client.with_trade_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:166:29
[INFO] [stdout]     |
[INFO] [stdout] 166 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 164 |                             let (mut client, rx) = client.with_liquidation_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0596, E0599, E0609.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0596`.
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:348:29
[INFO] [stdout]     |
[INFO] [stdout] 348 |                         let mut client = okx_api::OkxWsClient::new(self.config.clone());
[INFO] [stdout]     |                             ----^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:357:33
[INFO] [stdout]     |
[INFO] [stdout] 357 | ...                   let mut client = okx_api::OkxWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:367:33
[INFO] [stdout]     |
[INFO] [stdout] 367 | ...                   let mut client = okx_api::OkxWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:351:25
[INFO] [stdout]     |
[INFO] [stdout] 351 |                         client.connect().await?;
[INFO] [stdout]     |                         ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 349 |                         let (mut client, rx) = client.with_bbo_handler();
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:360:29
[INFO] [stdout]     |
[INFO] [stdout] 360 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 358 |                             let (mut client, rx) = client.with_trade_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:370:29
[INFO] [stdout]     |
[INFO] [stdout] 370 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 368 |                             let (mut client, rx) = client.with_liquidation_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `producer` (lib) due to 30 previous errors; 11 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:552:29
[INFO] [stdout]     |
[INFO] [stdout] 552 |                         let mut client = bybit_api::BybitWsClient::new(self.config.clone());
[INFO] [stdout]     |                             ----^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:561:33
[INFO] [stdout]     |
[INFO] [stdout] 561 | ...                   let mut client = bybit_api::BybitWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:571:33
[INFO] [stdout]     |
[INFO] [stdout] 571 | ...                   let mut client = bybit_api::BybitWsClient::new(self.config.clone());
[INFO] [stdout]     |                           ----^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:555:25
[INFO] [stdout]     |
[INFO] [stdout] 555 |                         client.connect().await?;
[INFO] [stdout]     |                         ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 553 |                         let (mut client, rx) = client.with_orderbook_handler();
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:564:29
[INFO] [stdout]     |
[INFO] [stdout] 564 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 562 |                             let (mut client, rx) = client.with_trade_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:574:29
[INFO] [stdout]     |
[INFO] [stdout] 574 | ...                   client.connect().await?;
[INFO] [stdout]     |                       ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 572 |                             let (mut client, rx) = client.with_liquidation_handler();
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:735:25
[INFO] [stdout]     |
[INFO] [stdout] 735 |                     let mut client = hyperliquid_api::HyperliquidWsClient::new(self.config.clone());
[INFO] [stdout]     |                         ----^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> producer/src/adapters.rs:744:29
[INFO] [stdout]     |
[INFO] [stdout] 744 |                         let mut client = hyperliquid_api::HyperliquidWsClient::new(self.config.clone());
[INFO] [stdout]     |                             ----^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:738:21
[INFO] [stdout]     |
[INFO] [stdout] 738 |                     client.connect().await?;
[INFO] [stdout]     |                     ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 736 |                     let (mut client, rx) = client.with_bbo_handler();
[INFO] [stdout]     |                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0596]: cannot borrow `client` as mutable, as it is not declared as mutable
[INFO] [stdout]    --> producer/src/adapters.rs:747:25
[INFO] [stdout]     |
[INFO] [stdout] 747 |                         client.connect().await?;
[INFO] [stdout]     |                         ^^^^^^ cannot borrow as mutable
[INFO] [stdout]     |
[INFO] [stdout] help: consider changing this to be mutable
[INFO] [stdout]     |
[INFO] [stdout] 745 |                         let (mut client, rx) = client.with_trade_handler();
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0596, E0599, E0609.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0596`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `producer` (lib test) due to 30 previous errors; 11 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "f6a6d4520abeec44b73554bd35d4bd60bcc9e2b369c7e42735636a573d6d4e89", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f6a6d4520abeec44b73554bd35d4bd60bcc9e2b369c7e42735636a573d6d4e89", kill_on_drop: false }`
[INFO] [stdout] f6a6d4520abeec44b73554bd35d4bd60bcc9e2b369c7e42735636a573d6d4e89
