[INFO] cloning repository https://github.com/Hy-u-3a4eM/rinab [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Hy-u-3a4eM/rinab" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FHy-u-3a4eM%2Frinab", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FHy-u-3a4eM%2Frinab'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 9191a84480a9f1caf7f138e844cb4283310ec461 [INFO] checking Hy-u-3a4eM/rinab/9191a84480a9f1caf7f138e844cb4283310ec461 against master#1280928a99ad3ef2c5735b42dc8852456ae3b974 for pr-120798 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FHy-u-3a4eM%2Frinab" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/Hy-u-3a4eM/rinab on toolchain 1280928a99ad3ef2c5735b42dc8852456ae3b974 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1280928a99ad3ef2c5735b42dc8852456ae3b974" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/Hy-u-3a4eM/rinab [INFO] finished tweaking git repo https://github.com/Hy-u-3a4eM/rinab [INFO] tweaked toml for git repo https://github.com/Hy-u-3a4eM/rinab written to /workspace/builds/worker-7-tc1/source/Cargo.toml [INFO] crate git repo https://github.com/Hy-u-3a4eM/rinab 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" "+1280928a99ad3ef2c5735b42dc8852456ae3b974" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+1280928a99ad3ef2c5735b42dc8852456ae3b974" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 70876a9c1989703335be7e849e5b5c8bbedf05777d65fdf7e3558c6609bd578b [INFO] running `Command { std: "docker" "start" "-a" "70876a9c1989703335be7e849e5b5c8bbedf05777d65fdf7e3558c6609bd578b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "70876a9c1989703335be7e849e5b5c8bbedf05777d65fdf7e3558c6609bd578b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "70876a9c1989703335be7e849e5b5c8bbedf05777d65fdf7e3558c6609bd578b", kill_on_drop: false }` [INFO] [stdout] 70876a9c1989703335be7e849e5b5c8bbedf05777d65fdf7e3558c6609bd578b [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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+1280928a99ad3ef2c5735b42dc8852456ae3b974" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 4beb8b9f9b4d4773c53e77ad29ecad63aa8e59e59ba8f446c27d9917f1d5dffb [INFO] running `Command { std: "docker" "start" "-a" "4beb8b9f9b4d4773c53e77ad29ecad63aa8e59e59ba8f446c27d9917f1d5dffb", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.76 [INFO] [stderr] Compiling libc v0.2.152 [INFO] [stderr] Checking once_cell v1.19.0 [INFO] [stderr] Checking itoa v1.0.10 [INFO] [stderr] Checking bytes v1.5.0 [INFO] [stderr] Compiling serde v1.0.196 [INFO] [stderr] Checking futures-core v0.3.30 [INFO] [stderr] Compiling ahash v0.8.7 [INFO] [stderr] Checking smallvec v1.13.1 [INFO] [stderr] Checking memchr v2.7.1 [INFO] [stderr] Checking futures-sink v0.3.30 [INFO] [stderr] Compiling vcpkg v0.2.15 [INFO] [stderr] Compiling pkg-config v0.3.29 [INFO] [stderr] Checking futures-task v0.3.30 [INFO] [stderr] Checking futures-io v0.3.30 [INFO] [stderr] Checking zerocopy v0.7.32 [INFO] [stderr] Checking allocator-api2 v0.2.16 [INFO] [stderr] Compiling openssl v0.10.63 [INFO] [stderr] Checking tracing-core v0.1.32 [INFO] [stderr] Compiling typenum v1.17.0 [INFO] [stderr] Compiling serde_json v1.0.113 [INFO] [stderr] Compiling native-tls v0.2.11 [INFO] [stderr] Compiling thiserror v1.0.56 [INFO] [stderr] Compiling crossbeam-utils v0.8.19 [INFO] [stderr] Checking crypto-common v0.1.6 [INFO] [stderr] Compiling num-traits v0.2.17 [INFO] [stderr] Checking percent-encoding v2.3.1 [INFO] [stderr] Checking futures-util v0.3.30 [INFO] [stderr] Compiling subtle v2.5.0 [INFO] [stderr] Compiling bitflags v2.4.2 [INFO] [stderr] Checking digest v0.10.7 [INFO] [stderr] Checking futures-channel v0.3.30 [INFO] [stderr] Compiling tinyvec_macros v0.1.1 [INFO] [stderr] Checking ryu v1.0.16 [INFO] [stderr] Checking form_urlencoded v1.2.1 [INFO] [stderr] Compiling tinyvec v1.6.0 [INFO] [stderr] Checking http v1.0.0 [INFO] [stderr] Compiling rustversion v1.0.14 [INFO] [stderr] Compiling pin-project-lite v0.2.13 [INFO] [stderr] Checking foreign-types-shared v0.1.1 [INFO] [stderr] Compiling quote v1.0.35 [INFO] [stderr] Checking foreign-types v0.3.2 [INFO] [stderr] Checking unicode-normalization v0.1.22 [INFO] [stderr] Compiling generic-array v0.14.7 [INFO] [stderr] Compiling unicode-bidi v0.3.15 [INFO] [stderr] Compiling syn v2.0.48 [INFO] [stderr] Compiling scopeguard v1.2.0 [INFO] [stderr] Checking getrandom v0.2.12 [INFO] [stderr] Checking parking_lot_core v0.9.9 [INFO] [stderr] Checking socket2 v0.5.5 [INFO] [stderr] Checking mio v0.8.10 [INFO] [stderr] Checking signal-hook-registry v1.4.1 [INFO] [stderr] Checking num_cpus v1.16.0 [INFO] [stderr] Checking parking_lot v0.12.1 [INFO] [stderr] Checking http-body v1.0.0 [INFO] [stderr] Compiling lock_api v0.4.11 [INFO] [stderr] Compiling minimal-lexical v0.2.1 [INFO] [stderr] Compiling block-buffer v0.10.4 [INFO] [stderr] Checking hashbrown v0.14.3 [INFO] [stderr] Compiling ppv-lite86 v0.2.17 [INFO] [stderr] Compiling cpufeatures v0.2.12 [INFO] [stderr] Compiling nom v7.1.3 [INFO] [stderr] Checking idna v0.5.0 [INFO] [stderr] Checking rand_core v0.6.4 [INFO] [stderr] Compiling cc v1.0.83 [INFO] [stderr] Checking indexmap v2.1.0 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling slab v0.4.9 [INFO] [stderr] Compiling unicode_categories v0.1.1 [INFO] [stderr] Compiling crc-catalog v2.4.0 [INFO] [stderr] Compiling rustix v0.38.30 [INFO] [stderr] Compiling tokio v1.36.0 [INFO] [stderr] Compiling time-core v0.1.2 [INFO] [stderr] Compiling num-conv v0.1.0 [INFO] [stderr] Compiling pin-utils v0.1.0 [INFO] [stderr] Compiling openssl-probe v0.1.5 [INFO] [stderr] Compiling iana-time-zone v0.1.60 [INFO] [stderr] Compiling async-trait v0.1.77 [INFO] [stderr] Checking base64 v0.21.7 [INFO] [stderr] Compiling time-macros v0.2.17 [INFO] [stderr] Compiling url v2.5.0 [INFO] [stderr] Checking deranged v0.3.11 [INFO] [stderr] Compiling chrono v0.4.33 [INFO] [stderr] Compiling crc v3.0.1 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling futures-intrusive v0.5.0 [INFO] [stderr] Compiling hashlink v0.8.4 [INFO] [stderr] Compiling atoi v2.0.0 [INFO] [stderr] Compiling crossbeam-queue v0.3.11 [INFO] [stderr] Compiling openssl-sys v0.9.99 [INFO] [stderr] Compiling hmac v0.12.1 [INFO] [stderr] Compiling sha2 v0.10.8 [INFO] [stderr] Checking http v0.2.11 [INFO] [stderr] Compiling uuid v1.7.0 [INFO] [stderr] Compiling hex v0.4.3 [INFO] [stderr] Compiling finl_unicode v1.2.0 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling dotenvy v0.15.7 [INFO] [stderr] Compiling event-listener v2.5.3 [INFO] [stderr] Compiling linux-raw-sys v0.4.13 [INFO] [stderr] Compiling byteorder v1.5.0 [INFO] [stderr] Compiling stringprep v0.1.4 [INFO] [stderr] Compiling hkdf v0.12.4 [INFO] [stderr] Checking http-body-util v0.1.0 [INFO] [stderr] Compiling axum-core v0.4.3 [INFO] [stderr] Compiling nix v0.27.1 [INFO] [stderr] Compiling sha1 v0.10.6 [INFO] [stderr] Compiling md-5 v0.10.6 [INFO] [stderr] Compiling num-bigint v0.4.4 [INFO] [stderr] Compiling whoami v1.4.1 [INFO] [stderr] Checking sync_wrapper v0.1.2 [INFO] [stderr] Checking try-lock v0.2.5 [INFO] [stderr] Compiling home v0.5.9 [INFO] [stderr] Checking want v0.3.1 [INFO] [stderr] Checking http-body v0.4.6 [INFO] [stderr] Compiling heck v0.4.1 [INFO] [stderr] Checking num-integer v0.1.45 [INFO] [stderr] Compiling ring v0.17.7 [INFO] [stderr] Checking time v0.3.34 [INFO] [stderr] Compiling axum v0.7.4 [INFO] [stderr] Compiling cookie v0.18.0 [INFO] [stderr] Compiling atomic-write-file v0.1.2 [INFO] [stderr] Checking regex-syntax v0.8.2 [INFO] [stderr] Checking matchit v0.7.3 [INFO] [stderr] Checking password-hash v0.5.0 [INFO] [stderr] Checking pem v3.0.3 [INFO] [stderr] Checking rustls-pemfile v1.0.4 [INFO] [stderr] Checking socket2 v0.4.10 [INFO] [stderr] Checking blake2 v0.10.6 [INFO] [stderr] Checking tracing-log v0.2.0 [INFO] [stderr] Checking thread_local v1.1.7 [INFO] [stderr] Checking sha1_smol v1.0.0 [INFO] [stderr] Checking tower-http v0.5.1 [INFO] [stderr] Checking argon2 v0.5.3 [INFO] [stderr] Compiling tempfile v3.9.0 [INFO] [stderr] Compiling serde_derive v1.0.196 [INFO] [stderr] Compiling tracing-attributes v0.1.27 [INFO] [stderr] Compiling tokio-macros v2.2.0 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling thiserror-impl v1.0.56 [INFO] [stderr] Compiling pin-project-internal v1.1.3 [INFO] [stderr] Checking regex-automata v0.4.3 [INFO] [stderr] Compiling tokio-stream v0.1.14 [INFO] [stderr] Checking regex v1.10.2 [INFO] [stderr] Checking pin-project v1.1.3 [INFO] [stderr] Checking tracing v0.1.40 [INFO] [stderr] Checking simple_asn1 v0.6.2 [INFO] [stderr] Checking tracing-subscriber v0.3.18 [INFO] [stderr] Checking tokio-util v0.7.10 [INFO] [stderr] Checking tokio-native-tls v0.3.1 [INFO] [stderr] Checking tower v0.4.13 [INFO] [stderr] Checking h2 v0.4.2 [INFO] [stderr] Checking h2 v0.3.24 [INFO] [stderr] Checking combine v4.6.6 [INFO] [stderr] Checking either v1.9.0 [INFO] [stderr] Checking serde_urlencoded v0.7.1 [INFO] [stderr] Checking serde_path_to_error v0.1.15 [INFO] [stderr] Checking itertools v0.12.0 [INFO] [stderr] Checking jsonwebtoken v9.2.0 [INFO] [stderr] Checking sqlformat v0.2.3 [INFO] [stderr] Checking sqlx-core v0.7.3 [INFO] [stderr] Checking hyper v0.14.28 [INFO] [stderr] Checking hyper v1.1.0 [INFO] [stderr] Checking hyper-util v0.1.2 [INFO] [stderr] Checking redis v0.24.0 [INFO] [stderr] Checking sqlx-postgres v0.7.3 [INFO] [stderr] Checking hyper-tls v0.5.0 [INFO] [stderr] Checking reqwest v0.11.24 [INFO] [stderr] Compiling sqlx-macros-core v0.7.3 [INFO] [stderr] Checking axum-extra v0.9.2 [INFO] [stderr] Compiling sqlx-macros v0.7.3 [INFO] [stderr] Checking sqlx v0.7.3 [INFO] [stderr] Checking rinab v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] error: error communicating with database: Connection refused (os error 111) [INFO] [stdout] --> src/handler.rs:88:16 [INFO] [stdout] | [INFO] [stdout] 88 | let user = sqlx::query_as!( [INFO] [stdout] | ________________^ [INFO] [stdout] 89 | | User, [INFO] [stdout] 90 | | "INSERT INTO users (name,email,password) VALUES ($1, $2, $3) RETURNING *", [INFO] [stdout] 91 | | body.name.to_string(), [INFO] [stdout] 92 | | body.email.to_string().to_ascii_lowercase(), [INFO] [stdout] 93 | | hashed_password [INFO] [stdout] 94 | | ) [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = note: this error originates in the macro `$crate::sqlx_macros::expand_query` which comes from the expansion of the macro `sqlx::query_as` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: error communicating with database: Connection refused (os error 111) [INFO] [stdout] --> src/handler.rs:88:16 [INFO] [stdout] | [INFO] [stdout] 88 | let user = sqlx::query_as!( [INFO] [stdout] | ________________^ [INFO] [stdout] 89 | | User, [INFO] [stdout] 90 | | "INSERT INTO users (name,email,password) VALUES ($1, $2, $3) RETURNING *", [INFO] [stdout] 91 | | body.name.to_string(), [INFO] [stdout] 92 | | body.email.to_string().to_ascii_lowercase(), [INFO] [stdout] 93 | | hashed_password [INFO] [stdout] 94 | | ) [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = note: this error originates in the macro `$crate::sqlx_macros::expand_query` which comes from the expansion of the macro `sqlx::query_as` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: error communicating with database: Connection refused (os error 111) [INFO] [stdout] --> src/handler.rs:116:16 [INFO] [stdout] | [INFO] [stdout] 116 | let user = sqlx::query_as!( [INFO] [stdout] | ________________^ [INFO] [stdout] 117 | | User, [INFO] [stdout] 118 | | "SELECT * FROM users WHERE email = $1", [INFO] [stdout] 119 | | body.email.to_ascii_lowercase() [INFO] [stdout] 120 | | ) [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = note: this error originates in the macro `$crate::sqlx_macros::expand_query` which comes from the expansion of the macro `sqlx::query_as` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: error communicating with database: Connection refused (os error 111) [INFO] [stdout] --> src/handler.rs:116:16 [INFO] [stdout] | [INFO] [stdout] 116 | let user = sqlx::query_as!( [INFO] [stdout] | ________________^ [INFO] [stdout] 117 | | User, [INFO] [stdout] 118 | | "SELECT * FROM users WHERE email = $1", [INFO] [stdout] 119 | | body.email.to_ascii_lowercase() [INFO] [stdout] 120 | | ) [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = note: this error originates in the macro `$crate::sqlx_macros::expand_query` which comes from the expansion of the macro `sqlx::query_as` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: error communicating with database: Connection refused (os error 111) [INFO] [stdout] --> src/handler.rs:279:16 [INFO] [stdout] | [INFO] [stdout] 279 | let user = sqlx::query_as!(User, "SELECT * FROM users WHERE id = $1", user_id_uuid) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this error originates in the macro `$crate::sqlx_macros::expand_query` which comes from the expansion of the macro `sqlx::query_as` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: error communicating with database: Connection refused (os error 111) [INFO] [stdout] --> src/handler.rs:279:16 [INFO] [stdout] | [INFO] [stdout] 279 | let user = sqlx::query_as!(User, "SELECT * FROM users WHERE id = $1", user_id_uuid) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this error originates in the macro `$crate::sqlx_macros::expand_query` which comes from the expansion of the macro `sqlx::query_as` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: error communicating with database: Connection refused (os error 111) [INFO] [stdout] --> src/auth.rs:112:16 [INFO] [stdout] | [INFO] [stdout] 112 | let user = sqlx::query_as!(User, "SELECT * FROM users WHERE id = $1", user_id_uuid) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this error originates in the macro `$crate::sqlx_macros::expand_query` which comes from the expansion of the macro `sqlx::query_as` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: error communicating with database: Connection refused (os error 111) [INFO] [stdout] --> src/auth.rs:112:16 [INFO] [stdout] | [INFO] [stdout] 112 | let user = sqlx::query_as!(User, "SELECT * FROM users WHERE id = $1", user_id_uuid) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this error originates in the macro `$crate::sqlx_macros::expand_query` which comes from the expansion of the macro `sqlx::query_as` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: aborting due to 4 previous errors [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: could not compile `rinab` (bin "rinab") due to 5 previous errors [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stdout] error: aborting due to 4 previous errors [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: could not compile `rinab` (bin "rinab" test) due to 5 previous errors [INFO] running `Command { std: "docker" "inspect" "4beb8b9f9b4d4773c53e77ad29ecad63aa8e59e59ba8f446c27d9917f1d5dffb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4beb8b9f9b4d4773c53e77ad29ecad63aa8e59e59ba8f446c27d9917f1d5dffb", kill_on_drop: false }` [INFO] [stdout] 4beb8b9f9b4d4773c53e77ad29ecad63aa8e59e59ba8f446c27d9917f1d5dffb