[INFO] cloning repository https://github.com/dugrema/millegrilles_core
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/dugrema/millegrilles_core" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdugrema%2Fmillegrilles_core", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdugrema%2Fmillegrilles_core'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 1ee296988dcf20e3b3d6005b27c09f501afd3cfb
[INFO] testing dugrema/millegrilles_core against master#350d0ef0ec0493e6d21cfb265cb8211a0e74d766 for pr-145330-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdugrema%2Fmillegrilles_core" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/dugrema/millegrilles_core
[INFO] finished tweaking git repo https://github.com/dugrema/millegrilles_core
[INFO] tweaked toml for git repo https://github.com/dugrema/millegrilles_core written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/dugrema/millegrilles_core on toolchain 350d0ef0ec0493e6d21cfb265cb8211a0e74d766
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/dugrema/millegrilles_core 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" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating git repository `https://github.com/dugrema/millegrilles_common_rust.git`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Updating git repository `https://github.com/dugrema/millegrilles_cryptographie.git`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded binstring v0.1.1
[INFO] [stderr]   Downloaded jwt-simple v0.11.9
[INFO] [stderr]   Downloaded pkcs1 v0.4.1
[INFO] [stderr]   Downloaded async-io v2.3.2
[INFO] [stderr]   Downloaded hyper-rustls v0.26.0
[INFO] [stderr]   Downloaded pem-rfc7468 v0.6.0
[INFO] [stderr]   Downloaded p12-keystore v0.1.2
[INFO] [stderr]   Downloaded executor-trait v2.1.0
[INFO] [stderr]   Downloaded sha1_smol v1.0.0
[INFO] [stderr]   Downloaded trust-dns-resolver v0.21.2
[INFO] [stderr]   Downloaded hmac-sha1-compact v1.1.4
[INFO] [stderr]   Downloaded brotli v5.0.0
[INFO] [stderr]   Downloaded unsigned-varint v0.2.3
[INFO] [stderr]   Downloaded flagset v0.4.5
[INFO] [stderr]   Downloaded dryoc v0.7.0
[INFO] [stderr]   Downloaded asn1-rs v0.6.1
[INFO] [stderr]   Downloaded http-body v1.0.0
[INFO] [stderr]   Downloaded prettyplease v0.2.19
[INFO] [stderr]   Downloaded xattr v0.2.3
[INFO] [stderr]   Downloaded async-tar v0.4.2
[INFO] [stderr]   Downloaded rustls-webpki v0.102.3
[INFO] [stderr]   Downloaded filetime v0.2.23
[INFO] [stderr]   Downloaded async-executor v1.11.0
[INFO] [stderr]   Downloaded base32 v0.5.1
[INFO] [stderr]   Downloaded async-channel v2.2.1
[INFO] [stderr]   Downloaded compact_jwt v0.2.10
[INFO] [stderr]   Downloaded rustls-native-certs v0.7.0
[INFO] [stderr]   Downloaded x509-parser v0.13.2
[INFO] [stderr]   Downloaded tokio-executor-trait v2.1.1
[INFO] [stderr]   Downloaded serde_yaml v0.7.5
[INFO] [stderr]   Downloaded p384 v0.13.0
[INFO] [stderr]   Downloaded tokio-socks v0.5.1
[INFO] [stderr]   Downloaded der_derive v0.7.2
[INFO] [stderr]   Downloaded coarsetime v0.1.34
[INFO] [stderr]   Downloaded base64urlsafedata v0.1.3
[INFO] [stderr]   Downloaded security-framework v2.10.0
[INFO] [stderr]   Downloaded rustls v0.23.5
[INFO] [stderr]   Downloaded pkcs8 v0.9.0
[INFO] [stderr]   Downloaded wasm-streams v0.4.0
[INFO] [stderr]   Downloaded webpki-roots v0.26.1
[INFO] [stderr]   Downloaded rustls-pki-types v1.5.0
[INFO] [stderr]   Downloaded der v0.6.1
[INFO] [stderr]   Downloaded http-body-util v0.1.1
[INFO] [stderr]   Downloaded serde-helpers v0.1.0
[INFO] [stderr]   Downloaded serde_derive v1.0.200
[INFO] [stderr]   Downloaded fiat-crypto v0.2.8
[INFO] [stderr]   Downloaded hmac-sha512 v1.1.5
[INFO] [stderr]   Downloaded base64-url v3.0.0
[INFO] [stderr]   Downloaded serde v1.0.200
[INFO] [stderr]   Downloaded hyper v1.3.1
[INFO] [stderr]   Downloaded webauthn-rs-core v0.4.9
[INFO] [stderr]   Downloaded deflate64 v0.1.8
[INFO] [stderr]   Downloaded trust-dns-proto v0.21.2
[INFO] [stderr]   Downloaded finl_unicode v1.2.0
[INFO] [stderr]   Downloaded brotli-decompressor v4.0.0
[INFO] [stderr]   Downloaded async-compression v0.4.9
[INFO] [stderr]   Downloaded rsa v0.7.2
[INFO] [stderr]   Downloaded serde_bytes v0.11.14
[INFO] [stderr]   Downloaded async-global-executor-trait v2.1.0
[INFO] [stderr]   Downloaded asn1-rs v0.3.1
[INFO] [stderr]   Downloaded resolv-conf v0.7.0
[INFO] [stderr]   Downloaded substring v1.4.5
[INFO] [stderr]   Downloaded event-listener v5.3.0
[INFO] [stderr]   Downloaded tokio-reactor-trait v1.1.0
[INFO] [stderr]   Downloaded oid-registry v0.7.0
[INFO] [stderr]   Downloaded aws-lc-rs v1.7.0
[INFO] [stderr]   Downloaded spki v0.6.0
[INFO] [stderr]   Downloaded serde-json-core v0.5.1
[INFO] [stderr]   Downloaded hyper-util v0.1.3
[INFO] [stderr]   Downloaded tokio-stream v0.1.15
[INFO] [stderr]   Downloaded asn1-rs-derive v0.5.0
[INFO] [stderr]   Downloaded totp-rs v5.7.0
[INFO] [stderr]   Downloaded polling v3.7.0
[INFO] [stderr]   Downloaded rustls-pemfile v2.1.2
[INFO] [stderr]   Downloaded clang-sys v1.7.0
[INFO] [stderr]   Downloaded hmac-sha256 v1.1.7
[INFO] [stderr]   Downloaded cc v1.0.96
[INFO] [stderr]   Downloaded asn1-rs-impl v0.1.0
[INFO] [stderr]   Downloaded h2 v0.4.4
[INFO] [stderr]   Downloaded dryoc v0.5.3
[INFO] [stderr]   Downloaded k256 v0.13.3
[INFO] [stderr]   Downloaded parking_lot v0.12.2
[INFO] [stderr]   Downloaded webauthn-rs-proto v0.4.9
[INFO] [stderr]   Downloaded webauthn-rs v0.4.8
[INFO] [stderr]   Downloaded rustc_version_runtime v0.2.1
[INFO] [stderr]   Downloaded serde_cbor_2 v0.12.0-dev
[INFO] [stderr]   Downloaded enum-as-inner v0.4.0
[INFO] [stderr]   Downloaded security-framework-sys v2.10.0
[INFO] [stderr]   Downloaded blocking v1.6.0
[INFO] [stderr]   Downloaded tokio-amqp v2.0.0
[INFO] [stderr]   Downloaded rustls-connector v0.20.0
[INFO] [stderr]   Downloaded multicodec v0.1.0
[INFO] [stderr]   Downloaded redis v0.25.4
[INFO] [stderr]   Downloaded lapin v2.5.4
[INFO] [stderr]   Downloaded stringprep v0.1.4
[INFO] [stderr]   Downloaded reqwest v0.12.4
[INFO] [stderr]   Downloaded x509-parser v0.16.0
[INFO] [stderr]   Downloaded oid-registry v0.4.0
[INFO] [stderr]   Downloaded mirai-annotations v1.12.0
[INFO] [stderr]   Downloaded mongodb v2.8.2
[INFO] [stderr]   Downloaded ct-codecs v1.1.1
[INFO] [stderr]   Downloaded der-parser v7.0.0
[INFO] [stderr]   Downloaded displaydoc v0.2.4
[INFO] [stderr]   Downloaded bson v2.10.0
[INFO] [stderr]   Downloaded wasix v0.12.21
[INFO] [stderr]   Downloaded multihash v0.15.0
[INFO] [stderr]   Downloaded der-parser v9.0.0
[INFO] [stderr]   Downloaded asn1-rs-derive v0.1.0
[INFO] [stderr]   Downloaded aws-lc-sys v0.15.0
[INFO] [stderr]   Downloaded openssl-src v300.2.3+3.2.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 6ce0ffd4c6754caeaa930d6a851a7684a5191645b50f9091d6f59af20c05b3b5
[INFO] running `Command { std: "docker" "start" "-a" "6ce0ffd4c6754caeaa930d6a851a7684a5191645b50f9091d6f59af20c05b3b5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "6ce0ffd4c6754caeaa930d6a851a7684a5191645b50f9091d6f59af20c05b3b5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6ce0ffd4c6754caeaa930d6a851a7684a5191645b50f9091d6f59af20c05b3b5", kill_on_drop: false }`
[INFO] [stdout] 6ce0ffd4c6754caeaa930d6a851a7684a5191645b50f9091d6f59af20c05b3b5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1981611c58b415b286cd6437040e26d1640b64441e275312428f975d14658622
[INFO] running `Command { std: "docker" "start" "-a" "1981611c58b415b286cd6437040e26d1640b64441e275312428f975d14658622", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.154
[INFO] [stderr]    Compiling subtle v2.5.0
[INFO] [stderr]    Compiling value-bag v1.9.0
[INFO] [stderr]    Compiling const-oid v0.9.6
[INFO] [stderr]    Compiling proc-macro2 v1.0.101
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]    Compiling serde v1.0.200
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling futures-io v0.3.30
[INFO] [stderr]    Compiling smallvec v1.13.2
[INFO] [stderr]    Compiling indexmap v2.2.6
[INFO] [stderr]    Compiling base64ct v1.6.0
[INFO] [stderr]    Compiling time-macros v0.2.18
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling unicode-normalization v0.1.23
[INFO] [stderr]    Compiling unicode-bidi v0.3.15
[INFO] [stderr]    Compiling crossbeam-utils v0.8.19
[INFO] [stderr]    Compiling pem-rfc7468 v0.7.0
[INFO] [stderr]    Compiling flagset v0.4.5
[INFO] [stderr]    Compiling lazy_static v1.4.0
[INFO] [stderr]    Compiling serde_json v1.0.116
[INFO] [stderr]    Compiling parking v2.2.0
[INFO] [stderr]    Compiling dunce v1.0.4
[INFO] [stderr]    Compiling log v0.4.21
[INFO] [stderr]    Compiling num-bigint v0.4.4
[INFO] [stderr]    Compiling data-encoding v2.6.0
[INFO] [stderr]    Compiling futures-channel v0.3.30
[INFO] [stderr]    Compiling quote v1.0.36
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling idna v0.5.0
[INFO] [stderr]    Compiling aws-lc-rs v1.7.0
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling rustls-pki-types v1.5.0
[INFO] [stderr]    Compiling mirai-annotations v1.12.0
[INFO] [stderr]    Compiling fastrand v2.1.0
[INFO] [stderr]    Compiling rustix v0.38.34
[INFO] [stderr]    Compiling openssl v0.10.64
[INFO] [stderr]    Compiling event-listener v4.0.3
[INFO] [stderr]    Compiling linux-raw-sys v0.4.13
[INFO] [stderr]    Compiling oid-registry v0.7.0
[INFO] [stderr]    Compiling event-listener v5.3.0
[INFO] [stderr]    Compiling io-lifetimes v1.0.11
[INFO] [stderr]    Compiling rustls-pemfile v2.1.2
[INFO] [stderr]    Compiling event-listener-strategy v0.4.0
[INFO] [stderr]    Compiling http v1.1.0
[INFO] [stderr]    Compiling futures-lite v2.3.0
[INFO] [stderr]    Compiling async-lock v3.3.0
[INFO] [stderr]    Compiling event-listener-strategy v0.5.2
[INFO] [stderr]    Compiling polling v2.8.0
[INFO] [stderr]    Compiling event-listener v2.5.3
[INFO] [stderr]    Compiling getrandom v0.2.14
[INFO] [stderr]    Compiling jobserver v0.1.31
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling mio v0.8.11
[INFO] [stderr]    Compiling num_cpus v1.16.0
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling signal-hook-registry v1.4.2
[INFO] [stderr]    Compiling socket2 v0.5.7
[INFO] [stderr]    Compiling parking_lot v0.12.2
[INFO] [stderr]    Compiling cc v1.0.96
[INFO] [stderr]    Compiling rusticata-macros v4.1.0
[INFO] [stderr]    Compiling time v0.3.36
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling ff v0.13.0
[INFO] [stderr]    Compiling rustls v0.23.5
[INFO] [stderr]    Compiling rustix v0.37.27
[INFO] [stderr]    Compiling async-task v4.7.1
[INFO] [stderr]    Compiling piper v0.2.1
[INFO] [stderr]    Compiling group v0.13.0
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling socket2 v0.4.10
[INFO] [stderr]    Compiling async-channel v2.2.1
[INFO] [stderr]    Compiling async-io v1.13.0
[INFO] [stderr]    Compiling fastrand v1.9.0
[INFO] [stderr]    Compiling waker-fn v1.1.1
[INFO] [stderr]    Compiling linux-raw-sys v0.3.8
[INFO] [stderr]    Compiling async-executor v1.11.0
[INFO] [stderr]    Compiling blocking v1.6.0
[INFO] [stderr]    Compiling futures-lite v1.13.0
[INFO] [stderr]    Compiling flate2 v1.0.30
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling http-body v1.0.0
[INFO] [stderr]    Compiling async-lock v2.8.0
[INFO] [stderr]    Compiling rustls-native-certs v0.7.0
[INFO] [stderr]    Compiling curve25519-dalek v4.1.3
[INFO] [stderr]    Compiling pem-rfc7468 v0.6.0
[INFO] [stderr]    Compiling unicase v2.7.0
[INFO] [stderr]    Compiling base64 v0.13.1
[INFO] [stderr]    Compiling semver-parser v0.7.0
[INFO] [stderr]    Compiling cookie-factory v0.3.3
[INFO] [stderr]    Compiling semver v0.9.0
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]    Compiling simd-adler32 v0.3.7
[INFO] [stderr]    Compiling radium v0.7.0
[INFO] [stderr]    Compiling cmake v0.1.50
[INFO] [stderr]    Compiling openssl-src v300.2.3+3.2.1
[INFO] [stderr]    Compiling tower-layer v0.3.2
[INFO] [stderr]    Compiling regex-syntax v0.8.3
[INFO] [stderr]    Compiling rustls v0.22.4
[INFO] [stderr]    Compiling rustc_version v0.2.3
[INFO] [stderr]    Compiling iovec v0.1.4
[INFO] [stderr]    Compiling heapless v0.7.17
[INFO] [stderr]    Compiling cookie v0.17.0
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]    Compiling block-padding v0.2.1
[INFO] [stderr]    Compiling stable_deref_trait v1.2.0
[INFO] [stderr]    Compiling oid-registry v0.4.0
[INFO] [stderr]    Compiling failure_derive v0.1.8
[INFO] [stderr]    Compiling tap v1.0.1
[INFO] [stderr]    Compiling matches v0.1.10
[INFO] [stderr]    Compiling amq-protocol v7.2.3
[INFO] [stderr]    Compiling toml_datetime v0.6.5
[INFO] [stderr]    Compiling gimli v0.28.1
[INFO] [stderr]    Compiling hostname v0.3.1
[INFO] [stderr]    Compiling idna v0.2.3
[INFO] [stderr]    Compiling wyz v0.5.1
[INFO] [stderr]    Compiling toml_edit v0.19.15
[INFO] [stderr]    Compiling mime_guess v2.0.4
[INFO] [stderr]    Compiling rustc_version_runtime v0.2.1
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling ring v0.17.8
[INFO] [stderr]    Compiling aws-lc-sys v0.15.0
[INFO] [stderr]    Compiling openssl-sys v0.9.102
[INFO] [stderr]    Compiling zstd-sys v2.0.10+zstd.1.5.6
[INFO] [stderr]    Compiling backtrace v0.3.71
[INFO] [stderr]    Compiling bzip2-sys v0.1.11+1.0.8
[INFO] [stderr]    Compiling lzma-sys v0.1.20
[INFO] [stderr]    Compiling regex-automata v0.4.6
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling synstructure v0.12.6
[INFO] [stderr]    Compiling darling_core v0.13.4
[INFO] [stderr]    Compiling blake3 v1.5.1
[INFO] [stderr]    Compiling bytes v0.4.12
[INFO] [stderr]    Compiling fdeflate v0.3.7
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling num-iter v0.1.44
[INFO] [stderr]    Compiling hash32 v0.2.1
[INFO] [stderr]    Compiling addr2line v0.21.0
[INFO] [stderr]    Compiling flume v0.11.0
[INFO] [stderr]    Compiling idna v0.3.0
[INFO] [stderr]    Compiling object v0.32.2
[INFO] [stderr]    Compiling constant_time_eq v0.1.5
[INFO] [stderr]    Compiling arrayvec v0.5.2
[INFO] [stderr]    Compiling oid-registry v0.8.1
[INFO] [stderr]    Compiling regex v1.10.4
[INFO] [stderr]    Compiling lapin v2.5.4
[INFO] [stderr]    Compiling psl-types v2.0.11
[INFO] [stderr]    Compiling zeroize_derive v1.4.2
[INFO] [stderr]    Compiling serde_derive v1.0.200
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]    Compiling thiserror-impl v1.0.59
[INFO] [stderr]    Compiling tokio-macros v2.2.0
[INFO] [stderr]    Compiling zeroize v1.8.1
[INFO] [stderr]    Compiling displaydoc v0.2.4
[INFO] [stderr]    Compiling der_derive v0.7.2
[INFO] [stderr]    Compiling asn1-rs-impl v0.2.0
[INFO] [stderr]    Compiling tokio v1.37.0
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling block-padding v0.3.3
[INFO] [stderr]    Compiling tracing v0.1.40
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling inout v0.1.3
[INFO] [stderr]    Compiling async-trait v0.1.80
[INFO] [stderr]    Compiling cipher v0.4.4
[INFO] [stderr]    Compiling asn1-rs-derive v0.5.0
[INFO] [stderr]    Compiling thiserror v1.0.59
[INFO] [stderr]    Compiling der v0.7.9
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling pbkdf2 v0.12.2
[INFO] [stderr]    Compiling salsa20 v0.10.2
[INFO] [stderr]    Compiling signature v2.2.0
[INFO] [stderr]    Compiling futures-util v0.3.30
[INFO] [stderr]    Compiling cbc v0.1.2
[INFO] [stderr]    Compiling aes v0.8.4
[INFO] [stderr]    Compiling hkdf v0.12.4
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling asn1-rs v0.6.1
[INFO] [stderr]    Compiling scrypt v0.11.0
[INFO] [stderr]    Compiling polling v3.7.0
[INFO] [stderr]    Compiling crypto-bigint v0.5.5
[INFO] [stderr]    Compiling pin-project-internal v1.1.5
[INFO] [stderr]    Compiling rc2 v0.8.1
[INFO] [stderr]    Compiling des v0.8.1
[INFO] [stderr]    Compiling async-io v2.3.2
[INFO] [stderr]    Compiling rfc6979 v0.4.0
[INFO] [stderr]    Compiling der v0.6.1
[INFO] [stderr]    Compiling asn1-rs-derive v0.1.0
[INFO] [stderr]    Compiling asn1-rs-impl v0.1.0
[INFO] [stderr]    Compiling curve25519-dalek-derive v0.1.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.16
[INFO] [stderr]    Compiling asn1-rs v0.3.1
[INFO] [stderr]    Compiling spki v0.7.3
[INFO] [stderr]    Compiling der-parser v9.0.0
[INFO] [stderr]    Compiling pin-project v1.1.5
[INFO] [stderr]    Compiling async-global-executor v2.4.1
[INFO] [stderr]    Compiling x509-cert v0.2.5
[INFO] [stderr]    Compiling pkcs8 v0.10.2
[INFO] [stderr]    Compiling sec1 v0.7.3
[INFO] [stderr]    Compiling pkcs5 v0.7.1
[INFO] [stderr]    Compiling spki v0.6.0
[INFO] [stderr]    Compiling elliptic-curve v0.13.8
[INFO] [stderr]    Compiling executor-trait v2.1.0
[INFO] [stderr]    Compiling x509-parser v0.16.0
[INFO] [stderr]    Compiling reactor-trait v1.1.0
[INFO] [stderr]    Compiling chacha20 v0.9.1
[INFO] [stderr]    Compiling ecdsa v0.16.9
[INFO] [stderr]    Compiling darling_macro v0.13.4
[INFO] [stderr]    Compiling asn1-rs-derive v0.6.0
[INFO] [stderr]    Compiling primeorder v0.13.6
[INFO] [stderr]    Compiling darling v0.13.4
[INFO] [stderr]    Compiling pkcs8 v0.9.0
[INFO] [stderr]    Compiling sct v0.7.1
[INFO] [stderr]    Compiling thiserror v2.0.16
[INFO] [stderr]    Compiling rustls-webpki v0.101.7
[INFO] [stderr]    Compiling universal-hash v0.5.1
[INFO] [stderr]    Compiling digest v0.9.0
[INFO] [stderr]    Compiling block-buffer v0.9.0
[INFO] [stderr]    Compiling rustls v0.21.12
[INFO] [stderr]    Compiling data-encoding-macro-internal v0.1.13
[INFO] [stderr]    Compiling enum-as-inner v0.4.0
[INFO] [stderr]    Compiling funty v2.0.0
[INFO] [stderr]    Compiling rustc-demangle v0.1.23
[INFO] [stderr]    Compiling unsigned-varint v0.7.2
[INFO] [stderr]    Compiling futures v0.1.31
[INFO] [stderr]    Compiling portable-atomic v1.6.0
[INFO] [stderr]    Compiling heapless v0.8.0
[INFO] [stderr]    Compiling data-encoding-macro v0.1.15
[INFO] [stderr]    Compiling asn1-rs v0.7.1
[INFO] [stderr]    Compiling bitvec v1.0.1
[INFO] [stderr]    Compiling cms v0.2.3
[INFO] [stderr]    Compiling tokio-util v0.7.10
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling tokio-stream v0.1.15
[INFO] [stderr]    Compiling h2 v0.4.4
[INFO] [stderr]    Compiling resolv-conf v0.7.0
[INFO] [stderr]    Compiling pkcs1 v0.4.1
[INFO] [stderr]    Compiling pkcs12 v0.1.0
[INFO] [stderr]    Compiling tokio-io v0.1.13
[INFO] [stderr]    Compiling poly1305 v0.8.0
[INFO] [stderr]    Compiling p12-keystore v0.1.2
[INFO] [stderr]    Compiling serde_with_macros v1.5.2
[INFO] [stderr]    Compiling futures-executor v0.3.30
[INFO] [stderr]    Compiling async-reactor-trait v1.1.0
[INFO] [stderr]    Compiling der-parser v7.0.0
[INFO] [stderr]    Compiling async-global-executor-trait v2.1.0
[INFO] [stderr]    Compiling ed25519 v2.2.3
[INFO] [stderr]    Compiling signature v1.6.4
[INFO] [stderr]    Compiling pinky-swear v6.2.0
[INFO] [stderr]    Compiling aead v0.5.2
[INFO] [stderr]    Compiling num-bigint-dig v0.8.4
[INFO] [stderr]    Compiling zstd-safe v7.1.0
[INFO] [stderr]    Compiling publicsuffix v2.2.3
[INFO] [stderr]    Compiling url v2.5.0
[INFO] [stderr]    Compiling uuid v1.8.0
[INFO] [stderr]    Compiling chrono v0.4.38
[INFO] [stderr]    Compiling serde_bytes v0.11.14
[INFO] [stderr]    Compiling png v0.17.16
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling trust-dns-proto v0.21.2
[INFO] [stderr]    Compiling proc-macro-crate v1.3.1
[INFO] [stderr]    Compiling brotli-decompressor v4.0.0
[INFO] [stderr]    Compiling lru-cache v0.1.2
[INFO] [stderr]    Compiling amq-protocol-types v7.2.3
[INFO] [stderr]    Compiling base64urlsafedata v0.1.3
[INFO] [stderr]    Compiling http-body-util v0.1.1
[INFO] [stderr]    Compiling async-channel v1.9.0
[INFO] [stderr]    Compiling hash32 v0.3.1
[INFO] [stderr]    Compiling kv-log-macro v1.0.7
[INFO] [stderr]    Compiling substring v1.4.5
[INFO] [stderr]    Compiling core2 v0.4.0
[INFO] [stderr]    Compiling amq-protocol-uri v7.2.3
[INFO] [stderr]    Compiling convert_case v0.4.0
[INFO] [stderr]    Compiling dtoa v0.4.8
[INFO] [stderr]    Compiling byteorder-lite v0.1.0
[INFO] [stderr]    Compiling ct-codecs v1.1.1
[INFO] [stderr]    Compiling bytemuck v1.23.2
[INFO] [stderr]    Compiling either v1.11.0
[INFO] [stderr]    Compiling finl_unicode v1.2.0
[INFO] [stderr]    Compiling sha3 v0.9.1
[INFO] [stderr]    Compiling serde_yaml v0.7.5
[INFO] [stderr]    Compiling ed25519-compact v2.1.1
[INFO] [stderr]    Compiling bson v2.10.0
[INFO] [stderr]    Compiling derive_more v0.99.17
[INFO] [stderr]    Compiling tokio-socks v0.5.1
[INFO] [stderr]    Compiling image v0.25.6
[INFO] [stderr]    Compiling multihash v0.19.1
[INFO] [stderr]    Compiling stringprep v0.1.4
[INFO] [stderr]    Compiling multibase v0.9.1
[INFO] [stderr]    Compiling brotli v5.0.0
[INFO] [stderr]    Compiling hyper v1.3.1
[INFO] [stderr]    Compiling serde_cbor_2 v0.12.0-dev
[INFO] [stderr]    Compiling async-std v1.12.0
[INFO] [stderr]    Compiling cookie_store v0.20.0
[INFO] [stderr]    Compiling webauthn-rs-proto v0.4.9
[INFO] [stderr]    Compiling multihash-derive v0.7.2
[INFO] [stderr]    Compiling xz2 v0.1.7
[INFO] [stderr]    Compiling trust-dns-resolver v0.21.2
[INFO] [stderr]    Compiling serde-json-core v0.5.1
[INFO] [stderr]    Compiling rsa v0.7.2
[INFO] [stderr]    Compiling bzip2 v0.4.4
[INFO] [stderr]    Compiling zstd v0.13.1
[INFO] [stderr]    Compiling hyper-util v0.1.3
[INFO] [stderr]    Compiling failure v0.1.8
[INFO] [stderr]    Compiling serde_with v1.14.0
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling x509-parser v0.13.2
[INFO] [stderr]    Compiling tokio-rustls v0.24.1
[INFO] [stderr]    Compiling chacha20poly1305 v0.10.1
[INFO] [stderr]    Compiling ed25519-dalek v2.1.1
[INFO] [stderr]    Compiling der-parser v10.0.0
[INFO] [stderr]    Compiling tokio-reactor-trait v1.1.0
[INFO] [stderr]    Compiling combine v4.6.7
[INFO] [stderr]    Compiling tokio-executor-trait v2.1.1
[INFO] [stderr]    Compiling dryoc v0.5.3
[INFO] [stderr]    Compiling sha2 v0.9.9
[INFO] [stderr]    Compiling p384 v0.13.0
[INFO] [stderr]    Compiling p256 v0.13.2
[INFO] [stderr]    Compiling k256 v0.13.3
[INFO] [stderr]    Compiling hmac-sha256 v1.1.7
[INFO] [stderr]    Compiling sha-1 v0.10.1
[INFO] [stderr]    Compiling pbkdf2 v0.11.0
[INFO] [stderr]    Compiling blake2 v0.10.6
[INFO] [stderr]    Compiling hmac-sha512 v1.1.5
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling typed-builder v0.10.0
[INFO] [stderr]    Compiling derivative v2.2.0
[INFO] [stderr]    Compiling env_filter v0.1.0
[INFO] [stderr]    Compiling blake2s_simd v0.5.11
[INFO] [stderr]    Compiling blake2b_simd v0.5.11
[INFO] [stderr]    Compiling serde_repr v0.1.19
[INFO] [stderr]    Compiling filetime v0.2.23
[INFO] [stderr]    Compiling coarsetime v0.1.34
[INFO] [stderr]    Compiling xattr v0.2.3
[INFO] [stderr]    Compiling webpki-roots v0.26.1
[INFO] [stderr]    Compiling encoding_rs v0.8.34
[INFO] [stderr]    Compiling take_mut v0.2.2
[INFO] [stderr]    Compiling sha1_smol v1.0.0
[INFO] [stderr]    Compiling qrcodegen v1.8.0
[INFO] [stderr]    Compiling unsigned-varint v0.2.3
[INFO] [stderr]    Compiling deflate64 v0.1.8
[INFO] [stderr]    Compiling webpki-roots v0.25.4
[INFO] [stderr]    Compiling binstring v0.1.1
[INFO] [stderr]    Compiling hmac-sha1-compact v1.1.4
[INFO] [stderr]    Compiling multicodec v0.1.0
[INFO] [stderr]    Compiling async-tar v0.4.2
[INFO] [stderr]    Compiling qrcodegen-image v1.5.0
[INFO] [stderr]    Compiling multihash v0.15.0
[INFO] [stderr]    Compiling env_logger v0.11.3
[INFO] [stderr]    Compiling static_cell v2.1.0
[INFO] [stderr]    Compiling jwt-simple v0.11.9
[INFO] [stderr]    Compiling x509-parser v0.17.0
[INFO] [stderr]    Compiling serde-helpers v0.1.0
[INFO] [stderr]    Compiling futures v0.3.30
[INFO] [stderr]    Compiling dryoc v0.7.0
[INFO] [stderr]    Compiling tempfile v3.10.1
[INFO] [stderr]    Compiling fs2 v0.4.3
[INFO] [stderr]    Compiling atty v0.2.14
[INFO] [stderr]    Compiling base64-url v3.0.0
[INFO] [stderr]    Compiling base32 v0.5.1
[INFO] [stderr]    Compiling env_logger v0.9.3
[INFO] [stderr]    Compiling async-compression v0.4.9
[INFO] [stderr]    Compiling totp-rs v5.7.0
[INFO] [stderr]    Compiling mongodb v2.8.2
[INFO] [stderr]    Compiling rustls-webpki v0.102.3
[INFO] [stderr]    Compiling native-tls v0.2.11
[INFO] [stderr]    Compiling tokio-rustls v0.25.0
[INFO] [stderr]    Compiling hyper-rustls v0.26.0
[INFO] [stderr]    Compiling rustls-connector v0.20.0
[INFO] [stderr]    Compiling tcp-stream v0.28.0
[INFO] [stderr]    Compiling amq-protocol-tcp v7.2.3
[INFO] [stderr]    Compiling compact_jwt v0.2.10
[INFO] [stderr]    Compiling millegrilles_cryptographie v2025.2.2 (https://github.com/dugrema/millegrilles_cryptographie.git?tag=2025.2-release#55e276a0)
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling redis v0.25.4
[INFO] [stderr]    Compiling reqwest v0.12.4
[INFO] [stderr]    Compiling webauthn-rs-core v0.4.9
[INFO] [stderr]    Compiling webauthn-rs v0.4.8
[INFO] [stderr]    Compiling tokio-amqp v2.0.0
[INFO] [stderr]    Compiling millegrilles_common_rust v2025.4.2 (https://github.com/dugrema/millegrilles_common_rust.git?tag=2025.4-release#5b6ce0e5)
[INFO] [stderr]    Compiling millegrilles_core v2025.4.116 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]  --> src/validateur_pki_mongo.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::error::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `MiddlewareMessage`, `ReponseCertificatMaitredescles`, and `configurer as configurer_messages`
[INFO] [stdout]   --> src/validateur_pki_mongo.rs:16:44
[INFO] [stdout]    |
[INFO] [stdout] 16 | ...::{configurer as configurer_messages, EmetteurCertificat, formatter_message_certificat, IsConfigurationPki, ReponseCertificatMaitredescles, upsert_certificat, Middleware, MiddlewareMessages, RedisTrait, MiddlewareRessources, RabbitMqTrait, EmetteurNotificationsTrait, repondre_certificat, MiddlewareMessage};
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                                                                                                                                       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mpsc`
[INFO] [stdout]   --> src/validateur_pki_mongo.rs:31:45
[INFO] [stdout]    |
[INFO] [stdout] 31 | use millegrilles_common_rust::tokio::sync::{mpsc, Notify};
[INFO] [stdout]    |                                             ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::tokio`
[INFO] [stdout]   --> src/validateur_pki_mongo.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 | use millegrilles_common_rust::tokio;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::backup_v2::thread_backup_v2`
[INFO] [stdout]   --> src/validateur_pki_mongo.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | use millegrilles_common_rust::backup_v2::thread_backup_v2;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]  --> src/webauthn.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::error::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Formatter`
[INFO] [stdout]  --> src/webauthn.rs:2:23
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fmt::{Debug, Formatter};
[INFO] [stdout]   |                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error` and `warn`
[INFO] [stdout]  --> src/webauthn.rs:4:18
[INFO] [stdout]   |
[INFO] [stdout] 4 | use log::{debug, error, info, warn};
[INFO] [stdout]   |                  ^^^^^        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::rand`
[INFO] [stdout]  --> src/webauthn.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use millegrilles_common_rust::rand;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::rand::Rng`
[INFO] [stdout]  --> src/webauthn.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use millegrilles_common_rust::rand::Rng;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Array`, `Bson`, and `Document`
[INFO] [stdout]   --> src/webauthn.rs:11:43
[INFO] [stdout]    |
[INFO] [stdout] 11 | use millegrilles_common_rust::bson::{doc, Document, Array, Bson, DateTime as DateTimeBson};
[INFO] [stdout]    |                                           ^^^^^^^^  ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::openssl`
[INFO] [stdout]   --> src/webauthn.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use millegrilles_common_rust::openssl;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BigNumRef` and `BigNum`
[INFO] [stdout]   --> src/webauthn.rs:15:45
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::openssl::bn::{BigNumRef, BigNum};
[INFO] [stdout]    |                                             ^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Deref`
[INFO] [stdout]  --> src/maitredescomptes_manager.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ops::Deref;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BACKUP_CHAMP_BACKUP_TRANSACTIONS`, `TRANSACTION_CHAMP_BACKUP_FLAG`, `TRANSACTION_CHAMP_COMPLETE`, `TRANSACTION_CHAMP_EVENEMENT_COMPLETE`, `TRANSACTION_CHAMP_ID`, and `TRANSACTION_CHAMP_TRANSACTION_TRAITEE`
[INFO] [stdout]   --> src/maitredescomptes_manager.rs:11:54
[INFO] [stdout]    |
[INFO] [stdout] 11 | ...e, BACKUP_CHAMP_BACKUP_TRANSACTIONS, DOMAINE_NOM_MAITREDESCOMPTES, TRANSACTION_CHAMP_BACKUP_FLAG, TRANSACTION_CHAMP_COMPLETE, TRANSACTION_CHAMP_EVENEMENT_COMPLETE, TRANSACTION_CHAMP_ID, TRANSACTION_CHAMP_TRANSACTION_TRAITEE};
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CleChiffrageX25519Impl` and `CleDechiffrageX25519Impl`
[INFO] [stdout]   --> src/maitredescomptes_manager.rs:21:105
[INFO] [stdout]    |
[INFO] [stdout] 21 | ...ffrage_cles::{Cipher, CleChiffrageHandler, CleChiffrageX25519Impl, CleDechiffrageX25519Impl, CleSecreteSerialisee, Decipher};
[INFO] [stdout]    |                                               ^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CleSecreteCipher` and `DecipherMgs4`
[INFO] [stdout]   --> src/maitredescomptes_manager.rs:23:88
[INFO] [stdout]    |
[INFO] [stdout] 23 | use millegrilles_common_rust::millegrilles_cryptographie::chiffrage_mgs4::{CipherMgs4, CleSecreteCipher, DecipherMgs4};
[INFO] [stdout]    |                                                                                        ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519`
[INFO] [stdout]   --> src/maitredescomptes_manager.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::SystemTime`
[INFO] [stdout]  --> src/maitredescomptes_commands.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::time::SystemTime;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PasskeyRegistration`, `Passkey`, and `RegisterPublicKeyCredential`
[INFO] [stdout]  --> src/maitredescomptes_commands.rs:3:74
[INFO] [stdout]   |
[INFO] [stdout] 3 | ...llengeResponse, Passkey, PasskeyAuthentication, PasskeyRegistration, PublicKeyCredential, RegisterPublicKeyCredential, RequestChalleng...
[INFO] [stdout]   |                    ^^^^^^^                         ^^^^^^^^^^^^^^^^^^^                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NaiveDateTime` and `Timelike`
[INFO] [stdout]  --> src/maitredescomptes_commands.rs:8:50
[INFO] [stdout]   |
[INFO] [stdout] 8 | use millegrilles_common_rust::chrono::{DateTime, NaiveDateTime, Timelike, Utc};
[INFO] [stdout]   |                                                  ^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Base64`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:12:53
[INFO] [stdout]    |
[INFO] [stdout] 12 | use millegrilles_common_rust::jwt_simple::prelude::{Base64, Deserialize, Serialize};
[INFO] [stdout]    |                                                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MessageMilleGrillesOwned`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:14:112
[INFO] [stdout]    |
[INFO] [stdout] 14 | ...::messages_structs::{MessageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stdout]    |                                                           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `filtrer_doc_id`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:15:93
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, filtrer_doc_id, start_transaction_regular, Mo...
[INFO] [stdout]    |                                                                                             ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Bson`, `DateTime as DateTimeBson`, and `bson`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:21:38
[INFO] [stdout]    |
[INFO] [stdout] 21 | use millegrilles_common_rust::bson::{Bson, bson, DateTime as DateTimeBson, doc};
[INFO] [stdout]    |                                      ^^^^  ^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hacheur`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:23:60
[INFO] [stdout]    |
[INFO] [stdout] 23 | use millegrilles_common_rust::hachages::{hacher_bytes_vu8, Hacheur};
[INFO] [stdout]    |                                                            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `EtatTransaction` and `marquer_transaction`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:25:46
[INFO] [stdout]    |
[INFO] [stdout] 25 | use millegrilles_common_rust::transactions::{marquer_transaction, EtatTransaction};
[INFO] [stdout]    |                                              ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MessageConfirmation`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:26:49
[INFO] [stdout]    |
[INFO] [stdout] 26 | use millegrilles_common_rust::common_messages::{MessageConfirmation, ReponseSignatureCertificat};
[INFO] [stdout]    |                                                 ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HacheurBlake2s256`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:30:97
[INFO] [stdout]    |
[INFO] [stdout] 30 | use millegrilles_common_rust::millegrilles_cryptographie::hachages::{hacher_bytes, HachageCode, HacheurBlake2s256};
[INFO] [stdout]    |                                                                                                 ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `optionepochseconds`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:32:92
[INFO] [stdout]    |
[INFO] [stdout] 32 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::{epochseconds, optionepochseconds};
[INFO] [stdout]    |                                                                                            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TransactionMajUsagerDelegations`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:38:308
[INFO] [stdout]    |
[INFO] [stdout] 38 | ... TransactionAjouterCle, TransactionInscrireUsager, TransactionMajUsagerDelegations, TransactionSupprimerCles};
[INFO] [stdout]    |                                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `transaction_ajouter_delegation_signee`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:39:44
[INFO] [stdout]    |
[INFO] [stdout] 39 | use crate::maitredescomptes_transactions::{transaction_ajouter_delegation_signee, CommandRegisterOtp, TransactionRegisterOtp};
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CompteCredential`, `ConfigChallenge`, `Credential`, `authenticate_complete`, `multibase_to_safe`, and `valider_commande`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:40:23
[INFO] [stdout]    |
[INFO] [stdout] 40 | ...::{authenticate_complete, ClientAssertionResponse, CompteCredential, ConfigChallenge, Credential, CredentialWebauthn, generer_challenge_authentification, generer_challenge_registration, multibase_to_safe, valider_commande, v...
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^                           ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^  ^^^^^^^^^^                                                                                          ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PasskeyRegistration`, `Passkey`, `PublicKeyCredential`, and `RegisterPublicKeyCredential`
[INFO] [stdout]  --> src/maitredescomptes_requests.rs:4:74
[INFO] [stdout]   |
[INFO] [stdout] 4 | ...llengeResponse, Passkey, PasskeyAuthentication, PasskeyRegistration, PublicKeyCredential, RegisterPublicKeyCredential, RequestChalleng...
[INFO] [stdout]   |                    ^^^^^^^                         ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Bson`, `DateTime as DateTimeBson`, and `bson`
[INFO] [stdout]  --> src/maitredescomptes_requests.rs:6:38
[INFO] [stdout]   |
[INFO] [stdout] 6 | use millegrilles_common_rust::bson::{Bson, bson, DateTime as DateTimeBson, doc};
[INFO] [stdout]   |                                      ^^^^  ^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `base64_url`, `chrono`, and `serde_json`
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:17:32
[INFO] [stdout]    |
[INFO] [stdout] 17 | use millegrilles_common_rust::{base64_url, chrono, openssl, serde_json, uuid};
[INFO] [stdout]    |                                ^^^^^^^^^^  ^^^^^^           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Value`
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:19:50
[INFO] [stdout]    |
[INFO] [stdout] 19 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stdout]    |                                                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ClientAssertionResponse`, `CompteCredential`, `ConfigChallenge`, `Credential`, `authenticate_complete`, `multibase_to_safe`, `valider_commande`, `verifier_challenge_authentification`, and `verifier_challenge_registration`
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:24:23
[INFO] [stdout]    |
[INFO] [stdout] 24 | ...::{authenticate_complete, ClientAssertionResponse, CompteCredential, ConfigChallenge, Credential, CredentialWebauthn, generer_challenge_authentification, generer_challenge_registration, multibase_to_safe, valider_commande, verifier_challenge_authentification, verifier_challenge_registration};
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^  ^^^^^^^^^^                                                                                          ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::messages_structs::optionepochseconds`
[INFO] [stdout]  --> src/pki_structs.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::optionepochseconds;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::maitredescomptes_manager::preparer_index_mongodb`
[INFO] [stdout]   --> src/topology_manager.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::maitredescomptes_manager::preparer_index_mongodb;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BACKUP_CHAMP_BACKUP_TRANSACTIONS`, `TRANSACTION_CHAMP_BACKUP_FLAG`, `TRANSACTION_CHAMP_COMPLETE`, `TRANSACTION_CHAMP_EVENEMENT_COMPLETE`, `TRANSACTION_CHAMP_ID`, and `TRANSACTION_CHAMP_TRANSACTION_TRAITEE`
[INFO] [stdout]  --> src/catalogues_manager.rs:7:54
[INFO] [stdout]   |
[INFO] [stdout] 7 | ...e, BACKUP_CHAMP_BACKUP_TRANSACTIONS, TRANSACTION_CHAMP_BACKUP_FLAG, TRANSACTION_CHAMP_COMPLETE, TRANSACTION_CHAMP_EVENEMENT_COMPLETE, TRANSACTION_CHAMP_ID, TRANSACTION_CHAMP_TRANSACTION_TRAITEE};
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::maitredescomptes_manager::preparer_index_mongodb`
[INFO] [stdout]   --> src/catalogues_manager.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use crate::maitredescomptes_manager::preparer_index_mongodb;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BACKUP_CHAMP_BACKUP_TRANSACTIONS`, `PKI_TRANSACTION_NOUVEAU_CERTIFICAT`, `TRANSACTION_CHAMP_BACKUP_FLAG`, `TRANSACTION_CHAMP_COMPLETE`, `TRANSACTION_CHAMP_EVENEMENT_COMPLETE`, `TRANSACTION_CHAMP_ID`, and `TRANSACTION_CHAMP_TRANSACTION_TRAITEE`
[INFO] [stdout]  --> src/pki_manager.rs:6:54
[INFO] [stdout]   |
[INFO] [stdout] 6 | ...e, BACKUP_CHAMP_BACKUP_TRANSACTIONS, PKI_DOCUMENT_CHAMP_FINGERPRINT, PKI_DOMAINE_CERTIFICAT_NOM, PKI_TRANSACTION_NOUVEAU_CERTIFICAT, TRANSACTION_CHAMP_BACKUP_FLAG, TRANSACTION_CHAMP_COMPLETE, TRANSACTION_CHAMP_EVENEMENT_COMPLETE, TRANSACTION_CHAMP_ID, TRANSACTION_CHAMP_TRANSACTION_TRAITEE};
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::maitredescomptes_manager::preparer_index_mongodb`
[INFO] [stdout]   --> src/pki_manager.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crate::maitredescomptes_manager::preparer_index_mongodb;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RoutageMessageAction`
[INFO] [stdout]  --> src/maitredescomptes_transactions.rs:4:73
[INFO] [stdout]   |
[INFO] [stdout] 4 | use millegrilles_common_rust::generateur_messages::{GenerateurMessages, RoutageMessageAction};
[INFO] [stdout]   |                                                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `convertir_to_bson`
[INFO] [stdout]  --> src/maitredescomptes_transactions.rs:6:43
[INFO] [stdout]   |
[INFO] [stdout] 6 | use millegrilles_common_rust::mongo_dao::{convertir_to_bson, MongoDao};
[INFO] [stdout]   |                                           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/maitredescomptes_common.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Mutex`
[INFO] [stdout]  --> src/maitredescomptes_common.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::sync::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Bson` and `bson`
[INFO] [stdout]  --> src/maitredescomptes_common.rs:4:38
[INFO] [stdout]   |
[INFO] [stdout] 4 | use millegrilles_common_rust::bson::{Bson, bson, DateTime as DateTimeBson, doc};
[INFO] [stdout]   |                                      ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519`
[INFO] [stdout]   --> src/maitredescomptes_common.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> src/topology_requests.rs:1:33
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/topology_requests.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DateTime`
[INFO] [stdout]   --> src/topology_requests.rs:10:40
[INFO] [stdout]    |
[INFO] [stdout] 10 | use millegrilles_common_rust::chrono::{DateTime, Utc};
[INFO] [stdout]    |                                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MessageMilleGrillesOwned`
[INFO] [stdout]   --> src/topology_requests.rs:14:112
[INFO] [stdout]    |
[INFO] [stdout] 14 | ...::messages_structs::{MessageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stdout]    |                                                           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `convertir_to_bson`
[INFO] [stdout]   --> src/topology_requests.rs:15:74
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, MongoDao};
[INFO] [stdout]    |                                                                          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FindOneOptions`, `Hint`, and `UpdateOptions`
[INFO] [stdout]   --> src/topology_requests.rs:16:50
[INFO] [stdout]    |
[INFO] [stdout] 16 | use millegrilles_common_rust::mongodb::options::{FindOneOptions, FindOptions, Hint, UpdateOptions};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^               ^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Value`
[INFO] [stdout]   --> src/topology_requests.rs:19:50
[INFO] [stdout]    |
[INFO] [stdout] 19 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stdout]    |                                                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::url::Url`
[INFO] [stdout]   --> src/topology_requests.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use millegrilles_common_rust::url::Url;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ReponseInformationConsignationFichiers`, `RequeteConsignationFichiers`, and `RequeteDechiffrage`
[INFO] [stdout]   --> src/topology_requests.rs:22:49
[INFO] [stdout]    |
[INFO] [stdout] 22 | ...ssages::{ReponseInformationConsignationFichiers, RequeteConsignationFichiers, PresenceFichiersRepertoire, RequeteDechiffrage, RequeteF...
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `epochseconds`
[INFO] [stdout]   --> src/topology_requests.rs:24:78
[INFO] [stdout]    |
[INFO] [stdout] 24 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::{epochseconds, optionepochseconds};
[INFO] [stdout]    |                                                                              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_v2`
[INFO] [stdout]   --> src/topology_requests.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | use millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_v2;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PresenceInstanceContainer`
[INFO] [stdout]   --> src/topology_requests.rs:33:70
[INFO] [stdout]    |
[INFO] [stdout] 33 | use crate::topology_events::{PresenceInstanceConfiguredApplications, PresenceInstanceContainer, PresenceInstanceWebApplication};
[INFO] [stdout]    |                                                                      ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::topology_manager::TopologyManager`
[INFO] [stdout]   --> src/topology_requests.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | use crate::topology_manager::TopologyManager;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ApplicationConfiguree`, `ApplicationsV2`, `InformationApplicationInstance`, `InformationInstance`, `InformationMonitor`, `PresenceMonitor`, `ReponseUrlEtag`, `TransactionConfigurerConsignation`, and `WebAppLink`
[INFO] [stdout]   --> src/topology_requests.rs:35:31
[INFO] [stdout]    |
[INFO] [stdout] 35 | ...::{ApplicationConfiguree, ApplicationPublique, ApplicationsV2, FichePublique, FilehostServerRow, FilehostingCongurationRow, InformationApplication, InformationApplicationInstance, InformationInstance, InformationMonitor, PresenceMonitor, ReponseRelaiWeb, ReponseUrlEtag, RowFilehostFuuid, ServerInstanceConfigurationRow, ServerInstanceStatus, TransactionConfigurerConsignation, WebAppLink};
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^                       ^^^^^^^^^^^^^^                                                                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^                   ^^^^^^^^^^^^^^                                                                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `demander_jwt_hebergement`
[INFO] [stdout]  --> src/topology_commands.rs:8:30
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::topology_common::{demander_jwt_hebergement, maj_fiche_publique};
[INFO] [stdout]   |                              ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PresenceMonitor` and `TransactionConfigurerConsignation`
[INFO] [stdout]   --> src/topology_commands.rs:11:110
[INFO] [stdout]    |
[INFO] [stdout] 11 | ...lehostingCongurationRow, PresenceMonitor, ReponseUrlEtag, RowFilehostFuuid, TransactionConfigurerConsignation, TransactionSetCleidBack...
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^                                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::bson`
[INFO] [stdout]   --> src/topology_commands.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::bson;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `optionepochseconds`
[INFO] [stdout]   --> src/topology_commands.rs:25:92
[INFO] [stdout]    |
[INFO] [stdout] 25 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::{epochseconds, optionepochseconds};
[INFO] [stdout]    |                                                                                            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FindOneOptions`, `InsertManyOptions`, and `WriteConcern`
[INFO] [stdout]   --> src/topology_commands.rs:28:50
[INFO] [stdout]    |
[INFO] [stdout] 28 | use millegrilles_common_rust::mongodb::options::{FindOneOptions, FindOptions, InsertManyOptions, UpdateOptions, WriteConcern};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^               ^^^^^^^^^^^^^^^^^                 ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `map_opt_chrono_datetime_as_bson_datetime` and `opt_chrono_datetime_as_bson_datetime`
[INFO] [stdout]   --> src/topology_commands.rs:35:43
[INFO] [stdout]    |
[INFO] [stdout] 35 | use millegrilles_common_rust::mongo_dao::{opt_chrono_datetime_as_bson_datetime, map_opt_chrono_datetime_as_bson_datetime};
[INFO] [stdout]    |                                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]   --> src/topology_common.rs:15:66
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::jwt_simple::prelude::{Deserialize, Serialize};
[INFO] [stdout]    |                                                                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ApplicationPublique` and `InformationMonitor`
[INFO] [stdout]   --> src/topology_common.rs:22:31
[INFO] [stdout]    |
[INFO] [stdout] 22 | ...ts::{ApplicationPublique, ApplicationsV2, FichePublique, InformationApplicationInstance, InformationInstance, InformationMonitor, JwtH...
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^                                                                                      ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Array`, `Bson`, and `DateTime`
[INFO] [stdout]  --> src/topology_events.rs:4:43
[INFO] [stdout]   |
[INFO] [stdout] 4 | use millegrilles_common_rust::bson::{doc, Bson, Array, DateTime};
[INFO] [stdout]   |                                           ^^^^  ^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DOMAINE_APPLICATION_INSTANCE`
[INFO] [stdout]  --> src/topology_events.rs:9:118
[INFO] [stdout]   |
[INFO] [stdout] 9 | ...RESENCE_DOMAINE, CHAMP_CREATION, CHAMP_MODIFICATION, DOMAINE_APPLICATION_INSTANCE, RolesCertificats, BACKUP_EVENEMENT_MAJ};
[INFO] [stdout]   |                                                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_serializable_v2`
[INFO] [stdout]   --> src/topology_events.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_serializable_v2;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::deser_message_buffer`
[INFO] [stdout]   --> src/topology_events.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use millegrilles_common_rust::millegrilles_cryptographie::deser_message_buffer;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `convertir_bson_deserializable`
[INFO] [stdout]   --> src/topology_events.rs:15:43
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, start_transaction_regular, MongoDao};
[INFO] [stdout]    |                                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `json`
[INFO] [stdout]   --> src/topology_events.rs:19:44
[INFO] [stdout]    |
[INFO] [stdout] 19 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stdout]    |                                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PresenceMonitor`, `RowFuuid`, and `TransactionSetFichiersPrimaire`
[INFO] [stdout]   --> src/topology_events.rs:25:83
[INFO] [stdout]    |
[INFO] [stdout] 25 | ...uid, PresenceDomaine, PresenceMonitor, RowFilehostFuuid, RowFilehostId, RowFuuid, TransactionSetFichiersPrimaire};
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^^                                   ^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::mongo_dao::opt_chrono_datetime_as_bson_datetime`
[INFO] [stdout]   --> src/topology_events.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use millegrilles_common_rust::mongo_dao::opt_chrono_datetime_as_bson_datetime;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RoutageMessageAction`
[INFO] [stdout]  --> src/topology_transactions.rs:5:73
[INFO] [stdout]   |
[INFO] [stdout] 5 | use millegrilles_common_rust::generateur_messages::{GenerateurMessages, RoutageMessageAction};
[INFO] [stdout]   |                                                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `convertir_bson_deserializable` and `convertir_to_bson`
[INFO] [stdout]  --> src/topology_transactions.rs:7:43
[INFO] [stdout]   |
[INFO] [stdout] 7 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, MongoDao};
[INFO] [stdout]   |                                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FilehostServerRow`, `PresenceMonitor`, `TransactionConfigurerConsignation`, `TransactionSetFichiersPrimaire`, and `TransactionSupprimerConsignationInstance`
[INFO] [stdout]   --> src/topology_transactions.rs:11:31
[INFO] [stdout]    |
[INFO] [stdout] 11 | ...::{FilehostServerRow, FilehostingCongurationRow, PresenceDomaine, PresenceMonitor, TransactionConfigurerConsignation, TransactionSetFichiersPrimaire, TransactionSetFilehostInstance, TransactionSupprimerConsignationInstance};
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^                                              ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::common_messages::ReponseInformationConsignationFichiers`
[INFO] [stdout]   --> src/topology_transactions.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use millegrilles_common_rust::common_messages::ReponseInformationConsignationFichiers;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FindOneAndUpdateOptions` and `ReturnDocument`
[INFO] [stdout]   --> src/topology_transactions.rs:17:50
[INFO] [stdout]    |
[INFO] [stdout] 17 | use millegrilles_common_rust::mongodb::options::{FindOneAndUpdateOptions, ReturnDocument, UpdateOptions};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::serde_json::json`
[INFO] [stdout]   --> src/topology_transactions.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use millegrilles_common_rust::serde_json::json;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::bson`
[INFO] [stdout]  --> src/topology_maintenance.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use millegrilles_common_rust::bson;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FichePublique` and `InformationMonitor`
[INFO] [stdout]  --> src/topology_maintenance.rs:7:31
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::topology_structs::{FichePublique, FilehostServerRow, FilehostTransfer, InformationMonitor, RowFilehostFuuid};
[INFO] [stdout]   |                               ^^^^^^^^^^^^^                                       ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Datelike`
[INFO] [stdout]   --> src/topology_maintenance.rs:11:50
[INFO] [stdout]    |
[INFO] [stdout] 11 | use millegrilles_common_rust::chrono::{DateTime, Datelike, Timelike, Utc};
[INFO] [stdout]    |                                                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::common_messages::EventFilehost`
[INFO] [stdout]   --> src/topology_maintenance.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use millegrilles_common_rust::common_messages::EventFilehost;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CHAMP_CREATION`, `CHAMP_MODIFICATION`, `TOPOLOGIE_NOM_DOMAINE`, and `TRANSACTION_CHAMP_IDMG`
[INFO] [stdout]   --> src/topology_maintenance.rs:14:54
[INFO] [stdout]    |
[INFO] [stdout] 14 | ...ntes::{Securite, CHAMP_CREATION, CHAMP_MODIFICATION, DOMAINE_TOPOLOGIE, TOPOLOGIE_NOM_DOMAINE, TRANSACTION_CHAMP_IDMG};
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^                     ^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::middleware::EmetteurNotificationsTrait`
[INFO] [stdout]   --> src/topology_maintenance.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use millegrilles_common_rust::middleware::EmetteurNotificationsTrait;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FindOptions` and `UpdateOptions`
[INFO] [stdout]   --> src/topology_maintenance.rs:21:68
[INFO] [stdout]    |
[INFO] [stdout] 21 | use millegrilles_common_rust::mongodb::options::{AggregateOptions, FindOptions, Hint, UpdateOptions};
[INFO] [stdout]    |                                                                    ^^^^^^^^^^^        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::notifications::NotificationMessageInterne`
[INFO] [stdout]   --> src/topology_maintenance.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use millegrilles_common_rust::notifications::NotificationMessageInterne;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/catalogues_requests.rs:2:25
[INFO] [stdout]   |
[INFO] [stdout] 2 | use log::{debug, error, warn};
[INFO] [stdout]   |                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `convertir_bson_value` and `filtrer_doc_id`
[INFO] [stdout]  --> src/catalogues_requests.rs:9:43
[INFO] [stdout]   |
[INFO] [stdout] 9 | use millegrilles_common_rust::mongo_dao::{convertir_bson_value, filtrer_doc_id, MongoDao};
[INFO] [stdout]   |                                           ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `json`
[INFO] [stdout]   --> src/catalogues_requests.rs:13:44
[INFO] [stdout]    |
[INFO] [stdout] 13 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stdout]    |                                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MessageMilleGrillesOwned`
[INFO] [stdout]  --> src/catalogues_commands.rs:7:112
[INFO] [stdout]   |
[INFO] [stdout] 7 | ...::messages_structs::{MessageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stdout]   |                                                           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Catalogue`
[INFO] [stdout]   --> src/catalogues_commands.rs:15:33
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::catalogues_structs::{Catalogue, MessageCatalogue, SetPackageVersionTransaction};
[INFO] [stdout]    |                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/pki_maintenance.rs:1:25
[INFO] [stdout]   |
[INFO] [stdout] 1 | use log::{debug, error, warn};
[INFO] [stdout]   |                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EmetteurNotificationsTrait`
[INFO] [stdout]  --> src/pki_maintenance.rs:8:93
[INFO] [stdout]   |
[INFO] [stdout] 8 | use millegrilles_common_rust::middleware::{sauvegarder_traiter_transaction_serializable_v2, EmetteurNotificationsTrait};
[INFO] [stdout]   |                                                                                             ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::topology_events::produire_fiche_publique`
[INFO] [stdout]   --> src/pki_maintenance.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::topology_events::produire_fiche_publique;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `while` condition
[INFO] [stdout]   --> src/pki_maintenance.rs:71:10
[INFO] [stdout]    |
[INFO] [stdout] 71 |     while(cursor.advance().await?) {
[INFO] [stdout]    |          ^                       ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 71 -     while(cursor.advance().await?) {
[INFO] [stdout] 71 +     while cursor.advance().await? {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `domaine`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:48:18
[INFO] [stdout]    |
[INFO] [stdout] 48 |     let (action, domaine) = match &m.type_message {
[INFO] [stdout]    |                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message_id`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:300:23
[INFO] [stdout]     |
[INFO] [stdout] 300 |     let (transaction, message_id) = {
[INFO] [stdout]     |                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `securite`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:325:17
[INFO] [stdout]     |
[INFO] [stdout] 325 |             let securite = &transaction.securite;
[INFO] [stdout]     |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_securite`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resultat_inscrire_usager`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:356:17
[INFO] [stdout]     |
[INFO] [stdout] 356 |             let resultat_inscrire_usager = sauvegarder_traiter_transaction_v2(
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resultat_inscrire_usager`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uuid_transaction`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:386:9
[INFO] [stdout]     |
[INFO] [stdout] 386 |     let uuid_transaction = message_ref.id.to_owned();
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_uuid_transaction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `compte_usager`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:440:9
[INFO] [stdout]     |
[INFO] [stdout] 440 |     let compte_usager = match charger_compte_user_id(middleware, &user_id_certificat, session).await? {
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_compte_usager`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message_id`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:498:9
[INFO] [stdout]     |
[INFO] [stdout] 498 |     let message_id = {
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:524:20
[INFO] [stdout]     |
[INFO] [stdout] 524 |         if let Err(e) = message_confirmation.verifier_signature() {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `flag_generer_nouveau_certificat`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:810:9
[INFO] [stdout]     |
[INFO] [stdout] 810 |     let flag_generer_nouveau_certificat = commande.commande_webauthn.demande_certificat.is_some();
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_flag_generer_nouveau_certificat`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `hostname`
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1076:9
[INFO] [stdout]      |
[INFO] [stdout] 1076 |     let hostname = commande.hostname.as_str();
[INFO] [stdout]      |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_hostname`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `common_name`
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1117:9
[INFO] [stdout]      |
[INFO] [stdout] 1117 |     let common_name = match csr_subject.get("commonName") {
[INFO] [stdout]      |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_common_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resultat`
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1155:9
[INFO] [stdout]      |
[INFO] [stdout] 1155 |     let resultat = collection.update_one_with_session(filtre, ops, Some(options), session).await?;
[INFO] [stdout]      |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resultat`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `compte`
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1547:9
[INFO] [stdout]      |
[INFO] [stdout] 1547 |     let compte: CompteUsager = {
[INFO] [stdout]      |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_compte`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1588:9
[INFO] [stdout]      |
[INFO] [stdout] 1588 |     let mut encrypted_url = gestionnaire.encrypt_string(middleware, totp_url).await?;
[INFO] [stdout]      |         ----^^^^^^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `idmg`
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1695:9
[INFO] [stdout]      |
[INFO] [stdout] 1695 |     let idmg = middleware.idmg();
[INFO] [stdout]      |         ^^^^ help: if this is intentional, prefix it with an underscore: `_idmg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `totp_url_used` is assigned to, but never used
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1710:13
[INFO] [stdout]      |
[INFO] [stdout] 1710 |     let mut totp_url_used = None;
[INFO] [stdout]      |             ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: consider using `_totp_url_used` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `totp_url_used` is never read
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1727:17
[INFO] [stdout]      |
[INFO] [stdout] 1727 |                 totp_url_used = Some(totp_url);
[INFO] [stdout]      |                 ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:70:9
[INFO] [stdout]    |
[INFO] [stdout] 50 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ----------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 70 |         _ => {
[INFO] [stdout]    |         ^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unreachable_patterns)]` on by default
[INFO] [stdout] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stdout]    |
[INFO] [stdout] 50 -         DOMAINE_NOM => {
[INFO] [stdout] 50 +         DOMAIN_NAME => {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `u`
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:44:18
[INFO] [stdout]    |
[INFO] [stdout] 44 |             Some(u) => Ok(()),
[INFO] [stdout]    |                  ^ help: if this is intentional, prefix it with an underscore: `_u`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `DOMAINE_NOM`
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:50:9
[INFO] [stdout]    |
[INFO] [stdout] 50 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_DOMAINE_NOM`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/maitredescomptes_requests.rs:221:14
[INFO] [stdout]     |
[INFO] [stdout] 221 |         Some(mut doc_usager) => {
[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]    --> src/maitredescomptes_requests.rs:468:17
[INFO] [stdout]     |
[INFO] [stdout] 468 |             let mut doc_usager = d?;
[INFO] [stdout]     |                 ----^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `requete`
[INFO] [stdout]    --> src/maitredescomptes_requests.rs:574:9
[INFO] [stdout]     |
[INFO] [stdout] 574 |     let requete: RequeteListeUsagers = message_contenu.deserialize()?;
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_requete`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `middleware`
[INFO] [stdout]   --> src/maitredescomptes_events.rs:11:54
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub async fn consommer_evenement_maitredescomptes<M>(middleware: &M, m: MessageValide)
[INFO] [stdout]    |                                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_middleware`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/maitredescomptes_transactions.rs:239:20
[INFO] [stdout]     |
[INFO] [stdout] 239 |         if let Err(e) = collection_totp.delete_many_with_session(filtre, None, session).await {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/maitredescomptes_transactions.rs:243:20
[INFO] [stdout]     |
[INFO] [stdout] 243 |         if let Err(e) = collection.delete_many_with_session(filtre, None, session).await {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/maitredescomptes_transactions.rs:402:20
[INFO] [stdout]     |
[INFO] [stdout] 402 |         if let Err(e) = collection.delete_many_with_session(filtre, None, session).await {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/maitredescomptes_transactions.rs:407:20
[INFO] [stdout]     |
[INFO] [stdout] 407 |         if let Err(e) = collection_webauthn.delete_many_with_session(filtre, None, session).await {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message_id`
[INFO] [stdout]    --> src/maitredescomptes_common.rs:115:10
[INFO] [stdout]     |
[INFO] [stdout] 115 |     let (message_id, commande) = {
[INFO] [stdout]     |          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `user_id`
[INFO] [stdout]    --> src/maitredescomptes_common.rs:122:9
[INFO] [stdout]     |
[INFO] [stdout] 122 |     let user_id = commande.user_id.as_str();
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/pki_requests.rs:87:9
[INFO] [stdout]    |
[INFO] [stdout] 67 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ----------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 87 |         DOMAINE_CERTIFICAT_NOM => {
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stdout]    |
[INFO] [stdout] 67 -         DOMAINE_NOM => {
[INFO] [stdout] 67 +         DOMAIN_NAME => {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/pki_requests.rs:98:9
[INFO] [stdout]    |
[INFO] [stdout] 67 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ----------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 98 |         _ => Err(String::from("Mauvais type de requete de certificat"))
[INFO] [stdout]    |         ^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stdout]    |
[INFO] [stdout] 67 -         DOMAINE_NOM => {
[INFO] [stdout] 67 +         DOMAIN_NAME => {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `DOMAINE_NOM`
[INFO] [stdout]   --> src/pki_requests.rs:67:9
[INFO] [stdout]    |
[INFO] [stdout] 67 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_DOMAINE_NOM`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/pki_requests.rs:120:9
[INFO] [stdout]     |
[INFO] [stdout] 120 |     let mut builder_routage = RoutageMessageAction::builder("certificat", "infoCertificat", exchange);
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `domaine`
[INFO] [stdout]   --> src/pki_commands.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let (domaine, action) = match &m.type_message {
[INFO] [stdout]    |          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]   --> src/pki_commands.rs:82:91
[INFO] [stdout]    |
[INFO] [stdout] 82 | pub async fn traiter_commande_sauvegarder_certificat<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stdout]    |                                                                                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `domaine`
[INFO] [stdout]   --> src/pki_commands.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let domaine = match &m.type_message {
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `middleware`
[INFO] [stdout]    --> src/pki_commands.rs:120:47
[INFO] [stdout]     |
[INFO] [stdout] 120 | async fn valider_demande_signature_csr<'a, M>(middleware: &M, m: &'a MessageValide)
[INFO] [stdout]     |                                               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_middleware`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]   --> src/pki_transactions.rs:59:84
[INFO] [stdout]    |
[INFO] [stdout] 59 | async fn sauvegarder_certificat<M>(middleware: &M, transaction: TransactionValide, session: &mut ClientSession)
[INFO] [stdout]    |                                                                                    ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/topology_requests.rs:134:9
[INFO] [stdout]     |
[INFO] [stdout] 134 |         _ => {
[INFO] [stdout]     |         ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/topology_requests.rs:134:9
[INFO] [stdout]     |
[INFO] [stdout]  59 |         Securite::L1Public => {
[INFO] [stdout]     |         ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout]  84 |         Securite::L2Prive => {
[INFO] [stdout]     |         ----------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 108 |         Securite::L3Protege | Securite::L4Secure => {
[INFO] [stdout]     |         ---------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 134 |         _ => {
[INFO] [stdout]     |         ^ collectively making this unreachable
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/topology_requests.rs:128:17
[INFO] [stdout]     |
[INFO] [stdout] 110 |                 DOMAINE_NOM => {
[INFO] [stdout]     |                 ----------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 128 |                 _ => {
[INFO] [stdout]     |                 ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stdout]     |
[INFO] [stdout] 110 -                 DOMAINE_NOM => {
[INFO] [stdout] 110 +                 DOMAIN_NAME => {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `DOMAINE_NOM`
[INFO] [stdout]    --> src/topology_requests.rs:110:17
[INFO] [stdout]     |
[INFO] [stdout] 110 |                 DOMAINE_NOM => {
[INFO] [stdout]     |                 ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_DOMAINE_NOM`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/topology_requests.rs:190:25
[INFO] [stdout]     |
[INFO] [stdout] 190 |                     let mut fiche: FichePublique = convertir_bson_deserializable(doc_fiche)?;
[INFO] [stdout]     |                         ----^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `url_verifie`
[INFO] [stdout]    --> src/topology_requests.rs:392:23
[INFO] [stdout]     |
[INFO] [stdout] 392 |             let (jwt, url_verifie) = match demander_jwt_hebergement(middleware, &fiche_publique, None).await {
[INFO] [stdout]     |                       ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_url_verifie`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `refus`
[INFO] [stdout]    --> src/topology_requests.rs:451:17
[INFO] [stdout]     |
[INFO] [stdout] 451 |             let refus = json!({"ok": false, "err": "Acces refuse"});
[INFO] [stdout]     |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_refus`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `d`
[INFO] [stdout]     --> src/topology_requests.rs:1026:22
[INFO] [stdout]      |
[INFO] [stdout] 1026 |                 Some(d) => {
[INFO] [stdout]      |                      ^ help: if this is intentional, prefix it with an underscore: `_d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `gestionnaire`
[INFO] [stdout]    --> src/topology_commands.rs:116:89
[INFO] [stdout]     |
[INFO] [stdout] 116 | ...essage: MessageValide, gestionnaire: &TopologyManager, session: &mut ClientSession)
[INFO] [stdout]     |                           ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_gestionnaire`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]    --> src/topology_commands.rs:116:121
[INFO] [stdout]     |
[INFO] [stdout] 116 | ...ionnaire: &TopologyManager, session: &mut ClientSession)
[INFO] [stdout]     |                                ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commande`
[INFO] [stdout]    --> src/topology_commands.rs:221:13
[INFO] [stdout]     |
[INFO] [stdout] 221 |         let commande: TransactionSetFichiersPrimaire = match message_owned.deserialize() {
[INFO] [stdout]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commande`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/topology_commands.rs:200:70
[INFO] [stdout]     |
[INFO] [stdout] 200 | async fn traiter_commande_configurer_consignation<M>(middleware: &M, mut message: MessageValide, gestionnaire: &TopologyManager, session:...
[INFO] [stdout]     |                                                                      ----^^^^^^^
[INFO] [stdout]     |                                                                      |
[INFO] [stdout]     |                                                                      help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `gestionnaire`
[INFO] [stdout]    --> src/topology_commands.rs:872:66
[INFO] [stdout]     |
[INFO] [stdout] 872 | async fn command_file_visit<M>(middleware: &M, m: MessageValide, gestionnaire: &TopologyManager, session: &mut ClientSession)
[INFO] [stdout]     |                                                                  ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_gestionnaire`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: irrefutable `if let` pattern
[INFO] [stdout]     --> src/topology_commands.rs:1009:12
[INFO] [stdout]      |
[INFO] [stdout] 1009 |         if let extensions = m.certificat.extensions()? {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: this pattern will always match, so the `if let` is useless
[INFO] [stdout]      = help: consider replacing the `if let` with a `let`
[INFO] [stdout]      = note: `#[warn(irrefutable_let_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]     --> src/topology_commands.rs:1094:81
[INFO] [stdout]      |
[INFO] [stdout] 1094 | async fn commande_filehost_batch_transfers<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stdout]      |                                                                                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]     --> src/topology_commands.rs:1186:85
[INFO] [stdout]      |
[INFO] [stdout] 1186 | async fn commande_filehost_reset_visits_claims<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stdout]      |                                                                                     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]     --> src/topology_commands.rs:1242:81
[INFO] [stdout]      |
[INFO] [stdout] 1242 | async fn commande_filehost_reset_transfers<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stdout]      |                                                                                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]     --> src/topology_commands.rs:1313:77
[INFO] [stdout]      |
[INFO] [stdout] 1313 | async fn commande_domain_visits_claims<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stdout]      |                                                                             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `instance_id`
[INFO] [stdout]   --> src/topology_common.rs:60:10
[INFO] [stdout]    |
[INFO] [stdout] 60 |     for (instance_id, instance) in &fiche.instances {
[INFO] [stdout]    |          ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_instance_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inner`
[INFO] [stdout]   --> src/topology_common.rs:68:26
[INFO] [stdout]    |
[INFO] [stdout] 68 |                     Some(inner) => match etag.as_ref() {
[INFO] [stdout]    |                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_inner`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `hostname`
[INFO] [stdout]    --> src/topology_common.rs:128:21
[INFO] [stdout]     |
[INFO] [stdout] 128 |         if let Some(hostname) = url.host_str() {
[INFO] [stdout]     |                     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_hostname`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/topology_common.rs:179:33
[INFO] [stdout]     |
[INFO] [stdout] 179 | ...                   Err(e) => {
[INFO] [stdout]     |                           ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/topology_common.rs:195:20
[INFO] [stdout]     |
[INFO] [stdout] 195 |         if let Err(e) = message_owned.verifier_signature() {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `domaine`
[INFO] [stdout]   --> src/topology_events.rs:36:10
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let (domaine, action) = match &m.type_message {
[INFO] [stdout]    |          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `gestionnaire`
[INFO] [stdout]   --> src/topology_events.rs:86:72
[INFO] [stdout]    |
[INFO] [stdout] 86 | async fn traiter_presence_domaine<M>(middleware: &M, m: MessageValide, gestionnaire: &TopologyManager)
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_gestionnaire`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> src/topology_events.rs:134:9
[INFO] [stdout]     |
[INFO] [stdout] 134 |     let result = match collection.find_one_and_update(filtre, ops, Some(options)).await {
[INFO] [stdout]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/topology_events.rs:455:17
[INFO] [stdout]     |
[INFO] [stdout] 455 |             let mut missing_from = filehost_ids.difference(&filehost_ids_visits);
[INFO] [stdout]     |                 ----^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]    --> src/topology_transactions.rs:400:74
[INFO] [stdout]     |
[INFO] [stdout] 400 | async fn filehost_add<M>(middleware: &M, transaction: TransactionValide, session: &mut ClientSession)
[INFO] [stdout]     |                                                                          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/catalogues_requests.rs:191:9
[INFO] [stdout]     |
[INFO] [stdout] 191 |     let mut catalogue = match collection.find_one(filtre, None).await? {
[INFO] [stdout]     |         ----^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inner`
[INFO] [stdout]    --> src/catalogues_commands.rs:120:12
[INFO] [stdout]     |
[INFO] [stdout] 120 |         Ok(inner) => {
[INFO] [stdout]     |            ^^^^^ help: if this is intentional, prefix it with an underscore: `_inner`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/catalogues_commands.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |     let mut message_catalogue: MessageCatalogue = {
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::redis::Commands`
[INFO] [stdout]   --> src/topology_commands.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | use millegrilles_common_rust::redis::Commands;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::kv::Source`
[INFO] [stdout]  --> src/topology_events.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use log::kv::Source;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MessageValidable`
[INFO] [stdout]   --> src/topology_requests.rs:14:138
[INFO] [stdout]    |
[INFO] [stdout] 14 | ...essageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stdout]    |                                                               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Decipher`
[INFO] [stdout]   --> src/maitredescomptes_manager.rs:21:177
[INFO] [stdout]    |
[INFO] [stdout] 21 | ...ageX25519Impl, CleDechiffrageX25519Impl, CleSecreteSerialisee, Decipher};
[INFO] [stdout]    |                                                                   ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::tokio_stream::StreamExt`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 31 | use millegrilles_common_rust::tokio_stream::StreamExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::tokio_stream::StreamExt`
[INFO] [stdout]   --> src/topology_maintenance.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use millegrilles_common_rust::tokio_stream::StreamExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/validateur_pki_mongo.rs:519:22
[INFO] [stdout]     |
[INFO] [stdout] 519 |     let (middleware, mut futures) = preparer_middleware_db_v2().expect("preparer_middleware_db_v2");
[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]   --> src/webauthn.rs:46:9
[INFO] [stdout]    |
[INFO] [stdout] 46 |     let mut builder = WebauthnBuilder::new(rp_id, &rp_origin)?
[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]   --> src/webauthn.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut builder = WebauthnBuilder::new(rp_id, &rp_origin)?
[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]    --> src/webauthn.rs:130:9
[INFO] [stdout]     |
[INFO] [stdout] 130 |     let mut builder = WebauthnBuilder::new(rp_id, &rp_origin)?
[INFO] [stdout]     |         ----^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `credentials`
[INFO] [stdout]    --> src/webauthn.rs:380:30
[INFO] [stdout]     |
[INFO] [stdout] 380 | pub fn authenticate_complete(credentials: u64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, respons...
[INFO] [stdout]     |                              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_credentials`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `challenge`
[INFO] [stdout]    --> src/webauthn.rs:380:48
[INFO] [stdout]     |
[INFO] [stdout] 380 | pub fn authenticate_complete(credentials: u64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, respons...
[INFO] [stdout]     |                                                ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_challenge`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rsp`
[INFO] [stdout]    --> src/webauthn.rs:380:76
[INFO] [stdout]     |
[INFO] [stdout] 380 | ...64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, response: AuthenticatorAssertionResponseRaw, cr...
[INFO] [stdout]     |                                    ^^^ help: if this is intentional, prefix it with an underscore: `_rsp`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `manager`
[INFO] [stdout]    --> src/topology_manager.rs:120:24
[INFO] [stdout]     |
[INFO] [stdout] 120 | pub fn preparer_queues(manager: &TopologyManager) -> Vec<QueueType> {
[INFO] [stdout]     |                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_manager`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `manager`
[INFO] [stdout]    --> src/catalogues_manager.rs:119:24
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub fn preparer_queues(manager: &CataloguesManager) -> Vec<QueueType> {
[INFO] [stdout]     |                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_manager`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `niveaux_securite_prive`
[INFO] [stdout]    --> src/pki_manager.rs:118:9
[INFO] [stdout]     |
[INFO] [stdout] 118 |     let niveaux_securite_prive = vec!(Securite::L2Prive);  //, Securite::L3Protege);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_niveaux_securite_prive`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `manager`
[INFO] [stdout]    --> src/pki_manager.rs:114:24
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub fn preparer_queues(manager: &PkiManager) -> Vec<QueueType> {
[INFO] [stdout]     |                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_manager`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generer_challenge_auth` is never used
[INFO] [stdout]    --> src/webauthn.rs:164:8
[INFO] [stdout]     |
[INFO] [stdout] 164 | pub fn generer_challenge_auth(url_site: &str, credentials: Vec<Credential>) -> Result<Challenge, millegrilles_common_rust::error::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Credential` is never constructed
[INFO] [stdout]    --> src/webauthn.rs:187:12
[INFO] [stdout]     |
[INFO] [stdout] 187 | pub struct Credential {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/webauthn.rs:197:12
[INFO] [stdout]     |
[INFO] [stdout] 196 | impl Credential {
[INFO] [stdout]     | --------------- associated function in this implementation
[INFO] [stdout] 197 |     pub fn new<S>(cred_id: S, key_type: S, counter: Option<usize>, public_key_pem: Option<String>) -> Self
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Challenge` is never constructed
[INFO] [stdout]    --> src/webauthn.rs:277:12
[INFO] [stdout]     |
[INFO] [stdout] 277 | pub struct Challenge {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ConfigChallenge` is never constructed
[INFO] [stdout]    --> src/webauthn.rs:286:12
[INFO] [stdout]     |
[INFO] [stdout] 286 | pub struct ConfigChallenge {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `try_new` and `get_commande` are never used
[INFO] [stdout]    --> src/webauthn.rs:293:12
[INFO] [stdout]     |
[INFO] [stdout] 292 | impl ConfigChallenge {
[INFO] [stdout]     | -------------------- associated items in this implementation
[INFO] [stdout] 293 |     pub fn try_new<S>(hostname: S, challenge: S) -> Result<Self, CoreError>
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 308 |     fn get_commande(&self) -> Result<CommandeWebauthn, millegrilles_common_rust::error::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CommandeWebauthn` is never used
[INFO] [stdout]    --> src/webauthn.rs:334:6
[INFO] [stdout]     |
[INFO] [stdout] 334 | enum CommandeWebauthn {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AllowCredential` is never constructed
[INFO] [stdout]    --> src/webauthn.rs:339:12
[INFO] [stdout]     |
[INFO] [stdout] 339 | pub struct AllowCredential {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompteCredential` is never constructed
[INFO] [stdout]    --> src/webauthn.rs:346:12
[INFO] [stdout]     |
[INFO] [stdout] 346 | pub struct CompteCredential {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `verifier_commande` is never used
[INFO] [stdout]    --> src/webauthn.rs:356:4
[INFO] [stdout]     |
[INFO] [stdout] 356 | fn verifier_commande<S>(commande: &CommandeWebauthn, message: &S) -> Result<bool, millegrilles_common_rust::error::Error>
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `authenticate_complete` is never used
[INFO] [stdout]    --> src/webauthn.rs:380:8
[INFO] [stdout]     |
[INFO] [stdout] 380 | pub fn authenticate_complete(credentials: u64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, respons...
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `multibase_to_b64` is never used
[INFO] [stdout]    --> src/webauthn.rs:470:8
[INFO] [stdout]     |
[INFO] [stdout] 470 | pub fn multibase_to_b64<S>(val: S) -> Result<String, CoreError>
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `multibase_to_safe` is never used
[INFO] [stdout]    --> src/webauthn.rs:484:8
[INFO] [stdout]     |
[INFO] [stdout] 484 | pub fn multibase_to_safe<S>(val: S) -> Result<Base64UrlSafeData, CoreError>
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `valider_commande` is never used
[INFO] [stdout]    --> src/webauthn.rs:494:8
[INFO] [stdout]     |
[INFO] [stdout] 494 | pub fn valider_commande<M, S>(hostname: S, challenge: S, message: &M) -> Result<bool, CoreError>
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/error.rs:9:31
[INFO] [stdout]   |
[INFO] [stdout] 9 |     MillegrillesCryptographie(millegrilles_common_rust::millegrilles_cryptographie::error::Error),
[INFO] [stdout]   |     ------------------------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |     |
[INFO] [stdout]   |     field in this variant
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]   |
[INFO] [stdout] 9 -     MillegrillesCryptographie(millegrilles_common_rust::millegrilles_cryptographie::error::Error),
[INFO] [stdout] 9 +     MillegrillesCryptographie(()),
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:10:24
[INFO] [stdout]    |
[INFO] [stdout] 10 |     MillegrillesCommon(millegrilles_common_rust::error::Error),
[INFO] [stdout]    |     ------------------ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 10 -     MillegrillesCommon(millegrilles_common_rust::error::Error),
[INFO] [stdout] 10 +     MillegrillesCommon(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 |     Webauthn(WebauthnError),
[INFO] [stdout]    |     -------- ^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 11 -     Webauthn(WebauthnError),
[INFO] [stdout] 11 +     Webauthn(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:12:14
[INFO] [stdout]    |
[INFO] [stdout] 12 |     UrlParse(millegrilles_common_rust::url::ParseError),
[INFO] [stdout]    |     -------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 12 -     UrlParse(millegrilles_common_rust::url::ParseError),
[INFO] [stdout] 12 +     UrlParse(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:13:15
[INFO] [stdout]    |
[INFO] [stdout] 13 |     UuidParse(uuid::Error),
[INFO] [stdout]    |     --------- ^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 13 -     UuidParse(uuid::Error),
[INFO] [stdout] 13 +     UuidParse(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:14:15
[INFO] [stdout]    |
[INFO] [stdout] 14 |     Multibase(multibase::Error),
[INFO] [stdout]    |     --------- ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 14 -     Multibase(multibase::Error),
[INFO] [stdout] 14 +     Multibase(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 |     MongDb(mongodb::error::Error),
[INFO] [stdout]    |     ------ ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 15 -     MongDb(mongodb::error::Error),
[INFO] [stdout] 15 +     MongDb(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:16:15
[INFO] [stdout]    |
[INFO] [stdout] 16 |     SerdeJson(serde_json::Error),
[INFO] [stdout]    |     --------- ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 16 -     SerdeJson(serde_json::Error),
[INFO] [stdout] 16 +     SerdeJson(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 18 |     String(String)
[INFO] [stdout]    |     ------ ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 18 -     String(String)
[INFO] [stdout] 18 +     String(())
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Str` is never constructed
[INFO] [stdout]   --> src/error.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub enum Error {
[INFO] [stdout]    |          ----- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 17 |     Str(&'static str),
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `user_id` is never read
[INFO] [stdout]    --> src/maitredescomptes_requests.rs:708:5
[INFO] [stdout]     |
[INFO] [stdout] 706 | struct RowWebauthnCredentials {
[INFO] [stdout]     |        ---------------------- field in this struct
[INFO] [stdout] 707 |     #[serde(rename="userId")]
[INFO] [stdout] 708 |     user_id: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `RowWebauthnCredentials` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `user_id` is never read
[INFO] [stdout]    --> src/maitredescomptes_requests.rs:719:5
[INFO] [stdout]     |
[INFO] [stdout] 717 | struct RowActivationInfo {
[INFO] [stdout]     |        ----------------- field in this struct
[INFO] [stdout] 718 |     #[serde(rename="userId")]
[INFO] [stdout] 719 |     user_id: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `RowActivationInfo` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `user_id` is never read
[INFO] [stdout]    --> src/maitredescomptes_requests.rs:736:5
[INFO] [stdout]     |
[INFO] [stdout] 735 | struct RowCookieInfo {
[INFO] [stdout]     |        ------------- field in this struct
[INFO] [stdout] 736 |     user_id: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `RowCookieInfo` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRANSACTIONS` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:11:11
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub const NOM_Q_TRANSACTIONS: &str = "CoreMaitreDesComptes/transactions";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:13:11
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub const NOM_Q_TRIGGERS: &str = "CoreMaitreDesComptes/triggers";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TRANSACTION_SUPPRIMER_USAGER` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:37:11
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub const TRANSACTION_SUPPRIMER_USAGER: &str = "supprimerUsager";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EVENEMENT_SUPPRIMER_COMPTE_USAGER` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:47:11
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub const EVENEMENT_SUPPRIMER_COMPTE_USAGER: &str = "supprimerCompteUsager";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHAMP_ACTIVATIONS_PAR_FINGERPRINT_PK` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const CHAMP_ACTIVATIONS_PAR_FINGERPRINT_PK: &str = "activations_par_fingerprint_pk";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHAMP_WEBAUTHN_HOSTNAMES` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:66:11
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub const CHAMP_WEBAUTHN_HOSTNAMES: &str = "webauthn_hostnames";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRANSACTIONS` is never used
[INFO] [stdout]  --> src/pki_constants.rs:6:11
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub const NOM_Q_TRANSACTIONS: &str = "CorePki/transactions";
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_VOLATILS` is never used
[INFO] [stdout]  --> src/pki_constants.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub const NOM_Q_VOLATILS: &str = "CorePki/volatils";
[INFO] [stdout]   |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stdout]  --> src/pki_constants.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const NOM_Q_TRIGGERS: &str = "CorePki/triggers";
[INFO] [stdout]   |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRANSACTIONS_PKI` is never used
[INFO] [stdout]   --> src/pki_constants.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub const NOM_Q_TRANSACTIONS_PKI: &str = "CorePki/transactions";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRIGGERS_PKI` is never used
[INFO] [stdout]   --> src/pki_constants.rs:19:11
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub const NOM_Q_TRIGGERS_PKI: &str = "CorePki/triggers";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_DOMAINE_CERTIFICATS` is never used
[INFO] [stdout]   --> src/pki_constants.rs:20:11
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub const NOM_DOMAINE_CERTIFICATS: &str = "certificat";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EVENEMENT_CERTIFICAT_MAITREDESCLES` is never used
[INFO] [stdout]   --> src/pki_constants.rs:21:11
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub const EVENEMENT_CERTIFICAT_MAITREDESCLES: &str = "certMaitreDesCles";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_COLLECTION_FILEHOSTING_FUUIDS_WORK` is never used
[INFO] [stdout]   --> src/topology_constants.rs:18:11
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub const NOM_COLLECTION_FILEHOSTING_FUUIDS_WORK: &str = "CoreTopologie/filehostingFuuidsWork";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DOMAINE_PRESENCE_NOM` is never used
[INFO] [stdout]   --> src/topology_constants.rs:28:11
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub const DOMAINE_PRESENCE_NOM: &str = "CoreTopologie";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRANSACTIONS` is never used
[INFO] [stdout]   --> src/topology_constants.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub const NOM_Q_TRANSACTIONS: &str = "CoreTopologie/transactions";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stdout]   --> src/topology_constants.rs:33:11
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub const NOM_Q_TRIGGERS: &str = "CoreTopologie/triggers";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REQUETE_LISTE_NOEUDS` is never used
[INFO] [stdout]   --> src/topology_constants.rs:39:11
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub const REQUETE_LISTE_NOEUDS: &str = "listeNoeuds";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EVENEMENT_MODIFICATION_CONSIGNATION` is never used
[INFO] [stdout]   --> src/topology_constants.rs:92:11
[INFO] [stdout]    |
[INFO] [stdout] 92 | pub const EVENEMENT_MODIFICATION_CONSIGNATION: &str = "modificationConsignation";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INDEX_NOEUDS` is never used
[INFO] [stdout]    --> src/topology_constants.rs:105:11
[INFO] [stdout]     |
[INFO] [stdout] 105 | pub const INDEX_NOEUDS: &str = "noeuds";
[INFO] [stdout]     |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INDEX_INSTANCE_ID` is never used
[INFO] [stdout]    --> src/topology_constants.rs:109:11
[INFO] [stdout]     |
[INFO] [stdout] 109 | pub const INDEX_INSTANCE_ID: &str = "instance_id";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHAMP_NOEUD_ID` is never used
[INFO] [stdout]    --> src/topology_constants.rs:113:11
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub const CHAMP_NOEUD_ID: &str = CHAMP_INSTANCE_ID;
[INFO] [stdout]     |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHAMP_CONSIGNATION_ID` is never used
[INFO] [stdout]    --> src/topology_constants.rs:116:11
[INFO] [stdout]     |
[INFO] [stdout] 116 | pub const CHAMP_CONSIGNATION_ID: &str = "consignation_id";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_PREFERENCE_PRIMAIRE` is never used
[INFO] [stdout]    --> src/topology_constants.rs:118:11
[INFO] [stdout]     |
[INFO] [stdout] 118 | pub const ADRESSE_PREFERENCE_PRIMAIRE: u8 = 1;
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_PREFERENCE_SECONDAIRE` is never used
[INFO] [stdout]    --> src/topology_constants.rs:119:11
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub const ADRESSE_PREFERENCE_SECONDAIRE: u8 = 2;
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_NATURE_DNS` is never used
[INFO] [stdout]    --> src/topology_constants.rs:121:11
[INFO] [stdout]     |
[INFO] [stdout] 121 | pub const ADRESSE_NATURE_DNS: &str = "dns";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_NATURE_IP4` is never used
[INFO] [stdout]    --> src/topology_constants.rs:122:11
[INFO] [stdout]     |
[INFO] [stdout] 122 | pub const ADRESSE_NATURE_IP4: &str = "ip4";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_NATURE_IP6` is never used
[INFO] [stdout]    --> src/topology_constants.rs:123:11
[INFO] [stdout]     |
[INFO] [stdout] 123 | pub const ADRESSE_NATURE_IP6: &str = "ip6";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_NATURE_ONION` is never used
[INFO] [stdout]    --> src/topology_constants.rs:124:11
[INFO] [stdout]     |
[INFO] [stdout] 124 | pub const ADRESSE_NATURE_ONION: &str = "onion";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_CONSIGNATION_URL` is never used
[INFO] [stdout]    --> src/topology_constants.rs:126:11
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub const DEFAULT_CONSIGNATION_URL: &str = "https://fichiers:1443";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stdout]  --> src/catalogues_constants.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const NOM_Q_TRIGGERS: &str = "CoreCatalogues/triggers";
[INFO] [stdout]   |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `idmg` and `role` are never read
[INFO] [stdout]    --> src/topology_requests.rs:319:5
[INFO] [stdout]     |
[INFO] [stdout] 318 | struct HebergementTokenRow {
[INFO] [stdout]     |        ------------------- fields in this struct
[INFO] [stdout] 319 |     idmg: String,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 320 |     role: String,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ParametresGetCleConfiguration` is never constructed
[INFO] [stdout]     --> src/topology_requests.rs:1061:8
[INFO] [stdout]      |
[INFO] [stdout] 1061 | struct ParametresGetCleConfiguration {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ReponseConsignationSatellite` is never constructed
[INFO] [stdout]     --> src/topology_requests.rs:1066:12
[INFO] [stdout]      |
[INFO] [stdout] 1066 | pub struct ReponseConsignationSatellite {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RequeteConfigurationFichiers` is never constructed
[INFO] [stdout]     --> src/topology_requests.rs:1324:12
[INFO] [stdout]      |
[INFO] [stdout] 1324 | pub struct RequeteConfigurationFichiers {}
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ReponseConfigurationFichiers` is never constructed
[INFO] [stdout]     --> src/topology_requests.rs:1327:12
[INFO] [stdout]      |
[INFO] [stdout] 1327 | pub struct ReponseConfigurationFichiers {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `domaine`, `instance_id`, `dirty`, and `reclame_fuuids` are never read
[INFO] [stdout]     --> src/topology_requests.rs:1373:5
[INFO] [stdout]      |
[INFO] [stdout] 1372 | struct RowCoreTopologieDomaines {
[INFO] [stdout]      |        ------------------------ fields in this struct
[INFO] [stdout] 1373 |     domaine: String,
[INFO] [stdout]      |     ^^^^^^^
[INFO] [stdout] 1374 |     instance_id: String,
[INFO] [stdout]      |     ^^^^^^^^^^^
[INFO] [stdout] 1375 |     dirty: Option<bool>,
[INFO] [stdout]      |     ^^^^^
[INFO] [stdout] 1376 |     reclame_fuuids: Option<bool>,
[INFO] [stdout]      |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FilehostForExternalRequest` is never constructed
[INFO] [stdout]     --> src/topology_requests.rs:1593:8
[INFO] [stdout]      |
[INFO] [stdout] 1593 | struct FilehostForExternalRequest {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TransactionConfigurerConsignation` is never constructed
[INFO] [stdout]   --> src/topology_structs.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct TransactionConfigurerConsignation {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InfoService` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:139:12
[INFO] [stdout]     |
[INFO] [stdout] 139 | pub struct InfoService {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ApplicationConfiguree` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:148:12
[INFO] [stdout]     |
[INFO] [stdout] 148 | pub struct ApplicationConfiguree {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WebAppLink` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:154:12
[INFO] [stdout]     |
[INFO] [stdout] 154 | pub struct WebAppLink {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PresenceMonitor` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:162:12
[INFO] [stdout]     |
[INFO] [stdout] 162 | pub struct PresenceMonitor {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InformationApplication` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:204:12
[INFO] [stdout]     |
[INFO] [stdout] 204 | pub struct InformationApplication {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InformationMonitor` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:214:12
[INFO] [stdout]     |
[INFO] [stdout] 214 | pub struct InformationMonitor {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TransactionSupprimerConsignationInstance` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:236:12
[INFO] [stdout]     |
[INFO] [stdout] 236 | pub struct TransactionSupprimerConsignationInstance {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RowFuuid` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:315:12
[INFO] [stdout]     |
[INFO] [stdout] 315 | pub struct RowFuuid { pub fuuid: String }
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CommandeAjouterConsignationHebergee` is never constructed
[INFO] [stdout]    --> src/topology_commands.rs:344:8
[INFO] [stdout]     |
[INFO] [stdout] 344 | struct CommandeAjouterConsignationHebergee {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ReponseCommandeAjouterConsignationHebergee` is never constructed
[INFO] [stdout]    --> src/topology_commands.rs:348:8
[INFO] [stdout]     |
[INFO] [stdout] 348 | struct ReponseCommandeAjouterConsignationHebergee {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ReponseRelaiWeb` is never constructed
[INFO] [stdout]    --> src/topology_commands.rs:353:8
[INFO] [stdout]     |
[INFO] [stdout] 353 | struct ReponseRelaiWeb {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `charger_fiche` is never used
[INFO] [stdout]    --> src/topology_commands.rs:361:10
[INFO] [stdout]     |
[INFO] [stdout] 361 | async fn charger_fiche<M>(middleware: &M, url: &Url, etag: Option<&String>)
[INFO] [stdout]     |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `domaine`, `instance_id`, `dirty`, `reclame_fuuids`, and `cle_id_backup` are never read
[INFO] [stdout]    --> src/topology_commands.rs:554:5
[INFO] [stdout]     |
[INFO] [stdout] 553 | struct RowCoreTopologieDomaines {
[INFO] [stdout]     |        ------------------------ fields in this struct
[INFO] [stdout] 554 |     domaine: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 555 |     instance_id: String,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 556 |     dirty: Option<bool>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 557 |     reclame_fuuids: Option<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 558 |     cle_id_backup: Option<String>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `batch_no` is never read
[INFO] [stdout]     --> src/topology_commands.rs:1308:5
[INFO] [stdout]      |
[INFO] [stdout] 1306 | struct RequestFuuidsVisits {
[INFO] [stdout]      |        ------------------- field in this struct
[INFO] [stdout] 1307 |     fuuids: Vec<String>,
[INFO] [stdout] 1308 |     batch_no: Option<usize>,
[INFO] [stdout]      |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `instance_id` is never read
[INFO] [stdout]    --> src/topology_common.rs:504:5
[INFO] [stdout]     |
[INFO] [stdout] 503 | struct InstanceConfiguredAppRow {
[INFO] [stdout]     |        ------------------------ field in this struct
[INFO] [stdout] 504 |     instance_id: String,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PresenceFichiers` is never constructed
[INFO] [stdout]    --> src/topology_events.rs:143:8
[INFO] [stdout]     |
[INFO] [stdout] 143 | struct PresenceFichiers {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RowInstanceActivite` is never constructed
[INFO] [stdout]   --> src/topology_maintenance.rs:85:8
[INFO] [stdout]    |
[INFO] [stdout] 85 | struct RowInstanceActivite {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `fuuid` and `destination_filehost_id` are never read
[INFO] [stdout]   --> src/topology_maintenance.rs:96:5
[INFO] [stdout]    |
[INFO] [stdout] 93 | struct FuuidFilehostRow {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 96 |     fuuid: String,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 97 |     destination_filehost_id: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `claimer_type` is never read
[INFO] [stdout]    --> src/topology_maintenance.rs:325:5
[INFO] [stdout]     |
[INFO] [stdout] 323 | struct SyncStatusRow {
[INFO] [stdout]     |        ------------- field in this struct
[INFO] [stdout] 324 |     claimer: String,
[INFO] [stdout] 325 |     claimer_type: String,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `v` is never read
[INFO] [stdout]    --> src/topology_maintenance.rs:739:5
[INFO] [stdout]     |
[INFO] [stdout] 736 | struct ObjectToArrayKeyStringValueDate {
[INFO] [stdout]     |        ------------------------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 739 |     v: Option<DateTime<Utc>>
[INFO] [stdout]     |     ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `rpId` should have a snake case name
[INFO] [stdout]    --> src/webauthn.rs:280:5
[INFO] [stdout]     |
[INFO] [stdout] 280 |     rpId: String,
[INFO] [stdout]     |     ^^^^ help: convert the identifier to snake case: `rp_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `userVerification` should have a snake case name
[INFO] [stdout]    --> src/webauthn.rs:281:5
[INFO] [stdout]     |
[INFO] [stdout] 281 |     userVerification: String,  // 'preferred',
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `user_verification`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `allowCredentials` should have a snake case name
[INFO] [stdout]    --> src/webauthn.rs:282:5
[INFO] [stdout]     |
[INFO] [stdout] 282 |     allowCredentials: Vec<AllowCredential>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `allow_credentials`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:304:40
[INFO] [stdout]     |
[INFO] [stdout] 304 |         let message_id = message_ref.id.clone();
[INFO] [stdout]     |                                        ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `DOMAINE_NOM` should have a snake case name
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:50:9
[INFO] [stdout]    |
[INFO] [stdout] 50 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `domaine_nom`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `champs_index__transferts_filehostfuuid` should have a snake case name
[INFO] [stdout]    --> src/topology_manager.rs:455:9
[INFO] [stdout]     |
[INFO] [stdout] 455 |     let champs_index__transferts_filehostfuuid = vec!(
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `champs_index_transferts_filehostfuuid`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `DOMAINE_NOM` should have a snake case name
[INFO] [stdout]   --> src/pki_requests.rs:67:9
[INFO] [stdout]    |
[INFO] [stdout] 67 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `domaine_nom`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `DOMAINE_NOM` should have a snake case name
[INFO] [stdout]    --> src/topology_requests.rs:110:17
[INFO] [stdout]     |
[INFO] [stdout] 110 |                 DOMAINE_NOM => {
[INFO] [stdout]     |                 ^^^^^^^^^^^ help: convert the identifier to snake case: `domaine_nom`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 10m 15s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: millegrilles_common_rust v2025.4.2 (https://github.com/dugrema/millegrilles_common_rust.git?tag=2025.4-release#5b6ce0e5), num-bigint-dig v0.8.4, redis v0.25.4
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 4`
[INFO] running `Command { std: "docker" "inspect" "1981611c58b415b286cd6437040e26d1640b64441e275312428f975d14658622", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1981611c58b415b286cd6437040e26d1640b64441e275312428f975d14658622", kill_on_drop: false }`
[INFO] [stdout] 1981611c58b415b286cd6437040e26d1640b64441e275312428f975d14658622
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1169695ce25e3194997eb30ece5c38da5fa5dc434c0d154245e935b9b6ef9ad1
[INFO] running `Command { std: "docker" "start" "-a" "1169695ce25e3194997eb30ece5c38da5fa5dc434c0d154245e935b9b6ef9ad1", kill_on_drop: false }`
[INFO] [stderr]    Compiling millegrilles_core v2025.4.116 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]  --> src/validateur_pki_mongo.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::error::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `MiddlewareMessage`, `ReponseCertificatMaitredescles`, and `configurer as configurer_messages`
[INFO] [stdout]   --> src/validateur_pki_mongo.rs:16:44
[INFO] [stdout]    |
[INFO] [stdout] 16 | ...::{configurer as configurer_messages, EmetteurCertificat, formatter_message_certificat, IsConfigurationPki, ReponseCertificatMaitredescles, upsert_certificat, Middleware, MiddlewareMessages, RedisTrait, MiddlewareRessources, RabbitMqTrait, EmetteurNotificationsTrait, repondre_certificat, MiddlewareMessage};
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                                                                                                                                       ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mpsc`
[INFO] [stdout]   --> src/validateur_pki_mongo.rs:31:45
[INFO] [stdout]    |
[INFO] [stdout] 31 | use millegrilles_common_rust::tokio::sync::{mpsc, Notify};
[INFO] [stdout]    |                                             ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::tokio`
[INFO] [stdout]   --> src/validateur_pki_mongo.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 | use millegrilles_common_rust::tokio;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::backup_v2::thread_backup_v2`
[INFO] [stdout]   --> src/validateur_pki_mongo.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | use millegrilles_common_rust::backup_v2::thread_backup_v2;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]  --> src/webauthn.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::error::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Formatter`
[INFO] [stdout]  --> src/webauthn.rs:2:23
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fmt::{Debug, Formatter};
[INFO] [stdout]   |                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error` and `warn`
[INFO] [stdout]  --> src/webauthn.rs:4:18
[INFO] [stdout]   |
[INFO] [stdout] 4 | use log::{debug, error, info, warn};
[INFO] [stdout]   |                  ^^^^^        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::rand`
[INFO] [stdout]  --> src/webauthn.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use millegrilles_common_rust::rand;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::rand::Rng`
[INFO] [stdout]  --> src/webauthn.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use millegrilles_common_rust::rand::Rng;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Array`, `Bson`, and `Document`
[INFO] [stdout]   --> src/webauthn.rs:11:43
[INFO] [stdout]    |
[INFO] [stdout] 11 | use millegrilles_common_rust::bson::{doc, Document, Array, Bson, DateTime as DateTimeBson};
[INFO] [stdout]    |                                           ^^^^^^^^  ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::openssl`
[INFO] [stdout]   --> src/webauthn.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use millegrilles_common_rust::openssl;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BigNumRef` and `BigNum`
[INFO] [stdout]   --> src/webauthn.rs:15:45
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::openssl::bn::{BigNumRef, BigNum};
[INFO] [stdout]    |                                             ^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: duplicated attribute
[INFO] [stdout]    --> src/webauthn.rs:622:5
[INFO] [stdout]     |
[INFO] [stdout] 622 |     #[test]
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(duplicate_macro_attributes)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: duplicated attribute
[INFO] [stdout]    --> src/webauthn.rs:642:5
[INFO] [stdout]     |
[INFO] [stdout] 642 |     #[test]
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::bson::Uuid`
[INFO] [stdout]    --> src/webauthn.rs:512:9
[INFO] [stdout]     |
[INFO] [stdout] 512 |     use millegrilles_common_rust::bson::Uuid;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::multibase::Base`
[INFO] [stdout]    --> src/webauthn.rs:513:9
[INFO] [stdout]     |
[INFO] [stdout] 513 |     use millegrilles_common_rust::multibase::Base;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::serde_json::Value`
[INFO] [stdout]    --> src/webauthn.rs:518:9
[INFO] [stdout]     |
[INFO] [stdout] 518 |     use millegrilles_common_rust::serde_json::Value;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `webauthn_rs::WebauthnBuilder`
[INFO] [stdout]    --> src/webauthn.rs:520:9
[INFO] [stdout]     |
[INFO] [stdout] 520 |     use webauthn_rs::WebauthnBuilder;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Deref`
[INFO] [stdout]  --> src/maitredescomptes_manager.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ops::Deref;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BACKUP_CHAMP_BACKUP_TRANSACTIONS`, `TRANSACTION_CHAMP_BACKUP_FLAG`, `TRANSACTION_CHAMP_COMPLETE`, `TRANSACTION_CHAMP_EVENEMENT_COMPLETE`, `TRANSACTION_CHAMP_ID`, and `TRANSACTION_CHAMP_TRANSACTION_TRAITEE`
[INFO] [stdout]   --> src/maitredescomptes_manager.rs:11:54
[INFO] [stdout]    |
[INFO] [stdout] 11 | ...e, BACKUP_CHAMP_BACKUP_TRANSACTIONS, DOMAINE_NOM_MAITREDESCOMPTES, TRANSACTION_CHAMP_BACKUP_FLAG, TRANSACTION_CHAMP_COMPLETE, TRANSACTION_CHAMP_EVENEMENT_COMPLETE, TRANSACTION_CHAMP_ID, TRANSACTION_CHAMP_TRANSACTION_TRAITEE};
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CleChiffrageX25519Impl` and `CleDechiffrageX25519Impl`
[INFO] [stdout]   --> src/maitredescomptes_manager.rs:21:105
[INFO] [stdout]    |
[INFO] [stdout] 21 | ...ffrage_cles::{Cipher, CleChiffrageHandler, CleChiffrageX25519Impl, CleDechiffrageX25519Impl, CleSecreteSerialisee, Decipher};
[INFO] [stdout]    |                                               ^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CleSecreteCipher` and `DecipherMgs4`
[INFO] [stdout]   --> src/maitredescomptes_manager.rs:23:88
[INFO] [stdout]    |
[INFO] [stdout] 23 | use millegrilles_common_rust::millegrilles_cryptographie::chiffrage_mgs4::{CipherMgs4, CleSecreteCipher, DecipherMgs4};
[INFO] [stdout]    |                                                                                        ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519`
[INFO] [stdout]   --> src/maitredescomptes_manager.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::SystemTime`
[INFO] [stdout]  --> src/maitredescomptes_commands.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::time::SystemTime;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PasskeyRegistration`, `Passkey`, and `RegisterPublicKeyCredential`
[INFO] [stdout]  --> src/maitredescomptes_commands.rs:3:74
[INFO] [stdout]   |
[INFO] [stdout] 3 | ...llengeResponse, Passkey, PasskeyAuthentication, PasskeyRegistration, PublicKeyCredential, RegisterPublicKeyCredential, RequestChalleng...
[INFO] [stdout]   |                    ^^^^^^^                         ^^^^^^^^^^^^^^^^^^^                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NaiveDateTime` and `Timelike`
[INFO] [stdout]  --> src/maitredescomptes_commands.rs:8:50
[INFO] [stdout]   |
[INFO] [stdout] 8 | use millegrilles_common_rust::chrono::{DateTime, NaiveDateTime, Timelike, Utc};
[INFO] [stdout]   |                                                  ^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Base64`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:12:53
[INFO] [stdout]    |
[INFO] [stdout] 12 | use millegrilles_common_rust::jwt_simple::prelude::{Base64, Deserialize, Serialize};
[INFO] [stdout]    |                                                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MessageMilleGrillesOwned`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:14:112
[INFO] [stdout]    |
[INFO] [stdout] 14 | ...::messages_structs::{MessageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stdout]    |                                                           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `filtrer_doc_id`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:15:93
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, filtrer_doc_id, start_transaction_regular, Mo...
[INFO] [stdout]    |                                                                                             ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Bson`, `DateTime as DateTimeBson`, and `bson`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:21:38
[INFO] [stdout]    |
[INFO] [stdout] 21 | use millegrilles_common_rust::bson::{Bson, bson, DateTime as DateTimeBson, doc};
[INFO] [stdout]    |                                      ^^^^  ^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hacheur`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:23:60
[INFO] [stdout]    |
[INFO] [stdout] 23 | use millegrilles_common_rust::hachages::{hacher_bytes_vu8, Hacheur};
[INFO] [stdout]    |                                                            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `EtatTransaction` and `marquer_transaction`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:25:46
[INFO] [stdout]    |
[INFO] [stdout] 25 | use millegrilles_common_rust::transactions::{marquer_transaction, EtatTransaction};
[INFO] [stdout]    |                                              ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MessageConfirmation`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:26:49
[INFO] [stdout]    |
[INFO] [stdout] 26 | use millegrilles_common_rust::common_messages::{MessageConfirmation, ReponseSignatureCertificat};
[INFO] [stdout]    |                                                 ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HacheurBlake2s256`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:30:97
[INFO] [stdout]    |
[INFO] [stdout] 30 | use millegrilles_common_rust::millegrilles_cryptographie::hachages::{hacher_bytes, HachageCode, HacheurBlake2s256};
[INFO] [stdout]    |                                                                                                 ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `optionepochseconds`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:32:92
[INFO] [stdout]    |
[INFO] [stdout] 32 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::{epochseconds, optionepochseconds};
[INFO] [stdout]    |                                                                                            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TransactionMajUsagerDelegations`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:38:308
[INFO] [stdout]    |
[INFO] [stdout] 38 | ... TransactionAjouterCle, TransactionInscrireUsager, TransactionMajUsagerDelegations, TransactionSupprimerCles};
[INFO] [stdout]    |                                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `transaction_ajouter_delegation_signee`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:39:44
[INFO] [stdout]    |
[INFO] [stdout] 39 | use crate::maitredescomptes_transactions::{transaction_ajouter_delegation_signee, CommandRegisterOtp, TransactionRegisterOtp};
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CompteCredential`, `ConfigChallenge`, `Credential`, `authenticate_complete`, `multibase_to_safe`, and `valider_commande`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:40:23
[INFO] [stdout]    |
[INFO] [stdout] 40 | ...::{authenticate_complete, ClientAssertionResponse, CompteCredential, ConfigChallenge, Credential, CredentialWebauthn, generer_challenge_authentification, generer_challenge_registration, multibase_to_safe, valider_commande, v...
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^                           ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^  ^^^^^^^^^^                                                                                          ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PasskeyRegistration`, `Passkey`, `PublicKeyCredential`, and `RegisterPublicKeyCredential`
[INFO] [stdout]  --> src/maitredescomptes_requests.rs:4:74
[INFO] [stdout]   |
[INFO] [stdout] 4 | ...llengeResponse, Passkey, PasskeyAuthentication, PasskeyRegistration, PublicKeyCredential, RegisterPublicKeyCredential, RequestChalleng...
[INFO] [stdout]   |                    ^^^^^^^                         ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Bson`, `DateTime as DateTimeBson`, and `bson`
[INFO] [stdout]  --> src/maitredescomptes_requests.rs:6:38
[INFO] [stdout]   |
[INFO] [stdout] 6 | use millegrilles_common_rust::bson::{Bson, bson, DateTime as DateTimeBson, doc};
[INFO] [stdout]   |                                      ^^^^  ^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `base64_url`, `chrono`, and `serde_json`
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:17:32
[INFO] [stdout]    |
[INFO] [stdout] 17 | use millegrilles_common_rust::{base64_url, chrono, openssl, serde_json, uuid};
[INFO] [stdout]    |                                ^^^^^^^^^^  ^^^^^^           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Value`
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:19:50
[INFO] [stdout]    |
[INFO] [stdout] 19 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stdout]    |                                                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ClientAssertionResponse`, `CompteCredential`, `ConfigChallenge`, `Credential`, `authenticate_complete`, `multibase_to_safe`, `valider_commande`, `verifier_challenge_authentification`, and `verifier_challenge_registration`
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:24:23
[INFO] [stdout]    |
[INFO] [stdout] 24 | ...::{authenticate_complete, ClientAssertionResponse, CompteCredential, ConfigChallenge, Credential, CredentialWebauthn, generer_challenge_authentification, generer_challenge_registration, multibase_to_safe, valider_commande, verifier_challenge_authentification, verifier_challenge_registration};
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^  ^^^^^^^^^^                                                                                          ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::messages_structs::optionepochseconds`
[INFO] [stdout]  --> src/pki_structs.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::optionepochseconds;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::maitredescomptes_manager::preparer_index_mongodb`
[INFO] [stdout]   --> src/topology_manager.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::maitredescomptes_manager::preparer_index_mongodb;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BACKUP_CHAMP_BACKUP_TRANSACTIONS`, `TRANSACTION_CHAMP_BACKUP_FLAG`, `TRANSACTION_CHAMP_COMPLETE`, `TRANSACTION_CHAMP_EVENEMENT_COMPLETE`, `TRANSACTION_CHAMP_ID`, and `TRANSACTION_CHAMP_TRANSACTION_TRAITEE`
[INFO] [stdout]  --> src/catalogues_manager.rs:7:54
[INFO] [stdout]   |
[INFO] [stdout] 7 | ...e, BACKUP_CHAMP_BACKUP_TRANSACTIONS, TRANSACTION_CHAMP_BACKUP_FLAG, TRANSACTION_CHAMP_COMPLETE, TRANSACTION_CHAMP_EVENEMENT_COMPLETE, TRANSACTION_CHAMP_ID, TRANSACTION_CHAMP_TRANSACTION_TRAITEE};
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::maitredescomptes_manager::preparer_index_mongodb`
[INFO] [stdout]   --> src/catalogues_manager.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use crate::maitredescomptes_manager::preparer_index_mongodb;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BACKUP_CHAMP_BACKUP_TRANSACTIONS`, `PKI_TRANSACTION_NOUVEAU_CERTIFICAT`, `TRANSACTION_CHAMP_BACKUP_FLAG`, `TRANSACTION_CHAMP_COMPLETE`, `TRANSACTION_CHAMP_EVENEMENT_COMPLETE`, `TRANSACTION_CHAMP_ID`, and `TRANSACTION_CHAMP_TRANSACTION_TRAITEE`
[INFO] [stdout]  --> src/pki_manager.rs:6:54
[INFO] [stdout]   |
[INFO] [stdout] 6 | ...e, BACKUP_CHAMP_BACKUP_TRANSACTIONS, PKI_DOCUMENT_CHAMP_FINGERPRINT, PKI_DOMAINE_CERTIFICAT_NOM, PKI_TRANSACTION_NOUVEAU_CERTIFICAT, TRANSACTION_CHAMP_BACKUP_FLAG, TRANSACTION_CHAMP_COMPLETE, TRANSACTION_CHAMP_EVENEMENT_COMPLETE, TRANSACTION_CHAMP_ID, TRANSACTION_CHAMP_TRANSACTION_TRAITEE};
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::maitredescomptes_manager::preparer_index_mongodb`
[INFO] [stdout]   --> src/pki_manager.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crate::maitredescomptes_manager::preparer_index_mongodb;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RoutageMessageAction`
[INFO] [stdout]  --> src/maitredescomptes_transactions.rs:4:73
[INFO] [stdout]   |
[INFO] [stdout] 4 | use millegrilles_common_rust::generateur_messages::{GenerateurMessages, RoutageMessageAction};
[INFO] [stdout]   |                                                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `convertir_to_bson`
[INFO] [stdout]  --> src/maitredescomptes_transactions.rs:6:43
[INFO] [stdout]   |
[INFO] [stdout] 6 | use millegrilles_common_rust::mongo_dao::{convertir_to_bson, MongoDao};
[INFO] [stdout]   |                                           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/maitredescomptes_common.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Mutex`
[INFO] [stdout]  --> src/maitredescomptes_common.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::sync::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Bson` and `bson`
[INFO] [stdout]  --> src/maitredescomptes_common.rs:4:38
[INFO] [stdout]   |
[INFO] [stdout] 4 | use millegrilles_common_rust::bson::{Bson, bson, DateTime as DateTimeBson, doc};
[INFO] [stdout]   |                                      ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519`
[INFO] [stdout]   --> src/maitredescomptes_common.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> src/topology_requests.rs:1:33
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/topology_requests.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DateTime`
[INFO] [stdout]   --> src/topology_requests.rs:10:40
[INFO] [stdout]    |
[INFO] [stdout] 10 | use millegrilles_common_rust::chrono::{DateTime, Utc};
[INFO] [stdout]    |                                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MessageMilleGrillesOwned`
[INFO] [stdout]   --> src/topology_requests.rs:14:112
[INFO] [stdout]    |
[INFO] [stdout] 14 | ...::messages_structs::{MessageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stdout]    |                                                           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `convertir_to_bson`
[INFO] [stdout]   --> src/topology_requests.rs:15:74
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, MongoDao};
[INFO] [stdout]    |                                                                          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FindOneOptions`, `Hint`, and `UpdateOptions`
[INFO] [stdout]   --> src/topology_requests.rs:16:50
[INFO] [stdout]    |
[INFO] [stdout] 16 | use millegrilles_common_rust::mongodb::options::{FindOneOptions, FindOptions, Hint, UpdateOptions};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^               ^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Value`
[INFO] [stdout]   --> src/topology_requests.rs:19:50
[INFO] [stdout]    |
[INFO] [stdout] 19 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stdout]    |                                                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::url::Url`
[INFO] [stdout]   --> src/topology_requests.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use millegrilles_common_rust::url::Url;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ReponseInformationConsignationFichiers`, `RequeteConsignationFichiers`, and `RequeteDechiffrage`
[INFO] [stdout]   --> src/topology_requests.rs:22:49
[INFO] [stdout]    |
[INFO] [stdout] 22 | ...ssages::{ReponseInformationConsignationFichiers, RequeteConsignationFichiers, PresenceFichiersRepertoire, RequeteDechiffrage, RequeteF...
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `epochseconds`
[INFO] [stdout]   --> src/topology_requests.rs:24:78
[INFO] [stdout]    |
[INFO] [stdout] 24 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::{epochseconds, optionepochseconds};
[INFO] [stdout]    |                                                                              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_v2`
[INFO] [stdout]   --> src/topology_requests.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | use millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_v2;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PresenceInstanceContainer`
[INFO] [stdout]   --> src/topology_requests.rs:33:70
[INFO] [stdout]    |
[INFO] [stdout] 33 | use crate::topology_events::{PresenceInstanceConfiguredApplications, PresenceInstanceContainer, PresenceInstanceWebApplication};
[INFO] [stdout]    |                                                                      ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::topology_manager::TopologyManager`
[INFO] [stdout]   --> src/topology_requests.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | use crate::topology_manager::TopologyManager;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ApplicationConfiguree`, `ApplicationsV2`, `InformationApplicationInstance`, `InformationInstance`, `InformationMonitor`, `PresenceMonitor`, `ReponseUrlEtag`, `TransactionConfigurerConsignation`, and `WebAppLink`
[INFO] [stdout]   --> src/topology_requests.rs:35:31
[INFO] [stdout]    |
[INFO] [stdout] 35 | ...::{ApplicationConfiguree, ApplicationPublique, ApplicationsV2, FichePublique, FilehostServerRow, FilehostingCongurationRow, InformationApplication, InformationApplicationInstance, InformationInstance, InformationMonitor, PresenceMonitor, ReponseRelaiWeb, ReponseUrlEtag, RowFilehostFuuid, ServerInstanceConfigurationRow, ServerInstanceStatus, TransactionConfigurerConsignation, WebAppLink};
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^                       ^^^^^^^^^^^^^^                                                                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^                   ^^^^^^^^^^^^^^                                                                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `demander_jwt_hebergement`
[INFO] [stdout]  --> src/topology_commands.rs:8:30
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::topology_common::{demander_jwt_hebergement, maj_fiche_publique};
[INFO] [stdout]   |                              ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PresenceMonitor` and `TransactionConfigurerConsignation`
[INFO] [stdout]   --> src/topology_commands.rs:11:110
[INFO] [stdout]    |
[INFO] [stdout] 11 | ...lehostingCongurationRow, PresenceMonitor, ReponseUrlEtag, RowFilehostFuuid, TransactionConfigurerConsignation, TransactionSetCleidBack...
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^                                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::bson`
[INFO] [stdout]   --> src/topology_commands.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::bson;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `optionepochseconds`
[INFO] [stdout]   --> src/topology_commands.rs:25:92
[INFO] [stdout]    |
[INFO] [stdout] 25 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::{epochseconds, optionepochseconds};
[INFO] [stdout]    |                                                                                            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FindOneOptions`, `InsertManyOptions`, and `WriteConcern`
[INFO] [stdout]   --> src/topology_commands.rs:28:50
[INFO] [stdout]    |
[INFO] [stdout] 28 | use millegrilles_common_rust::mongodb::options::{FindOneOptions, FindOptions, InsertManyOptions, UpdateOptions, WriteConcern};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^               ^^^^^^^^^^^^^^^^^                 ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `map_opt_chrono_datetime_as_bson_datetime` and `opt_chrono_datetime_as_bson_datetime`
[INFO] [stdout]   --> src/topology_commands.rs:35:43
[INFO] [stdout]    |
[INFO] [stdout] 35 | use millegrilles_common_rust::mongo_dao::{opt_chrono_datetime_as_bson_datetime, map_opt_chrono_datetime_as_bson_datetime};
[INFO] [stdout]    |                                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]   --> src/topology_common.rs:15:66
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::jwt_simple::prelude::{Deserialize, Serialize};
[INFO] [stdout]    |                                                                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ApplicationPublique` and `InformationMonitor`
[INFO] [stdout]   --> src/topology_common.rs:22:31
[INFO] [stdout]    |
[INFO] [stdout] 22 | ...ts::{ApplicationPublique, ApplicationsV2, FichePublique, InformationApplicationInstance, InformationInstance, InformationMonitor, JwtH...
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^                                                                                      ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Array`, `Bson`, and `DateTime`
[INFO] [stdout]  --> src/topology_events.rs:4:43
[INFO] [stdout]   |
[INFO] [stdout] 4 | use millegrilles_common_rust::bson::{doc, Bson, Array, DateTime};
[INFO] [stdout]   |                                           ^^^^  ^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DOMAINE_APPLICATION_INSTANCE`
[INFO] [stdout]  --> src/topology_events.rs:9:118
[INFO] [stdout]   |
[INFO] [stdout] 9 | ...RESENCE_DOMAINE, CHAMP_CREATION, CHAMP_MODIFICATION, DOMAINE_APPLICATION_INSTANCE, RolesCertificats, BACKUP_EVENEMENT_MAJ};
[INFO] [stdout]   |                                                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_serializable_v2`
[INFO] [stdout]   --> src/topology_events.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_serializable_v2;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::deser_message_buffer`
[INFO] [stdout]   --> src/topology_events.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use millegrilles_common_rust::millegrilles_cryptographie::deser_message_buffer;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `convertir_bson_deserializable`
[INFO] [stdout]   --> src/topology_events.rs:15:43
[INFO] [stdout]    |
[INFO] [stdout] 15 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, start_transaction_regular, MongoDao};
[INFO] [stdout]    |                                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `json`
[INFO] [stdout]   --> src/topology_events.rs:19:44
[INFO] [stdout]    |
[INFO] [stdout] 19 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stdout]    |                                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PresenceMonitor`, `RowFuuid`, and `TransactionSetFichiersPrimaire`
[INFO] [stdout]   --> src/topology_events.rs:25:83
[INFO] [stdout]    |
[INFO] [stdout] 25 | ...uid, PresenceDomaine, PresenceMonitor, RowFilehostFuuid, RowFilehostId, RowFuuid, TransactionSetFichiersPrimaire};
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^^                                   ^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::mongo_dao::opt_chrono_datetime_as_bson_datetime`
[INFO] [stdout]   --> src/topology_events.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use millegrilles_common_rust::mongo_dao::opt_chrono_datetime_as_bson_datetime;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RoutageMessageAction`
[INFO] [stdout]  --> src/topology_transactions.rs:5:73
[INFO] [stdout]   |
[INFO] [stdout] 5 | use millegrilles_common_rust::generateur_messages::{GenerateurMessages, RoutageMessageAction};
[INFO] [stdout]   |                                                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `convertir_bson_deserializable` and `convertir_to_bson`
[INFO] [stdout]  --> src/topology_transactions.rs:7:43
[INFO] [stdout]   |
[INFO] [stdout] 7 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, MongoDao};
[INFO] [stdout]   |                                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FilehostServerRow`, `PresenceMonitor`, `TransactionConfigurerConsignation`, `TransactionSetFichiersPrimaire`, and `TransactionSupprimerConsignationInstance`
[INFO] [stdout]   --> src/topology_transactions.rs:11:31
[INFO] [stdout]    |
[INFO] [stdout] 11 | ...::{FilehostServerRow, FilehostingCongurationRow, PresenceDomaine, PresenceMonitor, TransactionConfigurerConsignation, TransactionSetFichiersPrimaire, TransactionSetFilehostInstance, TransactionSupprimerConsignationInstance};
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^                                              ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::common_messages::ReponseInformationConsignationFichiers`
[INFO] [stdout]   --> src/topology_transactions.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use millegrilles_common_rust::common_messages::ReponseInformationConsignationFichiers;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FindOneAndUpdateOptions` and `ReturnDocument`
[INFO] [stdout]   --> src/topology_transactions.rs:17:50
[INFO] [stdout]    |
[INFO] [stdout] 17 | use millegrilles_common_rust::mongodb::options::{FindOneAndUpdateOptions, ReturnDocument, UpdateOptions};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::serde_json::json`
[INFO] [stdout]   --> src/topology_transactions.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use millegrilles_common_rust::serde_json::json;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::bson`
[INFO] [stdout]  --> src/topology_maintenance.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use millegrilles_common_rust::bson;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FichePublique` and `InformationMonitor`
[INFO] [stdout]  --> src/topology_maintenance.rs:7:31
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::topology_structs::{FichePublique, FilehostServerRow, FilehostTransfer, InformationMonitor, RowFilehostFuuid};
[INFO] [stdout]   |                               ^^^^^^^^^^^^^                                       ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Datelike`
[INFO] [stdout]   --> src/topology_maintenance.rs:11:50
[INFO] [stdout]    |
[INFO] [stdout] 11 | use millegrilles_common_rust::chrono::{DateTime, Datelike, Timelike, Utc};
[INFO] [stdout]    |                                                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::common_messages::EventFilehost`
[INFO] [stdout]   --> src/topology_maintenance.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use millegrilles_common_rust::common_messages::EventFilehost;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CHAMP_CREATION`, `CHAMP_MODIFICATION`, `TOPOLOGIE_NOM_DOMAINE`, and `TRANSACTION_CHAMP_IDMG`
[INFO] [stdout]   --> src/topology_maintenance.rs:14:54
[INFO] [stdout]    |
[INFO] [stdout] 14 | ...ntes::{Securite, CHAMP_CREATION, CHAMP_MODIFICATION, DOMAINE_TOPOLOGIE, TOPOLOGIE_NOM_DOMAINE, TRANSACTION_CHAMP_IDMG};
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^                     ^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::middleware::EmetteurNotificationsTrait`
[INFO] [stdout]   --> src/topology_maintenance.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use millegrilles_common_rust::middleware::EmetteurNotificationsTrait;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FindOptions` and `UpdateOptions`
[INFO] [stdout]   --> src/topology_maintenance.rs:21:68
[INFO] [stdout]    |
[INFO] [stdout] 21 | use millegrilles_common_rust::mongodb::options::{AggregateOptions, FindOptions, Hint, UpdateOptions};
[INFO] [stdout]    |                                                                    ^^^^^^^^^^^        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::notifications::NotificationMessageInterne`
[INFO] [stdout]   --> src/topology_maintenance.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use millegrilles_common_rust::notifications::NotificationMessageInterne;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/catalogues_requests.rs:2:25
[INFO] [stdout]   |
[INFO] [stdout] 2 | use log::{debug, error, warn};
[INFO] [stdout]   |                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `convertir_bson_value` and `filtrer_doc_id`
[INFO] [stdout]  --> src/catalogues_requests.rs:9:43
[INFO] [stdout]   |
[INFO] [stdout] 9 | use millegrilles_common_rust::mongo_dao::{convertir_bson_value, filtrer_doc_id, MongoDao};
[INFO] [stdout]   |                                           ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `json`
[INFO] [stdout]   --> src/catalogues_requests.rs:13:44
[INFO] [stdout]    |
[INFO] [stdout] 13 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stdout]    |                                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MessageMilleGrillesOwned`
[INFO] [stdout]  --> src/catalogues_commands.rs:7:112
[INFO] [stdout]   |
[INFO] [stdout] 7 | ...::messages_structs::{MessageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stdout]   |                                                           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Catalogue`
[INFO] [stdout]   --> src/catalogues_commands.rs:15:33
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::catalogues_structs::{Catalogue, MessageCatalogue, SetPackageVersionTransaction};
[INFO] [stdout]    |                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/pki_maintenance.rs:1:25
[INFO] [stdout]   |
[INFO] [stdout] 1 | use log::{debug, error, warn};
[INFO] [stdout]   |                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EmetteurNotificationsTrait`
[INFO] [stdout]  --> src/pki_maintenance.rs:8:93
[INFO] [stdout]   |
[INFO] [stdout] 8 | use millegrilles_common_rust::middleware::{sauvegarder_traiter_transaction_serializable_v2, EmetteurNotificationsTrait};
[INFO] [stdout]   |                                                                                             ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::topology_events::produire_fiche_publique`
[INFO] [stdout]   --> src/pki_maintenance.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::topology_events::produire_fiche_publique;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `while` condition
[INFO] [stdout]   --> src/pki_maintenance.rs:71:10
[INFO] [stdout]    |
[INFO] [stdout] 71 |     while(cursor.advance().await?) {
[INFO] [stdout]    |          ^                       ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 71 -     while(cursor.advance().await?) {
[INFO] [stdout] 71 +     while cursor.advance().await? {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `domaine`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:48:18
[INFO] [stdout]    |
[INFO] [stdout] 48 |     let (action, domaine) = match &m.type_message {
[INFO] [stdout]    |                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message_id`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:300:23
[INFO] [stdout]     |
[INFO] [stdout] 300 |     let (transaction, message_id) = {
[INFO] [stdout]     |                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `securite`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:325:17
[INFO] [stdout]     |
[INFO] [stdout] 325 |             let securite = &transaction.securite;
[INFO] [stdout]     |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_securite`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resultat_inscrire_usager`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:356:17
[INFO] [stdout]     |
[INFO] [stdout] 356 |             let resultat_inscrire_usager = sauvegarder_traiter_transaction_v2(
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resultat_inscrire_usager`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uuid_transaction`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:386:9
[INFO] [stdout]     |
[INFO] [stdout] 386 |     let uuid_transaction = message_ref.id.to_owned();
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_uuid_transaction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `compte_usager`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:440:9
[INFO] [stdout]     |
[INFO] [stdout] 440 |     let compte_usager = match charger_compte_user_id(middleware, &user_id_certificat, session).await? {
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_compte_usager`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message_id`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:498:9
[INFO] [stdout]     |
[INFO] [stdout] 498 |     let message_id = {
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:524:20
[INFO] [stdout]     |
[INFO] [stdout] 524 |         if let Err(e) = message_confirmation.verifier_signature() {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `flag_generer_nouveau_certificat`
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:810:9
[INFO] [stdout]     |
[INFO] [stdout] 810 |     let flag_generer_nouveau_certificat = commande.commande_webauthn.demande_certificat.is_some();
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_flag_generer_nouveau_certificat`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `hostname`
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1076:9
[INFO] [stdout]      |
[INFO] [stdout] 1076 |     let hostname = commande.hostname.as_str();
[INFO] [stdout]      |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_hostname`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `common_name`
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1117:9
[INFO] [stdout]      |
[INFO] [stdout] 1117 |     let common_name = match csr_subject.get("commonName") {
[INFO] [stdout]      |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_common_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resultat`
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1155:9
[INFO] [stdout]      |
[INFO] [stdout] 1155 |     let resultat = collection.update_one_with_session(filtre, ops, Some(options), session).await?;
[INFO] [stdout]      |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resultat`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `compte`
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1547:9
[INFO] [stdout]      |
[INFO] [stdout] 1547 |     let compte: CompteUsager = {
[INFO] [stdout]      |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_compte`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1588:9
[INFO] [stdout]      |
[INFO] [stdout] 1588 |     let mut encrypted_url = gestionnaire.encrypt_string(middleware, totp_url).await?;
[INFO] [stdout]      |         ----^^^^^^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `idmg`
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1695:9
[INFO] [stdout]      |
[INFO] [stdout] 1695 |     let idmg = middleware.idmg();
[INFO] [stdout]      |         ^^^^ help: if this is intentional, prefix it with an underscore: `_idmg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `totp_url_used` is assigned to, but never used
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1710:13
[INFO] [stdout]      |
[INFO] [stdout] 1710 |     let mut totp_url_used = None;
[INFO] [stdout]      |             ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: consider using `_totp_url_used` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `totp_url_used` is never read
[INFO] [stdout]     --> src/maitredescomptes_commands.rs:1727:17
[INFO] [stdout]      |
[INFO] [stdout] 1727 |                 totp_url_used = Some(totp_url);
[INFO] [stdout]      |                 ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:70:9
[INFO] [stdout]    |
[INFO] [stdout] 50 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ----------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 70 |         _ => {
[INFO] [stdout]    |         ^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unreachable_patterns)]` on by default
[INFO] [stdout] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stdout]    |
[INFO] [stdout] 50 -         DOMAINE_NOM => {
[INFO] [stdout] 50 +         DOMAIN_NAME => {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `u`
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:44:18
[INFO] [stdout]    |
[INFO] [stdout] 44 |             Some(u) => Ok(()),
[INFO] [stdout]    |                  ^ help: if this is intentional, prefix it with an underscore: `_u`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `DOMAINE_NOM`
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:50:9
[INFO] [stdout]    |
[INFO] [stdout] 50 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_DOMAINE_NOM`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/maitredescomptes_requests.rs:221:14
[INFO] [stdout]     |
[INFO] [stdout] 221 |         Some(mut doc_usager) => {
[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]    --> src/maitredescomptes_requests.rs:468:17
[INFO] [stdout]     |
[INFO] [stdout] 468 |             let mut doc_usager = d?;
[INFO] [stdout]     |                 ----^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `requete`
[INFO] [stdout]    --> src/maitredescomptes_requests.rs:574:9
[INFO] [stdout]     |
[INFO] [stdout] 574 |     let requete: RequeteListeUsagers = message_contenu.deserialize()?;
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_requete`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `middleware`
[INFO] [stdout]   --> src/maitredescomptes_events.rs:11:54
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub async fn consommer_evenement_maitredescomptes<M>(middleware: &M, m: MessageValide)
[INFO] [stdout]    |                                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_middleware`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/maitredescomptes_transactions.rs:239:20
[INFO] [stdout]     |
[INFO] [stdout] 239 |         if let Err(e) = collection_totp.delete_many_with_session(filtre, None, session).await {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/maitredescomptes_transactions.rs:243:20
[INFO] [stdout]     |
[INFO] [stdout] 243 |         if let Err(e) = collection.delete_many_with_session(filtre, None, session).await {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/maitredescomptes_transactions.rs:402:20
[INFO] [stdout]     |
[INFO] [stdout] 402 |         if let Err(e) = collection.delete_many_with_session(filtre, None, session).await {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/maitredescomptes_transactions.rs:407:20
[INFO] [stdout]     |
[INFO] [stdout] 407 |         if let Err(e) = collection_webauthn.delete_many_with_session(filtre, None, session).await {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message_id`
[INFO] [stdout]    --> src/maitredescomptes_common.rs:115:10
[INFO] [stdout]     |
[INFO] [stdout] 115 |     let (message_id, commande) = {
[INFO] [stdout]     |          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `user_id`
[INFO] [stdout]    --> src/maitredescomptes_common.rs:122:9
[INFO] [stdout]     |
[INFO] [stdout] 122 |     let user_id = commande.user_id.as_str();
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/pki_requests.rs:87:9
[INFO] [stdout]    |
[INFO] [stdout] 67 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ----------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 87 |         DOMAINE_CERTIFICAT_NOM => {
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stdout]    |
[INFO] [stdout] 67 -         DOMAINE_NOM => {
[INFO] [stdout] 67 +         DOMAIN_NAME => {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/pki_requests.rs:98:9
[INFO] [stdout]    |
[INFO] [stdout] 67 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ----------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 98 |         _ => Err(String::from("Mauvais type de requete de certificat"))
[INFO] [stdout]    |         ^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stdout]    |
[INFO] [stdout] 67 -         DOMAINE_NOM => {
[INFO] [stdout] 67 +         DOMAIN_NAME => {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `DOMAINE_NOM`
[INFO] [stdout]   --> src/pki_requests.rs:67:9
[INFO] [stdout]    |
[INFO] [stdout] 67 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_DOMAINE_NOM`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/pki_requests.rs:120:9
[INFO] [stdout]     |
[INFO] [stdout] 120 |     let mut builder_routage = RoutageMessageAction::builder("certificat", "infoCertificat", exchange);
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `domaine`
[INFO] [stdout]   --> src/pki_commands.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let (domaine, action) = match &m.type_message {
[INFO] [stdout]    |          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]   --> src/pki_commands.rs:82:91
[INFO] [stdout]    |
[INFO] [stdout] 82 | pub async fn traiter_commande_sauvegarder_certificat<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stdout]    |                                                                                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `domaine`
[INFO] [stdout]   --> src/pki_commands.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let domaine = match &m.type_message {
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `middleware`
[INFO] [stdout]    --> src/pki_commands.rs:120:47
[INFO] [stdout]     |
[INFO] [stdout] 120 | async fn valider_demande_signature_csr<'a, M>(middleware: &M, m: &'a MessageValide)
[INFO] [stdout]     |                                               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_middleware`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]   --> src/pki_transactions.rs:59:84
[INFO] [stdout]    |
[INFO] [stdout] 59 | async fn sauvegarder_certificat<M>(middleware: &M, transaction: TransactionValide, session: &mut ClientSession)
[INFO] [stdout]    |                                                                                    ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/topology_requests.rs:134:9
[INFO] [stdout]     |
[INFO] [stdout] 134 |         _ => {
[INFO] [stdout]     |         ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/topology_requests.rs:134:9
[INFO] [stdout]     |
[INFO] [stdout]  59 |         Securite::L1Public => {
[INFO] [stdout]     |         ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout]  84 |         Securite::L2Prive => {
[INFO] [stdout]     |         ----------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 108 |         Securite::L3Protege | Securite::L4Secure => {
[INFO] [stdout]     |         ---------------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 134 |         _ => {
[INFO] [stdout]     |         ^ collectively making this unreachable
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/topology_requests.rs:128:17
[INFO] [stdout]     |
[INFO] [stdout] 110 |                 DOMAINE_NOM => {
[INFO] [stdout]     |                 ----------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 128 |                 _ => {
[INFO] [stdout]     |                 ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stdout]     |
[INFO] [stdout] 110 -                 DOMAINE_NOM => {
[INFO] [stdout] 110 +                 DOMAIN_NAME => {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `DOMAINE_NOM`
[INFO] [stdout]    --> src/topology_requests.rs:110:17
[INFO] [stdout]     |
[INFO] [stdout] 110 |                 DOMAINE_NOM => {
[INFO] [stdout]     |                 ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_DOMAINE_NOM`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/topology_requests.rs:190:25
[INFO] [stdout]     |
[INFO] [stdout] 190 |                     let mut fiche: FichePublique = convertir_bson_deserializable(doc_fiche)?;
[INFO] [stdout]     |                         ----^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `url_verifie`
[INFO] [stdout]    --> src/topology_requests.rs:392:23
[INFO] [stdout]     |
[INFO] [stdout] 392 |             let (jwt, url_verifie) = match demander_jwt_hebergement(middleware, &fiche_publique, None).await {
[INFO] [stdout]     |                       ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_url_verifie`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `refus`
[INFO] [stdout]    --> src/topology_requests.rs:451:17
[INFO] [stdout]     |
[INFO] [stdout] 451 |             let refus = json!({"ok": false, "err": "Acces refuse"});
[INFO] [stdout]     |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_refus`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `d`
[INFO] [stdout]     --> src/topology_requests.rs:1026:22
[INFO] [stdout]      |
[INFO] [stdout] 1026 |                 Some(d) => {
[INFO] [stdout]      |                      ^ help: if this is intentional, prefix it with an underscore: `_d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `gestionnaire`
[INFO] [stdout]    --> src/topology_commands.rs:116:89
[INFO] [stdout]     |
[INFO] [stdout] 116 | ...essage: MessageValide, gestionnaire: &TopologyManager, session: &mut ClientSession)
[INFO] [stdout]     |                           ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_gestionnaire`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]    --> src/topology_commands.rs:116:121
[INFO] [stdout]     |
[INFO] [stdout] 116 | ...ionnaire: &TopologyManager, session: &mut ClientSession)
[INFO] [stdout]     |                                ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commande`
[INFO] [stdout]    --> src/topology_commands.rs:221:13
[INFO] [stdout]     |
[INFO] [stdout] 221 |         let commande: TransactionSetFichiersPrimaire = match message_owned.deserialize() {
[INFO] [stdout]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commande`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/topology_commands.rs:200:70
[INFO] [stdout]     |
[INFO] [stdout] 200 | async fn traiter_commande_configurer_consignation<M>(middleware: &M, mut message: MessageValide, gestionnaire: &TopologyManager, session:...
[INFO] [stdout]     |                                                                      ----^^^^^^^
[INFO] [stdout]     |                                                                      |
[INFO] [stdout]     |                                                                      help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `gestionnaire`
[INFO] [stdout]    --> src/topology_commands.rs:872:66
[INFO] [stdout]     |
[INFO] [stdout] 872 | async fn command_file_visit<M>(middleware: &M, m: MessageValide, gestionnaire: &TopologyManager, session: &mut ClientSession)
[INFO] [stdout]     |                                                                  ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_gestionnaire`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: irrefutable `if let` pattern
[INFO] [stdout]     --> src/topology_commands.rs:1009:12
[INFO] [stdout]      |
[INFO] [stdout] 1009 |         if let extensions = m.certificat.extensions()? {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: this pattern will always match, so the `if let` is useless
[INFO] [stdout]      = help: consider replacing the `if let` with a `let`
[INFO] [stdout]      = note: `#[warn(irrefutable_let_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]     --> src/topology_commands.rs:1094:81
[INFO] [stdout]      |
[INFO] [stdout] 1094 | async fn commande_filehost_batch_transfers<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stdout]      |                                                                                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]     --> src/topology_commands.rs:1186:85
[INFO] [stdout]      |
[INFO] [stdout] 1186 | async fn commande_filehost_reset_visits_claims<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stdout]      |                                                                                     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]     --> src/topology_commands.rs:1242:81
[INFO] [stdout]      |
[INFO] [stdout] 1242 | async fn commande_filehost_reset_transfers<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stdout]      |                                                                                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]     --> src/topology_commands.rs:1313:77
[INFO] [stdout]      |
[INFO] [stdout] 1313 | async fn commande_domain_visits_claims<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stdout]      |                                                                             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `instance_id`
[INFO] [stdout]   --> src/topology_common.rs:60:10
[INFO] [stdout]    |
[INFO] [stdout] 60 |     for (instance_id, instance) in &fiche.instances {
[INFO] [stdout]    |          ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_instance_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inner`
[INFO] [stdout]   --> src/topology_common.rs:68:26
[INFO] [stdout]    |
[INFO] [stdout] 68 |                     Some(inner) => match etag.as_ref() {
[INFO] [stdout]    |                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_inner`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `hostname`
[INFO] [stdout]    --> src/topology_common.rs:128:21
[INFO] [stdout]     |
[INFO] [stdout] 128 |         if let Some(hostname) = url.host_str() {
[INFO] [stdout]     |                     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_hostname`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/topology_common.rs:179:33
[INFO] [stdout]     |
[INFO] [stdout] 179 | ...                   Err(e) => {
[INFO] [stdout]     |                           ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/topology_common.rs:195:20
[INFO] [stdout]     |
[INFO] [stdout] 195 |         if let Err(e) = message_owned.verifier_signature() {
[INFO] [stdout]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `domaine`
[INFO] [stdout]   --> src/topology_events.rs:36:10
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let (domaine, action) = match &m.type_message {
[INFO] [stdout]    |          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `gestionnaire`
[INFO] [stdout]   --> src/topology_events.rs:86:72
[INFO] [stdout]    |
[INFO] [stdout] 86 | async fn traiter_presence_domaine<M>(middleware: &M, m: MessageValide, gestionnaire: &TopologyManager)
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_gestionnaire`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> src/topology_events.rs:134:9
[INFO] [stdout]     |
[INFO] [stdout] 134 |     let result = match collection.find_one_and_update(filtre, ops, Some(options)).await {
[INFO] [stdout]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/topology_events.rs:455:17
[INFO] [stdout]     |
[INFO] [stdout] 455 |             let mut missing_from = filehost_ids.difference(&filehost_ids_visits);
[INFO] [stdout]     |                 ----^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `session`
[INFO] [stdout]    --> src/topology_transactions.rs:400:74
[INFO] [stdout]     |
[INFO] [stdout] 400 | async fn filehost_add<M>(middleware: &M, transaction: TransactionValide, session: &mut ClientSession)
[INFO] [stdout]     |                                                                          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/catalogues_requests.rs:191:9
[INFO] [stdout]     |
[INFO] [stdout] 191 |     let mut catalogue = match collection.find_one(filtre, None).await? {
[INFO] [stdout]     |         ----^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inner`
[INFO] [stdout]    --> src/catalogues_commands.rs:120:12
[INFO] [stdout]     |
[INFO] [stdout] 120 |         Ok(inner) => {
[INFO] [stdout]     |            ^^^^^ help: if this is intentional, prefix it with an underscore: `_inner`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/catalogues_commands.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |     let mut message_catalogue: MessageCatalogue = {
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::redis::Commands`
[INFO] [stdout]   --> src/topology_commands.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | use millegrilles_common_rust::redis::Commands;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::kv::Source`
[INFO] [stdout]  --> src/topology_events.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use log::kv::Source;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MessageValidable`
[INFO] [stdout]   --> src/topology_requests.rs:14:138
[INFO] [stdout]    |
[INFO] [stdout] 14 | ...essageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stdout]    |                                                               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Decipher`
[INFO] [stdout]   --> src/maitredescomptes_manager.rs:21:177
[INFO] [stdout]    |
[INFO] [stdout] 21 | ...ageX25519Impl, CleDechiffrageX25519Impl, CleSecreteSerialisee, Decipher};
[INFO] [stdout]    |                                                                   ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::tokio_stream::StreamExt`
[INFO] [stdout]   --> src/maitredescomptes_commands.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 31 | use millegrilles_common_rust::tokio_stream::StreamExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `millegrilles_common_rust::tokio_stream::StreamExt`
[INFO] [stdout]   --> src/topology_maintenance.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use millegrilles_common_rust::tokio_stream::StreamExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/validateur_pki_mongo.rs:519:22
[INFO] [stdout]     |
[INFO] [stdout] 519 |     let (middleware, mut futures) = preparer_middleware_db_v2().expect("preparer_middleware_db_v2");
[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]   --> src/webauthn.rs:46:9
[INFO] [stdout]    |
[INFO] [stdout] 46 |     let mut builder = WebauthnBuilder::new(rp_id, &rp_origin)?
[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]   --> src/webauthn.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut builder = WebauthnBuilder::new(rp_id, &rp_origin)?
[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]    --> src/webauthn.rs:130:9
[INFO] [stdout]     |
[INFO] [stdout] 130 |     let mut builder = WebauthnBuilder::new(rp_id, &rp_origin)?
[INFO] [stdout]     |         ----^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `credentials`
[INFO] [stdout]    --> src/webauthn.rs:380:30
[INFO] [stdout]     |
[INFO] [stdout] 380 | pub fn authenticate_complete(credentials: u64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, respons...
[INFO] [stdout]     |                              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_credentials`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `challenge`
[INFO] [stdout]    --> src/webauthn.rs:380:48
[INFO] [stdout]     |
[INFO] [stdout] 380 | pub fn authenticate_complete(credentials: u64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, respons...
[INFO] [stdout]     |                                                ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_challenge`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rsp`
[INFO] [stdout]    --> src/webauthn.rs:380:76
[INFO] [stdout]     |
[INFO] [stdout] 380 | ...64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, response: AuthenticatorAssertionResponseRaw, cr...
[INFO] [stdout]     |                                    ^^^ help: if this is intentional, prefix it with an underscore: `_rsp`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `manager`
[INFO] [stdout]    --> src/topology_manager.rs:120:24
[INFO] [stdout]     |
[INFO] [stdout] 120 | pub fn preparer_queues(manager: &TopologyManager) -> Vec<QueueType> {
[INFO] [stdout]     |                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_manager`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `manager`
[INFO] [stdout]    --> src/catalogues_manager.rs:119:24
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub fn preparer_queues(manager: &CataloguesManager) -> Vec<QueueType> {
[INFO] [stdout]     |                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_manager`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `niveaux_securite_prive`
[INFO] [stdout]    --> src/pki_manager.rs:118:9
[INFO] [stdout]     |
[INFO] [stdout] 118 |     let niveaux_securite_prive = vec!(Securite::L2Prive);  //, Securite::L3Protege);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_niveaux_securite_prive`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `manager`
[INFO] [stdout]    --> src/pki_manager.rs:114:24
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub fn preparer_queues(manager: &PkiManager) -> Vec<QueueType> {
[INFO] [stdout]     |                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_manager`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `rp_id`, `hostname`, and `challenge_b64` are never read
[INFO] [stdout]    --> src/webauthn.rs:287:9
[INFO] [stdout]     |
[INFO] [stdout] 286 | pub struct ConfigChallenge {
[INFO] [stdout]     |            --------------- fields in this struct
[INFO] [stdout] 287 |     pub rp_id: String,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 288 |     pub hostname: String,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 289 |     pub challenge_b64: String,
[INFO] [stdout]     |         ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/webauthn.rs:335:29
[INFO] [stdout]     |
[INFO] [stdout] 335 |     DemandeSignerCertificat(Vec<u8>),
[INFO] [stdout]     |     ----------------------- ^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     field in this variant
[INFO] [stdout]     |
[INFO] [stdout]     = note: `CommandeWebauthn` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]     |
[INFO] [stdout] 335 -     DemandeSignerCertificat(Vec<u8>),
[INFO] [stdout] 335 +     DemandeSignerCertificat(()),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompteCredential` is never constructed
[INFO] [stdout]    --> src/webauthn.rs:346:12
[INFO] [stdout]     |
[INFO] [stdout] 346 | pub struct CompteCredential {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `verifier_commande` is never used
[INFO] [stdout]    --> src/webauthn.rs:356:4
[INFO] [stdout]     |
[INFO] [stdout] 356 | fn verifier_commande<S>(commande: &CommandeWebauthn, message: &S) -> Result<bool, millegrilles_common_rust::error::Error>
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `authenticate_complete` is never used
[INFO] [stdout]    --> src/webauthn.rs:380:8
[INFO] [stdout]     |
[INFO] [stdout] 380 | pub fn authenticate_complete(credentials: u64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, respons...
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `multibase_to_safe` is never used
[INFO] [stdout]    --> src/webauthn.rs:484:8
[INFO] [stdout]     |
[INFO] [stdout] 484 | pub fn multibase_to_safe<S>(val: S) -> Result<Base64UrlSafeData, CoreError>
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `valider_commande` is never used
[INFO] [stdout]    --> src/webauthn.rs:494:8
[INFO] [stdout]     |
[INFO] [stdout] 494 | pub fn valider_commande<M, S>(hostname: S, challenge: S, message: &M) -> Result<bool, CoreError>
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `COMMANDE_SIGNER_CERTIFICAT` is never used
[INFO] [stdout]    --> src/webauthn.rs:522:11
[INFO] [stdout]     |
[INFO] [stdout] 522 |     const COMMANDE_SIGNER_CERTIFICAT: &str = r#"
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/error.rs:9:31
[INFO] [stdout]   |
[INFO] [stdout] 9 |     MillegrillesCryptographie(millegrilles_common_rust::millegrilles_cryptographie::error::Error),
[INFO] [stdout]   |     ------------------------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |     |
[INFO] [stdout]   |     field in this variant
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]   |
[INFO] [stdout] 9 -     MillegrillesCryptographie(millegrilles_common_rust::millegrilles_cryptographie::error::Error),
[INFO] [stdout] 9 +     MillegrillesCryptographie(()),
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:10:24
[INFO] [stdout]    |
[INFO] [stdout] 10 |     MillegrillesCommon(millegrilles_common_rust::error::Error),
[INFO] [stdout]    |     ------------------ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 10 -     MillegrillesCommon(millegrilles_common_rust::error::Error),
[INFO] [stdout] 10 +     MillegrillesCommon(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 |     Webauthn(WebauthnError),
[INFO] [stdout]    |     -------- ^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 11 -     Webauthn(WebauthnError),
[INFO] [stdout] 11 +     Webauthn(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:12:14
[INFO] [stdout]    |
[INFO] [stdout] 12 |     UrlParse(millegrilles_common_rust::url::ParseError),
[INFO] [stdout]    |     -------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 12 -     UrlParse(millegrilles_common_rust::url::ParseError),
[INFO] [stdout] 12 +     UrlParse(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:13:15
[INFO] [stdout]    |
[INFO] [stdout] 13 |     UuidParse(uuid::Error),
[INFO] [stdout]    |     --------- ^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 13 -     UuidParse(uuid::Error),
[INFO] [stdout] 13 +     UuidParse(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:14:15
[INFO] [stdout]    |
[INFO] [stdout] 14 |     Multibase(multibase::Error),
[INFO] [stdout]    |     --------- ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 14 -     Multibase(multibase::Error),
[INFO] [stdout] 14 +     Multibase(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 |     MongDb(mongodb::error::Error),
[INFO] [stdout]    |     ------ ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 15 -     MongDb(mongodb::error::Error),
[INFO] [stdout] 15 +     MongDb(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:16:15
[INFO] [stdout]    |
[INFO] [stdout] 16 |     SerdeJson(serde_json::Error),
[INFO] [stdout]    |     --------- ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 16 -     SerdeJson(serde_json::Error),
[INFO] [stdout] 16 +     SerdeJson(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/error.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 18 |     String(String)
[INFO] [stdout]    |     ------ ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 18 -     String(String)
[INFO] [stdout] 18 +     String(())
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Str` is never constructed
[INFO] [stdout]   --> src/error.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub enum Error {
[INFO] [stdout]    |          ----- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 17 |     Str(&'static str),
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `user_id` is never read
[INFO] [stdout]    --> src/maitredescomptes_requests.rs:708:5
[INFO] [stdout]     |
[INFO] [stdout] 706 | struct RowWebauthnCredentials {
[INFO] [stdout]     |        ---------------------- field in this struct
[INFO] [stdout] 707 |     #[serde(rename="userId")]
[INFO] [stdout] 708 |     user_id: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `RowWebauthnCredentials` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `user_id` is never read
[INFO] [stdout]    --> src/maitredescomptes_requests.rs:719:5
[INFO] [stdout]     |
[INFO] [stdout] 717 | struct RowActivationInfo {
[INFO] [stdout]     |        ----------------- field in this struct
[INFO] [stdout] 718 |     #[serde(rename="userId")]
[INFO] [stdout] 719 |     user_id: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `RowActivationInfo` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `user_id` is never read
[INFO] [stdout]    --> src/maitredescomptes_requests.rs:736:5
[INFO] [stdout]     |
[INFO] [stdout] 735 | struct RowCookieInfo {
[INFO] [stdout]     |        ------------- field in this struct
[INFO] [stdout] 736 |     user_id: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `RowCookieInfo` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRANSACTIONS` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:11:11
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub const NOM_Q_TRANSACTIONS: &str = "CoreMaitreDesComptes/transactions";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:13:11
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub const NOM_Q_TRIGGERS: &str = "CoreMaitreDesComptes/triggers";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TRANSACTION_SUPPRIMER_USAGER` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:37:11
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub const TRANSACTION_SUPPRIMER_USAGER: &str = "supprimerUsager";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EVENEMENT_SUPPRIMER_COMPTE_USAGER` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:47:11
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub const EVENEMENT_SUPPRIMER_COMPTE_USAGER: &str = "supprimerCompteUsager";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHAMP_ACTIVATIONS_PAR_FINGERPRINT_PK` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const CHAMP_ACTIVATIONS_PAR_FINGERPRINT_PK: &str = "activations_par_fingerprint_pk";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHAMP_WEBAUTHN_HOSTNAMES` is never used
[INFO] [stdout]   --> src/maitredescomptes_constants.rs:66:11
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub const CHAMP_WEBAUTHN_HOSTNAMES: &str = "webauthn_hostnames";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRANSACTIONS` is never used
[INFO] [stdout]  --> src/pki_constants.rs:6:11
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub const NOM_Q_TRANSACTIONS: &str = "CorePki/transactions";
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_VOLATILS` is never used
[INFO] [stdout]  --> src/pki_constants.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub const NOM_Q_VOLATILS: &str = "CorePki/volatils";
[INFO] [stdout]   |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stdout]  --> src/pki_constants.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const NOM_Q_TRIGGERS: &str = "CorePki/triggers";
[INFO] [stdout]   |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRANSACTIONS_PKI` is never used
[INFO] [stdout]   --> src/pki_constants.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub const NOM_Q_TRANSACTIONS_PKI: &str = "CorePki/transactions";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRIGGERS_PKI` is never used
[INFO] [stdout]   --> src/pki_constants.rs:19:11
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub const NOM_Q_TRIGGERS_PKI: &str = "CorePki/triggers";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_DOMAINE_CERTIFICATS` is never used
[INFO] [stdout]   --> src/pki_constants.rs:20:11
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub const NOM_DOMAINE_CERTIFICATS: &str = "certificat";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EVENEMENT_CERTIFICAT_MAITREDESCLES` is never used
[INFO] [stdout]   --> src/pki_constants.rs:21:11
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub const EVENEMENT_CERTIFICAT_MAITREDESCLES: &str = "certMaitreDesCles";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_COLLECTION_FILEHOSTING_FUUIDS_WORK` is never used
[INFO] [stdout]   --> src/topology_constants.rs:18:11
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub const NOM_COLLECTION_FILEHOSTING_FUUIDS_WORK: &str = "CoreTopologie/filehostingFuuidsWork";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DOMAINE_PRESENCE_NOM` is never used
[INFO] [stdout]   --> src/topology_constants.rs:28:11
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub const DOMAINE_PRESENCE_NOM: &str = "CoreTopologie";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRANSACTIONS` is never used
[INFO] [stdout]   --> src/topology_constants.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub const NOM_Q_TRANSACTIONS: &str = "CoreTopologie/transactions";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stdout]   --> src/topology_constants.rs:33:11
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub const NOM_Q_TRIGGERS: &str = "CoreTopologie/triggers";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REQUETE_LISTE_NOEUDS` is never used
[INFO] [stdout]   --> src/topology_constants.rs:39:11
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub const REQUETE_LISTE_NOEUDS: &str = "listeNoeuds";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EVENEMENT_MODIFICATION_CONSIGNATION` is never used
[INFO] [stdout]   --> src/topology_constants.rs:92:11
[INFO] [stdout]    |
[INFO] [stdout] 92 | pub const EVENEMENT_MODIFICATION_CONSIGNATION: &str = "modificationConsignation";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INDEX_NOEUDS` is never used
[INFO] [stdout]    --> src/topology_constants.rs:105:11
[INFO] [stdout]     |
[INFO] [stdout] 105 | pub const INDEX_NOEUDS: &str = "noeuds";
[INFO] [stdout]     |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INDEX_INSTANCE_ID` is never used
[INFO] [stdout]    --> src/topology_constants.rs:109:11
[INFO] [stdout]     |
[INFO] [stdout] 109 | pub const INDEX_INSTANCE_ID: &str = "instance_id";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHAMP_NOEUD_ID` is never used
[INFO] [stdout]    --> src/topology_constants.rs:113:11
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub const CHAMP_NOEUD_ID: &str = CHAMP_INSTANCE_ID;
[INFO] [stdout]     |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHAMP_CONSIGNATION_ID` is never used
[INFO] [stdout]    --> src/topology_constants.rs:116:11
[INFO] [stdout]     |
[INFO] [stdout] 116 | pub const CHAMP_CONSIGNATION_ID: &str = "consignation_id";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_PREFERENCE_PRIMAIRE` is never used
[INFO] [stdout]    --> src/topology_constants.rs:118:11
[INFO] [stdout]     |
[INFO] [stdout] 118 | pub const ADRESSE_PREFERENCE_PRIMAIRE: u8 = 1;
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_PREFERENCE_SECONDAIRE` is never used
[INFO] [stdout]    --> src/topology_constants.rs:119:11
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub const ADRESSE_PREFERENCE_SECONDAIRE: u8 = 2;
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_NATURE_DNS` is never used
[INFO] [stdout]    --> src/topology_constants.rs:121:11
[INFO] [stdout]     |
[INFO] [stdout] 121 | pub const ADRESSE_NATURE_DNS: &str = "dns";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_NATURE_IP4` is never used
[INFO] [stdout]    --> src/topology_constants.rs:122:11
[INFO] [stdout]     |
[INFO] [stdout] 122 | pub const ADRESSE_NATURE_IP4: &str = "ip4";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_NATURE_IP6` is never used
[INFO] [stdout]    --> src/topology_constants.rs:123:11
[INFO] [stdout]     |
[INFO] [stdout] 123 | pub const ADRESSE_NATURE_IP6: &str = "ip6";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ADRESSE_NATURE_ONION` is never used
[INFO] [stdout]    --> src/topology_constants.rs:124:11
[INFO] [stdout]     |
[INFO] [stdout] 124 | pub const ADRESSE_NATURE_ONION: &str = "onion";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_CONSIGNATION_URL` is never used
[INFO] [stdout]    --> src/topology_constants.rs:126:11
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub const DEFAULT_CONSIGNATION_URL: &str = "https://fichiers:1443";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stdout]  --> src/catalogues_constants.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const NOM_Q_TRIGGERS: &str = "CoreCatalogues/triggers";
[INFO] [stdout]   |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `idmg` and `role` are never read
[INFO] [stdout]    --> src/topology_requests.rs:319:5
[INFO] [stdout]     |
[INFO] [stdout] 318 | struct HebergementTokenRow {
[INFO] [stdout]     |        ------------------- fields in this struct
[INFO] [stdout] 319 |     idmg: String,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 320 |     role: String,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ParametresGetCleConfiguration` is never constructed
[INFO] [stdout]     --> src/topology_requests.rs:1061:8
[INFO] [stdout]      |
[INFO] [stdout] 1061 | struct ParametresGetCleConfiguration {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ReponseConsignationSatellite` is never constructed
[INFO] [stdout]     --> src/topology_requests.rs:1066:12
[INFO] [stdout]      |
[INFO] [stdout] 1066 | pub struct ReponseConsignationSatellite {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RequeteConfigurationFichiers` is never constructed
[INFO] [stdout]     --> src/topology_requests.rs:1324:12
[INFO] [stdout]      |
[INFO] [stdout] 1324 | pub struct RequeteConfigurationFichiers {}
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ReponseConfigurationFichiers` is never constructed
[INFO] [stdout]     --> src/topology_requests.rs:1327:12
[INFO] [stdout]      |
[INFO] [stdout] 1327 | pub struct ReponseConfigurationFichiers {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `domaine`, `instance_id`, `dirty`, and `reclame_fuuids` are never read
[INFO] [stdout]     --> src/topology_requests.rs:1373:5
[INFO] [stdout]      |
[INFO] [stdout] 1372 | struct RowCoreTopologieDomaines {
[INFO] [stdout]      |        ------------------------ fields in this struct
[INFO] [stdout] 1373 |     domaine: String,
[INFO] [stdout]      |     ^^^^^^^
[INFO] [stdout] 1374 |     instance_id: String,
[INFO] [stdout]      |     ^^^^^^^^^^^
[INFO] [stdout] 1375 |     dirty: Option<bool>,
[INFO] [stdout]      |     ^^^^^
[INFO] [stdout] 1376 |     reclame_fuuids: Option<bool>,
[INFO] [stdout]      |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FilehostForExternalRequest` is never constructed
[INFO] [stdout]     --> src/topology_requests.rs:1593:8
[INFO] [stdout]      |
[INFO] [stdout] 1593 | struct FilehostForExternalRequest {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TransactionConfigurerConsignation` is never constructed
[INFO] [stdout]   --> src/topology_structs.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct TransactionConfigurerConsignation {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InfoService` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:139:12
[INFO] [stdout]     |
[INFO] [stdout] 139 | pub struct InfoService {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ApplicationConfiguree` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:148:12
[INFO] [stdout]     |
[INFO] [stdout] 148 | pub struct ApplicationConfiguree {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WebAppLink` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:154:12
[INFO] [stdout]     |
[INFO] [stdout] 154 | pub struct WebAppLink {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PresenceMonitor` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:162:12
[INFO] [stdout]     |
[INFO] [stdout] 162 | pub struct PresenceMonitor {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InformationApplication` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:204:12
[INFO] [stdout]     |
[INFO] [stdout] 204 | pub struct InformationApplication {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InformationMonitor` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:214:12
[INFO] [stdout]     |
[INFO] [stdout] 214 | pub struct InformationMonitor {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TransactionSupprimerConsignationInstance` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:236:12
[INFO] [stdout]     |
[INFO] [stdout] 236 | pub struct TransactionSupprimerConsignationInstance {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RowFuuid` is never constructed
[INFO] [stdout]    --> src/topology_structs.rs:315:12
[INFO] [stdout]     |
[INFO] [stdout] 315 | pub struct RowFuuid { pub fuuid: String }
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CommandeAjouterConsignationHebergee` is never constructed
[INFO] [stdout]    --> src/topology_commands.rs:344:8
[INFO] [stdout]     |
[INFO] [stdout] 344 | struct CommandeAjouterConsignationHebergee {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ReponseCommandeAjouterConsignationHebergee` is never constructed
[INFO] [stdout]    --> src/topology_commands.rs:348:8
[INFO] [stdout]     |
[INFO] [stdout] 348 | struct ReponseCommandeAjouterConsignationHebergee {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ReponseRelaiWeb` is never constructed
[INFO] [stdout]    --> src/topology_commands.rs:353:8
[INFO] [stdout]     |
[INFO] [stdout] 353 | struct ReponseRelaiWeb {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `charger_fiche` is never used
[INFO] [stdout]    --> src/topology_commands.rs:361:10
[INFO] [stdout]     |
[INFO] [stdout] 361 | async fn charger_fiche<M>(middleware: &M, url: &Url, etag: Option<&String>)
[INFO] [stdout]     |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `domaine`, `instance_id`, `dirty`, `reclame_fuuids`, and `cle_id_backup` are never read
[INFO] [stdout]    --> src/topology_commands.rs:554:5
[INFO] [stdout]     |
[INFO] [stdout] 553 | struct RowCoreTopologieDomaines {
[INFO] [stdout]     |        ------------------------ fields in this struct
[INFO] [stdout] 554 |     domaine: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 555 |     instance_id: String,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 556 |     dirty: Option<bool>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 557 |     reclame_fuuids: Option<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 558 |     cle_id_backup: Option<String>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `batch_no` is never read
[INFO] [stdout]     --> src/topology_commands.rs:1308:5
[INFO] [stdout]      |
[INFO] [stdout] 1306 | struct RequestFuuidsVisits {
[INFO] [stdout]      |        ------------------- field in this struct
[INFO] [stdout] 1307 |     fuuids: Vec<String>,
[INFO] [stdout] 1308 |     batch_no: Option<usize>,
[INFO] [stdout]      |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `instance_id` is never read
[INFO] [stdout]    --> src/topology_common.rs:504:5
[INFO] [stdout]     |
[INFO] [stdout] 503 | struct InstanceConfiguredAppRow {
[INFO] [stdout]     |        ------------------------ field in this struct
[INFO] [stdout] 504 |     instance_id: String,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PresenceFichiers` is never constructed
[INFO] [stdout]    --> src/topology_events.rs:143:8
[INFO] [stdout]     |
[INFO] [stdout] 143 | struct PresenceFichiers {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RowInstanceActivite` is never constructed
[INFO] [stdout]   --> src/topology_maintenance.rs:85:8
[INFO] [stdout]    |
[INFO] [stdout] 85 | struct RowInstanceActivite {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `fuuid` and `destination_filehost_id` are never read
[INFO] [stdout]   --> src/topology_maintenance.rs:96:5
[INFO] [stdout]    |
[INFO] [stdout] 93 | struct FuuidFilehostRow {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 96 |     fuuid: String,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 97 |     destination_filehost_id: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `claimer_type` is never read
[INFO] [stdout]    --> src/topology_maintenance.rs:325:5
[INFO] [stdout]     |
[INFO] [stdout] 323 | struct SyncStatusRow {
[INFO] [stdout]     |        ------------- field in this struct
[INFO] [stdout] 324 |     claimer: String,
[INFO] [stdout] 325 |     claimer_type: String,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `v` is never read
[INFO] [stdout]    --> src/topology_maintenance.rs:739:5
[INFO] [stdout]     |
[INFO] [stdout] 736 | struct ObjectToArrayKeyStringValueDate {
[INFO] [stdout]     |        ------------------------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 739 |     v: Option<DateTime<Utc>>
[INFO] [stdout]     |     ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `rpId` should have a snake case name
[INFO] [stdout]    --> src/webauthn.rs:280:5
[INFO] [stdout]     |
[INFO] [stdout] 280 |     rpId: String,
[INFO] [stdout]     |     ^^^^ help: convert the identifier to snake case: `rp_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `userVerification` should have a snake case name
[INFO] [stdout]    --> src/webauthn.rs:281:5
[INFO] [stdout]     |
[INFO] [stdout] 281 |     userVerification: String,  // 'preferred',
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `user_verification`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `allowCredentials` should have a snake case name
[INFO] [stdout]    --> src/webauthn.rs:282:5
[INFO] [stdout]     |
[INFO] [stdout] 282 |     allowCredentials: Vec<AllowCredential>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `allow_credentials`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/maitredescomptes_commands.rs:304:40
[INFO] [stdout]     |
[INFO] [stdout] 304 |         let message_id = message_ref.id.clone();
[INFO] [stdout]     |                                        ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `DOMAINE_NOM` should have a snake case name
[INFO] [stdout]   --> src/maitredescomptes_requests.rs:50:9
[INFO] [stdout]    |
[INFO] [stdout] 50 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `domaine_nom`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `champs_index__transferts_filehostfuuid` should have a snake case name
[INFO] [stdout]    --> src/topology_manager.rs:455:9
[INFO] [stdout]     |
[INFO] [stdout] 455 |     let champs_index__transferts_filehostfuuid = vec!(
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `champs_index_transferts_filehostfuuid`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `DOMAINE_NOM` should have a snake case name
[INFO] [stdout]   --> src/pki_requests.rs:67:9
[INFO] [stdout]    |
[INFO] [stdout] 67 |         DOMAINE_NOM => {
[INFO] [stdout]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `domaine_nom`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `DOMAINE_NOM` should have a snake case name
[INFO] [stdout]    --> src/topology_requests.rs:110:17
[INFO] [stdout]     |
[INFO] [stdout] 110 |                 DOMAINE_NOM => {
[INFO] [stdout]     |                 ^^^^^^^^^^^ help: convert the identifier to snake case: `domaine_nom`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 45.51s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: millegrilles_common_rust v2025.4.2 (https://github.com/dugrema/millegrilles_common_rust.git?tag=2025.4-release#5b6ce0e5), num-bigint-dig v0.8.4, redis v0.25.4
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 4`
[INFO] running `Command { std: "docker" "inspect" "1169695ce25e3194997eb30ece5c38da5fa5dc434c0d154245e935b9b6ef9ad1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1169695ce25e3194997eb30ece5c38da5fa5dc434c0d154245e935b9b6ef9ad1", kill_on_drop: false }`
[INFO] [stdout] 1169695ce25e3194997eb30ece5c38da5fa5dc434c0d154245e935b9b6ef9ad1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+350d0ef0ec0493e6d21cfb265cb8211a0e74d766" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] cc8f53a69125dfa0b81352731c8f420d991ee8af7707824088058f649356c0bc
[INFO] running `Command { std: "docker" "start" "-a" "cc8f53a69125dfa0b81352731c8f420d991ee8af7707824088058f649356c0bc", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `std::error::Error`
[INFO] [stderr]  --> src/validateur_pki_mongo.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::error::Error;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `MiddlewareMessage`, `ReponseCertificatMaitredescles`, and `configurer as configurer_messages`
[INFO] [stderr]   --> src/validateur_pki_mongo.rs:16:44
[INFO] [stderr]    |
[INFO] [stderr] 16 | ...::{configurer as configurer_messages, EmetteurCertificat, formatter_message_certificat, IsConfigurationPki, ReponseCertificatMaitredescles, upsert_certificat, Middleware, MiddlewareMessages, RedisTrait, MiddlewareRessources, RabbitMqTrait, EmetteurNotificationsTrait, repondre_certificat, MiddlewareMessage};
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                                                                                                                                       ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `mpsc`
[INFO] [stderr]   --> src/validateur_pki_mongo.rs:31:45
[INFO] [stderr]    |
[INFO] [stderr] 31 | use millegrilles_common_rust::tokio::sync::{mpsc, Notify};
[INFO] [stderr]    |                                             ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::tokio`
[INFO] [stderr]   --> src/validateur_pki_mongo.rs:38:5
[INFO] [stderr]    |
[INFO] [stderr] 38 | use millegrilles_common_rust::tokio;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::backup_v2::thread_backup_v2`
[INFO] [stderr]   --> src/validateur_pki_mongo.rs:42:5
[INFO] [stderr]    |
[INFO] [stderr] 42 | use millegrilles_common_rust::backup_v2::thread_backup_v2;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::error::Error`
[INFO] [stderr]  --> src/webauthn.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::error::Error;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Formatter`
[INFO] [stderr]  --> src/webauthn.rs:2:23
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::fmt::{Debug, Formatter};
[INFO] [stderr]   |                       ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `error` and `warn`
[INFO] [stderr]  --> src/webauthn.rs:4:18
[INFO] [stderr]   |
[INFO] [stderr] 4 | use log::{debug, error, info, warn};
[INFO] [stderr]   |                  ^^^^^        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::rand`
[INFO] [stderr]  --> src/webauthn.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use millegrilles_common_rust::rand;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::rand::Rng`
[INFO] [stderr]  --> src/webauthn.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use millegrilles_common_rust::rand::Rng;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Array`, `Bson`, and `Document`
[INFO] [stderr]   --> src/webauthn.rs:11:43
[INFO] [stderr]    |
[INFO] [stderr] 11 | use millegrilles_common_rust::bson::{doc, Document, Array, Bson, DateTime as DateTimeBson};
[INFO] [stderr]    |                                           ^^^^^^^^  ^^^^^  ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::openssl`
[INFO] [stderr]   --> src/webauthn.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | use millegrilles_common_rust::openssl;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `BigNumRef` and `BigNum`
[INFO] [stderr]   --> src/webauthn.rs:15:45
[INFO] [stderr]    |
[INFO] [stderr] 15 | use millegrilles_common_rust::openssl::bn::{BigNumRef, BigNum};
[INFO] [stderr]    |                                             ^^^^^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: duplicated attribute
[INFO] [stderr]    --> src/webauthn.rs:622:5
[INFO] [stderr]     |
[INFO] [stderr] 622 |     #[test]
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(duplicate_macro_attributes)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: duplicated attribute
[INFO] [stderr]    --> src/webauthn.rs:642:5
[INFO] [stderr]     |
[INFO] [stderr] 642 |     #[test]
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::bson::Uuid`
[INFO] [stderr]    --> src/webauthn.rs:512:9
[INFO] [stderr]     |
[INFO] [stderr] 512 |     use millegrilles_common_rust::bson::Uuid;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::multibase::Base`
[INFO] [stderr]    --> src/webauthn.rs:513:9
[INFO] [stderr]     |
[INFO] [stderr] 513 |     use millegrilles_common_rust::multibase::Base;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::serde_json::Value`
[INFO] [stderr]    --> src/webauthn.rs:518:9
[INFO] [stderr]     |
[INFO] [stderr] 518 |     use millegrilles_common_rust::serde_json::Value;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `webauthn_rs::WebauthnBuilder`
[INFO] [stderr]    --> src/webauthn.rs:520:9
[INFO] [stderr]     |
[INFO] [stderr] 520 |     use webauthn_rs::WebauthnBuilder;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::ops::Deref`
[INFO] [stderr]  --> src/maitredescomptes_manager.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::ops::Deref;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `BACKUP_CHAMP_BACKUP_TRANSACTIONS`, `TRANSACTION_CHAMP_BACKUP_FLAG`, `TRANSACTION_CHAMP_COMPLETE`, `TRANSACTION_CHAMP_EVENEMENT_COMPLETE`, `TRANSACTION_CHAMP_ID`, and `TRANSACTION_CHAMP_TRANSACTION_TRAITEE`
[INFO] [stderr]   --> src/maitredescomptes_manager.rs:11:54
[INFO] [stderr]    |
[INFO] [stderr] 11 | ...e, BACKUP_CHAMP_BACKUP_TRANSACTIONS, DOMAINE_NOM_MAITREDESCOMPTES, TRANSACTION_CHAMP_BACKUP_FLAG, TRANSACTION_CHAMP_COMPLETE, TRANSACTION_CHAMP_EVENEMENT_COMPLETE, TRANSACTION_CHAMP_ID, TRANSACTION_CHAMP_TRANSACTION_TRAITEE};
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `CleChiffrageX25519Impl` and `CleDechiffrageX25519Impl`
[INFO] [stderr]   --> src/maitredescomptes_manager.rs:21:105
[INFO] [stderr]    |
[INFO] [stderr] 21 | ...ffrage_cles::{Cipher, CleChiffrageHandler, CleChiffrageX25519Impl, CleDechiffrageX25519Impl, CleSecreteSerialisee, Decipher};
[INFO] [stderr]    |                                               ^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `CleSecreteCipher` and `DecipherMgs4`
[INFO] [stderr]   --> src/maitredescomptes_manager.rs:23:88
[INFO] [stderr]    |
[INFO] [stderr] 23 | use millegrilles_common_rust::millegrilles_cryptographie::chiffrage_mgs4::{CipherMgs4, CleSecreteCipher, DecipherMgs4};
[INFO] [stderr]    |                                                                                        ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519`
[INFO] [stderr]   --> src/maitredescomptes_manager.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 | use millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::time::SystemTime`
[INFO] [stderr]  --> src/maitredescomptes_commands.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::time::SystemTime;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `PasskeyRegistration`, `Passkey`, and `RegisterPublicKeyCredential`
[INFO] [stderr]  --> src/maitredescomptes_commands.rs:3:74
[INFO] [stderr]   |
[INFO] [stderr] 3 | ...llengeResponse, Passkey, PasskeyAuthentication, PasskeyRegistration, PublicKeyCredential, RegisterPublicKeyCredential, RequestChalleng...
[INFO] [stderr]   |                    ^^^^^^^                         ^^^^^^^^^^^^^^^^^^^                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `NaiveDateTime` and `Timelike`
[INFO] [stderr]  --> src/maitredescomptes_commands.rs:8:50
[INFO] [stderr]   |
[INFO] [stderr] 8 | use millegrilles_common_rust::chrono::{DateTime, NaiveDateTime, Timelike, Utc};
[INFO] [stderr]   |                                                  ^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Base64`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:12:53
[INFO] [stderr]    |
[INFO] [stderr] 12 | use millegrilles_common_rust::jwt_simple::prelude::{Base64, Deserialize, Serialize};
[INFO] [stderr]    |                                                     ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `MessageMilleGrillesOwned`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:14:112
[INFO] [stderr]    |
[INFO] [stderr] 14 | ...::messages_structs::{MessageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stderr]    |                                                           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `filtrer_doc_id`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:15:93
[INFO] [stderr]    |
[INFO] [stderr] 15 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, filtrer_doc_id, start_transaction_regular, Mo...
[INFO] [stderr]    |                                                                                             ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Bson`, `DateTime as DateTimeBson`, and `bson`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:21:38
[INFO] [stderr]    |
[INFO] [stderr] 21 | use millegrilles_common_rust::bson::{Bson, bson, DateTime as DateTimeBson, doc};
[INFO] [stderr]    |                                      ^^^^  ^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Hacheur`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:23:60
[INFO] [stderr]    |
[INFO] [stderr] 23 | use millegrilles_common_rust::hachages::{hacher_bytes_vu8, Hacheur};
[INFO] [stderr]    |                                                            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `EtatTransaction` and `marquer_transaction`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:25:46
[INFO] [stderr]    |
[INFO] [stderr] 25 | use millegrilles_common_rust::transactions::{marquer_transaction, EtatTransaction};
[INFO] [stderr]    |                                              ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `MessageConfirmation`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:26:49
[INFO] [stderr]    |
[INFO] [stderr] 26 | use millegrilles_common_rust::common_messages::{MessageConfirmation, ReponseSignatureCertificat};
[INFO] [stderr]    |                                                 ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `HacheurBlake2s256`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:30:97
[INFO] [stderr]    |
[INFO] [stderr] 30 | use millegrilles_common_rust::millegrilles_cryptographie::hachages::{hacher_bytes, HachageCode, HacheurBlake2s256};
[INFO] [stderr]    |                                                                                                 ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `optionepochseconds`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:32:92
[INFO] [stderr]    |
[INFO] [stderr] 32 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::{epochseconds, optionepochseconds};
[INFO] [stderr]    |                                                                                            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `TransactionMajUsagerDelegations`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:38:308
[INFO] [stderr]    |
[INFO] [stderr] 38 | ... TransactionAjouterCle, TransactionInscrireUsager, TransactionMajUsagerDelegations, TransactionSupprimerCles};
[INFO] [stderr]    |                                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `transaction_ajouter_delegation_signee`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:39:44
[INFO] [stderr]    |
[INFO] [stderr] 39 | use crate::maitredescomptes_transactions::{transaction_ajouter_delegation_signee, CommandRegisterOtp, TransactionRegisterOtp};
[INFO] [stderr]    |                                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `CompteCredential`, `ConfigChallenge`, `Credential`, `authenticate_complete`, `multibase_to_safe`, and `valider_commande`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:40:23
[INFO] [stderr]    |
[INFO] [stderr] 40 | ...::{authenticate_complete, ClientAssertionResponse, CompteCredential, ConfigChallenge, Credential, CredentialWebauthn, generer_challenge_authentification, generer_challenge_registration, multibase_to_safe, valider_commande, v...
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^^^^^^^                           ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^  ^^^^^^^^^^                                                                                          ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `PasskeyRegistration`, `Passkey`, `PublicKeyCredential`, and `RegisterPublicKeyCredential`
[INFO] [stderr]  --> src/maitredescomptes_requests.rs:4:74
[INFO] [stderr]   |
[INFO] [stderr] 4 | ...llengeResponse, Passkey, PasskeyAuthentication, PasskeyRegistration, PublicKeyCredential, RegisterPublicKeyCredential, RequestChalleng...
[INFO] [stderr]   |                    ^^^^^^^                         ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Bson`, `DateTime as DateTimeBson`, and `bson`
[INFO] [stderr]  --> src/maitredescomptes_requests.rs:6:38
[INFO] [stderr]   |
[INFO] [stderr] 6 | use millegrilles_common_rust::bson::{Bson, bson, DateTime as DateTimeBson, doc};
[INFO] [stderr]   |                                      ^^^^  ^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `base64_url`, `chrono`, and `serde_json`
[INFO] [stderr]   --> src/maitredescomptes_requests.rs:17:32
[INFO] [stderr]    |
[INFO] [stderr] 17 | use millegrilles_common_rust::{base64_url, chrono, openssl, serde_json, uuid};
[INFO] [stderr]    |                                ^^^^^^^^^^  ^^^^^^           ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Value`
[INFO] [stderr]   --> src/maitredescomptes_requests.rs:19:50
[INFO] [stderr]    |
[INFO] [stderr] 19 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stderr]    |                                                  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `ClientAssertionResponse`, `CompteCredential`, `ConfigChallenge`, `Credential`, `authenticate_complete`, `multibase_to_safe`, `valider_commande`, `verifier_challenge_authentification`, and `verifier_challenge_registration`
[INFO] [stderr]   --> src/maitredescomptes_requests.rs:24:23
[INFO] [stderr]    |
[INFO] [stderr] 24 | ...::{authenticate_complete, ClientAssertionResponse, CompteCredential, ConfigChallenge, Credential, CredentialWebauthn, generer_challenge_authentification, generer_challenge_registration, multibase_to_safe, valider_commande, verifier_challenge_authentification, verifier_challenge_registration};
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^  ^^^^^^^^^^                                                                                          ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::messages_structs::optionepochseconds`
[INFO] [stderr]  --> src/pki_structs.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::optionepochseconds;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::maitredescomptes_manager::preparer_index_mongodb`
[INFO] [stderr]   --> src/topology_manager.rs:24:5
[INFO] [stderr]    |
[INFO] [stderr] 24 | use crate::maitredescomptes_manager::preparer_index_mongodb;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `BACKUP_CHAMP_BACKUP_TRANSACTIONS`, `TRANSACTION_CHAMP_BACKUP_FLAG`, `TRANSACTION_CHAMP_COMPLETE`, `TRANSACTION_CHAMP_EVENEMENT_COMPLETE`, `TRANSACTION_CHAMP_ID`, and `TRANSACTION_CHAMP_TRANSACTION_TRAITEE`
[INFO] [stderr]  --> src/catalogues_manager.rs:7:54
[INFO] [stderr]   |
[INFO] [stderr] 7 | ...e, BACKUP_CHAMP_BACKUP_TRANSACTIONS, TRANSACTION_CHAMP_BACKUP_FLAG, TRANSACTION_CHAMP_COMPLETE, TRANSACTION_CHAMP_EVENEMENT_COMPLETE, TRANSACTION_CHAMP_ID, TRANSACTION_CHAMP_TRANSACTION_TRAITEE};
[INFO] [stderr]   |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::maitredescomptes_manager::preparer_index_mongodb`
[INFO] [stderr]   --> src/catalogues_manager.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 | use crate::maitredescomptes_manager::preparer_index_mongodb;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `BACKUP_CHAMP_BACKUP_TRANSACTIONS`, `PKI_TRANSACTION_NOUVEAU_CERTIFICAT`, `TRANSACTION_CHAMP_BACKUP_FLAG`, `TRANSACTION_CHAMP_COMPLETE`, `TRANSACTION_CHAMP_EVENEMENT_COMPLETE`, `TRANSACTION_CHAMP_ID`, and `TRANSACTION_CHAMP_TRANSACTION_TRAITEE`
[INFO] [stderr]  --> src/pki_manager.rs:6:54
[INFO] [stderr]   |
[INFO] [stderr] 6 | ...e, BACKUP_CHAMP_BACKUP_TRANSACTIONS, PKI_DOCUMENT_CHAMP_FINGERPRINT, PKI_DOMAINE_CERTIFICAT_NOM, PKI_TRANSACTION_NOUVEAU_CERTIFICAT, TRANSACTION_CHAMP_BACKUP_FLAG, TRANSACTION_CHAMP_COMPLETE, TRANSACTION_CHAMP_EVENEMENT_COMPLETE, TRANSACTION_CHAMP_ID, TRANSACTION_CHAMP_TRANSACTION_TRAITEE};
[INFO] [stderr]   |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::maitredescomptes_manager::preparer_index_mongodb`
[INFO] [stderr]   --> src/pki_manager.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 | use crate::maitredescomptes_manager::preparer_index_mongodb;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `RoutageMessageAction`
[INFO] [stderr]  --> src/maitredescomptes_transactions.rs:4:73
[INFO] [stderr]   |
[INFO] [stderr] 4 | use millegrilles_common_rust::generateur_messages::{GenerateurMessages, RoutageMessageAction};
[INFO] [stderr]   |                                                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `convertir_to_bson`
[INFO] [stderr]  --> src/maitredescomptes_transactions.rs:6:43
[INFO] [stderr]   |
[INFO] [stderr] 6 | use millegrilles_common_rust::mongo_dao::{convertir_to_bson, MongoDao};
[INFO] [stderr]   |                                           ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::collections::HashMap`
[INFO] [stderr]  --> src/maitredescomptes_common.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::collections::HashMap;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::sync::Mutex`
[INFO] [stderr]  --> src/maitredescomptes_common.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::sync::Mutex;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Bson` and `bson`
[INFO] [stderr]  --> src/maitredescomptes_common.rs:4:38
[INFO] [stderr]   |
[INFO] [stderr] 4 | use millegrilles_common_rust::bson::{Bson, bson, DateTime as DateTimeBson, doc};
[INFO] [stderr]   |                                      ^^^^  ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519`
[INFO] [stderr]   --> src/maitredescomptes_common.rs:11:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | use millegrilles_common_rust::millegrilles_cryptographie::x25519::CleSecreteX25519;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `HashSet`
[INFO] [stderr]  --> src/topology_requests.rs:1:33
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::collections::{HashMap, HashSet};
[INFO] [stderr]   |                                 ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::time::Duration`
[INFO] [stderr]  --> src/topology_requests.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::time::Duration;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `DateTime`
[INFO] [stderr]   --> src/topology_requests.rs:10:40
[INFO] [stderr]    |
[INFO] [stderr] 10 | use millegrilles_common_rust::chrono::{DateTime, Utc};
[INFO] [stderr]    |                                        ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `MessageMilleGrillesOwned`
[INFO] [stderr]   --> src/topology_requests.rs:14:112
[INFO] [stderr]    |
[INFO] [stderr] 14 | ...::messages_structs::{MessageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stderr]    |                                                           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `convertir_to_bson`
[INFO] [stderr]   --> src/topology_requests.rs:15:74
[INFO] [stderr]    |
[INFO] [stderr] 15 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, MongoDao};
[INFO] [stderr]    |                                                                          ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `FindOneOptions`, `Hint`, and `UpdateOptions`
[INFO] [stderr]   --> src/topology_requests.rs:16:50
[INFO] [stderr]    |
[INFO] [stderr] 16 | use millegrilles_common_rust::mongodb::options::{FindOneOptions, FindOptions, Hint, UpdateOptions};
[INFO] [stderr]    |                                                  ^^^^^^^^^^^^^^               ^^^^  ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Value`
[INFO] [stderr]   --> src/topology_requests.rs:19:50
[INFO] [stderr]    |
[INFO] [stderr] 19 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stderr]    |                                                  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::url::Url`
[INFO] [stderr]   --> src/topology_requests.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 20 | use millegrilles_common_rust::url::Url;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `ReponseInformationConsignationFichiers`, `RequeteConsignationFichiers`, and `RequeteDechiffrage`
[INFO] [stderr]   --> src/topology_requests.rs:22:49
[INFO] [stderr]    |
[INFO] [stderr] 22 | ...ssages::{ReponseInformationConsignationFichiers, RequeteConsignationFichiers, PresenceFichiersRepertoire, RequeteDechiffrage, RequeteF...
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^                              ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `epochseconds`
[INFO] [stderr]   --> src/topology_requests.rs:24:78
[INFO] [stderr]    |
[INFO] [stderr] 24 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::{epochseconds, optionepochseconds};
[INFO] [stderr]    |                                                                              ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_v2`
[INFO] [stderr]   --> src/topology_requests.rs:27:5
[INFO] [stderr]    |
[INFO] [stderr] 27 | use millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_v2;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `PresenceInstanceContainer`
[INFO] [stderr]   --> src/topology_requests.rs:33:70
[INFO] [stderr]    |
[INFO] [stderr] 33 | use crate::topology_events::{PresenceInstanceConfiguredApplications, PresenceInstanceContainer, PresenceInstanceWebApplication};
[INFO] [stderr]    |                                                                      ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::topology_manager::TopologyManager`
[INFO] [stderr]   --> src/topology_requests.rs:34:5
[INFO] [stderr]    |
[INFO] [stderr] 34 | use crate::topology_manager::TopologyManager;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `ApplicationConfiguree`, `ApplicationsV2`, `InformationApplicationInstance`, `InformationInstance`, `InformationMonitor`, `PresenceMonitor`, `ReponseUrlEtag`, `TransactionConfigurerConsignation`, and `WebAppLink`
[INFO] [stderr]   --> src/topology_requests.rs:35:31
[INFO] [stderr]    |
[INFO] [stderr] 35 | ...::{ApplicationConfiguree, ApplicationPublique, ApplicationsV2, FichePublique, FilehostServerRow, FilehostingCongurationRow, InformationApplication, InformationApplicationInstance, InformationInstance, InformationMonitor, PresenceMonitor, ReponseRelaiWeb, ReponseUrlEtag, RowFilehostFuuid, ServerInstanceConfigurationRow, ServerInstanceStatus, TransactionConfigurerConsignation, WebAppLink};
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^^^^^^^                       ^^^^^^^^^^^^^^                                                                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^                   ^^^^^^^^^^^^^^                                                                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `demander_jwt_hebergement`
[INFO] [stderr]  --> src/topology_commands.rs:8:30
[INFO] [stderr]   |
[INFO] [stderr] 8 | use crate::topology_common::{demander_jwt_hebergement, maj_fiche_publique};
[INFO] [stderr]   |                              ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `PresenceMonitor` and `TransactionConfigurerConsignation`
[INFO] [stderr]   --> src/topology_commands.rs:11:110
[INFO] [stderr]    |
[INFO] [stderr] 11 | ...lehostingCongurationRow, PresenceMonitor, ReponseUrlEtag, RowFilehostFuuid, TransactionConfigurerConsignation, TransactionSetCleidBack...
[INFO] [stderr]    |                             ^^^^^^^^^^^^^^^                                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::bson`
[INFO] [stderr]   --> src/topology_commands.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | use millegrilles_common_rust::bson;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `optionepochseconds`
[INFO] [stderr]   --> src/topology_commands.rs:25:92
[INFO] [stderr]    |
[INFO] [stderr] 25 | use millegrilles_common_rust::millegrilles_cryptographie::messages_structs::{epochseconds, optionepochseconds};
[INFO] [stderr]    |                                                                                            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `FindOneOptions`, `InsertManyOptions`, and `WriteConcern`
[INFO] [stderr]   --> src/topology_commands.rs:28:50
[INFO] [stderr]    |
[INFO] [stderr] 28 | use millegrilles_common_rust::mongodb::options::{FindOneOptions, FindOptions, InsertManyOptions, UpdateOptions, WriteConcern};
[INFO] [stderr]    |                                                  ^^^^^^^^^^^^^^               ^^^^^^^^^^^^^^^^^                 ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `map_opt_chrono_datetime_as_bson_datetime` and `opt_chrono_datetime_as_bson_datetime`
[INFO] [stderr]   --> src/topology_commands.rs:35:43
[INFO] [stderr]    |
[INFO] [stderr] 35 | use millegrilles_common_rust::mongo_dao::{opt_chrono_datetime_as_bson_datetime, map_opt_chrono_datetime_as_bson_datetime};
[INFO] [stderr]    |                                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Serialize`
[INFO] [stderr]   --> src/topology_common.rs:15:66
[INFO] [stderr]    |
[INFO] [stderr] 15 | use millegrilles_common_rust::jwt_simple::prelude::{Deserialize, Serialize};
[INFO] [stderr]    |                                                                  ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `ApplicationPublique` and `InformationMonitor`
[INFO] [stderr]   --> src/topology_common.rs:22:31
[INFO] [stderr]    |
[INFO] [stderr] 22 | ...ts::{ApplicationPublique, ApplicationsV2, FichePublique, InformationApplicationInstance, InformationInstance, InformationMonitor, JwtH...
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^                                                                                      ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Array`, `Bson`, and `DateTime`
[INFO] [stderr]  --> src/topology_events.rs:4:43
[INFO] [stderr]   |
[INFO] [stderr] 4 | use millegrilles_common_rust::bson::{doc, Bson, Array, DateTime};
[INFO] [stderr]   |                                           ^^^^  ^^^^^  ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `DOMAINE_APPLICATION_INSTANCE`
[INFO] [stderr]  --> src/topology_events.rs:9:118
[INFO] [stderr]   |
[INFO] [stderr] 9 | ...RESENCE_DOMAINE, CHAMP_CREATION, CHAMP_MODIFICATION, DOMAINE_APPLICATION_INSTANCE, RolesCertificats, BACKUP_EVENEMENT_MAJ};
[INFO] [stderr]   |                                                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_serializable_v2`
[INFO] [stderr]   --> src/topology_events.rs:11:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | use millegrilles_common_rust::middleware::sauvegarder_traiter_transaction_serializable_v2;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::millegrilles_cryptographie::deser_message_buffer`
[INFO] [stderr]   --> src/topology_events.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | use millegrilles_common_rust::millegrilles_cryptographie::deser_message_buffer;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `convertir_bson_deserializable`
[INFO] [stderr]   --> src/topology_events.rs:15:43
[INFO] [stderr]    |
[INFO] [stderr] 15 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, start_transaction_regular, MongoDao};
[INFO] [stderr]    |                                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `json`
[INFO] [stderr]   --> src/topology_events.rs:19:44
[INFO] [stderr]    |
[INFO] [stderr] 19 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stderr]    |                                            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `PresenceMonitor`, `RowFuuid`, and `TransactionSetFichiersPrimaire`
[INFO] [stderr]   --> src/topology_events.rs:25:83
[INFO] [stderr]    |
[INFO] [stderr] 25 | ...uid, PresenceDomaine, PresenceMonitor, RowFilehostFuuid, RowFilehostId, RowFuuid, TransactionSetFichiersPrimaire};
[INFO] [stderr]    |                          ^^^^^^^^^^^^^^^                                   ^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::mongo_dao::opt_chrono_datetime_as_bson_datetime`
[INFO] [stderr]   --> src/topology_events.rs:26:5
[INFO] [stderr]    |
[INFO] [stderr] 26 | use millegrilles_common_rust::mongo_dao::opt_chrono_datetime_as_bson_datetime;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `RoutageMessageAction`
[INFO] [stderr]  --> src/topology_transactions.rs:5:73
[INFO] [stderr]   |
[INFO] [stderr] 5 | use millegrilles_common_rust::generateur_messages::{GenerateurMessages, RoutageMessageAction};
[INFO] [stderr]   |                                                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `convertir_bson_deserializable` and `convertir_to_bson`
[INFO] [stderr]  --> src/topology_transactions.rs:7:43
[INFO] [stderr]   |
[INFO] [stderr] 7 | use millegrilles_common_rust::mongo_dao::{convertir_bson_deserializable, convertir_to_bson, MongoDao};
[INFO] [stderr]   |                                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `FilehostServerRow`, `PresenceMonitor`, `TransactionConfigurerConsignation`, `TransactionSetFichiersPrimaire`, and `TransactionSupprimerConsignationInstance`
[INFO] [stderr]   --> src/topology_transactions.rs:11:31
[INFO] [stderr]    |
[INFO] [stderr] 11 | ...::{FilehostServerRow, FilehostingCongurationRow, PresenceDomaine, PresenceMonitor, TransactionConfigurerConsignation, TransactionSetFichiersPrimaire, TransactionSetFilehostInstance, TransactionSupprimerConsignationInstance};
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^^^                                              ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::common_messages::ReponseInformationConsignationFichiers`
[INFO] [stderr]   --> src/topology_transactions.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | use millegrilles_common_rust::common_messages::ReponseInformationConsignationFichiers;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `FindOneAndUpdateOptions` and `ReturnDocument`
[INFO] [stderr]   --> src/topology_transactions.rs:17:50
[INFO] [stderr]    |
[INFO] [stderr] 17 | use millegrilles_common_rust::mongodb::options::{FindOneAndUpdateOptions, ReturnDocument, UpdateOptions};
[INFO] [stderr]    |                                                  ^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::serde_json::json`
[INFO] [stderr]   --> src/topology_transactions.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 | use millegrilles_common_rust::serde_json::json;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::bson`
[INFO] [stderr]  --> src/topology_maintenance.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use millegrilles_common_rust::bson;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `FichePublique` and `InformationMonitor`
[INFO] [stderr]  --> src/topology_maintenance.rs:7:31
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::topology_structs::{FichePublique, FilehostServerRow, FilehostTransfer, InformationMonitor, RowFilehostFuuid};
[INFO] [stderr]   |                               ^^^^^^^^^^^^^                                       ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Datelike`
[INFO] [stderr]   --> src/topology_maintenance.rs:11:50
[INFO] [stderr]    |
[INFO] [stderr] 11 | use millegrilles_common_rust::chrono::{DateTime, Datelike, Timelike, Utc};
[INFO] [stderr]    |                                                  ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::common_messages::EventFilehost`
[INFO] [stderr]   --> src/topology_maintenance.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | use millegrilles_common_rust::common_messages::EventFilehost;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `CHAMP_CREATION`, `CHAMP_MODIFICATION`, `TOPOLOGIE_NOM_DOMAINE`, and `TRANSACTION_CHAMP_IDMG`
[INFO] [stderr]   --> src/topology_maintenance.rs:14:54
[INFO] [stderr]    |
[INFO] [stderr] 14 | ...ntes::{Securite, CHAMP_CREATION, CHAMP_MODIFICATION, DOMAINE_TOPOLOGIE, TOPOLOGIE_NOM_DOMAINE, TRANSACTION_CHAMP_IDMG};
[INFO] [stderr]    |                     ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^                     ^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::middleware::EmetteurNotificationsTrait`
[INFO] [stderr]   --> src/topology_maintenance.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 | use millegrilles_common_rust::middleware::EmetteurNotificationsTrait;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `FindOptions` and `UpdateOptions`
[INFO] [stderr]   --> src/topology_maintenance.rs:21:68
[INFO] [stderr]    |
[INFO] [stderr] 21 | use millegrilles_common_rust::mongodb::options::{AggregateOptions, FindOptions, Hint, UpdateOptions};
[INFO] [stderr]    |                                                                    ^^^^^^^^^^^        ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::notifications::NotificationMessageInterne`
[INFO] [stderr]   --> src/topology_maintenance.rs:22:5
[INFO] [stderr]    |
[INFO] [stderr] 22 | use millegrilles_common_rust::notifications::NotificationMessageInterne;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `warn`
[INFO] [stderr]  --> src/catalogues_requests.rs:2:25
[INFO] [stderr]   |
[INFO] [stderr] 2 | use log::{debug, error, warn};
[INFO] [stderr]   |                         ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `convertir_bson_value` and `filtrer_doc_id`
[INFO] [stderr]  --> src/catalogues_requests.rs:9:43
[INFO] [stderr]   |
[INFO] [stderr] 9 | use millegrilles_common_rust::mongo_dao::{convertir_bson_value, filtrer_doc_id, MongoDao};
[INFO] [stderr]   |                                           ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `json`
[INFO] [stderr]   --> src/catalogues_requests.rs:13:44
[INFO] [stderr]    |
[INFO] [stderr] 13 | use millegrilles_common_rust::serde_json::{json, Value};
[INFO] [stderr]    |                                            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `MessageMilleGrillesOwned`
[INFO] [stderr]  --> src/catalogues_commands.rs:7:112
[INFO] [stderr]   |
[INFO] [stderr] 7 | ...::messages_structs::{MessageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stderr]   |                                                           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Catalogue`
[INFO] [stderr]   --> src/catalogues_commands.rs:15:33
[INFO] [stderr]    |
[INFO] [stderr] 15 | use crate::catalogues_structs::{Catalogue, MessageCatalogue, SetPackageVersionTransaction};
[INFO] [stderr]    |                                 ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `warn`
[INFO] [stderr]  --> src/pki_maintenance.rs:1:25
[INFO] [stderr]   |
[INFO] [stderr] 1 | use log::{debug, error, warn};
[INFO] [stderr]   |                         ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `EmetteurNotificationsTrait`
[INFO] [stderr]  --> src/pki_maintenance.rs:8:93
[INFO] [stderr]   |
[INFO] [stderr] 8 | use millegrilles_common_rust::middleware::{sauvegarder_traiter_transaction_serializable_v2, EmetteurNotificationsTrait};
[INFO] [stderr]   |                                                                                             ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::topology_events::produire_fiche_publique`
[INFO] [stderr]   --> src/pki_maintenance.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 16 | use crate::topology_events::produire_fiche_publique;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `while` condition
[INFO] [stderr]   --> src/pki_maintenance.rs:71:10
[INFO] [stderr]    |
[INFO] [stderr] 71 |     while(cursor.advance().await?) {
[INFO] [stderr]    |          ^                       ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 71 -     while(cursor.advance().await?) {
[INFO] [stderr] 71 +     while cursor.advance().await? {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `domaine`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:48:18
[INFO] [stderr]    |
[INFO] [stderr] 48 |     let (action, domaine) = match &m.type_message {
[INFO] [stderr]    |                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `message_id`
[INFO] [stderr]    --> src/maitredescomptes_commands.rs:300:23
[INFO] [stderr]     |
[INFO] [stderr] 300 |     let (transaction, message_id) = {
[INFO] [stderr]     |                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `securite`
[INFO] [stderr]    --> src/maitredescomptes_commands.rs:325:17
[INFO] [stderr]     |
[INFO] [stderr] 325 |             let securite = &transaction.securite;
[INFO] [stderr]     |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_securite`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `resultat_inscrire_usager`
[INFO] [stderr]    --> src/maitredescomptes_commands.rs:356:17
[INFO] [stderr]     |
[INFO] [stderr] 356 |             let resultat_inscrire_usager = sauvegarder_traiter_transaction_v2(
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resultat_inscrire_usager`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `uuid_transaction`
[INFO] [stderr]    --> src/maitredescomptes_commands.rs:386:9
[INFO] [stderr]     |
[INFO] [stderr] 386 |     let uuid_transaction = message_ref.id.to_owned();
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_uuid_transaction`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `compte_usager`
[INFO] [stderr]    --> src/maitredescomptes_commands.rs:440:9
[INFO] [stderr]     |
[INFO] [stderr] 440 |     let compte_usager = match charger_compte_user_id(middleware, &user_id_certificat, session).await? {
[INFO] [stderr]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_compte_usager`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `message_id`
[INFO] [stderr]    --> src/maitredescomptes_commands.rs:498:9
[INFO] [stderr]     |
[INFO] [stderr] 498 |     let message_id = {
[INFO] [stderr]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/maitredescomptes_commands.rs:524:20
[INFO] [stderr]     |
[INFO] [stderr] 524 |         if let Err(e) = message_confirmation.verifier_signature() {
[INFO] [stderr]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `flag_generer_nouveau_certificat`
[INFO] [stderr]    --> src/maitredescomptes_commands.rs:810:9
[INFO] [stderr]     |
[INFO] [stderr] 810 |     let flag_generer_nouveau_certificat = commande.commande_webauthn.demande_certificat.is_some();
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_flag_generer_nouveau_certificat`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `hostname`
[INFO] [stderr]     --> src/maitredescomptes_commands.rs:1076:9
[INFO] [stderr]      |
[INFO] [stderr] 1076 |     let hostname = commande.hostname.as_str();
[INFO] [stderr]      |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_hostname`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `common_name`
[INFO] [stderr]     --> src/maitredescomptes_commands.rs:1117:9
[INFO] [stderr]      |
[INFO] [stderr] 1117 |     let common_name = match csr_subject.get("commonName") {
[INFO] [stderr]      |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_common_name`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `resultat`
[INFO] [stderr]     --> src/maitredescomptes_commands.rs:1155:9
[INFO] [stderr]      |
[INFO] [stderr] 1155 |     let resultat = collection.update_one_with_session(filtre, ops, Some(options), session).await?;
[INFO] [stderr]      |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resultat`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `compte`
[INFO] [stderr]     --> src/maitredescomptes_commands.rs:1547:9
[INFO] [stderr]      |
[INFO] [stderr] 1547 |     let compte: CompteUsager = {
[INFO] [stderr]      |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_compte`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/maitredescomptes_commands.rs:1588:9
[INFO] [stderr]      |
[INFO] [stderr] 1588 |     let mut encrypted_url = gestionnaire.encrypt_string(middleware, totp_url).await?;
[INFO] [stderr]      |         ----^^^^^^^^^^^^^
[INFO] [stderr]      |         |
[INFO] [stderr]      |         help: remove this `mut`
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `idmg`
[INFO] [stderr]     --> src/maitredescomptes_commands.rs:1695:9
[INFO] [stderr]      |
[INFO] [stderr] 1695 |     let idmg = middleware.idmg();
[INFO] [stderr]      |         ^^^^ help: if this is intentional, prefix it with an underscore: `_idmg`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `totp_url_used` is assigned to, but never used
[INFO] [stderr]     --> src/maitredescomptes_commands.rs:1710:13
[INFO] [stderr]      |
[INFO] [stderr] 1710 |     let mut totp_url_used = None;
[INFO] [stderr]      |             ^^^^^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: consider using `_totp_url_used` instead
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `totp_url_used` is never read
[INFO] [stderr]     --> src/maitredescomptes_commands.rs:1727:17
[INFO] [stderr]      |
[INFO] [stderr] 1727 |                 totp_url_used = Some(totp_url);
[INFO] [stderr]      |                 ^^^^^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = help: maybe it is overwritten before being read?
[INFO] [stderr]      = note: `#[warn(unused_assignments)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]   --> src/maitredescomptes_requests.rs:70:9
[INFO] [stderr]    |
[INFO] [stderr] 50 |         DOMAINE_NOM => {
[INFO] [stderr]    |         ----------- matches any value
[INFO] [stderr] ...
[INFO] [stderr] 70 |         _ => {
[INFO] [stderr]    |         ^ no value can reach this
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unreachable_patterns)]` on by default
[INFO] [stderr] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stderr]    |
[INFO] [stderr] 50 -         DOMAINE_NOM => {
[INFO] [stderr] 50 +         DOMAIN_NAME => {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `u`
[INFO] [stderr]   --> src/maitredescomptes_requests.rs:44:18
[INFO] [stderr]    |
[INFO] [stderr] 44 |             Some(u) => Ok(()),
[INFO] [stderr]    |                  ^ help: if this is intentional, prefix it with an underscore: `_u`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `DOMAINE_NOM`
[INFO] [stderr]   --> src/maitredescomptes_requests.rs:50:9
[INFO] [stderr]    |
[INFO] [stderr] 50 |         DOMAINE_NOM => {
[INFO] [stderr]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_DOMAINE_NOM`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/maitredescomptes_requests.rs:221:14
[INFO] [stderr]     |
[INFO] [stderr] 221 |         Some(mut doc_usager) => {
[INFO] [stderr]     |              ----^^^^^^^^^^
[INFO] [stderr]     |              |
[INFO] [stderr]     |              help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/maitredescomptes_requests.rs:468:17
[INFO] [stderr]     |
[INFO] [stderr] 468 |             let mut doc_usager = d?;
[INFO] [stderr]     |                 ----^^^^^^^^^^
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `requete`
[INFO] [stderr]    --> src/maitredescomptes_requests.rs:574:9
[INFO] [stderr]     |
[INFO] [stderr] 574 |     let requete: RequeteListeUsagers = message_contenu.deserialize()?;
[INFO] [stderr]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_requete`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `middleware`
[INFO] [stderr]   --> src/maitredescomptes_events.rs:11:54
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub async fn consommer_evenement_maitredescomptes<M>(middleware: &M, m: MessageValide)
[INFO] [stderr]    |                                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_middleware`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/maitredescomptes_transactions.rs:239:20
[INFO] [stderr]     |
[INFO] [stderr] 239 |         if let Err(e) = collection_totp.delete_many_with_session(filtre, None, session).await {
[INFO] [stderr]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/maitredescomptes_transactions.rs:243:20
[INFO] [stderr]     |
[INFO] [stderr] 243 |         if let Err(e) = collection.delete_many_with_session(filtre, None, session).await {
[INFO] [stderr]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/maitredescomptes_transactions.rs:402:20
[INFO] [stderr]     |
[INFO] [stderr] 402 |         if let Err(e) = collection.delete_many_with_session(filtre, None, session).await {
[INFO] [stderr]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/maitredescomptes_transactions.rs:407:20
[INFO] [stderr]     |
[INFO] [stderr] 407 |         if let Err(e) = collection_webauthn.delete_many_with_session(filtre, None, session).await {
[INFO] [stderr]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `message_id`
[INFO] [stderr]    --> src/maitredescomptes_common.rs:115:10
[INFO] [stderr]     |
[INFO] [stderr] 115 |     let (message_id, commande) = {
[INFO] [stderr]     |          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `user_id`
[INFO] [stderr]    --> src/maitredescomptes_common.rs:122:9
[INFO] [stderr]     |
[INFO] [stderr] 122 |     let user_id = commande.user_id.as_str();
[INFO] [stderr]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]   --> src/pki_requests.rs:87:9
[INFO] [stderr]    |
[INFO] [stderr] 67 |         DOMAINE_NOM => {
[INFO] [stderr]    |         ----------- matches any value
[INFO] [stderr] ...
[INFO] [stderr] 87 |         DOMAINE_CERTIFICAT_NOM => {
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stderr]    |
[INFO] [stderr] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stderr]    |
[INFO] [stderr] 67 -         DOMAINE_NOM => {
[INFO] [stderr] 67 +         DOMAIN_NAME => {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]   --> src/pki_requests.rs:98:9
[INFO] [stderr]    |
[INFO] [stderr] 67 |         DOMAINE_NOM => {
[INFO] [stderr]    |         ----------- matches any value
[INFO] [stderr] ...
[INFO] [stderr] 98 |         _ => Err(String::from("Mauvais type de requete de certificat"))
[INFO] [stderr]    |         ^ no value can reach this
[INFO] [stderr]    |
[INFO] [stderr] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stderr]    |
[INFO] [stderr] 67 -         DOMAINE_NOM => {
[INFO] [stderr] 67 +         DOMAIN_NAME => {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `DOMAINE_NOM`
[INFO] [stderr]   --> src/pki_requests.rs:67:9
[INFO] [stderr]    |
[INFO] [stderr] 67 |         DOMAINE_NOM => {
[INFO] [stderr]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_DOMAINE_NOM`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/pki_requests.rs:120:9
[INFO] [stderr]     |
[INFO] [stderr] 120 |     let mut builder_routage = RoutageMessageAction::builder("certificat", "infoCertificat", exchange);
[INFO] [stderr]     |         ----^^^^^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `domaine`
[INFO] [stderr]   --> src/pki_commands.rs:27:10
[INFO] [stderr]    |
[INFO] [stderr] 27 |     let (domaine, action) = match &m.type_message {
[INFO] [stderr]    |          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `session`
[INFO] [stderr]   --> src/pki_commands.rs:82:91
[INFO] [stderr]    |
[INFO] [stderr] 82 | pub async fn traiter_commande_sauvegarder_certificat<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stderr]    |                                                                                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `domaine`
[INFO] [stderr]   --> src/pki_commands.rs:86:9
[INFO] [stderr]    |
[INFO] [stderr] 86 |     let domaine = match &m.type_message {
[INFO] [stderr]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `middleware`
[INFO] [stderr]    --> src/pki_commands.rs:120:47
[INFO] [stderr]     |
[INFO] [stderr] 120 | async fn valider_demande_signature_csr<'a, M>(middleware: &M, m: &'a MessageValide)
[INFO] [stderr]     |                                               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_middleware`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `session`
[INFO] [stderr]   --> src/pki_transactions.rs:59:84
[INFO] [stderr]    |
[INFO] [stderr] 59 | async fn sauvegarder_certificat<M>(middleware: &M, transaction: TransactionValide, session: &mut ClientSession)
[INFO] [stderr]    |                                                                                    ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]    --> src/topology_requests.rs:134:9
[INFO] [stderr]     |
[INFO] [stderr] 134 |         _ => {
[INFO] [stderr]     |         ^ no value can reach this
[INFO] [stderr]     |
[INFO] [stderr] note: multiple earlier patterns match some of the same values
[INFO] [stderr]    --> src/topology_requests.rs:134:9
[INFO] [stderr]     |
[INFO] [stderr]  59 |         Securite::L1Public => {
[INFO] [stderr]     |         ------------------ matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr]  84 |         Securite::L2Prive => {
[INFO] [stderr]     |         ----------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 108 |         Securite::L3Protege | Securite::L4Secure => {
[INFO] [stderr]     |         ---------------------------------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 134 |         _ => {
[INFO] [stderr]     |         ^ collectively making this unreachable
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]    --> src/topology_requests.rs:128:17
[INFO] [stderr]     |
[INFO] [stderr] 110 |                 DOMAINE_NOM => {
[INFO] [stderr]     |                 ----------- matches any value
[INFO] [stderr] ...
[INFO] [stderr] 128 |                 _ => {
[INFO] [stderr]     |                 ^ no value can reach this
[INFO] [stderr]     |
[INFO] [stderr] help: you might have meant to pattern match against the value of similarly named constant `DOMAIN_NAME` instead of introducing a new catch-all binding
[INFO] [stderr]     |
[INFO] [stderr] 110 -                 DOMAINE_NOM => {
[INFO] [stderr] 110 +                 DOMAIN_NAME => {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `DOMAINE_NOM`
[INFO] [stderr]    --> src/topology_requests.rs:110:17
[INFO] [stderr]     |
[INFO] [stderr] 110 |                 DOMAINE_NOM => {
[INFO] [stderr]     |                 ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_DOMAINE_NOM`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/topology_requests.rs:190:25
[INFO] [stderr]     |
[INFO] [stderr] 190 |                     let mut fiche: FichePublique = convertir_bson_deserializable(doc_fiche)?;
[INFO] [stderr]     |                         ----^^^^^
[INFO] [stderr]     |                         |
[INFO] [stderr]     |                         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `url_verifie`
[INFO] [stderr]    --> src/topology_requests.rs:392:23
[INFO] [stderr]     |
[INFO] [stderr] 392 |             let (jwt, url_verifie) = match demander_jwt_hebergement(middleware, &fiche_publique, None).await {
[INFO] [stderr]     |                       ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_url_verifie`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `refus`
[INFO] [stderr]    --> src/topology_requests.rs:451:17
[INFO] [stderr]     |
[INFO] [stderr] 451 |             let refus = json!({"ok": false, "err": "Acces refuse"});
[INFO] [stderr]     |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_refus`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `d`
[INFO] [stderr]     --> src/topology_requests.rs:1026:22
[INFO] [stderr]      |
[INFO] [stderr] 1026 |                 Some(d) => {
[INFO] [stderr]      |                      ^ help: if this is intentional, prefix it with an underscore: `_d`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `gestionnaire`
[INFO] [stderr]    --> src/topology_commands.rs:116:89
[INFO] [stderr]     |
[INFO] [stderr] 116 | ...essage: MessageValide, gestionnaire: &TopologyManager, session: &mut ClientSession)
[INFO] [stderr]     |                           ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_gestionnaire`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `session`
[INFO] [stderr]    --> src/topology_commands.rs:116:121
[INFO] [stderr]     |
[INFO] [stderr] 116 | ...ionnaire: &TopologyManager, session: &mut ClientSession)
[INFO] [stderr]     |                                ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `commande`
[INFO] [stderr]    --> src/topology_commands.rs:221:13
[INFO] [stderr]     |
[INFO] [stderr] 221 |         let commande: TransactionSetFichiersPrimaire = match message_owned.deserialize() {
[INFO] [stderr]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commande`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/topology_commands.rs:200:70
[INFO] [stderr]     |
[INFO] [stderr] 200 | async fn traiter_commande_configurer_consignation<M>(middleware: &M, mut message: MessageValide, gestionnaire: &TopologyManager, session:...
[INFO] [stderr]     |                                                                      ----^^^^^^^
[INFO] [stderr]     |                                                                      |
[INFO] [stderr]     |                                                                      help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `gestionnaire`
[INFO] [stderr]    --> src/topology_commands.rs:872:66
[INFO] [stderr]     |
[INFO] [stderr] 872 | async fn command_file_visit<M>(middleware: &M, m: MessageValide, gestionnaire: &TopologyManager, session: &mut ClientSession)
[INFO] [stderr]     |                                                                  ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_gestionnaire`
[INFO] [stderr] 
[INFO] [stderr] warning: irrefutable `if let` pattern
[INFO] [stderr]     --> src/topology_commands.rs:1009:12
[INFO] [stderr]      |
[INFO] [stderr] 1009 |         if let extensions = m.certificat.extensions()? {
[INFO] [stderr]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: this pattern will always match, so the `if let` is useless
[INFO] [stderr]      = help: consider replacing the `if let` with a `let`
[INFO] [stderr]      = note: `#[warn(irrefutable_let_patterns)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `session`
[INFO] [stderr]     --> src/topology_commands.rs:1094:81
[INFO] [stderr]      |
[INFO] [stderr] 1094 | async fn commande_filehost_batch_transfers<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stderr]      |                                                                                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `session`
[INFO] [stderr]     --> src/topology_commands.rs:1186:85
[INFO] [stderr]      |
[INFO] [stderr] 1186 | async fn commande_filehost_reset_visits_claims<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stderr]      |                                                                                     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `session`
[INFO] [stderr]     --> src/topology_commands.rs:1242:81
[INFO] [stderr]      |
[INFO] [stderr] 1242 | async fn commande_filehost_reset_transfers<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stderr]      |                                                                                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `session`
[INFO] [stderr]     --> src/topology_commands.rs:1313:77
[INFO] [stderr]      |
[INFO] [stderr] 1313 | async fn commande_domain_visits_claims<M>(middleware: &M, m: MessageValide, session: &mut ClientSession)
[INFO] [stderr]      |                                                                             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `instance_id`
[INFO] [stderr]   --> src/topology_common.rs:60:10
[INFO] [stderr]    |
[INFO] [stderr] 60 |     for (instance_id, instance) in &fiche.instances {
[INFO] [stderr]    |          ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_instance_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `inner`
[INFO] [stderr]   --> src/topology_common.rs:68:26
[INFO] [stderr]    |
[INFO] [stderr] 68 |                     Some(inner) => match etag.as_ref() {
[INFO] [stderr]    |                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_inner`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `hostname`
[INFO] [stderr]    --> src/topology_common.rs:128:21
[INFO] [stderr]     |
[INFO] [stderr] 128 |         if let Some(hostname) = url.host_str() {
[INFO] [stderr]     |                     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_hostname`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/topology_common.rs:179:33
[INFO] [stderr]     |
[INFO] [stderr] 179 | ...                   Err(e) => {
[INFO] [stderr]     |                           ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/topology_common.rs:195:20
[INFO] [stderr]     |
[INFO] [stderr] 195 |         if let Err(e) = message_owned.verifier_signature() {
[INFO] [stderr]     |                    ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `domaine`
[INFO] [stderr]   --> src/topology_events.rs:36:10
[INFO] [stderr]    |
[INFO] [stderr] 36 |     let (domaine, action) = match &m.type_message {
[INFO] [stderr]    |          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_domaine`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `gestionnaire`
[INFO] [stderr]   --> src/topology_events.rs:86:72
[INFO] [stderr]    |
[INFO] [stderr] 86 | async fn traiter_presence_domaine<M>(middleware: &M, m: MessageValide, gestionnaire: &TopologyManager)
[INFO] [stderr]    |                                                                        ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_gestionnaire`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `result`
[INFO] [stderr]    --> src/topology_events.rs:134:9
[INFO] [stderr]     |
[INFO] [stderr] 134 |     let result = match collection.find_one_and_update(filtre, ops, Some(options)).await {
[INFO] [stderr]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/topology_events.rs:455:17
[INFO] [stderr]     |
[INFO] [stderr] 455 |             let mut missing_from = filehost_ids.difference(&filehost_ids_visits);
[INFO] [stderr]     |                 ----^^^^^^^^^^^^
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `session`
[INFO] [stderr]    --> src/topology_transactions.rs:400:74
[INFO] [stderr]     |
[INFO] [stderr] 400 | async fn filehost_add<M>(middleware: &M, transaction: TransactionValide, session: &mut ClientSession)
[INFO] [stderr]     |                                                                          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_session`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/catalogues_requests.rs:191:9
[INFO] [stderr]     |
[INFO] [stderr] 191 |     let mut catalogue = match collection.find_one(filtre, None).await? {
[INFO] [stderr]     |         ----^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `inner`
[INFO] [stderr]    --> src/catalogues_commands.rs:120:12
[INFO] [stderr]     |
[INFO] [stderr] 120 |         Ok(inner) => {
[INFO] [stderr]     |            ^^^^^ help: if this is intentional, prefix it with an underscore: `_inner`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/catalogues_commands.rs:76:9
[INFO] [stderr]    |
[INFO] [stderr] 76 |     let mut message_catalogue: MessageCatalogue = {
[INFO] [stderr]    |         ----^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::redis::Commands`
[INFO] [stderr]   --> src/topology_commands.rs:34:5
[INFO] [stderr]    |
[INFO] [stderr] 34 | use millegrilles_common_rust::redis::Commands;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `log::kv::Source`
[INFO] [stderr]  --> src/topology_events.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use log::kv::Source;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `MessageValidable`
[INFO] [stderr]   --> src/topology_requests.rs:14:138
[INFO] [stderr]    |
[INFO] [stderr] 14 | ...essageMilleGrillesBufferDefault, MessageMilleGrillesOwned, MessageValidable};
[INFO] [stderr]    |                                                               ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Decipher`
[INFO] [stderr]   --> src/maitredescomptes_manager.rs:21:177
[INFO] [stderr]    |
[INFO] [stderr] 21 | ...ageX25519Impl, CleDechiffrageX25519Impl, CleSecreteSerialisee, Decipher};
[INFO] [stderr]    |                                                                   ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::tokio_stream::StreamExt`
[INFO] [stderr]   --> src/maitredescomptes_commands.rs:31:5
[INFO] [stderr]    |
[INFO] [stderr] 31 | use millegrilles_common_rust::tokio_stream::StreamExt;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `millegrilles_common_rust::tokio_stream::StreamExt`
[INFO] [stderr]   --> src/topology_maintenance.rs:24:5
[INFO] [stderr]    |
[INFO] [stderr] 24 | use millegrilles_common_rust::tokio_stream::StreamExt;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/validateur_pki_mongo.rs:519:22
[INFO] [stderr]     |
[INFO] [stderr] 519 |     let (middleware, mut futures) = preparer_middleware_db_v2().expect("preparer_middleware_db_v2");
[INFO] [stderr]     |                      ----^^^^^^^
[INFO] [stderr]     |                      |
[INFO] [stderr]     |                      help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/webauthn.rs:46:9
[INFO] [stderr]    |
[INFO] [stderr] 46 |     let mut builder = WebauthnBuilder::new(rp_id, &rp_origin)?
[INFO] [stderr]    |         ----^^^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/webauthn.rs:69:9
[INFO] [stderr]    |
[INFO] [stderr] 69 |     let mut builder = WebauthnBuilder::new(rp_id, &rp_origin)?
[INFO] [stderr]    |         ----^^^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/webauthn.rs:130:9
[INFO] [stderr]     |
[INFO] [stderr] 130 |     let mut builder = WebauthnBuilder::new(rp_id, &rp_origin)?
[INFO] [stderr]     |         ----^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `credentials`
[INFO] [stderr]    --> src/webauthn.rs:380:30
[INFO] [stderr]     |
[INFO] [stderr] 380 | pub fn authenticate_complete(credentials: u64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, respons...
[INFO] [stderr]     |                              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_credentials`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `challenge`
[INFO] [stderr]    --> src/webauthn.rs:380:48
[INFO] [stderr]     |
[INFO] [stderr] 380 | pub fn authenticate_complete(credentials: u64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, respons...
[INFO] [stderr]     |                                                ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_challenge`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rsp`
[INFO] [stderr]    --> src/webauthn.rs:380:76
[INFO] [stderr]     |
[INFO] [stderr] 380 | ...64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, response: AuthenticatorAssertionResponseRaw, cr...
[INFO] [stderr]     |                                    ^^^ help: if this is intentional, prefix it with an underscore: `_rsp`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `manager`
[INFO] [stderr]    --> src/topology_manager.rs:120:24
[INFO] [stderr]     |
[INFO] [stderr] 120 | pub fn preparer_queues(manager: &TopologyManager) -> Vec<QueueType> {
[INFO] [stderr]     |                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_manager`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `manager`
[INFO] [stderr]    --> src/catalogues_manager.rs:119:24
[INFO] [stderr]     |
[INFO] [stderr] 119 | pub fn preparer_queues(manager: &CataloguesManager) -> Vec<QueueType> {
[INFO] [stderr]     |                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_manager`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `niveaux_securite_prive`
[INFO] [stderr]    --> src/pki_manager.rs:118:9
[INFO] [stderr]     |
[INFO] [stderr] 118 |     let niveaux_securite_prive = vec!(Securite::L2Prive);  //, Securite::L3Protege);
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_niveaux_securite_prive`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `manager`
[INFO] [stderr]    --> src/pki_manager.rs:114:24
[INFO] [stderr]     |
[INFO] [stderr] 114 | pub fn preparer_queues(manager: &PkiManager) -> Vec<QueueType> {
[INFO] [stderr]     |                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_manager`
[INFO] [stderr] 
[INFO] [stderr] warning: fields `rp_id`, `hostname`, and `challenge_b64` are never read
[INFO] [stderr]    --> src/webauthn.rs:287:9
[INFO] [stderr]     |
[INFO] [stderr] 286 | pub struct ConfigChallenge {
[INFO] [stderr]     |            --------------- fields in this struct
[INFO] [stderr] 287 |     pub rp_id: String,
[INFO] [stderr]     |         ^^^^^
[INFO] [stderr] 288 |     pub hostname: String,
[INFO] [stderr]     |         ^^^^^^^^
[INFO] [stderr] 289 |     pub challenge_b64: String,
[INFO] [stderr]     |         ^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]    --> src/webauthn.rs:335:29
[INFO] [stderr]     |
[INFO] [stderr] 335 |     DemandeSignerCertificat(Vec<u8>),
[INFO] [stderr]     |     ----------------------- ^^^^^^^
[INFO] [stderr]     |     |
[INFO] [stderr]     |     field in this variant
[INFO] [stderr]     |
[INFO] [stderr]     = note: `CommandeWebauthn` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]     |
[INFO] [stderr] 335 -     DemandeSignerCertificat(Vec<u8>),
[INFO] [stderr] 335 +     DemandeSignerCertificat(()),
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CompteCredential` is never constructed
[INFO] [stderr]    --> src/webauthn.rs:346:12
[INFO] [stderr]     |
[INFO] [stderr] 346 | pub struct CompteCredential {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `verifier_commande` is never used
[INFO] [stderr]    --> src/webauthn.rs:356:4
[INFO] [stderr]     |
[INFO] [stderr] 356 | fn verifier_commande<S>(commande: &CommandeWebauthn, message: &S) -> Result<bool, millegrilles_common_rust::error::Error>
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `authenticate_complete` is never used
[INFO] [stderr]    --> src/webauthn.rs:380:8
[INFO] [stderr]     |
[INFO] [stderr] 380 | pub fn authenticate_complete(credentials: u64, challenge: ConfigChallenge, rsp: PublicKeyCredential)  // , challenge: &Challenge, respons...
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `multibase_to_safe` is never used
[INFO] [stderr]    --> src/webauthn.rs:484:8
[INFO] [stderr]     |
[INFO] [stderr] 484 | pub fn multibase_to_safe<S>(val: S) -> Result<Base64UrlSafeData, CoreError>
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `valider_commande` is never used
[INFO] [stderr]    --> src/webauthn.rs:494:8
[INFO] [stderr]     |
[INFO] [stderr] 494 | pub fn valider_commande<M, S>(hostname: S, challenge: S, message: &M) -> Result<bool, CoreError>
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `COMMANDE_SIGNER_CERTIFICAT` is never used
[INFO] [stderr]    --> src/webauthn.rs:522:11
[INFO] [stderr]     |
[INFO] [stderr] 522 |     const COMMANDE_SIGNER_CERTIFICAT: &str = r#"
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]  --> src/error.rs:9:31
[INFO] [stderr]   |
[INFO] [stderr] 9 |     MillegrillesCryptographie(millegrilles_common_rust::millegrilles_cryptographie::error::Error),
[INFO] [stderr]   |     ------------------------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |     |
[INFO] [stderr]   |     field in this variant
[INFO] [stderr]   |
[INFO] [stderr]   = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]   |
[INFO] [stderr] 9 -     MillegrillesCryptographie(millegrilles_common_rust::millegrilles_cryptographie::error::Error),
[INFO] [stderr] 9 +     MillegrillesCryptographie(()),
[INFO] [stderr]   |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/error.rs:10:24
[INFO] [stderr]    |
[INFO] [stderr] 10 |     MillegrillesCommon(millegrilles_common_rust::error::Error),
[INFO] [stderr]    |     ------------------ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 10 -     MillegrillesCommon(millegrilles_common_rust::error::Error),
[INFO] [stderr] 10 +     MillegrillesCommon(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/error.rs:11:14
[INFO] [stderr]    |
[INFO] [stderr] 11 |     Webauthn(WebauthnError),
[INFO] [stderr]    |     -------- ^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 11 -     Webauthn(WebauthnError),
[INFO] [stderr] 11 +     Webauthn(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/error.rs:12:14
[INFO] [stderr]    |
[INFO] [stderr] 12 |     UrlParse(millegrilles_common_rust::url::ParseError),
[INFO] [stderr]    |     -------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 12 -     UrlParse(millegrilles_common_rust::url::ParseError),
[INFO] [stderr] 12 +     UrlParse(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/error.rs:13:15
[INFO] [stderr]    |
[INFO] [stderr] 13 |     UuidParse(uuid::Error),
[INFO] [stderr]    |     --------- ^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 13 -     UuidParse(uuid::Error),
[INFO] [stderr] 13 +     UuidParse(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/error.rs:14:15
[INFO] [stderr]    |
[INFO] [stderr] 14 |     Multibase(multibase::Error),
[INFO] [stderr]    |     --------- ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 14 -     Multibase(multibase::Error),
[INFO] [stderr] 14 +     Multibase(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/error.rs:15:12
[INFO] [stderr]    |
[INFO] [stderr] 15 |     MongDb(mongodb::error::Error),
[INFO] [stderr]    |     ------ ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 15 -     MongDb(mongodb::error::Error),
[INFO] [stderr] 15 +     MongDb(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/error.rs:16:15
[INFO] [stderr]    |
[INFO] [stderr] 16 |     SerdeJson(serde_json::Error),
[INFO] [stderr]    |     --------- ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 16 -     SerdeJson(serde_json::Error),
[INFO] [stderr] 16 +     SerdeJson(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/error.rs:18:12
[INFO] [stderr]    |
[INFO] [stderr] 18 |     String(String)
[INFO] [stderr]    |     ------ ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 18 -     String(String)
[INFO] [stderr] 18 +     String(())
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Str` is never constructed
[INFO] [stderr]   --> src/error.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr]  8 | pub enum Error {
[INFO] [stderr]    |          ----- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 17 |     Str(&'static str),
[INFO] [stderr]    |     ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `user_id` is never read
[INFO] [stderr]    --> src/maitredescomptes_requests.rs:708:5
[INFO] [stderr]     |
[INFO] [stderr] 706 | struct RowWebauthnCredentials {
[INFO] [stderr]     |        ---------------------- field in this struct
[INFO] [stderr] 707 |     #[serde(rename="userId")]
[INFO] [stderr] 708 |     user_id: String,
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `RowWebauthnCredentials` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `user_id` is never read
[INFO] [stderr]    --> src/maitredescomptes_requests.rs:719:5
[INFO] [stderr]     |
[INFO] [stderr] 717 | struct RowActivationInfo {
[INFO] [stderr]     |        ----------------- field in this struct
[INFO] [stderr] 718 |     #[serde(rename="userId")]
[INFO] [stderr] 719 |     user_id: String,
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `RowActivationInfo` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `user_id` is never read
[INFO] [stderr]    --> src/maitredescomptes_requests.rs:736:5
[INFO] [stderr]     |
[INFO] [stderr] 735 | struct RowCookieInfo {
[INFO] [stderr]     |        ------------- field in this struct
[INFO] [stderr] 736 |     user_id: String,
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `RowCookieInfo` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_Q_TRANSACTIONS` is never used
[INFO] [stderr]   --> src/maitredescomptes_constants.rs:11:11
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub const NOM_Q_TRANSACTIONS: &str = "CoreMaitreDesComptes/transactions";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stderr]   --> src/maitredescomptes_constants.rs:13:11
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub const NOM_Q_TRIGGERS: &str = "CoreMaitreDesComptes/triggers";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `TRANSACTION_SUPPRIMER_USAGER` is never used
[INFO] [stderr]   --> src/maitredescomptes_constants.rs:37:11
[INFO] [stderr]    |
[INFO] [stderr] 37 | pub const TRANSACTION_SUPPRIMER_USAGER: &str = "supprimerUsager";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `EVENEMENT_SUPPRIMER_COMPTE_USAGER` is never used
[INFO] [stderr]   --> src/maitredescomptes_constants.rs:47:11
[INFO] [stderr]    |
[INFO] [stderr] 47 | pub const EVENEMENT_SUPPRIMER_COMPTE_USAGER: &str = "supprimerCompteUsager";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `CHAMP_ACTIVATIONS_PAR_FINGERPRINT_PK` is never used
[INFO] [stderr]   --> src/maitredescomptes_constants.rs:64:11
[INFO] [stderr]    |
[INFO] [stderr] 64 | pub const CHAMP_ACTIVATIONS_PAR_FINGERPRINT_PK: &str = "activations_par_fingerprint_pk";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `CHAMP_WEBAUTHN_HOSTNAMES` is never used
[INFO] [stderr]   --> src/maitredescomptes_constants.rs:66:11
[INFO] [stderr]    |
[INFO] [stderr] 66 | pub const CHAMP_WEBAUTHN_HOSTNAMES: &str = "webauthn_hostnames";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_Q_TRANSACTIONS` is never used
[INFO] [stderr]  --> src/pki_constants.rs:6:11
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub const NOM_Q_TRANSACTIONS: &str = "CorePki/transactions";
[INFO] [stderr]   |           ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_Q_VOLATILS` is never used
[INFO] [stderr]  --> src/pki_constants.rs:7:11
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub const NOM_Q_VOLATILS: &str = "CorePki/volatils";
[INFO] [stderr]   |           ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stderr]  --> src/pki_constants.rs:8:11
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub const NOM_Q_TRIGGERS: &str = "CorePki/triggers";
[INFO] [stderr]   |           ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_Q_TRANSACTIONS_PKI` is never used
[INFO] [stderr]   --> src/pki_constants.rs:17:11
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub const NOM_Q_TRANSACTIONS_PKI: &str = "CorePki/transactions";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_Q_TRIGGERS_PKI` is never used
[INFO] [stderr]   --> src/pki_constants.rs:19:11
[INFO] [stderr]    |
[INFO] [stderr] 19 | pub const NOM_Q_TRIGGERS_PKI: &str = "CorePki/triggers";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_DOMAINE_CERTIFICATS` is never used
[INFO] [stderr]   --> src/pki_constants.rs:20:11
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub const NOM_DOMAINE_CERTIFICATS: &str = "certificat";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `EVENEMENT_CERTIFICAT_MAITREDESCLES` is never used
[INFO] [stderr]   --> src/pki_constants.rs:21:11
[INFO] [stderr]    |
[INFO] [stderr] 21 | pub const EVENEMENT_CERTIFICAT_MAITREDESCLES: &str = "certMaitreDesCles";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_COLLECTION_FILEHOSTING_FUUIDS_WORK` is never used
[INFO] [stderr]   --> src/topology_constants.rs:18:11
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub const NOM_COLLECTION_FILEHOSTING_FUUIDS_WORK: &str = "CoreTopologie/filehostingFuuidsWork";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `DOMAINE_PRESENCE_NOM` is never used
[INFO] [stderr]   --> src/topology_constants.rs:28:11
[INFO] [stderr]    |
[INFO] [stderr] 28 | pub const DOMAINE_PRESENCE_NOM: &str = "CoreTopologie";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_Q_TRANSACTIONS` is never used
[INFO] [stderr]   --> src/topology_constants.rs:31:11
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub const NOM_Q_TRANSACTIONS: &str = "CoreTopologie/transactions";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stderr]   --> src/topology_constants.rs:33:11
[INFO] [stderr]    |
[INFO] [stderr] 33 | pub const NOM_Q_TRIGGERS: &str = "CoreTopologie/triggers";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `REQUETE_LISTE_NOEUDS` is never used
[INFO] [stderr]   --> src/topology_constants.rs:39:11
[INFO] [stderr]    |
[INFO] [stderr] 39 | pub const REQUETE_LISTE_NOEUDS: &str = "listeNoeuds";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `EVENEMENT_MODIFICATION_CONSIGNATION` is never used
[INFO] [stderr]   --> src/topology_constants.rs:92:11
[INFO] [stderr]    |
[INFO] [stderr] 92 | pub const EVENEMENT_MODIFICATION_CONSIGNATION: &str = "modificationConsignation";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `INDEX_NOEUDS` is never used
[INFO] [stderr]    --> src/topology_constants.rs:105:11
[INFO] [stderr]     |
[INFO] [stderr] 105 | pub const INDEX_NOEUDS: &str = "noeuds";
[INFO] [stderr]     |           ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `INDEX_INSTANCE_ID` is never used
[INFO] [stderr]    --> src/topology_constants.rs:109:11
[INFO] [stderr]     |
[INFO] [stderr] 109 | pub const INDEX_INSTANCE_ID: &str = "instance_id";
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `CHAMP_NOEUD_ID` is never used
[INFO] [stderr]    --> src/topology_constants.rs:113:11
[INFO] [stderr]     |
[INFO] [stderr] 113 | pub const CHAMP_NOEUD_ID: &str = CHAMP_INSTANCE_ID;
[INFO] [stderr]     |           ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `CHAMP_CONSIGNATION_ID` is never used
[INFO] [stderr]    --> src/topology_constants.rs:116:11
[INFO] [stderr]     |
[INFO] [stderr] 116 | pub const CHAMP_CONSIGNATION_ID: &str = "consignation_id";
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `ADRESSE_PREFERENCE_PRIMAIRE` is never used
[INFO] [stderr]    --> src/topology_constants.rs:118:11
[INFO] [stderr]     |
[INFO] [stderr] 118 | pub const ADRESSE_PREFERENCE_PRIMAIRE: u8 = 1;
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `ADRESSE_PREFERENCE_SECONDAIRE` is never used
[INFO] [stderr]    --> src/topology_constants.rs:119:11
[INFO] [stderr]     |
[INFO] [stderr] 119 | pub const ADRESSE_PREFERENCE_SECONDAIRE: u8 = 2;
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `ADRESSE_NATURE_DNS` is never used
[INFO] [stderr]    --> src/topology_constants.rs:121:11
[INFO] [stderr]     |
[INFO] [stderr] 121 | pub const ADRESSE_NATURE_DNS: &str = "dns";
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `ADRESSE_NATURE_IP4` is never used
[INFO] [stderr]    --> src/topology_constants.rs:122:11
[INFO] [stderr]     |
[INFO] [stderr] 122 | pub const ADRESSE_NATURE_IP4: &str = "ip4";
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `ADRESSE_NATURE_IP6` is never used
[INFO] [stderr]    --> src/topology_constants.rs:123:11
[INFO] [stderr]     |
[INFO] [stderr] 123 | pub const ADRESSE_NATURE_IP6: &str = "ip6";
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `ADRESSE_NATURE_ONION` is never used
[INFO] [stderr]    --> src/topology_constants.rs:124:11
[INFO] [stderr]     |
[INFO] [stderr] 124 | pub const ADRESSE_NATURE_ONION: &str = "onion";
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `DEFAULT_CONSIGNATION_URL` is never used
[INFO] [stderr]    --> src/topology_constants.rs:126:11
[INFO] [stderr]     |
[INFO] [stderr] 126 | pub const DEFAULT_CONSIGNATION_URL: &str = "https://fichiers:1443";
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `NOM_Q_TRIGGERS` is never used
[INFO] [stderr]  --> src/catalogues_constants.rs:8:11
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub const NOM_Q_TRIGGERS: &str = "CoreCatalogues/triggers";
[INFO] [stderr]   |           ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `idmg` and `role` are never read
[INFO] [stderr]    --> src/topology_requests.rs:319:5
[INFO] [stderr]     |
[INFO] [stderr] 318 | struct HebergementTokenRow {
[INFO] [stderr]     |        ------------------- fields in this struct
[INFO] [stderr] 319 |     idmg: String,
[INFO] [stderr]     |     ^^^^
[INFO] [stderr] 320 |     role: String,
[INFO] [stderr]     |     ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ParametresGetCleConfiguration` is never constructed
[INFO] [stderr]     --> src/topology_requests.rs:1061:8
[INFO] [stderr]      |
[INFO] [stderr] 1061 | struct ParametresGetCleConfiguration {
[INFO] [stderr]      |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ReponseConsignationSatellite` is never constructed
[INFO] [stderr]     --> src/topology_requests.rs:1066:12
[INFO] [stderr]      |
[INFO] [stderr] 1066 | pub struct ReponseConsignationSatellite {
[INFO] [stderr]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `RequeteConfigurationFichiers` is never constructed
[INFO] [stderr]     --> src/topology_requests.rs:1324:12
[INFO] [stderr]      |
[INFO] [stderr] 1324 | pub struct RequeteConfigurationFichiers {}
[INFO] [stderr]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ReponseConfigurationFichiers` is never constructed
[INFO] [stderr]     --> src/topology_requests.rs:1327:12
[INFO] [stderr]      |
[INFO] [stderr] 1327 | pub struct ReponseConfigurationFichiers {
[INFO] [stderr]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `domaine`, `instance_id`, `dirty`, and `reclame_fuuids` are never read
[INFO] [stderr]     --> src/topology_requests.rs:1373:5
[INFO] [stderr]      |
[INFO] [stderr] 1372 | struct RowCoreTopologieDomaines {
[INFO] [stderr]      |        ------------------------ fields in this struct
[INFO] [stderr] 1373 |     domaine: String,
[INFO] [stderr]      |     ^^^^^^^
[INFO] [stderr] 1374 |     instance_id: String,
[INFO] [stderr]      |     ^^^^^^^^^^^
[INFO] [stderr] 1375 |     dirty: Option<bool>,
[INFO] [stderr]      |     ^^^^^
[INFO] [stderr] 1376 |     reclame_fuuids: Option<bool>,
[INFO] [stderr]      |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `FilehostForExternalRequest` is never constructed
[INFO] [stderr]     --> src/topology_requests.rs:1593:8
[INFO] [stderr]      |
[INFO] [stderr] 1593 | struct FilehostForExternalRequest {
[INFO] [stderr]      |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `TransactionConfigurerConsignation` is never constructed
[INFO] [stderr]   --> src/topology_structs.rs:20:12
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub struct TransactionConfigurerConsignation {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `InfoService` is never constructed
[INFO] [stderr]    --> src/topology_structs.rs:139:12
[INFO] [stderr]     |
[INFO] [stderr] 139 | pub struct InfoService {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ApplicationConfiguree` is never constructed
[INFO] [stderr]    --> src/topology_structs.rs:148:12
[INFO] [stderr]     |
[INFO] [stderr] 148 | pub struct ApplicationConfiguree {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `WebAppLink` is never constructed
[INFO] [stderr]    --> src/topology_structs.rs:154:12
[INFO] [stderr]     |
[INFO] [stderr] 154 | pub struct WebAppLink {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PresenceMonitor` is never constructed
[INFO] [stderr]    --> src/topology_structs.rs:162:12
[INFO] [stderr]     |
[INFO] [stderr] 162 | pub struct PresenceMonitor {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `InformationApplication` is never constructed
[INFO] [stderr]    --> src/topology_structs.rs:204:12
[INFO] [stderr]     |
[INFO] [stderr] 204 | pub struct InformationApplication {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `InformationMonitor` is never constructed
[INFO] [stderr]    --> src/topology_structs.rs:214:12
[INFO] [stderr]     |
[INFO] [stderr] 214 | pub struct InformationMonitor {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `TransactionSupprimerConsignationInstance` is never constructed
[INFO] [stderr]    --> src/topology_structs.rs:236:12
[INFO] [stderr]     |
[INFO] [stderr] 236 | pub struct TransactionSupprimerConsignationInstance {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `RowFuuid` is never constructed
[INFO] [stderr]    --> src/topology_structs.rs:315:12
[INFO] [stderr]     |
[INFO] [stderr] 315 | pub struct RowFuuid { pub fuuid: String }
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CommandeAjouterConsignationHebergee` is never constructed
[INFO] [stderr]    --> src/topology_commands.rs:344:8
[INFO] [stderr]     |
[INFO] [stderr] 344 | struct CommandeAjouterConsignationHebergee {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ReponseCommandeAjouterConsignationHebergee` is never constructed
[INFO] [stderr]    --> src/topology_commands.rs:348:8
[INFO] [stderr]     |
[INFO] [stderr] 348 | struct ReponseCommandeAjouterConsignationHebergee {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ReponseRelaiWeb` is never constructed
[INFO] [stderr]    --> src/topology_commands.rs:353:8
[INFO] [stderr]     |
[INFO] [stderr] 353 | struct ReponseRelaiWeb {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `charger_fiche` is never used
[INFO] [stderr]    --> src/topology_commands.rs:361:10
[INFO] [stderr]     |
[INFO] [stderr] 361 | async fn charger_fiche<M>(middleware: &M, url: &Url, etag: Option<&String>)
[INFO] [stderr]     |          ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `domaine`, `instance_id`, `dirty`, `reclame_fuuids`, and `cle_id_backup` are never read
[INFO] [stderr]    --> src/topology_commands.rs:554:5
[INFO] [stderr]     |
[INFO] [stderr] 553 | struct RowCoreTopologieDomaines {
[INFO] [stderr]     |        ------------------------ fields in this struct
[INFO] [stderr] 554 |     domaine: String,
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr] 555 |     instance_id: String,
[INFO] [stderr]     |     ^^^^^^^^^^^
[INFO] [stderr] 556 |     dirty: Option<bool>,
[INFO] [stderr]     |     ^^^^^
[INFO] [stderr] 557 |     reclame_fuuids: Option<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^
[INFO] [stderr] 558 |     cle_id_backup: Option<String>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `batch_no` is never read
[INFO] [stderr]     --> src/topology_commands.rs:1308:5
[INFO] [stderr]      |
[INFO] [stderr] 1306 | struct RequestFuuidsVisits {
[INFO] [stderr]      |        ------------------- field in this struct
[INFO] [stderr] 1307 |     fuuids: Vec<String>,
[INFO] [stderr] 1308 |     batch_no: Option<usize>,
[INFO] [stderr]      |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `instance_id` is never read
[INFO] [stderr]    --> src/topology_common.rs:504:5
[INFO] [stderr]     |
[INFO] [stderr] 503 | struct InstanceConfiguredAppRow {
[INFO] [stderr]     |        ------------------------ field in this struct
[INFO] [stderr] 504 |     instance_id: String,
[INFO] [stderr]     |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PresenceFichiers` is never constructed
[INFO] [stderr]    --> src/topology_events.rs:143:8
[INFO] [stderr]     |
[INFO] [stderr] 143 | struct PresenceFichiers {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `RowInstanceActivite` is never constructed
[INFO] [stderr]   --> src/topology_maintenance.rs:85:8
[INFO] [stderr]    |
[INFO] [stderr] 85 | struct RowInstanceActivite {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `fuuid` and `destination_filehost_id` are never read
[INFO] [stderr]   --> src/topology_maintenance.rs:96:5
[INFO] [stderr]    |
[INFO] [stderr] 93 | struct FuuidFilehostRow {
[INFO] [stderr]    |        ---------------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 96 |     fuuid: String,
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr] 97 |     destination_filehost_id: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `claimer_type` is never read
[INFO] [stderr]    --> src/topology_maintenance.rs:325:5
[INFO] [stderr]     |
[INFO] [stderr] 323 | struct SyncStatusRow {
[INFO] [stderr]     |        ------------- field in this struct
[INFO] [stderr] 324 |     claimer: String,
[INFO] [stderr] 325 |     claimer_type: String,
[INFO] [stderr]     |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `v` is never read
[INFO] [stderr]    --> src/topology_maintenance.rs:739:5
[INFO] [stderr]     |
[INFO] [stderr] 736 | struct ObjectToArrayKeyStringValueDate {
[INFO] [stderr]     |        ------------------------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 739 |     v: Option<DateTime<Utc>>
[INFO] [stderr]     |     ^
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `rpId` should have a snake case name
[INFO] [stderr]    --> src/webauthn.rs:280:5
[INFO] [stderr]     |
[INFO] [stderr] 280 |     rpId: String,
[INFO] [stderr]     |     ^^^^ help: convert the identifier to snake case: `rp_id`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(non_snake_case)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `userVerification` should have a snake case name
[INFO] [stderr]    --> src/webauthn.rs:281:5
[INFO] [stderr]     |
[INFO] [stderr] 281 |     userVerification: String,  // 'preferred',
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `user_verification`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `allowCredentials` should have a snake case name
[INFO] [stderr]    --> src/webauthn.rs:282:5
[INFO] [stderr]     |
[INFO] [stderr] 282 |     allowCredentials: Vec<AllowCredential>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `allow_credentials`
[INFO] [stderr] 
[INFO] [stderr] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stderr]    --> src/maitredescomptes_commands.rs:304:40
[INFO] [stderr]     |
[INFO] [stderr] 304 |         let message_id = message_ref.id.clone();
[INFO] [stderr]     |                                        ^^^^^^^^ help: remove this redundant call
[INFO] [stderr]     |
[INFO] [stderr]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stderr]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable `DOMAINE_NOM` should have a snake case name
[INFO] [stderr]   --> src/maitredescomptes_requests.rs:50:9
[INFO] [stderr]    |
[INFO] [stderr] 50 |         DOMAINE_NOM => {
[INFO] [stderr]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `domaine_nom`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `champs_index__transferts_filehostfuuid` should have a snake case name
[INFO] [stderr]    --> src/topology_manager.rs:455:9
[INFO] [stderr]     |
[INFO] [stderr] 455 |     let champs_index__transferts_filehostfuuid = vec!(
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `champs_index_transferts_filehostfuuid`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `DOMAINE_NOM` should have a snake case name
[INFO] [stderr]   --> src/pki_requests.rs:67:9
[INFO] [stderr]    |
[INFO] [stderr] 67 |         DOMAINE_NOM => {
[INFO] [stderr]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `domaine_nom`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `DOMAINE_NOM` should have a snake case name
[INFO] [stderr]    --> src/topology_requests.rs:110:17
[INFO] [stderr]     |
[INFO] [stderr] 110 |                 DOMAINE_NOM => {
[INFO] [stderr]     |                 ^^^^^^^^^^^ help: convert the identifier to snake case: `domaine_nom`
[INFO] [stderr] 
[INFO] [stderr] warning: `millegrilles_core` (bin "millegrilles_core" test) generated 283 warnings (run `cargo fix --bin "millegrilles_core" --tests` to apply 125 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.14s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: millegrilles_common_rust v2025.4.2 (https://github.com/dugrema/millegrilles_common_rust.git?tag=2025.4-release#5b6ce0e5), num-bigint-dig v0.8.4, redis v0.25.4
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 4`
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/millegrilles_core-0f92d09d1790defa)
[INFO] [stdout] 
[INFO] [stdout] running 5 tests
[INFO] [stdout] test webauthn::webauthn_test::verifier_commande_test ... ok
[INFO] [stdout] test webauthn::webauthn_test::generer_challenge_auth_1 ... ok
[INFO] [stdout] test webauthn::webauthn_test::verifier_commande_test ... ok
[INFO] [stdout] test webauthn::webauthn_test::generer_challenge_registration_1 ... ok
[INFO] [stdout] test webauthn::webauthn_test::verifier_commande_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "cc8f53a69125dfa0b81352731c8f420d991ee8af7707824088058f649356c0bc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cc8f53a69125dfa0b81352731c8f420d991ee8af7707824088058f649356c0bc", kill_on_drop: false }`
[INFO] [stdout] cc8f53a69125dfa0b81352731c8f420d991ee8af7707824088058f649356c0bc
