From eb7ad0fdccc092e49f8e9269d2402cf3c479cf76 Mon Sep 17 00:00:00 2001 From: Gerard CL Date: Sun, 21 Apr 2024 19:10:24 +0200 Subject: [PATCH 1/6] dependencies maintenance with focus on rustls --- CHANGELOG.md | 4 ++ Cargo.lock | 181 ++++++++++++++++++++++++++------------------------- Cargo.toml | 2 +- 3 files changed, 99 insertions(+), 88 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 20c7175..ab4a657 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ # Changelog +## v4.3.2 (2024-04-21) + +* General dependencies maintenance with rustls focus [#196](https://github.com/gerardcl/renfe-cli/issues/196) + ## v4.3.1 (2024-03-30) * Upgrade PyO3 with general dependencies maintenance [#192](https://github.com/gerardcl/renfe-cli/issues/192) diff --git a/Cargo.lock b/Cargo.lock index 41d0d6c..19e2ca1 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -58,9 +58,9 @@ dependencies = [ [[package]] name = "anyhow" -version = "1.0.81" +version = "1.0.82" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0952808a6c2afd1aa8947271f3a60f1a6763c7b912d210184c5149b5cf147247" +checksum = "f538837af36e6f6a9be0faa67f9a314f8119e4e4b5867c6ab40ed60360142519" [[package]] name = "auto_generate_cdp" @@ -117,9 +117,9 @@ dependencies = [ [[package]] name = "bumpalo" -version = "3.15.4" +version = "3.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7ff69b9dd49fd426c69a0db9fc04dd934cdb6645ff000864d98f7e2af8830eaa" +checksum = "79296716171880943b8470b5f8d03aa55eb2e645a4874bdbb28adb49162e012c" [[package]] name = "byteorder" @@ -156,12 +156,13 @@ dependencies = [ [[package]] name = "cc" -version = "1.0.90" +version = "1.0.95" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8cd6604a82acf3039f1144f54b8eb34e91ffba622051189e71b781822d5ee1f5" +checksum = "d32a725bc159af97c3e629873bb9f88fb8cf8a4867175f76dc987815ea07c83b" dependencies = [ "jobserver", "libc", + "once_cell", ] [[package]] @@ -172,16 +173,16 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" [[package]] name = "chrono" -version = "0.4.37" +version = "0.4.38" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8a0d04d43504c61aa6c7531f1871dd0d418d91130162063b789da00fd7057a5e" +checksum = "a21f936df1771bf62b77f047b726c4625ff2e8aa607c01ec06e5a05bd8463401" dependencies = [ "android-tzdata", "iana-time-zone", "js-sys", "num-traits", "wasm-bindgen", - "windows-targets 0.52.4", + "windows-targets 0.52.5", ] [[package]] @@ -266,7 +267,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "13b588ba4ac1a99f7f2964d24b3d896ddc6bf847ee3855dbd4366f058cfcd331" dependencies = [ "quote", - "syn 2.0.57", + "syn 2.0.60", ] [[package]] @@ -416,9 +417,9 @@ checksum = "3a68a4904193147e0a8dec3314640e6db742afd5f6e634f428a6af230d9b3591" [[package]] name = "either" -version = "1.10.0" +version = "1.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "11157ac094ffbdde99aa67b23417ebdd801842852b500e395a45a9c0aac03e4a" +checksum = "a47c1c47d2f5964e29c61246e81db715514cd532db6b5116a25ea3c03d6780a2" [[package]] name = "errno" @@ -501,9 +502,9 @@ dependencies = [ [[package]] name = "getrandom" -version = "0.2.12" +version = "0.2.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "190092ea657667030ac6a35e305e62fc4dd69fd98ac98631e5d3a2b1575a12b5" +checksum = "94b22e06ecb0110981051723910cbf0b5f5e09a2062dd7663334ee79a9d1286c" dependencies = [ "cfg-if", "libc", @@ -654,9 +655,9 @@ checksum = "49f1f14873335454500d59611f1cf4a4b0f786f9ac11f4312a78e4cf2566695b" [[package]] name = "jobserver" -version = "0.1.28" +version = "0.1.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ab46a6e9526ddef3ae7f787c06f0f2600639ba80ea3eade3d8e670a2230f51d6" +checksum = "685a7d121ee3f65ae4fddd72b25a04bb36b6af81bc0828f7d5434c0fe60fa3a2" dependencies = [ "libc", ] @@ -678,13 +679,12 @@ checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd" [[package]] name = "libredox" -version = "0.0.1" +version = "0.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "85c833ca1e66078851dba29046874e38f08b2c883700aa29a03ddd3b23814ee8" +checksum = "c0ff37bd590ca25063e35af745c343cb7a0271906fb7b37e4813e8f79f00268d" dependencies = [ "bitflags 2.5.0", "libc", - "redox_syscall", ] [[package]] @@ -897,7 +897,7 @@ dependencies = [ "phf_shared 0.11.2", "proc-macro2", "quote", - "syn 2.0.57", + "syn 2.0.60", ] [[package]] @@ -950,18 +950,18 @@ checksum = "925383efa346730478fb4838dbe9137d2a47675ad789c546d150a6e1dd4ab31c" [[package]] name = "proc-macro2" -version = "1.0.79" +version = "1.0.81" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e835ff2298f5721608eb1a980ecaee1aef2c132bf95ecc026a11b7bf3c01c02e" +checksum = "3d1597b0c024618f09a9c3b8655b7e430397a36d23fdafec26d6965e9eec3eba" dependencies = [ "unicode-ident", ] [[package]] name = "pyo3" -version = "0.21.0" +version = "0.21.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a02a88a17e74cadbc8ce77855e1d6c8ad0ab82901a4a9b5046bd01c1c0bd95cd" +checksum = "a5e00b96a521718e08e03b1a622f01c8a8deb50719335de3f60b3b3950f069d8" dependencies = [ "cfg-if", "indoc", @@ -977,9 +977,9 @@ dependencies = [ [[package]] name = "pyo3-build-config" -version = "0.21.0" +version = "0.21.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a5eb0b6ecba38961f6f4bd6cd5906dfab3cd426ff37b2eed5771006aa31656f1" +checksum = "7883df5835fafdad87c0d888b266c8ec0f4c9ca48a5bed6bbb592e8dedee1b50" dependencies = [ "once_cell", "target-lexicon", @@ -987,9 +987,9 @@ dependencies = [ [[package]] name = "pyo3-ffi" -version = "0.21.0" +version = "0.21.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ba8a6e48a29b5d22e4fdaf132d8ba8d3203ee9f06362d48f244346902a594ec3" +checksum = "01be5843dc60b916ab4dad1dca6d20b9b4e6ddc8e15f50c47fe6d85f1fb97403" dependencies = [ "libc", "pyo3-build-config", @@ -997,34 +997,34 @@ dependencies = [ [[package]] name = "pyo3-macros" -version = "0.21.0" +version = "0.21.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4e80493c5965f94a747d0782a607b2328a4eea5391327b152b00e2f3b001cede" +checksum = "77b34069fc0682e11b31dbd10321cbf94808394c56fd996796ce45217dfac53c" dependencies = [ "proc-macro2", "pyo3-macros-backend", "quote", - "syn 2.0.57", + "syn 2.0.60", ] [[package]] name = "pyo3-macros-backend" -version = "0.21.0" +version = "0.21.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fcd7d86f42004025200e12a6a8119bd878329e6fddef8178eaafa4e4b5906c5b" +checksum = "08260721f32db5e1a5beae69a55553f56b99bd0e1c3e6e0a5e8851a9d0f5a85c" dependencies = [ "heck", "proc-macro2", "pyo3-build-config", "quote", - "syn 2.0.57", + "syn 2.0.60", ] [[package]] name = "quote" -version = "1.0.35" +version = "1.0.36" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "291ec9ab5efd934aaf503a6466c5d5251535d108ee747472c3977cc5acc868ef" +checksum = "0fa76aaf39101c457836aec0ce2316dbdc3ab723cdda1c6bd4e6ad4208acaca7" dependencies = [ "proc-macro2", ] @@ -1070,9 +1070,9 @@ dependencies = [ [[package]] name = "redox_users" -version = "0.4.4" +version = "0.4.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a18479200779601e498ada4e8c1e1f50e3ee19deb0259c25825a98b5603b2cb4" +checksum = "bd283d9651eeda4b2a83a43c1c91b266c40fd76ecd39a50a8c630ae69dc72891" dependencies = [ "getrandom", "libredox", @@ -1110,7 +1110,7 @@ checksum = "adad44e29e4c806119491a7f06f03de4d1af22c3a680dd47f1e6e179439d1f56" [[package]] name = "renfe-cli" -version = "4.3.1" +version = "4.3.2" dependencies = [ "chrono", "getopts", @@ -1137,9 +1137,9 @@ dependencies = [ [[package]] name = "rustix" -version = "0.38.32" +version = "0.38.33" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "65e04861e65f21776e67888bfbea442b3642beaa0138fdb1dd7a84a52dffdb89" +checksum = "e3cc72858054fcff6d7dea32df2aeaee6a7c24227366d7ea429aada2f26b16ad" dependencies = [ "bitflags 2.5.0", "errno", @@ -1150,9 +1150,9 @@ dependencies = [ [[package]] name = "rustls" -version = "0.22.3" +version = "0.22.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "99008d7ad0bbbea527ec27bddbc0e432c5b87d8175178cee68d2eec9c4a1813c" +checksum = "bf4ef73721ac7bcd79b2b315da7779d8fc09718c6b3d2d1b2d94850eb8c18432" dependencies = [ "log", "ring", @@ -1237,29 +1237,29 @@ dependencies = [ [[package]] name = "serde" -version = "1.0.197" +version = "1.0.198" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3fb1c873e1b9b056a4dc4c0c198b24c3ffa059243875552b2bd0933b1aee4ce2" +checksum = "9846a40c979031340571da2545a4e5b7c4163bdae79b301d5f86d03979451fcc" dependencies = [ "serde_derive", ] [[package]] name = "serde_derive" -version = "1.0.197" +version = "1.0.198" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7eb0b34b42edc17f6b7cac84a52a1c5f0e1bb2227e997ca9011ea3dd34e8610b" +checksum = "e88edab869b01783ba905e7d0153f9fc1a6505a96e4ad3018011eedb838566d9" dependencies = [ "proc-macro2", "quote", - "syn 2.0.57", + "syn 2.0.60", ] [[package]] name = "serde_json" -version = "1.0.115" +version = "1.0.116" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "12dc5c46daa8e9fdf4f5e71b6cf9a53f2487da0e86e55808e2d35539666497dd" +checksum = "3e17db7126d17feb94eb3fad46bf1a96b034e8aacbc2e775fe81505f8b0b2813" dependencies = [ "itoa", "ryu", @@ -1383,9 +1383,9 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.57" +version = "2.0.60" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "11a6ae1e52eb25aab8f3fb9fca13be982a373b8f1157ca14b897a825ba4a2d35" +checksum = "909518bc7b1c9b779f1bbf07f2929d35af9f0f37e47c6e9ef7f9dddc1e1821f3" dependencies = [ "proc-macro2", "quote", @@ -1423,29 +1423,29 @@ dependencies = [ [[package]] name = "thiserror" -version = "1.0.58" +version = "1.0.59" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "03468839009160513471e86a034bb2c5c0e4baae3b43f79ffc55c4a5427b3297" +checksum = "f0126ad08bff79f29fc3ae6a55cc72352056dfff61e3ff8bb7129476d44b23aa" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.58" +version = "1.0.59" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c61f3ba182994efc43764a46c018c347bc492c79f024e705f46567b418f6d4f7" +checksum = "d1cd413b5d558b4c5bf3680e324a6fa5014e7b7c067a51e69dbdf47eb7148b66" dependencies = [ "proc-macro2", "quote", - "syn 2.0.57", + "syn 2.0.60", ] [[package]] name = "time" -version = "0.3.34" +version = "0.3.36" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c8248b6521bb14bc45b4067159b9b6ad792e2d6d754d6c41fb50e29fefe38749" +checksum = "5dfd88e563464686c916c7e46e623e520ddc6d79fa6641390f2e3fa86e83e885" dependencies = [ "deranged", "num-conv", @@ -1617,7 +1617,7 @@ dependencies = [ "once_cell", "proc-macro2", "quote", - "syn 2.0.57", + "syn 2.0.60", "wasm-bindgen-shared", ] @@ -1639,7 +1639,7 @@ checksum = "e94f17b526d0a461a191c78ea52bbce64071ed5c04c9ffe424dcb38f74171bb7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.57", + "syn 2.0.60", "wasm-bindgen-backend", "wasm-bindgen-shared", ] @@ -1709,7 +1709,7 @@ version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" dependencies = [ - "windows-targets 0.52.4", + "windows-targets 0.52.5", ] [[package]] @@ -1727,7 +1727,7 @@ version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" dependencies = [ - "windows-targets 0.52.4", + "windows-targets 0.52.5", ] [[package]] @@ -1747,17 +1747,18 @@ dependencies = [ [[package]] name = "windows-targets" -version = "0.52.4" +version = "0.52.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7dd37b7e5ab9018759f893a1952c9420d060016fc19a472b4bb20d1bdd694d1b" +checksum = "6f0713a46559409d202e70e28227288446bf7841d3211583a4b53e3f6d96e7eb" dependencies = [ - "windows_aarch64_gnullvm 0.52.4", - "windows_aarch64_msvc 0.52.4", - "windows_i686_gnu 0.52.4", - "windows_i686_msvc 0.52.4", - "windows_x86_64_gnu 0.52.4", - "windows_x86_64_gnullvm 0.52.4", - "windows_x86_64_msvc 0.52.4", + "windows_aarch64_gnullvm 0.52.5", + "windows_aarch64_msvc 0.52.5", + "windows_i686_gnu 0.52.5", + "windows_i686_gnullvm", + "windows_i686_msvc 0.52.5", + "windows_x86_64_gnu 0.52.5", + "windows_x86_64_gnullvm 0.52.5", + "windows_x86_64_msvc 0.52.5", ] [[package]] @@ -1768,9 +1769,9 @@ checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" [[package]] name = "windows_aarch64_gnullvm" -version = "0.52.4" +version = "0.52.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bcf46cf4c365c6f2d1cc93ce535f2c8b244591df96ceee75d8e83deb70a9cac9" +checksum = "7088eed71e8b8dda258ecc8bac5fb1153c5cffaf2578fc8ff5d61e23578d3263" [[package]] name = "windows_aarch64_msvc" @@ -1780,9 +1781,9 @@ checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" [[package]] name = "windows_aarch64_msvc" -version = "0.52.4" +version = "0.52.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "da9f259dd3bcf6990b55bffd094c4f7235817ba4ceebde8e6d11cd0c5633b675" +checksum = "9985fd1504e250c615ca5f281c3f7a6da76213ebd5ccc9561496568a2752afb6" [[package]] name = "windows_i686_gnu" @@ -1792,9 +1793,15 @@ checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" [[package]] name = "windows_i686_gnu" -version = "0.52.4" +version = "0.52.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "88ba073cf16d5372720ec942a8ccbf61626074c6d4dd2e745299726ce8b89670" + +[[package]] +name = "windows_i686_gnullvm" +version = "0.52.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b474d8268f99e0995f25b9f095bc7434632601028cf86590aea5c8a5cb7801d3" +checksum = "87f4261229030a858f36b459e748ae97545d6f1ec60e5e0d6a3d32e0dc232ee9" [[package]] name = "windows_i686_msvc" @@ -1804,9 +1811,9 @@ checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" [[package]] name = "windows_i686_msvc" -version = "0.52.4" +version = "0.52.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1515e9a29e5bed743cb4415a9ecf5dfca648ce85ee42e15873c3cd8610ff8e02" +checksum = "db3c2bf3d13d5b658be73463284eaf12830ac9a26a90c717b7f771dfe97487bf" [[package]] name = "windows_x86_64_gnu" @@ -1816,9 +1823,9 @@ checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" [[package]] name = "windows_x86_64_gnu" -version = "0.52.4" +version = "0.52.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5eee091590e89cc02ad514ffe3ead9eb6b660aedca2183455434b93546371a03" +checksum = "4e4246f76bdeff09eb48875a0fd3e2af6aada79d409d33011886d3e1581517d9" [[package]] name = "windows_x86_64_gnullvm" @@ -1828,9 +1835,9 @@ checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" [[package]] name = "windows_x86_64_gnullvm" -version = "0.52.4" +version = "0.52.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "77ca79f2451b49fa9e2af39f0747fe999fcda4f5e241b2898624dca97a1f2177" +checksum = "852298e482cd67c356ddd9570386e2862b5673c85bd5f88df9ab6802b334c596" [[package]] name = "windows_x86_64_msvc" @@ -1840,9 +1847,9 @@ checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" [[package]] name = "windows_x86_64_msvc" -version = "0.52.4" +version = "0.52.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "32b752e52a2da0ddfbdbcc6fceadfeede4c939ed16d13e648833a61dfb611ed8" +checksum = "bec47e5bfd1bff0eeaf6d8b485cc1074891a197ab4225d504cb7a1ab88b02bf0" [[package]] name = "winreg" @@ -1871,7 +1878,7 @@ checksum = "9ce1b18ccd8e73a9321186f97e46f9f04b778851177567b1975109d26a08d2a6" dependencies = [ "proc-macro2", "quote", - "syn 2.0.57", + "syn 2.0.60", ] [[package]] diff --git a/Cargo.toml b/Cargo.toml index 2911c26..3b430ca 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "renfe-cli" -version = "4.3.1" +version = "4.3.2" edition = "2021" license = "BSD-3-Clause" description = "CLI for searching Renfe train timetables in the Spanish country" From 91befa433c3f450f550110f97218afce77dce640 Mon Sep 17 00:00:00 2001 From: Gerard CL Date: Sun, 22 Sep 2024 19:50:22 +0200 Subject: [PATCH 2/6] playing with GTFS renfe site data - looking good! --- Cargo.lock | 1541 +++++++++++++++++++++------------------------- Cargo.toml | 6 +- src/gtfs.rs | 141 +++++ src/stations.rs | 30 +- src/timetable.rs | 281 ++++----- 5 files changed, 989 insertions(+), 1010 deletions(-) create mode 100644 src/gtfs.rs diff --git a/Cargo.lock b/Cargo.lock index 19e2ca1..1504bc5 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -3,10 +3,19 @@ version = 3 [[package]] -name = "adler" -version = "1.0.2" +name = "addr2line" +version = "0.24.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f5fb1d8e4442bd405fdfd1dacb42792696b0cf9cb15882e5d097b742a676d375" +dependencies = [ + "gimli", +] + +[[package]] +name = "adler2" +version = "2.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe" +checksum = "512761e0bb2578dd7380c6baaa0f4ce03e84f95e960231d1dec8bf4d7d6e2627" [[package]] name = "aes" @@ -19,28 +28,6 @@ dependencies = [ "cpufeatures", ] -[[package]] -name = "ahash" -version = "0.8.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e89da841a80418a9b391ebaea17f5c112ffaaa96f621d2c285b5174da76b9011" -dependencies = [ - "cfg-if", - "getrandom", - "once_cell", - "version_check", - "zerocopy", -] - -[[package]] -name = "aho-corasick" -version = "1.1.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8e60d3430d3a69478ad0993f19238d2df97c507009a52b3c10addcd7f6bcb916" -dependencies = [ - "memchr", -] - [[package]] name = "android-tzdata" version = "0.1.1" @@ -57,31 +44,26 @@ dependencies = [ ] [[package]] -name = "anyhow" -version = "1.0.82" +name = "autocfg" +version = "1.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f538837af36e6f6a9be0faa67f9a314f8119e4e4b5867c6ab40ed60360142519" +checksum = "0c4b4d0bd25bd0b74681c0ad21497610ce1b7c91b1022cd21c80c6fbdd9476b0" [[package]] -name = "auto_generate_cdp" -version = "0.4.4" +name = "backtrace" +version = "0.3.74" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7af08ed49930c50104b2f1699d257e5053fb1809e370647bde9c58b31d65d417" +checksum = "8d82cb332cdfaed17ae235a638438ac4d4839913cc2af585c3c6746e8f8bee1a" dependencies = [ - "convert_case", - "proc-macro2", - "quote", - "serde", - "serde_json", - "ureq", + "addr2line", + "cfg-if", + "libc", + "miniz_oxide", + "object", + "rustc-demangle", + "windows-targets 0.52.6", ] -[[package]] -name = "autocfg" -version = "1.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1fdabc7756949593fe60f30ec81974b613357de856987752631dea1e3394c80" - [[package]] name = "base64" version = "0.21.7" @@ -102,9 +84,9 @@ checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" [[package]] name = "bitflags" -version = "2.5.0" +version = "2.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cf4b9d6a944f767f8e5e0db018570623c85f3d925ac718db4e06d0187adb21c1" +checksum = "b048fb63fd8b5923fc5aa7b340d8e156aec7ec02f0c78fa8a6ddc2613f6f71de" [[package]] name = "block-buffer" @@ -121,6 +103,12 @@ version = "3.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "79296716171880943b8470b5f8d03aa55eb2e645a4874bdbb28adb49162e012c" +[[package]] +name = "bytemuck" +version = "1.18.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "94bbb0ad554ad961ddc5da507a12a29b14e4ae5bda06b19f575a3e6079d2e2ae" + [[package]] name = "byteorder" version = "1.5.0" @@ -129,9 +117,9 @@ checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b" [[package]] name = "bytes" -version = "1.6.0" +version = "1.7.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "514de17de45fdb8dc022b1a7975556c53c86f9f0aa5f534b98977b171857c2c9" +checksum = "428d9aa8fbc0670b7b8d6030a7fadd0f86151cae55e4dbbece15f3780a3dfaf3" [[package]] name = "bzip2" @@ -156,13 +144,13 @@ dependencies = [ [[package]] name = "cc" -version = "1.0.95" +version = "1.1.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d32a725bc159af97c3e629873bb9f88fb8cf8a4867175f76dc987815ea07c83b" +checksum = "07b1695e2c7e8fc85310cde85aeaab7e3097f593c91d209d3f9df76c928100f0" dependencies = [ "jobserver", "libc", - "once_cell", + "shlex", ] [[package]] @@ -182,7 +170,7 @@ dependencies = [ "js-sys", "num-traits", "wasm-bindgen", - "windows-targets 0.52.5", + "windows-targets 0.52.6", ] [[package]] @@ -202,40 +190,44 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "245097e9a4535ee1e3e3931fcfcd55a796a44c643e8596ff6566d68f09b87bbc" [[package]] -name = "convert_case" -version = "0.4.0" +name = "core-foundation" +version = "0.9.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6245d59a3e82a7fc217c5828a6692dbc6dfb63a0c8c90495621f7b9d79704a0e" +checksum = "91e195e091a93c46f7102ec7818a2aa394e1e1771c3ab4825963fa03e45afb8f" +dependencies = [ + "core-foundation-sys", + "libc", +] [[package]] name = "core-foundation-sys" -version = "0.8.6" +version = "0.8.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "06ea2b9bc92be3c2baa9334a323ebca2d6f074ff852cd1d7b11064035cd3868f" +checksum = "773648b94d0e5d620f64f280777445740e61fe701025087ec8b57f45c791888b" [[package]] name = "cpufeatures" -version = "0.2.12" +version = "0.2.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "53fe5e26ff1b7aef8bca9c6080520cfb8d9333c7568e1829cef191a9723e5504" +checksum = "608697df725056feaccfa42cffdaeeec3fccc4ffc38358ecd19b243e716a78e0" dependencies = [ "libc", ] [[package]] name = "crc32fast" -version = "1.4.0" +version = "1.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b3855a8a784b474f333699ef2bbca9db2c4a1f6d9088a90a2d25b1eb53111eaa" +checksum = "a97769d94ddab943e4510d138150169a2758b5ef3eb191a9ee688de3e23ef7b3" dependencies = [ "cfg-if", ] [[package]] name = "crossbeam-utils" -version = "0.8.19" +version = "0.8.20" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "248e3bacc7dc6baa3b21e405ee045c3047101a49145e7e9eca583ab4c2ca5345" +checksum = "22ec99545bb0ed0ea7bb9b8e1e9122ea386ff8a48c0922e43f36d45ab09e0e80" [[package]] name = "crypto-common" @@ -248,237 +240,221 @@ dependencies = [ ] [[package]] -name = "cssparser" -version = "0.31.2" +name = "csv" +version = "1.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5b3df4f93e5fbbe73ec01ec8d3f68bba73107993a5b1e7519273c32db9b0d5be" +checksum = "ac574ff4d437a7b5ad237ef331c17ccca63c46479e5b5453eb8e10bb99a759fe" dependencies = [ - "cssparser-macros", - "dtoa-short", + "csv-core", "itoa", - "phf 0.11.2", - "smallvec", + "ryu", + "serde", ] [[package]] -name = "cssparser-macros" -version = "0.6.1" +name = "csv-core" +version = "0.1.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "13b588ba4ac1a99f7f2964d24b3d896ddc6bf847ee3855dbd4366f058cfcd331" +checksum = "5efa2b3d7902f4b634a20cae3c9c4e6209dc4779feb6863329607560143efa70" dependencies = [ - "quote", - "syn 2.0.60", + "memchr", ] [[package]] -name = "darling" -version = "0.14.4" +name = "deranged" +version = "0.3.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b750cb3417fd1b327431a470f388520309479ab0bf5e323505daf0290cd3850" +checksum = "b42b6fa04a440b495c8b04d0e71b707c585f83cb9cb28cf8cd0d976c315e31b4" dependencies = [ - "darling_core", - "darling_macro", + "powerfmt", ] [[package]] -name = "darling_core" -version = "0.14.4" +name = "derivative" +version = "2.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "109c1ca6e6b7f82cc233a97004ea8ed7ca123a9af07a8230878fcfda9b158bf0" +checksum = "fcc3dd5e9e9c0b295d6e1e4d811fb6f157d5ffd784b8d202fc62eac8035a770b" dependencies = [ - "fnv", - "ident_case", "proc-macro2", "quote", - "strsim", "syn 1.0.109", ] [[package]] -name = "darling_macro" -version = "0.14.4" +name = "digest" +version = "0.10.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a4aab4dbc9f7611d8b55048a3a16d2d010c2c8334e46304b40ac1cc14bf3b48e" +checksum = "9ed9a281f7bc9b7576e61468ba615a66a5c8cfdff42420a70aa82701a3b1e292" dependencies = [ - "darling_core", - "quote", - "syn 1.0.109", + "block-buffer", + "crypto-common", + "subtle", ] [[package]] -name = "data-encoding" -version = "2.5.0" +name = "either" +version = "1.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7e962a19be5cfc3f3bf6dd8f61eb50107f356ad6270fbb3ed41476571db78be5" +checksum = "60b1af1c220855b6ceac025d3f6ecdd2b7c4894bfe9cd9bda4fbb4bc7c0d4cf0" [[package]] -name = "deranged" -version = "0.3.11" +name = "encoding_rs" +version = "0.8.34" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b42b6fa04a440b495c8b04d0e71b707c585f83cb9cb28cf8cd0d976c315e31b4" +checksum = "b45de904aa0b010bce2ab45264d0631681847fa7b6f2eaa7dab7619943bc4f59" dependencies = [ - "powerfmt", + "cfg-if", ] [[package]] -name = "derive_builder" -version = "0.12.0" +name = "equivalent" +version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8d67778784b508018359cbc8696edb3db78160bab2c2a28ba7f56ef6932997f8" -dependencies = [ - "derive_builder_macro", -] +checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" [[package]] -name = "derive_builder_core" -version = "0.12.0" +name = "errno" +version = "0.3.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c11bdc11a0c47bc7d37d582b5285da6849c96681023680b906673c5707af7b0f" +checksum = "534c5cf6194dfab3db3242765c03bbe257cf92f22b38f6bc0c58d59108a820ba" dependencies = [ - "darling", - "proc-macro2", - "quote", - "syn 1.0.109", + "libc", + "windows-sys 0.52.0", ] [[package]] -name = "derive_builder_macro" -version = "0.12.0" +name = "fastrand" +version = "2.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ebcda35c7a396850a55ffeac740804b40ffec779b98fffbb1738f4033f0ee79e" -dependencies = [ - "derive_builder_core", - "syn 1.0.109", -] +checksum = "e8c02a5121d4ea3eb16a80748c74f5549a5665e4c21333c6098f283870fbdea6" [[package]] -name = "derive_more" -version = "0.99.17" +name = "flate2" +version = "1.0.33" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4fb810d30a7c1953f91334de7244731fc3f3c10d7fe163338a35b9f640960321" +checksum = "324a1be68054ef05ad64b861cc9eaf1d623d2d8cb25b4bf2cb9cdd902b4bf253" dependencies = [ - "proc-macro2", - "quote", - "syn 1.0.109", + "crc32fast", + "miniz_oxide", ] [[package]] -name = "digest" -version = "0.10.7" +name = "fnv" +version = "1.0.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9ed9a281f7bc9b7576e61468ba615a66a5c8cfdff42420a70aa82701a3b1e292" -dependencies = [ - "block-buffer", - "crypto-common", - "subtle", -] +checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" [[package]] -name = "directories" -version = "5.0.1" +name = "foreign-types" +version = "0.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9a49173b84e034382284f27f1af4dcbbd231ffa358c0fe316541a7337f376a35" +checksum = "f6f339eb8adc052cd2ca78910fda869aefa38d22d5cb648e6485e4d3fc06f3b1" dependencies = [ - "dirs-sys", + "foreign-types-shared", ] [[package]] -name = "dirs-sys" -version = "0.4.1" +name = "foreign-types-shared" +version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "520f05a5cbd335fae5a99ff7a6ab8627577660ee5cfd6a94a6a929b52ff0321c" -dependencies = [ - "libc", - "option-ext", - "redox_users", - "windows-sys 0.48.0", -] +checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" [[package]] -name = "dtoa" -version = "1.0.9" +name = "form_urlencoded" +version = "1.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dcbb2bf8e87535c23f7a8a321e364ce21462d0ff10cb6407820e8e96dfff6653" +checksum = "e13624c2627564efccf4934284bdd98cbaa14e79b0b5a141218e507b3a823456" +dependencies = [ + "percent-encoding", +] [[package]] -name = "dtoa-short" -version = "0.3.4" +name = "futures" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dbaceec3c6e4211c79e7b1800fb9680527106beb2f9c51904a3210c03a448c74" +checksum = "645c6916888f6cb6350d2550b80fb63e734897a8498abe35cfb732b6487804b0" dependencies = [ - "dtoa", + "futures-channel", + "futures-core", + "futures-executor", + "futures-io", + "futures-sink", + "futures-task", + "futures-util", ] [[package]] -name = "ego-tree" -version = "0.6.2" +name = "futures-channel" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3a68a4904193147e0a8dec3314640e6db742afd5f6e634f428a6af230d9b3591" +checksum = "eac8f7d7865dcb88bd4373ab671c8cf4508703796caa2b1985a9ca867b3fcb78" +dependencies = [ + "futures-core", + "futures-sink", +] [[package]] -name = "either" -version = "1.11.0" +name = "futures-core" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a47c1c47d2f5964e29c61246e81db715514cd532db6b5116a25ea3c03d6780a2" +checksum = "dfc6580bb841c5a68e9ef15c77ccc837b40a7504914d52e47b8b0e9bbda25a1d" [[package]] -name = "errno" -version = "0.3.8" +name = "futures-executor" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a258e46cdc063eb8519c00b9fc845fc47bcfca4130e2f08e88665ceda8474245" +checksum = "a576fc72ae164fca6b9db127eaa9a9dda0d61316034f33a0a0d4eda41f02b01d" dependencies = [ - "libc", - "windows-sys 0.52.0", + "futures-core", + "futures-task", + "futures-util", ] [[package]] -name = "fastrand" -version = "2.0.2" +name = "futures-io" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "658bd65b1cf4c852a3cc96f18a8ce7b5640f6b703f905c7d74532294c2a63984" +checksum = "a44623e20b9681a318efdd71c299b6b222ed6f231972bfe2f224ebad6311f0c1" [[package]] -name = "flate2" -version = "1.0.28" +name = "futures-macro" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "46303f565772937ffe1d394a4fac6f411c6013172fadde9dcdb1e147a086940e" +checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac" dependencies = [ - "crc32fast", - "miniz_oxide", + "proc-macro2", + "quote", + "syn 2.0.77", ] [[package]] -name = "fnv" -version = "1.0.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" - -[[package]] -name = "form_urlencoded" -version = "1.2.1" +name = "futures-sink" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e13624c2627564efccf4934284bdd98cbaa14e79b0b5a141218e507b3a823456" -dependencies = [ - "percent-encoding", -] +checksum = "9fb8e00e87438d937621c1c6269e53f536c14d3fbd6a042bb24879e57d474fb5" [[package]] -name = "futf" -version = "0.1.5" +name = "futures-task" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "df420e2e84819663797d1ec6544b13c5be84629e7bb00dc960d6917db2987843" -dependencies = [ - "mac", - "new_debug_unreachable", -] +checksum = "38d84fa142264698cdce1a9f9172cf383a0c82de1bddcf3092901442c4097004" [[package]] -name = "fxhash" -version = "0.2.1" +name = "futures-util" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c31b6d751ae2c7f11320402d34e41349dd1016f8d5d45e48c4312bc8625af50c" +checksum = "3d6401deb83407ab3da39eba7e33987a73c3df0c82b4bb5813ee871c19c41d48" dependencies = [ - "byteorder", + "futures-channel", + "futures-core", + "futures-io", + "futures-macro", + "futures-sink", + "futures-task", + "memchr", + "pin-project-lite", + "pin-utils", + "slab", ] [[package]] @@ -501,48 +477,68 @@ dependencies = [ ] [[package]] -name = "getrandom" -version = "0.2.14" +name = "gimli" +version = "0.31.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "94b22e06ecb0110981051723910cbf0b5f5e09a2062dd7663334ee79a9d1286c" -dependencies = [ - "cfg-if", - "libc", - "wasi", -] +checksum = "32085ea23f3234fc7846555e85283ba4de91e21016dc0455a16286d87a292d64" [[package]] -name = "headless_chrome" -version = "1.0.9" +name = "gtfs-structures" +version = "0.41.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "05dec19562a4024376a8a13c3a1b40a3b8006c5bb35c43f7d62d672cfe7b943c" +checksum = "ad38521102d1da04102f3ff28b3f0d8d4b8812cadccc3ff60d858473d9aa3a88" dependencies = [ - "anyhow", - "auto_generate_cdp", - "base64", - "derive_builder", - "directories", - "log", - "rand", - "regex", + "bytes", + "chrono", + "csv", + "derivative", + "futures", + "itertools", + "reqwest", + "rgb", "serde", - "serde_json", - "tempfile", + "serde_derive", + "sha2", "thiserror", - "tungstenite", - "ureq", - "url", - "walkdir", - "which", - "winreg", "zip", ] +[[package]] +name = "h2" +version = "0.3.26" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "81fe527a889e1532da5c525686d96d4c2e74cdd345badf8dfef9f6b39dd5f5e8" +dependencies = [ + "bytes", + "fnv", + "futures-core", + "futures-sink", + "futures-util", + "http", + "indexmap", + "slab", + "tokio", + "tokio-util", + "tracing", +] + +[[package]] +name = "hashbrown" +version = "0.14.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e5274423e17b7c9fc20b6e7e208532f9b19825d82dfd615708b70edd83df41f1" + [[package]] name = "heck" -version = "0.4.1" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2304e00983f87ffb38b55b444b5e3b60a884b5d30c0fca7d82fe33449bbe55ea" + +[[package]] +name = "hermit-abi" +version = "0.3.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" +checksum = "d231dfb89cfffdbc30e7fc41579ed6066ad03abda9e567ccafae602b97ec5024" [[package]] name = "hmac" @@ -554,50 +550,81 @@ dependencies = [ ] [[package]] -name = "home" -version = "0.5.9" +name = "http" +version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e3d1354bf6b7235cb4a0576c2619fd4ed18183f689b12b006a0ee7329eeff9a5" +checksum = "601cbb57e577e2f5ef5be8e7b83f0f63994f25aa94d673e54a92d5c516d101f1" dependencies = [ - "windows-sys 0.52.0", + "bytes", + "fnv", + "itoa", ] [[package]] -name = "html5ever" -version = "0.26.0" +name = "http-body" +version = "0.4.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bea68cab48b8459f17cf1c944c67ddc572d272d9f2b274140f223ecb1da4a3b7" +checksum = "7ceab25649e9960c0311ea418d17bee82c0dcec1bd053b5f9a66e265a693bed2" dependencies = [ - "log", - "mac", - "markup5ever", - "proc-macro2", - "quote", - "syn 1.0.109", + "bytes", + "http", + "pin-project-lite", ] [[package]] -name = "http" -version = "1.1.0" +name = "httparse" +version = "1.9.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0fcc0b4a115bf80b728eb8ea024ad5bd707b615bfed49e0665b6e0f86fd082d9" + +[[package]] +name = "httpdate" +version = "1.0.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "df3b46402a9d5adb4c86a0cf463f42e19994e3ee891101b1841f30a545cb49a9" + +[[package]] +name = "hyper" +version = "0.14.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "21b9ddb458710bc376481b842f5da65cdf31522de232c1ca8146abce2a358258" +checksum = "a152ddd61dfaec7273fe8419ab357f33aee0d914c5f4efbf0d96fa749eea5ec9" dependencies = [ "bytes", - "fnv", + "futures-channel", + "futures-core", + "futures-util", + "h2", + "http", + "http-body", + "httparse", + "httpdate", "itoa", + "pin-project-lite", + "socket2", + "tokio", + "tower-service", + "tracing", + "want", ] [[package]] -name = "httparse" -version = "1.8.0" +name = "hyper-tls" +version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d897f394bad6a705d5f4104762e116a75639e470d80901eed05a860a95cb1904" +checksum = "d6183ddfa99b85da61a140bea0efc93fdf56ceaa041b37d553518030827f9905" +dependencies = [ + "bytes", + "hyper", + "native-tls", + "tokio", + "tokio-native-tls", +] [[package]] name = "iana-time-zone" -version = "0.1.60" +version = "0.1.61" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e7ffbb5a1b541ea2561f8c41c087286cc091e21e556a4f09a8f6cbf17b69b141" +checksum = "235e081f3925a06703c2d0117ea8b91f042756fd6e7a6e5d901e8ca1a996b220" dependencies = [ "android_system_properties", "core-foundation-sys", @@ -616,12 +643,6 @@ dependencies = [ "cc", ] -[[package]] -name = "ident_case" -version = "1.0.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b9e0384b61958566e926dc50660321d12159025e767c18e043daf26b70104c39" - [[package]] name = "idna" version = "0.5.0" @@ -632,6 +653,16 @@ dependencies = [ "unicode-normalization", ] +[[package]] +name = "indexmap" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "68b900aa2f7301e21c36462b170ee99994de34dff39a4a6a528e80e7376d07e5" +dependencies = [ + "equivalent", + "hashbrown", +] + [[package]] name = "indoc" version = "2.0.5" @@ -647,6 +678,21 @@ dependencies = [ "generic-array", ] +[[package]] +name = "ipnet" +version = "2.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "187674a687eed5fe42285b40c6291f9a01517d415fad1c3cbc6a9f778af7fcd4" + +[[package]] +name = "itertools" +version = "0.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b1c173a5686ce8bfa551b3563d0c2170bf24ca44da99c7ca4bfdab5418c3fe57" +dependencies = [ + "either", +] + [[package]] name = "itoa" version = "1.0.11" @@ -655,109 +701,98 @@ checksum = "49f1f14873335454500d59611f1cf4a4b0f786f9ac11f4312a78e4cf2566695b" [[package]] name = "jobserver" -version = "0.1.30" +version = "0.1.32" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "685a7d121ee3f65ae4fddd72b25a04bb36b6af81bc0828f7d5434c0fe60fa3a2" +checksum = "48d1dbcbbeb6a7fec7e059840aa538bd62aaccf972c7346c4d9d2059312853d0" dependencies = [ "libc", ] [[package]] name = "js-sys" -version = "0.3.69" +version = "0.3.70" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "29c15563dc2726973df627357ce0c9ddddbea194836909d655df6a75d2cf296d" +checksum = "1868808506b929d7b0cfa8f75951347aa71bb21144b7791bae35d9bccfcfe37a" dependencies = [ "wasm-bindgen", ] [[package]] name = "libc" -version = "0.2.153" +version = "0.2.158" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd" - -[[package]] -name = "libredox" -version = "0.1.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c0ff37bd590ca25063e35af745c343cb7a0271906fb7b37e4813e8f79f00268d" -dependencies = [ - "bitflags 2.5.0", - "libc", -] +checksum = "d8adc4bb1803a324070e64a98ae98f38934d91957a99cfb3a43dcbc01bc56439" [[package]] name = "linux-raw-sys" -version = "0.4.13" +version = "0.4.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "01cda141df6706de531b6c46c3a33ecca755538219bd484262fa09410c13539c" - -[[package]] -name = "lock_api" -version = "0.4.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c168f8615b12bc01f9c17e2eb0cc07dcae1940121185446edc3744920e8ef45" -dependencies = [ - "autocfg", - "scopeguard", -] +checksum = "78b3ae25bc7c8c38cec158d1f2757ee79e9b3740fbc7ccf0e59e4b08d793fa89" [[package]] name = "log" -version = "0.4.21" +version = "0.4.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "90ed8c1e510134f979dbc4f070f87d4313098b704861a105fe34231c70a3901c" +checksum = "a7a70ba024b9dc04c27ea2f0c0548feb474ec5c54bba33a7f72f873a39d07b24" [[package]] -name = "mac" -version = "0.1.1" +name = "memchr" +version = "2.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c41e0c4fef86961ac6d6f8a82609f55f31b05e4fce149ac5710e439df7619ba4" +checksum = "78ca9ab1a0babb1e7d5695e3530886289c18cf2f87ec19a575a0abdce112e3a3" [[package]] -name = "markup5ever" -version = "0.11.0" +name = "memoffset" +version = "0.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7a2629bb1404f3d34c2e921f21fd34ba00b206124c81f65c50b43b6aaefeb016" +checksum = "488016bfae457b036d996092f6cb448677611ce4449e970ceaf42695203f218a" dependencies = [ - "log", - "phf 0.10.1", - "phf_codegen", - "string_cache", - "string_cache_codegen", - "tendril", + "autocfg", ] [[package]] -name = "memchr" -version = "2.7.2" +name = "mime" +version = "0.3.17" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6c8640c5d730cb13ebd907d8d04b52f55ac9a2eec55b440c8892f40d56c76c1d" +checksum = "6877bb514081ee2a7ff5ef9de3281f14a4dd4bceac4c09388074a6b5df8a139a" [[package]] -name = "memoffset" -version = "0.9.1" +name = "miniz_oxide" +version = "0.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "488016bfae457b036d996092f6cb448677611ce4449e970ceaf42695203f218a" +checksum = "e2d80299ef12ff69b16a84bb182e3b9df68b5a91574d3d4fa6e41b65deec4df1" dependencies = [ - "autocfg", + "adler2", ] [[package]] -name = "miniz_oxide" -version = "0.7.2" +name = "mio" +version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9d811f3e15f28568be3407c8e7fdb6514c1cda3cb30683f15b6a1a1dc4ea14a7" +checksum = "80e04d1dcff3aae0704555fe5fee3bcfaf3d1fdf8a7e521d5b9d2b42acb52cec" dependencies = [ - "adler", + "hermit-abi", + "libc", + "wasi", + "windows-sys 0.52.0", ] [[package]] -name = "new_debug_unreachable" -version = "1.0.6" +name = "native-tls" +version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "650eef8c711430f1a879fdd01d4745a7deea475becfb90269c06775983bbf086" +checksum = "a8614eb2c83d59d1c8cc974dd3f920198647674a0a035e1af1fa58707e317466" +dependencies = [ + "libc", + "log", + "openssl", + "openssl-probe", + "openssl-sys", + "schannel", + "security-framework", + "security-framework-sys", + "tempfile", +] [[package]] name = "num-conv" @@ -767,13 +802,22 @@ checksum = "51d515d32fb182ee37cda2ccdcb92950d6a3c2893aa280e540671c2cd0f3b1d9" [[package]] name = "num-traits" -version = "0.2.18" +version = "0.2.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "da0df0e5185db44f69b44f26786fe401b6c293d1907744beaa7fa62b2e5a517a" +checksum = "071dfc062690e90b734c0b2273ce72ad0ffa95f0c74596bc250dcfd960262841" dependencies = [ "autocfg", ] +[[package]] +name = "object" +version = "0.36.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "084f1a5821ac4c651660a94a7153d27ac9d8a53736203f58b31945ded098070a" +dependencies = [ + "memchr", +] + [[package]] name = "once_cell" version = "1.19.0" @@ -781,32 +825,47 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92" [[package]] -name = "option-ext" -version = "0.2.0" +name = "openssl" +version = "0.10.66" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "04744f49eae99ab78e0d5c0b603ab218f515ea8cfe5a456d7629ad883a3b6e7d" +checksum = "9529f4786b70a3e8c61e11179af17ab6188ad8d0ded78c5529441ed39d4bd9c1" +dependencies = [ + "bitflags 2.6.0", + "cfg-if", + "foreign-types", + "libc", + "once_cell", + "openssl-macros", + "openssl-sys", +] [[package]] -name = "parking_lot" -version = "0.12.1" +name = "openssl-macros" +version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3742b2c103b9f06bc9fff0a37ff4912935851bee6d36f3c02bcc755bcfec228f" +checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" dependencies = [ - "lock_api", - "parking_lot_core", + "proc-macro2", + "quote", + "syn 2.0.77", ] [[package]] -name = "parking_lot_core" -version = "0.9.9" +name = "openssl-probe" +version = "0.1.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4c42a9226546d68acdd9c0a280d17ce19bfe27a46bf68784e4066115788d008e" +checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" + +[[package]] +name = "openssl-sys" +version = "0.9.103" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f9e8deee91df40a943c71b917e5874b951d32a802526c85721ce3b776c929d6" dependencies = [ - "cfg-if", + "cc", "libc", - "redox_syscall", - "smallvec", - "windows-targets 0.48.5", + "pkg-config", + "vcpkg", ] [[package]] @@ -839,84 +898,16 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e" [[package]] -name = "phf" -version = "0.10.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fabbf1ead8a5bcbc20f5f8b939ee3f5b0f6f281b6ad3468b84656b658b455259" -dependencies = [ - "phf_shared 0.10.0", -] - -[[package]] -name = "phf" -version = "0.11.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ade2d8b8f33c7333b51bcf0428d37e217e9f32192ae4772156f65063b8ce03dc" -dependencies = [ - "phf_macros", - "phf_shared 0.11.2", -] - -[[package]] -name = "phf_codegen" -version = "0.10.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4fb1c3a8bc4dd4e5cfce29b44ffc14bedd2ee294559a294e2a4d4c9e9a6a13cd" -dependencies = [ - "phf_generator 0.10.0", - "phf_shared 0.10.0", -] - -[[package]] -name = "phf_generator" -version = "0.10.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5d5285893bb5eb82e6aaf5d59ee909a06a16737a8970984dd7746ba9283498d6" -dependencies = [ - "phf_shared 0.10.0", - "rand", -] - -[[package]] -name = "phf_generator" -version = "0.11.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "48e4cc64c2ad9ebe670cb8fd69dd50ae301650392e81c05f9bfcb2d5bdbc24b0" -dependencies = [ - "phf_shared 0.11.2", - "rand", -] - -[[package]] -name = "phf_macros" -version = "0.11.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3444646e286606587e49f3bcf1679b8cef1dc2c5ecc29ddacaffc305180d464b" -dependencies = [ - "phf_generator 0.11.2", - "phf_shared 0.11.2", - "proc-macro2", - "quote", - "syn 2.0.60", -] - -[[package]] -name = "phf_shared" -version = "0.10.0" +name = "pin-project-lite" +version = "0.2.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b6796ad771acdc0123d2a88dc428b5e38ef24456743ddb1744ed628f9815c096" -dependencies = [ - "siphasher", -] +checksum = "bda66fc9667c18cb2758a2ac84d1167245054bcf85d5d1aaa6923f45801bdd02" [[package]] -name = "phf_shared" -version = "0.11.2" +name = "pin-utils" +version = "0.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "90fcb95eef784c2ac79119d1dd819e162b5da872ce6f3c3abe1e8ca1c082f72b" -dependencies = [ - "siphasher", -] +checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" [[package]] name = "pkg-config" @@ -926,48 +917,36 @@ checksum = "d231b230927b5e4ad203db57bbcbee2802f6bce620b1e4a9024a07d94e2907ec" [[package]] name = "portable-atomic" -version = "1.6.0" +version = "1.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7170ef9988bc169ba16dd36a7fa041e5c4cbeb6a35b76d4c03daded371eae7c0" +checksum = "d30538d42559de6b034bc76fd6dd4c38961b1ee5c6c56e3808c50128fdbc22ce" [[package]] name = "powerfmt" version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391" - -[[package]] -name = "ppv-lite86" -version = "0.2.17" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5b40af805b3121feab8a3c29f04d8ad262fa8e0561883e7653e024ae4479e6de" - -[[package]] -name = "precomputed-hash" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "925383efa346730478fb4838dbe9137d2a47675ad789c546d150a6e1dd4ab31c" +checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391" [[package]] name = "proc-macro2" -version = "1.0.81" +version = "1.0.86" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3d1597b0c024618f09a9c3b8655b7e430397a36d23fdafec26d6965e9eec3eba" +checksum = "5e719e8df665df0d1c8fbfd238015744736151d4445ec0836b8e628aae103b77" dependencies = [ "unicode-ident", ] [[package]] name = "pyo3" -version = "0.21.2" +version = "0.22.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a5e00b96a521718e08e03b1a622f01c8a8deb50719335de3f60b3b3950f069d8" +checksum = "15ee168e30649f7f234c3d49ef5a7a6cbf5134289bc46c29ff3155fa3221c225" dependencies = [ "cfg-if", "indoc", "libc", "memoffset", - "parking_lot", + "once_cell", "portable-atomic", "pyo3-build-config", "pyo3-ffi", @@ -977,9 +956,9 @@ dependencies = [ [[package]] name = "pyo3-build-config" -version = "0.21.2" +version = "0.22.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7883df5835fafdad87c0d888b266c8ec0f4c9ca48a5bed6bbb592e8dedee1b50" +checksum = "e61cef80755fe9e46bb8a0b8f20752ca7676dcc07a5277d8b7768c6172e529b3" dependencies = [ "once_cell", "target-lexicon", @@ -987,9 +966,9 @@ dependencies = [ [[package]] name = "pyo3-ffi" -version = "0.21.2" +version = "0.22.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "01be5843dc60b916ab4dad1dca6d20b9b4e6ddc8e15f50c47fe6d85f1fb97403" +checksum = "67ce096073ec5405f5ee2b8b31f03a68e02aa10d5d4f565eca04acc41931fa1c" dependencies = [ "libc", "pyo3-build-config", @@ -997,151 +976,116 @@ dependencies = [ [[package]] name = "pyo3-macros" -version = "0.21.2" +version = "0.22.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "77b34069fc0682e11b31dbd10321cbf94808394c56fd996796ce45217dfac53c" +checksum = "2440c6d12bc8f3ae39f1e775266fa5122fd0c8891ce7520fa6048e683ad3de28" dependencies = [ "proc-macro2", "pyo3-macros-backend", "quote", - "syn 2.0.60", + "syn 2.0.77", ] [[package]] name = "pyo3-macros-backend" -version = "0.21.2" +version = "0.22.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "08260721f32db5e1a5beae69a55553f56b99bd0e1c3e6e0a5e8851a9d0f5a85c" +checksum = "1be962f0e06da8f8465729ea2cb71a416d2257dff56cbe40a70d3e62a93ae5d1" dependencies = [ "heck", "proc-macro2", "pyo3-build-config", "quote", - "syn 2.0.60", + "syn 2.0.77", ] [[package]] name = "quote" -version = "1.0.36" +version = "1.0.37" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0fa76aaf39101c457836aec0ce2316dbdc3ab723cdda1c6bd4e6ad4208acaca7" +checksum = "b5b9d34b8991d19d98081b46eacdd8eb58c6f2b201139f7c5f643cc155a633af" dependencies = [ "proc-macro2", ] -[[package]] -name = "rand" -version = "0.8.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "34af8d1a0e25924bc5b7c43c079c942339d8f0a8b57c39049bef581b46327404" -dependencies = [ - "libc", - "rand_chacha", - "rand_core", -] - -[[package]] -name = "rand_chacha" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e6c10a63a0fa32252be49d21e7709d4d4baf8d231c2dbce1eaa8141b9b127d88" -dependencies = [ - "ppv-lite86", - "rand_core", -] - [[package]] name = "rand_core" version = "0.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ec0be4795e2f6a28069bec0b5ff3e2ac9bafc99e6a9a7dc3547996c5c816922c" -dependencies = [ - "getrandom", -] - -[[package]] -name = "redox_syscall" -version = "0.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4722d768eff46b75989dd134e5c353f0d6296e5aaa3132e776cbdb56be7731aa" -dependencies = [ - "bitflags 1.3.2", -] [[package]] -name = "redox_users" -version = "0.4.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bd283d9651eeda4b2a83a43c1c91b266c40fd76ecd39a50a8c630ae69dc72891" -dependencies = [ - "getrandom", - "libredox", - "thiserror", -] - -[[package]] -name = "regex" -version = "1.10.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c117dbdfde9c8308975b6a18d71f3f385c89461f7b3fb054288ecf2a2058ba4c" +name = "renfe-cli" +version = "4.3.2" dependencies = [ - "aho-corasick", - "memchr", - "regex-automata", - "regex-syntax", + "chrono", + "getopts", + "gtfs-structures", + "pyo3", ] [[package]] -name = "regex-automata" -version = "0.4.6" +name = "reqwest" +version = "0.11.27" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "86b83b8b9847f9bf95ef68afb0b8e6cdb80f498442f5179a29fad448fcc1eaea" +checksum = "dd67538700a17451e7cba03ac727fb961abb7607553461627b97de0b89cf4a62" dependencies = [ - "aho-corasick", - "memchr", - "regex-syntax", + "base64", + "bytes", + "encoding_rs", + "futures-core", + "futures-util", + "h2", + "http", + "http-body", + "hyper", + "hyper-tls", + "ipnet", + "js-sys", + "log", + "mime", + "native-tls", + "once_cell", + "percent-encoding", + "pin-project-lite", + "rustls-pemfile", + "serde", + "serde_json", + "serde_urlencoded", + "sync_wrapper", + "system-configuration", + "tokio", + "tokio-native-tls", + "tower-service", + "url", + "wasm-bindgen", + "wasm-bindgen-futures", + "web-sys", + "winreg", ] [[package]] -name = "regex-syntax" -version = "0.8.3" +name = "rgb" +version = "0.8.50" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "adad44e29e4c806119491a7f06f03de4d1af22c3a680dd47f1e6e179439d1f56" - -[[package]] -name = "renfe-cli" -version = "4.3.2" +checksum = "57397d16646700483b67d2dd6511d79318f9d057fdbd21a4066aeac8b41d310a" dependencies = [ - "chrono", - "getopts", - "headless_chrome", - "pyo3", - "scraper", - "ureq", + "bytemuck", ] [[package]] -name = "ring" -version = "0.17.8" +name = "rustc-demangle" +version = "0.1.24" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c17fa4cb658e3583423e915b9f3acc01cceaee1860e33d59ebae66adc3a2dc0d" -dependencies = [ - "cc", - "cfg-if", - "getrandom", - "libc", - "spin", - "untrusted", - "windows-sys 0.52.0", -] +checksum = "719b953e2095829ee67db738b3bfa9fa368c94900df327b3f07fe6e794d2fe1f" [[package]] name = "rustix" -version = "0.38.33" +version = "0.38.37" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e3cc72858054fcff6d7dea32df2aeaee6a7c24227366d7ea429aada2f26b16ad" +checksum = "8acb788b847c24f28525660c4d7758620a7210875711f79e7f663cc152726811" dependencies = [ - "bitflags 2.5.0", + "bitflags 2.6.0", "errno", "libc", "linux-raw-sys", @@ -1149,130 +1093,94 @@ dependencies = [ ] [[package]] -name = "rustls" -version = "0.22.4" +name = "rustls-pemfile" +version = "1.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bf4ef73721ac7bcd79b2b315da7779d8fc09718c6b3d2d1b2d94850eb8c18432" +checksum = "1c74cae0a4cf6ccbbf5f359f08efdf8ee7e1dc532573bf0db71968cb56b1448c" dependencies = [ - "log", - "ring", - "rustls-pki-types", - "rustls-webpki", - "subtle", - "zeroize", -] - -[[package]] -name = "rustls-pki-types" -version = "1.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ecd36cc4259e3e4514335c4a138c6b43171a8d61d8f5c9348f9fc7529416f247" - -[[package]] -name = "rustls-webpki" -version = "0.102.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "faaa0a62740bedb9b2ef5afa303da42764c012f743917351dc9a237ea1663610" -dependencies = [ - "ring", - "rustls-pki-types", - "untrusted", + "base64", ] [[package]] name = "ryu" -version = "1.0.17" +version = "1.0.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e86697c916019a8588c99b5fac3cead74ec0b4b819707a682fd4d23fa0ce1ba1" +checksum = "f3cb5ba0dc43242ce17de99c180e96db90b235b8a9fdc9543c96d2209116bd9f" [[package]] -name = "same-file" -version = "1.0.6" +name = "schannel" +version = "0.1.24" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "93fc1dc3aaa9bfed95e02e6eadabb4baf7e3078b0bd1b4d7b6b0b68378900502" +checksum = "e9aaafd5a2b6e3d657ff009d82fbd630b6bd54dd4eb06f21693925cdf80f9b8b" dependencies = [ - "winapi-util", + "windows-sys 0.59.0", ] [[package]] -name = "scopeguard" -version = "1.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" - -[[package]] -name = "scraper" -version = "0.19.0" +name = "security-framework" +version = "2.11.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5b80b33679ff7a0ea53d37f3b39de77ea0c75b12c5805ac43ec0c33b3051af1b" +checksum = "897b2245f0b511c87893af39b033e5ca9cce68824c4d7e7630b5a1d339658d02" dependencies = [ - "ahash", - "cssparser", - "ego-tree", - "getopts", - "html5ever", - "once_cell", - "selectors", - "tendril", + "bitflags 2.6.0", + "core-foundation", + "core-foundation-sys", + "libc", + "security-framework-sys", ] [[package]] -name = "selectors" -version = "0.25.0" +name = "security-framework-sys" +version = "2.12.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4eb30575f3638fc8f6815f448d50cb1a2e255b0897985c8c59f4d37b72a07b06" +checksum = "ea4a292869320c0272d7bc55a5a6aafaff59b4f63404a003887b679a2e05b4b6" dependencies = [ - "bitflags 2.5.0", - "cssparser", - "derive_more", - "fxhash", - "log", - "new_debug_unreachable", - "phf 0.10.1", - "phf_codegen", - "precomputed-hash", - "servo_arc", - "smallvec", + "core-foundation-sys", + "libc", ] [[package]] name = "serde" -version = "1.0.198" +version = "1.0.210" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9846a40c979031340571da2545a4e5b7c4163bdae79b301d5f86d03979451fcc" +checksum = "c8e3592472072e6e22e0a54d5904d9febf8508f65fb8552499a1abc7d1078c3a" dependencies = [ "serde_derive", ] [[package]] name = "serde_derive" -version = "1.0.198" +version = "1.0.210" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e88edab869b01783ba905e7d0153f9fc1a6505a96e4ad3018011eedb838566d9" +checksum = "243902eda00fad750862fc144cea25caca5e20d615af0a81bee94ca738f1df1f" dependencies = [ "proc-macro2", "quote", - "syn 2.0.60", + "syn 2.0.77", ] [[package]] name = "serde_json" -version = "1.0.116" +version = "1.0.128" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3e17db7126d17feb94eb3fad46bf1a96b034e8aacbc2e775fe81505f8b0b2813" +checksum = "6ff5456707a1de34e7e37f2a6fd3d3f808c318259cbd01ab6377795054b483d8" dependencies = [ "itoa", + "memchr", "ryu", "serde", ] [[package]] -name = "servo_arc" -version = "0.3.0" +name = "serde_urlencoded" +version = "0.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d036d71a959e00c77a63538b90a6c2390969f9772b096ea837205c6bd0491a44" +checksum = "d3491c14715ca2294c4d6a88f15e84739788c1d030eed8c110436aafdaa2f3fd" dependencies = [ - "stable_deref_trait", + "form_urlencoded", + "itoa", + "ryu", + "serde", ] [[package]] @@ -1298,147 +1206,122 @@ dependencies = [ ] [[package]] -name = "siphasher" -version = "0.3.11" +name = "shlex" +version = "1.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "38b58827f4464d87d377d175e90bf58eb00fd8716ff0a62f80356b5e61555d0d" +checksum = "0fda2ff0d084019ba4d7c6f371c95d8fd75ce3524c3cb8fb653a3023f6323e64" [[package]] -name = "smallvec" -version = "1.13.2" +name = "slab" +version = "0.4.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c5e1a9a646d36c3599cd173a41282daf47c44583ad367b8e6837255952e5c67" +checksum = "8f92a496fb766b417c996b9c5e57daf2f7ad3b0bebe1ccfca4856390e3d3bb67" +dependencies = [ + "autocfg", +] [[package]] -name = "socks" -version = "0.3.4" +name = "socket2" +version = "0.5.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f0c3dbbd9ae980613c6dd8e28a9407b50509d3803b57624d5dfe8315218cd58b" +checksum = "ce305eb0b4296696835b71df73eb912e0f1ffd2556a501fcede6e0c50349191c" dependencies = [ - "byteorder", "libc", - "winapi", + "windows-sys 0.52.0", ] [[package]] -name = "spin" -version = "0.9.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6980e8d7511241f8acf4aebddbb1ff938df5eebe98691418c4468d0b72a96a67" - -[[package]] -name = "stable_deref_trait" -version = "1.2.0" +name = "subtle" +version = "2.6.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a8f112729512f8e442d81f95a8a7ddf2b7c6b8a1a6f509a95864142b30cab2d3" +checksum = "13c2bddecc57b384dee18652358fb23172facb8a2c51ccc10d74c157bdea3292" [[package]] -name = "string_cache" -version = "0.8.7" +name = "syn" +version = "1.0.109" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f91138e76242f575eb1d3b38b4f1362f10d3a43f47d182a5b359af488a02293b" +checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237" dependencies = [ - "new_debug_unreachable", - "once_cell", - "parking_lot", - "phf_shared 0.10.0", - "precomputed-hash", - "serde", + "proc-macro2", + "quote", + "unicode-ident", ] [[package]] -name = "string_cache_codegen" -version = "0.5.2" +name = "syn" +version = "2.0.77" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6bb30289b722be4ff74a408c3cc27edeaad656e06cb1fe8fa9231fa59c728988" +checksum = "9f35bcdf61fd8e7be6caf75f429fdca8beb3ed76584befb503b1569faee373ed" dependencies = [ - "phf_generator 0.10.0", - "phf_shared 0.10.0", "proc-macro2", "quote", + "unicode-ident", ] [[package]] -name = "strsim" -version = "0.10.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623" - -[[package]] -name = "subtle" -version = "2.5.0" +name = "sync_wrapper" +version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "81cdd64d312baedb58e21336b31bc043b77e01cc99033ce76ef539f78e965ebc" +checksum = "2047c6ded9c721764247e62cd3b03c09ffc529b2ba5b10ec482ae507a4a70160" [[package]] -name = "syn" -version = "1.0.109" +name = "system-configuration" +version = "0.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237" +checksum = "ba3a3adc5c275d719af8cb4272ea1c4a6d668a777f37e115f6d11ddbc1c8e0e7" dependencies = [ - "proc-macro2", - "quote", - "unicode-ident", + "bitflags 1.3.2", + "core-foundation", + "system-configuration-sys", ] [[package]] -name = "syn" -version = "2.0.60" +name = "system-configuration-sys" +version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "909518bc7b1c9b779f1bbf07f2929d35af9f0f37e47c6e9ef7f9dddc1e1821f3" +checksum = "a75fb188eb626b924683e3b95e3a48e63551fcfb51949de2f06a9d91dbee93c9" dependencies = [ - "proc-macro2", - "quote", - "unicode-ident", + "core-foundation-sys", + "libc", ] [[package]] name = "target-lexicon" -version = "0.12.14" +version = "0.12.16" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e1fc403891a21bcfb7c37834ba66a547a8f402146eba7265b5a6d88059c9ff2f" +checksum = "61c41af27dd6d1e27b1b16b489db798443478cef1f06a660c96db617ba5de3b1" [[package]] name = "tempfile" -version = "3.10.1" +version = "3.12.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "85b77fafb263dd9d05cbeac119526425676db3784113aa9295c88498cbf8bff1" +checksum = "04cbcdd0c794ebb0d4cf35e88edd2f7d2c4c3e9a5a6dab322839b321c6a87a64" dependencies = [ "cfg-if", "fastrand", + "once_cell", "rustix", - "windows-sys 0.52.0", -] - -[[package]] -name = "tendril" -version = "0.4.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d24a120c5fc464a3458240ee02c299ebcb9d67b5249c8848b09d639dca8d7bb0" -dependencies = [ - "futf", - "mac", - "utf-8", + "windows-sys 0.59.0", ] [[package]] name = "thiserror" -version = "1.0.59" +version = "1.0.63" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f0126ad08bff79f29fc3ae6a55cc72352056dfff61e3ff8bb7129476d44b23aa" +checksum = "c0342370b38b6a11b6cc11d6a805569958d54cfa061a29969c3b5ce2ea405724" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.59" +version = "1.0.63" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d1cd413b5d558b4c5bf3680e324a6fa5014e7b7c067a51e69dbdf47eb7148b66" +checksum = "a4558b58466b9ad7ca0f102865eccc95938dca1a74a856f2b57b6629050da261" dependencies = [ "proc-macro2", "quote", - "syn 2.0.60", + "syn 2.0.77", ] [[package]] @@ -1462,9 +1345,9 @@ checksum = "ef927ca75afb808a4d64dd374f00a2adf8d0fcff8e7b184af886c3c87ec4a3f3" [[package]] name = "tinyvec" -version = "1.6.0" +version = "1.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "87cc5ceb3875bb20c2890005a4e226a4651264a5c75edb2421b52861a0a0cb50" +checksum = "445e881f4f6d382d5f27c034e25eb92edd7c784ceab92a0937db7f2e9471b938" dependencies = [ "tinyvec_macros", ] @@ -1476,24 +1359,74 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" [[package]] -name = "tungstenite" -version = "0.21.0" +name = "tokio" +version = "1.40.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9ef1a641ea34f399a848dea702823bbecfb4c486f911735368f1f137cb8257e1" +checksum = "e2b070231665d27ad9ec9b8df639893f46727666c6767db40317fbe920a5d998" dependencies = [ - "byteorder", + "backtrace", "bytes", - "data-encoding", - "http", - "httparse", - "log", - "rand", - "sha1", - "thiserror", - "url", - "utf-8", + "libc", + "mio", + "pin-project-lite", + "socket2", + "windows-sys 0.52.0", +] + +[[package]] +name = "tokio-native-tls" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bbae76ab933c85776efabc971569dd6119c580d8f5d448769dec1764bf796ef2" +dependencies = [ + "native-tls", + "tokio", +] + +[[package]] +name = "tokio-util" +version = "0.7.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "61e7c3654c13bcd040d4a03abee2c75b1d14a37b423cf5a813ceae1cc903ec6a" +dependencies = [ + "bytes", + "futures-core", + "futures-sink", + "pin-project-lite", + "tokio", +] + +[[package]] +name = "tower-service" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8df9b6e13f2d32c91b9bd719c00d1958837bc7dec474d94952798cc8e69eeec3" + +[[package]] +name = "tracing" +version = "0.1.40" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c3523ab5a71916ccf420eebdf5521fcef02141234bbc0b8a49f2fdc4544364ef" +dependencies = [ + "pin-project-lite", + "tracing-core", +] + +[[package]] +name = "tracing-core" +version = "0.1.32" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c06d3da6113f116aaee68e4d601191614c9053067f9ab7f6edbcb161237daa54" +dependencies = [ + "once_cell", ] +[[package]] +name = "try-lock" +version = "0.2.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e421abadd41a4225275504ea4d6566923418b7f05506fbc9c0fe86ba7396114b" + [[package]] name = "typenum" version = "1.17.0" @@ -1508,24 +1441,24 @@ checksum = "08f95100a766bf4f8f28f90d77e0a5461bbdb219042e7679bebe79004fed8d75" [[package]] name = "unicode-ident" -version = "1.0.12" +version = "1.0.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" +checksum = "e91b56cd4cadaeb79bbf1a5645f6b4f8dc5bde8834ad5894a8db35fda9efa1fe" [[package]] name = "unicode-normalization" -version = "0.1.23" +version = "0.1.24" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a56d1686db2308d901306f92a263857ef59ea39678a5458e7cb17f01415101f5" +checksum = "5033c97c4262335cded6d6fc3e5c18ab755e1a3dc96376350f3d8e9f009ad956" dependencies = [ "tinyvec", ] [[package]] name = "unicode-width" -version = "0.1.11" +version = "0.1.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e51733f11c9c4f72aa0c160008246859e340b00807569a0da0e7a1079b27ba85" +checksum = "7dd6e30e90baa6f72411720665d41d89b9a3d039dc45b8faea1ddd07f617f6af" [[package]] name = "unindent" @@ -1533,35 +1466,11 @@ version = "0.2.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c7de7d73e1754487cb58364ee906a499937a0dfabd86bcb980fa99ec8c8fa2ce" -[[package]] -name = "untrusted" -version = "0.9.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8ecb6da28b8a351d773b68d5825ac39017e680750f980f3a1a85cd8dd28a47c1" - -[[package]] -name = "ureq" -version = "2.9.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "11f214ce18d8b2cbe84ed3aa6486ed3f5b285cf8d8fbdbce9f3f767a724adc35" -dependencies = [ - "base64", - "flate2", - "log", - "once_cell", - "rustls", - "rustls-pki-types", - "rustls-webpki", - "socks", - "url", - "webpki-roots", -] - [[package]] name = "url" -version = "2.5.0" +version = "2.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "31e6302e3bb753d46e83516cae55ae196fc0c309407cf11ab35cc51a4c2a4633" +checksum = "22784dbdf76fdde8af1aeda5622b546b422b6fc585325248a2bf9f5e41e94d6c" dependencies = [ "form_urlencoded", "idna", @@ -1569,25 +1478,24 @@ dependencies = [ ] [[package]] -name = "utf-8" -version = "0.7.6" +name = "vcpkg" +version = "0.2.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "09cc8ee72d2a9becf2f2febe0205bbed8fc6615b7cb429ad062dc7b7ddd036a9" +checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" [[package]] name = "version_check" -version = "0.9.4" +version = "0.9.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "49874b5167b65d7193b8aba1567f5c7d93d001cafc34600cee003eda787e483f" +checksum = "0b928f33d975fc6ad9f86c8f283853ad26bdd5b10b7f1542aa2fa15e2289105a" [[package]] -name = "walkdir" -version = "2.5.0" +name = "want" +version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "29790946404f91d9c5d06f9874efddea1dc06c5efe94541a7d6863108e3a5e4b" +checksum = "bfa7760aed19e106de2c7c0b581b509f2f25d3dacaf737cb82ac61bc6d760b0e" dependencies = [ - "same-file", - "winapi-util", + "try-lock", ] [[package]] @@ -1598,34 +1506,47 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasm-bindgen" -version = "0.2.92" +version = "0.2.93" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4be2531df63900aeb2bca0daaaddec08491ee64ceecbee5076636a3b026795a8" +checksum = "a82edfc16a6c469f5f44dc7b571814045d60404b55a0ee849f9bcfa2e63dd9b5" dependencies = [ "cfg-if", + "once_cell", "wasm-bindgen-macro", ] [[package]] name = "wasm-bindgen-backend" -version = "0.2.92" +version = "0.2.93" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "614d787b966d3989fa7bb98a654e369c762374fd3213d212cfc0251257e747da" +checksum = "9de396da306523044d3302746f1208fa71d7532227f15e347e2d93e4145dd77b" dependencies = [ "bumpalo", "log", "once_cell", "proc-macro2", "quote", - "syn 2.0.60", + "syn 2.0.77", "wasm-bindgen-shared", ] +[[package]] +name = "wasm-bindgen-futures" +version = "0.4.43" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "61e9300f63a621e96ed275155c108eb6f843b6a26d053f122ab69724559dc8ed" +dependencies = [ + "cfg-if", + "js-sys", + "wasm-bindgen", + "web-sys", +] + [[package]] name = "wasm-bindgen-macro" -version = "0.2.92" +version = "0.2.93" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a1f8823de937b71b9460c0c34e25f3da88250760bec0ebac694b49997550d726" +checksum = "585c4c91a46b072c92e908d99cb1dcdf95c5218eeb6f3bf1efa991ee7a68cccf" dependencies = [ "quote", "wasm-bindgen-macro-support", @@ -1633,83 +1554,40 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro-support" -version = "0.2.92" +version = "0.2.93" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e94f17b526d0a461a191c78ea52bbce64071ed5c04c9ffe424dcb38f74171bb7" +checksum = "afc340c74d9005395cf9dd098506f7f44e38f2b4a21c6aaacf9a105ea5e1e836" dependencies = [ "proc-macro2", "quote", - "syn 2.0.60", + "syn 2.0.77", "wasm-bindgen-backend", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-shared" -version = "0.2.92" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "af190c94f2773fdb3729c55b007a722abb5384da03bc0986df4c289bf5567e96" - -[[package]] -name = "webpki-roots" -version = "0.26.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b3de34ae270483955a94f4b21bdaaeb83d508bb84a01435f393818edb0012009" -dependencies = [ - "rustls-pki-types", -] - -[[package]] -name = "which" -version = "5.0.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9bf3ea8596f3a0dd5980b46430f2058dfe2c36a27ccfbb1845d6fbfcd9ba6e14" -dependencies = [ - "either", - "home", - "once_cell", - "rustix", - "windows-sys 0.48.0", -] - -[[package]] -name = "winapi" -version = "0.3.9" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5c839a674fcd7a98952e593242ea400abe93992746761e38641405d28b00f419" -dependencies = [ - "winapi-i686-pc-windows-gnu", - "winapi-x86_64-pc-windows-gnu", -] - -[[package]] -name = "winapi-i686-pc-windows-gnu" -version = "0.4.0" +version = "0.2.93" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6" +checksum = "c62a0a307cb4a311d3a07867860911ca130c3494e8c2719593806c08bc5d0484" [[package]] -name = "winapi-util" -version = "0.1.6" +name = "web-sys" +version = "0.3.70" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f29e6f9198ba0d26b4c9f07dbe6f9ed633e1f3d5b8b414090084349e46a52596" +checksum = "26fdeaafd9bd129f65e7c031593c24d62186301e0c72c8978fa1678be7d532c0" dependencies = [ - "winapi", + "js-sys", + "wasm-bindgen", ] -[[package]] -name = "winapi-x86_64-pc-windows-gnu" -version = "0.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" - [[package]] name = "windows-core" version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" dependencies = [ - "windows-targets 0.52.5", + "windows-targets 0.52.6", ] [[package]] @@ -1727,7 +1605,16 @@ version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" dependencies = [ - "windows-targets 0.52.5", + "windows-targets 0.52.6", +] + +[[package]] +name = "windows-sys" +version = "0.59.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e38bc4d79ed67fd075bcc251a1c39b32a1776bbe92e5bef1f0bf1f8c531853b" +dependencies = [ + "windows-targets 0.52.6", ] [[package]] @@ -1747,18 +1634,18 @@ dependencies = [ [[package]] name = "windows-targets" -version = "0.52.5" +version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6f0713a46559409d202e70e28227288446bf7841d3211583a4b53e3f6d96e7eb" +checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973" dependencies = [ - "windows_aarch64_gnullvm 0.52.5", - "windows_aarch64_msvc 0.52.5", - "windows_i686_gnu 0.52.5", + "windows_aarch64_gnullvm 0.52.6", + "windows_aarch64_msvc 0.52.6", + "windows_i686_gnu 0.52.6", "windows_i686_gnullvm", - "windows_i686_msvc 0.52.5", - "windows_x86_64_gnu 0.52.5", - "windows_x86_64_gnullvm 0.52.5", - "windows_x86_64_msvc 0.52.5", + "windows_i686_msvc 0.52.6", + "windows_x86_64_gnu 0.52.6", + "windows_x86_64_gnullvm 0.52.6", + "windows_x86_64_msvc 0.52.6", ] [[package]] @@ -1769,9 +1656,9 @@ checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" [[package]] name = "windows_aarch64_gnullvm" -version = "0.52.5" +version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7088eed71e8b8dda258ecc8bac5fb1153c5cffaf2578fc8ff5d61e23578d3263" +checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3" [[package]] name = "windows_aarch64_msvc" @@ -1781,9 +1668,9 @@ checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" [[package]] name = "windows_aarch64_msvc" -version = "0.52.5" +version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9985fd1504e250c615ca5f281c3f7a6da76213ebd5ccc9561496568a2752afb6" +checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469" [[package]] name = "windows_i686_gnu" @@ -1793,15 +1680,15 @@ checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" [[package]] name = "windows_i686_gnu" -version = "0.52.5" +version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "88ba073cf16d5372720ec942a8ccbf61626074c6d4dd2e745299726ce8b89670" +checksum = "8e9b5ad5ab802e97eb8e295ac6720e509ee4c243f69d781394014ebfe8bbfa0b" [[package]] name = "windows_i686_gnullvm" -version = "0.52.5" +version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "87f4261229030a858f36b459e748ae97545d6f1ec60e5e0d6a3d32e0dc232ee9" +checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66" [[package]] name = "windows_i686_msvc" @@ -1811,9 +1698,9 @@ checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" [[package]] name = "windows_i686_msvc" -version = "0.52.5" +version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "db3c2bf3d13d5b658be73463284eaf12830ac9a26a90c717b7f771dfe97487bf" +checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66" [[package]] name = "windows_x86_64_gnu" @@ -1823,9 +1710,9 @@ checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" [[package]] name = "windows_x86_64_gnu" -version = "0.52.5" +version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4e4246f76bdeff09eb48875a0fd3e2af6aada79d409d33011886d3e1581517d9" +checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78" [[package]] name = "windows_x86_64_gnullvm" @@ -1835,9 +1722,9 @@ checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" [[package]] name = "windows_x86_64_gnullvm" -version = "0.52.5" +version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "852298e482cd67c356ddd9570386e2862b5673c85bd5f88df9ab6802b334c596" +checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d" [[package]] name = "windows_x86_64_msvc" @@ -1847,46 +1734,20 @@ checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" [[package]] name = "windows_x86_64_msvc" -version = "0.52.5" +version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bec47e5bfd1bff0eeaf6d8b485cc1074891a197ab4225d504cb7a1ab88b02bf0" +checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec" [[package]] name = "winreg" -version = "0.52.0" +version = "0.50.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a277a57398d4bfa075df44f501a17cfdf8542d224f0d36095a2adc7aee4ef0a5" +checksum = "524e57b2c537c0f9b1e69f1965311ec12182b4122e45035b1508cd24d2adadb1" dependencies = [ "cfg-if", "windows-sys 0.48.0", ] -[[package]] -name = "zerocopy" -version = "0.7.32" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "74d4d3961e53fa4c9a25a8637fc2bfaf2595b3d3ae34875568a5cf64787716be" -dependencies = [ - "zerocopy-derive", -] - -[[package]] -name = "zerocopy-derive" -version = "0.7.32" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9ce1b18ccd8e73a9321186f97e46f9f04b778851177567b1975109d26a08d2a6" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.60", -] - -[[package]] -name = "zeroize" -version = "1.7.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "525b4ec142c6b68a2d10f01f7bbf6755599ca3f81ea53b8431b7dd348f5fdb2d" - [[package]] name = "zip" version = "0.6.6" @@ -1928,9 +1789,9 @@ dependencies = [ [[package]] name = "zstd-sys" -version = "2.0.10+zstd.1.5.6" +version = "2.0.13+zstd.1.5.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c253a4914af5bafc8fa8c86ee400827e83cf6ec01195ec1f1ed8441bf00d65aa" +checksum = "38ff0f21cfee8f97d94cef41359e0c89aa6113028ab0291aa8ca0038995a95aa" dependencies = [ "cc", "pkg-config", diff --git a/Cargo.toml b/Cargo.toml index 3b430ca..43912fd 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -16,9 +16,7 @@ name = "renfe_cli" crate-type = ["cdylib"] [dependencies] -pyo3 = { version = "0.21", features = ["abi3-py37"] } -headless_chrome = { version = "1.0", features = ["fetch"] } -scraper = "0.19" -ureq = "2.9" +pyo3 = { version = "0.22", features = ["abi3-py37"] } getopts = "0.2" chrono = "0.4" +gtfs-structures = "0.41" diff --git a/src/gtfs.rs b/src/gtfs.rs new file mode 100644 index 0000000..5bc131a --- /dev/null +++ b/src/gtfs.rs @@ -0,0 +1,141 @@ +use chrono::{Datelike, NaiveDate , NaiveTime}; +use gtfs_structures::Gtfs; + +fn main() { + // Set input parameters + let gtfs_zip_path = "./google_transit.zip"; // path to the GTFS zip file + let origin_station_id = "79300"; // Girona - the ID of the origin station + let destination_station_id = "71801"; // Barcelona Sants - the ID of the destination station + let date = NaiveDate::from_ymd_opt(2024, 9, 22).unwrap(); // the date for which schedules are needed + + // Load the GTFS zip file + let gtfs = Gtfs::from_path(gtfs_zip_path) // from_url("https://ssl.renfe.com/gtransit/Fichero_AV_LD/google_transit.zip") + .expect("Error parsing GTFS zip"); + + gtfs.print_stats(); + // println!("{:?}", gtfs.stops); + + // Get timetable + let mut schedules = get_train_schedules(>fs, origin_station_id, destination_station_id, date); + + // Sort schedules by departure_time + schedules.sort_by_key(|schedule| schedule.departure_time); + + // Print the results + for schedule in schedules { + println!( + "Trip {} from {} to {} - departure at {} - arrival at {} - with duration {}", + schedule.trip_id, + schedule.origin_stop_name, + schedule.destination_stop_name, + schedule.departure_time, + schedule.arrival_time, + schedule.duration + ); + } +} + +// Function to get train schedules between an origin and a destination on a given date +fn get_train_schedules( + gtfs: &Gtfs, + origin_station_id: &str, + destination_station_id: &str, + date: NaiveDate, +) -> Vec { + let mut schedules = Vec::new(); + + // Loop through each trip to find ones active on the given date + for trip in gtfs.trips.values() { + // Check if the trip's service is active on the given date + if is_service_active(>fs, &trip.service_id, date) { + // Filter stop times for the trip + let stop_times: Vec<_> = trip.stop_times.clone(); + + // Find the origin and destination stops in the trip's stop times + let origin_stop = stop_times.iter().find(|st| st.stop.id == origin_station_id); + let destination_stop = stop_times + .iter() + .find(|st| st.stop.id == destination_station_id); + + // If the trip includes both origin and destination, and origin is before destination + if let (Some(origin), Some(destination)) = (origin_stop, destination_stop) { + if origin.stop_sequence < destination.stop_sequence { + let time_origin = origin.departure_time.unwrap(); + let time_destination = destination.arrival_time.unwrap(); + let departure_time = NaiveTime::from_hms_opt( + time_origin / 3600, + time_origin % 3600 / 60, + time_origin % 60, + ) + .unwrap(); + let arrival_time = NaiveTime::from_hms_opt( + time_destination / 3600, + time_destination % 3600 / 60, + time_destination % 60, + ) + .unwrap(); + let duration = arrival_time.signed_duration_since(departure_time); + + schedules.push(Schedule { + trip_id: gtfs.get_route(&trip.route_id).unwrap().short_name.clone().unwrap(), + origin_stop_name: gtfs.stops[&origin.stop.id].name.clone().unwrap(), + destination_stop_name: gtfs.stops[&destination.stop.id] + .name + .clone() + .unwrap(), + departure_time, + arrival_time, + duration: format!( + "{:02}:{:02}", + duration.num_hours(), + duration.num_minutes() % 60 + ), + }); + } + } + } + } + + schedules +} + +// Helper function to check if a service is active on a given date +fn is_service_active(gtfs: &Gtfs, service_id: &str, date: NaiveDate) -> bool { + // First check the `calendar.txt` + if let Some(calendar) = gtfs.calendar.get(service_id) { + let weekday = match date.weekday() { + chrono::Weekday::Mon => calendar.monday, + chrono::Weekday::Tue => calendar.tuesday, + chrono::Weekday::Wed => calendar.wednesday, + chrono::Weekday::Thu => calendar.thursday, + chrono::Weekday::Fri => calendar.friday, + chrono::Weekday::Sat => calendar.saturday, + chrono::Weekday::Sun => calendar.sunday, + }; + + if weekday && date >= calendar.start_date && date <= calendar.end_date { + return true; + } + } + + // Then check the `calendar_dates.txt` for exceptions + if let Some(calendar_dates) = gtfs.calendar_dates.get(service_id) { + for date_override in calendar_dates { + if date_override.date == date { + return date_override.exception_type == gtfs_structures::Exception::Added; + } + } + } + + false +} + +// Struct to hold the schedule details +struct Schedule { + trip_id: String, + origin_stop_name: String, + destination_stop_name: String, + departure_time: NaiveTime, + arrival_time: NaiveTime, + duration: String +} diff --git a/src/stations.rs b/src/stations.rs index a3efbc1..1e18e74 100644 --- a/src/stations.rs +++ b/src/stations.rs @@ -2,7 +2,6 @@ use pyo3::{ exceptions::{PyConnectionError, PyValueError}, pyclass, pymethods, PyResult, }; -use scraper::{Html, Selector}; #[pyclass] pub struct Renfe { @@ -14,24 +13,25 @@ impl Renfe { #[new] pub fn new() -> PyResult { println!("Loading stations from Renfe web"); - let response = match ureq::get("https://www.renfe.com/content/renfe/es/en/viajar/informacion-util/horarios/app-horarios.html").call() { - Ok(response) => { response }, - Err(_) => { return Err(PyConnectionError::new_err("something wrong")) } - }; + // let response = match ureq::get("https://www.renfe.com/content/renfe/es/en/viajar/informacion-util/horarios/app-horarios.html").call() { + // Ok(response) => { response }, + // Err(_) => { return Err(PyConnectionError::new_err("something wrong")) } + // }; - let parsed_html = Html::parse_document(&response.into_string().unwrap()); + // let parsed_html = Html::parse_document(&response.into_string().unwrap()); - let selector = &Selector::parse(r#"#O > option"#).unwrap(); + // let selector = &Selector::parse(r#"#O > option"#).unwrap(); - let stations: Vec = parsed_html - .select(selector) - .flat_map(|el| el.text()) - .map(|t| t.to_string()) - .collect(); + // let stations: Vec = parsed_html + // .select(selector) + // .flat_map(|el| el.text()) + // .map(|t| t.to_string()) + // .collect(); - Ok(Renfe { - stations: stations[1..].to_vec(), - }) + // Ok(Renfe { + // stations: stations[1..].to_vec(), + // }) + todo!() } pub fn stations_match(&self, station: String) -> PyResult> { diff --git a/src/timetable.rs b/src/timetable.rs index db5d993..8a98767 100644 --- a/src/timetable.rs +++ b/src/timetable.rs @@ -1,28 +1,6 @@ -use headless_chrome::{Browser, LaunchOptions}; use pyo3::{pyfunction, PyResult}; -use scraper::{ElementRef, Html, Selector}; use std::{collections::HashMap, thread::sleep, time::Duration}; -trait VecParser { - fn texts_parser(&self, selector: Selector) -> Vec; -} - -impl VecParser for ElementRef<'_> { - fn texts_parser(&self, selector: Selector) -> Vec { - self.select(&selector) - .flat_map(|el| el.text()) - .map(|t| t.to_string()) - .map(|x| x.trim().to_string()) - .filter(|x| !x.is_empty()) - .collect() - } -} - -// Convenience function to avoid unwrap()ing all the time -fn make_selector(selector: &str) -> Selector { - Selector::parse(selector).unwrap() -} - fn to_renfe_day(day: String) -> String { let first_digit: u8 = day.parse::().unwrap() / 10; let last_digit: u8 = day.parse::().unwrap() % 10; @@ -76,138 +54,139 @@ pub fn search_timetable( wait: u64, sorted: bool, ) -> PyResult>> { - println!("loading headless chrome browser"); - let browser = Browser::new(LaunchOptions { - headless: true, - sandbox: true, - enable_gpu: false, - enable_logging: false, - idle_browser_timeout: Duration::from_secs(30), - window_size: Some((1920, 1080)), - path: None, - user_data_dir: None, - port: None, - ignore_certificate_errors: true, - extensions: Vec::new(), - process_envs: None, - fetcher_options: Default::default(), - args: Vec::new(), - disable_default_args: false, - proxy_server: None, - }) - .unwrap(); - - let tab = browser.new_tab().unwrap(); - tab.set_default_timeout(Duration::from_secs(wait)); - - println!("navigating to renfe timetable search page"); - tab.navigate_to("https://www.renfe.com/es/es/viajar/informacion-util/horarios") - .unwrap() - .wait_until_navigated() - .unwrap(); - - println!("waiting for search page"); - tab.wait_until_navigated() - .unwrap() - .wait_for_elements_by_xpath(r#"//*[@id="O"]"#) - .unwrap(); - - // let _jpeg_data = tab - // .capture_screenshot(Page::CaptureScreenshotFormatOption::Jpeg, None, None, true) + // println!("loading headless chrome browser"); + // let browser = Browser::new(LaunchOptions { + // headless: true, + // sandbox: true, + // enable_gpu: false, + // enable_logging: false, + // idle_browser_timeout: Duration::from_secs(30), + // window_size: Some((1920, 1080)), + // path: None, + // user_data_dir: None, + // port: None, + // ignore_certificate_errors: true, + // extensions: Vec::new(), + // process_envs: None, + // fetcher_options: Default::default(), + // args: Vec::new(), + // disable_default_args: false, + // proxy_server: None, + // }) + // .unwrap(); + + // let tab = browser.new_tab().unwrap(); + // tab.set_default_timeout(Duration::from_secs(wait)); + + // println!("navigating to renfe timetable search page"); + // tab.navigate_to("https://www.renfe.com/es/es/viajar/informacion-util/horarios") + // .unwrap() + // .wait_until_navigated() // .unwrap(); - // std::fs::write("./screenshot1.jpg", _jpeg_data)?; - - println!("adding origin station"); - tab.find_element_by_xpath(r#"//*[@id="O"]"#) - .unwrap() - .type_into(&origin) - .unwrap(); - - println!("adding destination station"); - tab.find_element_by_xpath(r#"//*[@id="D"]"#) - .unwrap() - .type_into(&destination) - .unwrap(); - - println!("adding day"); - tab.find_element_by_xpath(r#"//*[@id="DF"]"#) - .unwrap() - .type_into(&to_renfe_day(day)) - .unwrap(); - - println!("adding month"); - tab.find_element_by_xpath(r#"//*[@id="MF"]"#) - .unwrap() - .type_into(&to_renfe_month(month)) - .unwrap(); - - println!("adding year"); - tab.find_element_by_xpath(r#"//*[@id="AF"]"#) - .unwrap() - .type_into(&year) - .unwrap(); - - println!("searching timetable"); - - tab.find_element_by_xpath(r#"//*[@id="seleccion"]/fieldset/div[3]/button"#) - .unwrap() - .click() - .unwrap(); - - // wait on navigating and prepare search in result page - let html = tab.wait_until_navigated().unwrap(); - println!("got timetable page"); - - println!("wait for timetable iframe"); - sleep(Duration::from_secs(wait)); - - let table_content = html - .wait_for_elements_by_xpath(r#"//*[@id="contenedor"]"#) - .unwrap() - .first() - .unwrap() - .get_content() - .unwrap(); - - println!("loading timetable"); - - let parsed_html = Html::parse_document(&table_content); - - let resum_selector = make_selector(r#"tr.odd"#); - let total_tracks = parsed_html.select(&resum_selector); - // println!("#trajectes: {:?}", &total_tracks.count()); - - let mut tracks: Vec> = Vec::new(); - for track in total_tracks { - let columns_selector: Selector = make_selector(r#"td"#); - let columns = track.texts_parser(columns_selector); - let mut row = Vec::::with_capacity(4); - for (idx, column) in columns.iter().enumerate() { - if idx == 0 { - let train = column - .trim_start_matches(char::is_numeric) - .trim() - .to_owned(); - // println!("#sortida: {:?}", &train); - row.push(train); - } - if (1..4).contains(&idx) { - let timing = column.trim().to_owned(); - // println!("#sortida: {:?}", &timing); - row.push(timing); - } - } - tracks.push(row); - } - if sorted { - println!("sorting timetable"); - tracks.sort_by(|a, b| { - get_duration_from_renfe_string(&a[3]).cmp(&get_duration_from_renfe_string(&b[3])) - }); - } + // println!("waiting for search page"); + // tab.wait_until_navigated() + // .unwrap() + // .wait_for_elements_by_xpath(r#"//*[@id="O"]"#) + // .unwrap(); + + // // let _jpeg_data = tab + // // .capture_screenshot(Page::CaptureScreenshotFormatOption::Jpeg, None, None, true) + // // .unwrap(); + // // std::fs::write("./screenshot1.jpg", _jpeg_data)?; + + // println!("adding origin station"); + // tab.find_element_by_xpath(r#"//*[@id="O"]"#) + // .unwrap() + // .type_into(&origin) + // .unwrap(); + + // println!("adding destination station"); + // tab.find_element_by_xpath(r#"//*[@id="D"]"#) + // .unwrap() + // .type_into(&destination) + // .unwrap(); + + // println!("adding day"); + // tab.find_element_by_xpath(r#"//*[@id="DF"]"#) + // .unwrap() + // .type_into(&to_renfe_day(day)) + // .unwrap(); + + // println!("adding month"); + // tab.find_element_by_xpath(r#"//*[@id="MF"]"#) + // .unwrap() + // .type_into(&to_renfe_month(month)) + // .unwrap(); + + // println!("adding year"); + // tab.find_element_by_xpath(r#"//*[@id="AF"]"#) + // .unwrap() + // .type_into(&year) + // .unwrap(); + + // println!("searching timetable"); + + // tab.find_element_by_xpath(r#"//*[@id="seleccion"]/fieldset/div[3]/button"#) + // .unwrap() + // .click() + // .unwrap(); + + // // wait on navigating and prepare search in result page + // let html = tab.wait_until_navigated().unwrap(); + // println!("got timetable page"); + + // println!("wait for timetable iframe"); + // sleep(Duration::from_secs(wait)); + + // let table_content = html + // .wait_for_elements_by_xpath(r#"//*[@id="contenedor"]"#) + // .unwrap() + // .first() + // .unwrap() + // .get_content() + // .unwrap(); - Ok(tracks) + // println!("loading timetable"); + + // let parsed_html = Html::parse_document(&table_content); + + // let resum_selector = make_selector(r#"tr.odd"#); + // let total_tracks = parsed_html.select(&resum_selector); + // // println!("#trajectes: {:?}", &total_tracks.count()); + + // let mut tracks: Vec> = Vec::new(); + // for track in total_tracks { + // let columns_selector: Selector = make_selector(r#"td"#); + // let columns = track.texts_parser(columns_selector); + // let mut row = Vec::::with_capacity(4); + // for (idx, column) in columns.iter().enumerate() { + // if idx == 0 { + // let train = column + // .trim_start_matches(char::is_numeric) + // .trim() + // .to_owned(); + // // println!("#sortida: {:?}", &train); + // row.push(train); + // } + // if (1..4).contains(&idx) { + // let timing = column.trim().to_owned(); + // // println!("#sortida: {:?}", &timing); + // row.push(timing); + // } + // } + // tracks.push(row); + // } + + // if sorted { + // println!("sorting timetable"); + // tracks.sort_by(|a, b| { + // get_duration_from_renfe_string(&a[3]).cmp(&get_duration_from_renfe_string(&b[3])) + // }); + // } + + // Ok(tracks) + todo!() } #[pyfunction] From 47d472195340360a56fe4cc2c1dc4e79c0cf537c Mon Sep 17 00:00:00 2001 From: Gerard CL Date: Sat, 28 Sep 2024 23:12:42 +0200 Subject: [PATCH 3/6] mega refactor to using GTFS as data source - keep same functionality but enhacing Renfe python class - preparing new major release --- Cargo.lock | 2 +- Cargo.toml | 2 +- README.md | 4 +- src/cli.rs | 61 ++++++------- src/gtfs.rs | 141 ----------------------------- src/lib.rs | 8 +- src/renfe.rs | 209 ++++++++++++++++++++++++++++++++++++++++++ src/stations.rs | 61 ------------- src/timetable.rs | 231 ----------------------------------------------- 9 files changed, 243 insertions(+), 476 deletions(-) delete mode 100644 src/gtfs.rs create mode 100644 src/renfe.rs delete mode 100644 src/stations.rs delete mode 100644 src/timetable.rs diff --git a/Cargo.lock b/Cargo.lock index 1504bc5..4e5995b 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -1016,7 +1016,7 @@ checksum = "ec0be4795e2f6a28069bec0b5ff3e2ac9bafc99e6a9a7dc3547996c5c816922c" [[package]] name = "renfe-cli" -version = "4.3.2" +version = "5.0.0" dependencies = [ "chrono", "getopts", diff --git a/Cargo.toml b/Cargo.toml index 43912fd..27cf382 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "renfe-cli" -version = "4.3.2" +version = "5.0.0" edition = "2021" license = "BSD-3-Clause" description = "CLI for searching Renfe train timetables in the Spanish country" diff --git a/README.md b/README.md index 419f9bf..550409d 100644 --- a/README.md +++ b/README.md @@ -170,8 +170,8 @@ Example of first time working with this repository: ```bash $ git clone https://github.com/gerardcl/renfe-cli.git && cd renfe-cli -$ python -m venv venv -$ . venv/bin/activate +$ python -m venv .venv +$ . .venv/bin/activate $ pip install -U pip $ pip install -U maturin $ maturin develop diff --git a/src/cli.rs b/src/cli.rs index 3decc88..525e952 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -3,10 +3,7 @@ use getopts::Options; use pyo3::{exceptions::PyValueError, pyfunction, PyResult}; use std::env; -use crate::{ - stations::Renfe, - timetable::{print_timetable, search_timetable}, -}; +use crate::renfe::Renfe; #[pyfunction] pub fn main() -> PyResult<()> { @@ -14,7 +11,6 @@ pub fn main() -> PyResult<()> { let program = args[0].clone(); let now = Utc::now(); let opts = set_opts(); - let renfe = Renfe::new()?; let matches = match opts.parse(&args[1..]) { Ok(m) => m, @@ -27,39 +23,44 @@ pub fn main() -> PyResult<()> { print_usage(&program, opts); return Ok(()); } + + let mut renfe = Renfe::new()?; + let origin = renfe.filter_station(matches.opt_str("f").unwrap_or("".to_owned()))?; let destination = renfe.filter_station(matches.opt_str("t").unwrap_or("".to_owned()))?; - let day = enrich_day(matches.opt_str("d").unwrap_or(now.day().to_string())); - let month = matches.opt_str("m").unwrap_or(now.month().to_string()); - let year = matches.opt_str("y").unwrap_or(now.year().to_string()); - let wait = matches - .opt_str("w") - .unwrap_or(2.to_string()) - .parse::()?; + let day = match matches.opt_str("d") { + Some(day) => day.parse().unwrap(), + None => now.day(), + }; + let month = match matches.opt_str("m") { + Some(day) => day.parse().unwrap(), + None => now.month(), + }; + let year = match matches.opt_str("y") { + Some(day) => day.parse().unwrap(), + None => now.year(), + }; let sorted: bool = matches.opt_present("s"); + println!("Today is: {}-{}-{}", now.year(), now.month(), now.day()); + println!("Searching timetable for date: {}-{}-{}", year, month, day); + + renfe.set_train_schedules(&origin.1, &destination.1, day, month, year, sorted)?; + println!( - "Today is: {}-{}-{}", - now.year(), - now.month(), - enrich_day(now.day().to_string()) + "Origin station: {}", + origin.0 + ); + println!( + "Destination station: {}", + destination.0 ); - println!("Searching timetable for date: {}-{}-{}", year, month, day); - let timetable = search_timetable(origin, destination, day, month, year, wait, sorted)?; + renfe.print_timetable(); - print_timetable(timetable); Ok(()) } -fn enrich_day(day: String) -> String { - if day.len() == 1 { - "0".to_owned() + &day - } else { - day - } -} - fn print_usage(program: &str, opts: Options) { let brief = format!("Usage: {} [options]", program); print!("{}", opts.usage(&brief)); @@ -87,12 +88,6 @@ fn set_opts() -> Options { "Set Year to search timetable for (default: today's year)", "YEAR", ); - opts.optopt( - "w", - "wait", - "Set Wait time in seconds for Renfe search result page (default: 2)", - "SECONDS", - ); opts.optflag("s", "sort", "Option to sort the timetable by Duration"); opts.optflag("h", "help", "Print this help menu"); diff --git a/src/gtfs.rs b/src/gtfs.rs deleted file mode 100644 index 5bc131a..0000000 --- a/src/gtfs.rs +++ /dev/null @@ -1,141 +0,0 @@ -use chrono::{Datelike, NaiveDate , NaiveTime}; -use gtfs_structures::Gtfs; - -fn main() { - // Set input parameters - let gtfs_zip_path = "./google_transit.zip"; // path to the GTFS zip file - let origin_station_id = "79300"; // Girona - the ID of the origin station - let destination_station_id = "71801"; // Barcelona Sants - the ID of the destination station - let date = NaiveDate::from_ymd_opt(2024, 9, 22).unwrap(); // the date for which schedules are needed - - // Load the GTFS zip file - let gtfs = Gtfs::from_path(gtfs_zip_path) // from_url("https://ssl.renfe.com/gtransit/Fichero_AV_LD/google_transit.zip") - .expect("Error parsing GTFS zip"); - - gtfs.print_stats(); - // println!("{:?}", gtfs.stops); - - // Get timetable - let mut schedules = get_train_schedules(>fs, origin_station_id, destination_station_id, date); - - // Sort schedules by departure_time - schedules.sort_by_key(|schedule| schedule.departure_time); - - // Print the results - for schedule in schedules { - println!( - "Trip {} from {} to {} - departure at {} - arrival at {} - with duration {}", - schedule.trip_id, - schedule.origin_stop_name, - schedule.destination_stop_name, - schedule.departure_time, - schedule.arrival_time, - schedule.duration - ); - } -} - -// Function to get train schedules between an origin and a destination on a given date -fn get_train_schedules( - gtfs: &Gtfs, - origin_station_id: &str, - destination_station_id: &str, - date: NaiveDate, -) -> Vec { - let mut schedules = Vec::new(); - - // Loop through each trip to find ones active on the given date - for trip in gtfs.trips.values() { - // Check if the trip's service is active on the given date - if is_service_active(>fs, &trip.service_id, date) { - // Filter stop times for the trip - let stop_times: Vec<_> = trip.stop_times.clone(); - - // Find the origin and destination stops in the trip's stop times - let origin_stop = stop_times.iter().find(|st| st.stop.id == origin_station_id); - let destination_stop = stop_times - .iter() - .find(|st| st.stop.id == destination_station_id); - - // If the trip includes both origin and destination, and origin is before destination - if let (Some(origin), Some(destination)) = (origin_stop, destination_stop) { - if origin.stop_sequence < destination.stop_sequence { - let time_origin = origin.departure_time.unwrap(); - let time_destination = destination.arrival_time.unwrap(); - let departure_time = NaiveTime::from_hms_opt( - time_origin / 3600, - time_origin % 3600 / 60, - time_origin % 60, - ) - .unwrap(); - let arrival_time = NaiveTime::from_hms_opt( - time_destination / 3600, - time_destination % 3600 / 60, - time_destination % 60, - ) - .unwrap(); - let duration = arrival_time.signed_duration_since(departure_time); - - schedules.push(Schedule { - trip_id: gtfs.get_route(&trip.route_id).unwrap().short_name.clone().unwrap(), - origin_stop_name: gtfs.stops[&origin.stop.id].name.clone().unwrap(), - destination_stop_name: gtfs.stops[&destination.stop.id] - .name - .clone() - .unwrap(), - departure_time, - arrival_time, - duration: format!( - "{:02}:{:02}", - duration.num_hours(), - duration.num_minutes() % 60 - ), - }); - } - } - } - } - - schedules -} - -// Helper function to check if a service is active on a given date -fn is_service_active(gtfs: &Gtfs, service_id: &str, date: NaiveDate) -> bool { - // First check the `calendar.txt` - if let Some(calendar) = gtfs.calendar.get(service_id) { - let weekday = match date.weekday() { - chrono::Weekday::Mon => calendar.monday, - chrono::Weekday::Tue => calendar.tuesday, - chrono::Weekday::Wed => calendar.wednesday, - chrono::Weekday::Thu => calendar.thursday, - chrono::Weekday::Fri => calendar.friday, - chrono::Weekday::Sat => calendar.saturday, - chrono::Weekday::Sun => calendar.sunday, - }; - - if weekday && date >= calendar.start_date && date <= calendar.end_date { - return true; - } - } - - // Then check the `calendar_dates.txt` for exceptions - if let Some(calendar_dates) = gtfs.calendar_dates.get(service_id) { - for date_override in calendar_dates { - if date_override.date == date { - return date_override.exception_type == gtfs_structures::Exception::Added; - } - } - } - - false -} - -// Struct to hold the schedule details -struct Schedule { - trip_id: String, - origin_stop_name: String, - destination_stop_name: String, - departure_time: NaiveTime, - arrival_time: NaiveTime, - duration: String -} diff --git a/src/lib.rs b/src/lib.rs index 2cb0b3b..824f41f 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1,9 +1,7 @@ use pyo3::prelude::*; -mod stations; -use stations::Renfe; -mod timetable; -use timetable::{print_timetable, search_timetable}; +mod renfe; +use renfe::Renfe; mod cli; use cli::main; @@ -13,8 +11,6 @@ use cli::main; #[pymodule] fn renfe_cli(m: &Bound<'_, PyModule>) -> PyResult<()> { m.add_class::()?; - m.add_function(wrap_pyfunction!(search_timetable, m)?)?; - m.add_function(wrap_pyfunction!(print_timetable, m)?)?; m.add_function(wrap_pyfunction!(main, m)?)?; Ok(()) diff --git a/src/renfe.rs b/src/renfe.rs new file mode 100644 index 0000000..fc96da8 --- /dev/null +++ b/src/renfe.rs @@ -0,0 +1,209 @@ +use chrono::{Datelike, NaiveDate, NaiveTime, TimeDelta, Timelike}; +use gtfs_structures::Gtfs; +use pyo3::{exceptions::PyValueError, pyclass, pymethods, PyResult}; + +#[pyclass] +pub struct Renfe { + gtfs: Gtfs, + schedules: Vec, +} + +// Struct to hold the schedule details +#[pyclass] +pub struct Schedule { + train_type: String, + origin_stop_name: String, + destination_stop_name: String, + departure_time: NaiveTime, + arrival_time: NaiveTime, + duration: TimeDelta, +} + +#[pymethods] +impl Renfe { + #[new] + pub fn new() -> PyResult { + println!("Loading GTFS data from Renfe web"); + let gtfs_zip_path = "./google_transit.zip"; // path to the GTFS zip file + + let gtfs = Gtfs::from_path(gtfs_zip_path) // from_url("https://ssl.renfe.com/gtransit/Fichero_AV_LD/google_transit.zip") + .expect("Error parsing GTFS zip"); + + // gtfs.print_stats(); + + Ok(Renfe { + gtfs, + schedules: Vec::new(), + }) + } + + pub fn stations_match(&self, station: String) -> PyResult> { + let found: Vec<(String, String)> = self + .gtfs + .stops + .iter() + .filter(|s| s.1.name.clone().unwrap().contains(&station)) + .map(|s| (s.1.name.clone().unwrap(), s.1.id.clone())) + .collect(); + Ok(found) + } + + pub fn filter_station(&self, station: String) -> PyResult<(String, String)> { + match self.stations_match(station.clone()) { + Ok(v) if v.len() == 1 => { + println!( + "Provided input '{}' station matches with '{}'...continue", + station, v[0].0 + ); + Ok(v[0].clone()) + } + Ok(v) => Err(PyValueError::new_err(format!( + "Provided input '{station}' station does not match one '{v:?}'" + ))), + Err(e) => Err(e), + } + } + + // Function to get train schedules between an origin and a destination on a given date + pub fn set_train_schedules( + &mut self, + origin_station_id: &str, + destination_station_id: &str, + day: u32, + month: u32, + year: i32, + sorted: bool, + ) -> PyResult<()> { + let gtfs = &self.gtfs; + let date = NaiveDate::from_ymd_opt(year, month, day).unwrap(); // the date for which schedules are needed + + let mut schedules = Vec::new(); + + // Loop through each trip to find ones active on the given date + for trip in gtfs.trips.values() { + // Check if the trip's service is active on the given date + if is_service_active(gtfs, &trip.service_id, date) { + // Filter stop times for the trip + let stop_times: Vec<_> = trip.stop_times.clone(); + + // Find the origin and destination stops in the trip's stop times + let origin_stop = stop_times.iter().find(|st| st.stop.id == origin_station_id); + let destination_stop = stop_times + .iter() + .find(|st| st.stop.id == destination_station_id); + + // If the trip includes both origin and destination, and origin is before destination + if let (Some(origin), Some(destination)) = (origin_stop, destination_stop) { + if origin.stop_sequence < destination.stop_sequence { + let time_origin = origin.departure_time.unwrap(); + let time_destination = destination.arrival_time.unwrap(); + let departure_time = NaiveTime::from_hms_opt( + time_origin / 3600, + time_origin % 3600 / 60, + time_origin % 60, + ) + .unwrap(); + let arrival_time = NaiveTime::from_hms_opt( + time_destination / 3600, + time_destination % 3600 / 60, + time_destination % 60, + ) + .unwrap(); + let duration = arrival_time.signed_duration_since(departure_time); + + schedules.push(Schedule { + train_type: gtfs + .get_route(&trip.route_id) + .unwrap() + .short_name + .clone() + .unwrap(), + origin_stop_name: gtfs.stops[&origin.stop.id].name.clone().unwrap(), + destination_stop_name: gtfs.stops[&destination.stop.id] + .name + .clone() + .unwrap(), + departure_time, + arrival_time, + duration, + }); + } + } + } + } + + // Sort schedules by departure_time + schedules.sort_by_key(|schedule| schedule.departure_time); + + if sorted { + println!("sorting timetable by duration"); + schedules.sort_by(|a, b| a.duration.cmp(&b.duration)); + } + + self.schedules = schedules; + + Ok(()) + } + + pub fn print_timetable(&self) { + println!("=========================TIMETABLE========================="); + println!( + "{0: <12} | {1: <10} | {2: <10} | {3: <12}", + "Train", "Departure", "Arrival", "Duration" + ); + for track in &self.schedules { + println!("-----------------------------------------------------------"); + println!( + "{0: <12} | {1: <9} | {2: <9} | {3: <10}", + track.train_type, + format!( + "{:02}:{:02}", + track.departure_time.hour(), + track.departure_time.minute() % 60 + ), + format!( + "{:02}:{:02}", + track.arrival_time.hour(), + track.arrival_time.minute() % 60 + ), + format!( + "{:02}:{:02}", + track.duration.num_hours(), + track.duration.num_minutes() % 60 + ) + ); + } + println!("==========================================================="); + } +} + +// Helper function to check if a service is active on a given date +fn is_service_active(gtfs: &Gtfs, service_id: &str, date: NaiveDate) -> bool { + // First check the `calendar.txt` + if let Some(calendar) = gtfs.calendar.get(service_id) { + let weekday = match date.weekday() { + chrono::Weekday::Mon => calendar.monday, + chrono::Weekday::Tue => calendar.tuesday, + chrono::Weekday::Wed => calendar.wednesday, + chrono::Weekday::Thu => calendar.thursday, + chrono::Weekday::Fri => calendar.friday, + chrono::Weekday::Sat => calendar.saturday, + chrono::Weekday::Sun => calendar.sunday, + }; + + if weekday && date >= calendar.start_date && date <= calendar.end_date { + return true; + } + } + + // Then check the `calendar_dates.txt` for exceptions + if let Some(calendar_dates) = gtfs.calendar_dates.get(service_id) { + for date_override in calendar_dates { + if date_override.date == date { + return date_override.exception_type == gtfs_structures::Exception::Added; + } + } + } + + false +} diff --git a/src/stations.rs b/src/stations.rs deleted file mode 100644 index 1e18e74..0000000 --- a/src/stations.rs +++ /dev/null @@ -1,61 +0,0 @@ -use pyo3::{ - exceptions::{PyConnectionError, PyValueError}, - pyclass, pymethods, PyResult, -}; - -#[pyclass] -pub struct Renfe { - stations: Vec, -} - -#[pymethods] -impl Renfe { - #[new] - pub fn new() -> PyResult { - println!("Loading stations from Renfe web"); - // let response = match ureq::get("https://www.renfe.com/content/renfe/es/en/viajar/informacion-util/horarios/app-horarios.html").call() { - // Ok(response) => { response }, - // Err(_) => { return Err(PyConnectionError::new_err("something wrong")) } - // }; - - // let parsed_html = Html::parse_document(&response.into_string().unwrap()); - - // let selector = &Selector::parse(r#"#O > option"#).unwrap(); - - // let stations: Vec = parsed_html - // .select(selector) - // .flat_map(|el| el.text()) - // .map(|t| t.to_string()) - // .collect(); - - // Ok(Renfe { - // stations: stations[1..].to_vec(), - // }) - todo!() - } - - pub fn stations_match(&self, station: String) -> PyResult> { - let found: Vec<&String> = self - .stations - .iter() - .filter(|s| s.contains(&station)) - .collect(); - Ok(found) - } - - pub fn filter_station(&self, station: String) -> PyResult { - match self.stations_match(station.clone()) { - Ok(v) if v.len() == 1 => { - println!( - "Provided input '{}' station matches with '{}'...continue", - station, v[0] - ); - Ok(v[0].to_owned()) - } - Ok(v) => Err(PyValueError::new_err(format!( - "Provided input '{station}' station does not match one '{v:?}'" - ))), - Err(e) => Err(e), - } - } -} diff --git a/src/timetable.rs b/src/timetable.rs deleted file mode 100644 index 8a98767..0000000 --- a/src/timetable.rs +++ /dev/null @@ -1,231 +0,0 @@ -use pyo3::{pyfunction, PyResult}; -use std::{collections::HashMap, thread::sleep, time::Duration}; - -fn to_renfe_day(day: String) -> String { - let first_digit: u8 = day.parse::().unwrap() / 10; - let last_digit: u8 = day.parse::().unwrap() % 10; - let mut renfe_day: String = String::new(); - if day.starts_with('0') { - day - } else { - for _ in 0..last_digit + 1 { - renfe_day += &first_digit.to_string(); - } - renfe_day - } -} - -fn to_renfe_month(month: String) -> String { - let months: HashMap<&str, &str> = HashMap::from([ - ("1", "Ene"), - ("2", "Feb"), - ("3", "Mar"), - ("4", "Abr"), - ("5", "May"), - ("6", "Jun"), - ("7", "Jul"), - ("8", "Ago"), - ("9", "Sep"), - ("10", "Oct"), - ("11", "Nov"), - ("12", "Dec"), - ]); - months[month.as_str()].to_owned() -} - -fn get_duration_from_renfe_string(s: &str) -> u16 { - let splits: Vec<&str> = s.split(' ').collect(); - if s.contains('h') { - let hours = splits[0].parse::().unwrap(); - let minutes = splits[2].parse::().unwrap(); - hours * 60 + minutes - } else { - splits[0].parse::().unwrap() - } -} - -#[pyfunction] -pub fn search_timetable( - origin: String, - destination: String, - day: String, - month: String, - year: String, - wait: u64, - sorted: bool, -) -> PyResult>> { - // println!("loading headless chrome browser"); - // let browser = Browser::new(LaunchOptions { - // headless: true, - // sandbox: true, - // enable_gpu: false, - // enable_logging: false, - // idle_browser_timeout: Duration::from_secs(30), - // window_size: Some((1920, 1080)), - // path: None, - // user_data_dir: None, - // port: None, - // ignore_certificate_errors: true, - // extensions: Vec::new(), - // process_envs: None, - // fetcher_options: Default::default(), - // args: Vec::new(), - // disable_default_args: false, - // proxy_server: None, - // }) - // .unwrap(); - - // let tab = browser.new_tab().unwrap(); - // tab.set_default_timeout(Duration::from_secs(wait)); - - // println!("navigating to renfe timetable search page"); - // tab.navigate_to("https://www.renfe.com/es/es/viajar/informacion-util/horarios") - // .unwrap() - // .wait_until_navigated() - // .unwrap(); - - // println!("waiting for search page"); - // tab.wait_until_navigated() - // .unwrap() - // .wait_for_elements_by_xpath(r#"//*[@id="O"]"#) - // .unwrap(); - - // // let _jpeg_data = tab - // // .capture_screenshot(Page::CaptureScreenshotFormatOption::Jpeg, None, None, true) - // // .unwrap(); - // // std::fs::write("./screenshot1.jpg", _jpeg_data)?; - - // println!("adding origin station"); - // tab.find_element_by_xpath(r#"//*[@id="O"]"#) - // .unwrap() - // .type_into(&origin) - // .unwrap(); - - // println!("adding destination station"); - // tab.find_element_by_xpath(r#"//*[@id="D"]"#) - // .unwrap() - // .type_into(&destination) - // .unwrap(); - - // println!("adding day"); - // tab.find_element_by_xpath(r#"//*[@id="DF"]"#) - // .unwrap() - // .type_into(&to_renfe_day(day)) - // .unwrap(); - - // println!("adding month"); - // tab.find_element_by_xpath(r#"//*[@id="MF"]"#) - // .unwrap() - // .type_into(&to_renfe_month(month)) - // .unwrap(); - - // println!("adding year"); - // tab.find_element_by_xpath(r#"//*[@id="AF"]"#) - // .unwrap() - // .type_into(&year) - // .unwrap(); - - // println!("searching timetable"); - - // tab.find_element_by_xpath(r#"//*[@id="seleccion"]/fieldset/div[3]/button"#) - // .unwrap() - // .click() - // .unwrap(); - - // // wait on navigating and prepare search in result page - // let html = tab.wait_until_navigated().unwrap(); - // println!("got timetable page"); - - // println!("wait for timetable iframe"); - // sleep(Duration::from_secs(wait)); - - // let table_content = html - // .wait_for_elements_by_xpath(r#"//*[@id="contenedor"]"#) - // .unwrap() - // .first() - // .unwrap() - // .get_content() - // .unwrap(); - - // println!("loading timetable"); - - // let parsed_html = Html::parse_document(&table_content); - - // let resum_selector = make_selector(r#"tr.odd"#); - // let total_tracks = parsed_html.select(&resum_selector); - // // println!("#trajectes: {:?}", &total_tracks.count()); - - // let mut tracks: Vec> = Vec::new(); - // for track in total_tracks { - // let columns_selector: Selector = make_selector(r#"td"#); - // let columns = track.texts_parser(columns_selector); - // let mut row = Vec::::with_capacity(4); - // for (idx, column) in columns.iter().enumerate() { - // if idx == 0 { - // let train = column - // .trim_start_matches(char::is_numeric) - // .trim() - // .to_owned(); - // // println!("#sortida: {:?}", &train); - // row.push(train); - // } - // if (1..4).contains(&idx) { - // let timing = column.trim().to_owned(); - // // println!("#sortida: {:?}", &timing); - // row.push(timing); - // } - // } - // tracks.push(row); - // } - - // if sorted { - // println!("sorting timetable"); - // tracks.sort_by(|a, b| { - // get_duration_from_renfe_string(&a[3]).cmp(&get_duration_from_renfe_string(&b[3])) - // }); - // } - - // Ok(tracks) - todo!() -} - -#[pyfunction] -pub fn print_timetable(tracks: Vec>) { - println!("=========================TIMETABLE========================="); - println!( - "{0: <12} | {1: <10} | {2: <10} | {3: <12}", - "Train", "Departure", "Arrival", "Duration" - ); - for track in tracks { - println!("-----------------------------------------------------------"); - println!( - "{0: <12} | {1: <9} | {2: <9} | {3: <12}", - track[0], track[1], track[2], track[3] - ); - } - println!("==========================================================="); -} - -#[cfg(test)] -mod tests { - use chrono::{Datelike, Utc}; - - use crate::{print_timetable, search_timetable}; - - #[test] - fn test_search_and_print_timetable() -> Result<(), Box> { - let now = Utc::now(); - - print_timetable(search_timetable( - "Girona".to_owned(), - "Barcelona".to_owned(), - now.day().to_string(), - now.month().to_string(), - now.year().to_string(), - 15, - false, - )?); - - Ok(()) - } -} From ec8a1c7362ad6a8ccb8548034bfc27faef044352 Mon Sep 17 00:00:00 2001 From: Gerard CL Date: Sun, 29 Sep 2024 13:19:31 +0200 Subject: [PATCH 4/6] usability improvements --- src/cli.rs | 12 ++------ src/renfe.rs | 85 ++++++++++++++++++++++++++++++++++------------------ 2 files changed, 59 insertions(+), 38 deletions(-) diff --git a/src/cli.rs b/src/cli.rs index 525e952..be8cd6a 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -35,7 +35,7 @@ pub fn main() -> PyResult<()> { let month = match matches.opt_str("m") { Some(day) => day.parse().unwrap(), None => now.month(), - }; + }; let year = match matches.opt_str("y") { Some(day) => day.parse().unwrap(), None => now.year(), @@ -47,14 +47,8 @@ pub fn main() -> PyResult<()> { renfe.set_train_schedules(&origin.1, &destination.1, day, month, year, sorted)?; - println!( - "Origin station: {}", - origin.0 - ); - println!( - "Destination station: {}", - destination.0 - ); + println!("Origin station: {}", origin.0); + println!("Destination station: {}", destination.0); renfe.print_timetable(); diff --git a/src/renfe.rs b/src/renfe.rs index fc96da8..09f25a1 100644 --- a/src/renfe.rs +++ b/src/renfe.rs @@ -42,7 +42,13 @@ impl Renfe { .gtfs .stops .iter() - .filter(|s| s.1.name.clone().unwrap().contains(&station)) + .filter(|s| { + s.1.name + .clone() + .unwrap() + .to_lowercase() + .contains(&station.to_lowercase()) + }) .map(|s| (s.1.name.clone().unwrap(), s.1.id.clone())) .collect(); Ok(found) @@ -52,13 +58,13 @@ impl Renfe { match self.stations_match(station.clone()) { Ok(v) if v.len() == 1 => { println!( - "Provided input '{}' station matches with '{}'...continue", + "Provided input '{}' does a match with '{}'", station, v[0].0 ); Ok(v[0].clone()) } Ok(v) => Err(PyValueError::new_err(format!( - "Provided input '{station}' station does not match one '{v:?}'" + "Provided input '{station}' does match with '{v:?}' -> There must be ONLY one match" ))), Err(e) => Err(e), } @@ -75,7 +81,15 @@ impl Renfe { sorted: bool, ) -> PyResult<()> { let gtfs = &self.gtfs; - let date = NaiveDate::from_ymd_opt(year, month, day).unwrap(); // the date for which schedules are needed + // the date for which schedules are needed + let date = match NaiveDate::from_ymd_opt(year, month, day) { + Some(date) => date, + None => { + return Err(PyValueError::new_err(format!( + "Provided date '{year}-{month}-{day}' does not exist" + ))) + } + }; let mut schedules = Vec::new(); @@ -146,34 +160,38 @@ impl Renfe { } pub fn print_timetable(&self) { - println!("=========================TIMETABLE========================="); - println!( - "{0: <12} | {1: <10} | {2: <10} | {3: <12}", - "Train", "Departure", "Arrival", "Duration" - ); - for track in &self.schedules { - println!("-----------------------------------------------------------"); + if self.schedules.len() == 0 { + println!("\nNo schedules available...won't print timetable."); + } else { + println!("\n=========================TIMETABLE========================="); println!( - "{0: <12} | {1: <9} | {2: <9} | {3: <10}", - track.train_type, - format!( - "{:02}:{:02}", - track.departure_time.hour(), - track.departure_time.minute() % 60 - ), - format!( - "{:02}:{:02}", - track.arrival_time.hour(), - track.arrival_time.minute() % 60 - ), - format!( - "{:02}:{:02}", - track.duration.num_hours(), - track.duration.num_minutes() % 60 - ) + " {0: <12} | {1: <10} | {2: <10} | {3: <12}", + "Train", "Departure", "Arrival", "Duration" ); + for track in &self.schedules { + println!("-----------------------------------------------------------"); + println!( + " {0: <11} | {1: <9} | {2: <9} | {3: <10}", + track.train_type, + format!( + "{:02}:{:02}", + track.departure_time.hour(), + track.departure_time.minute() % 60 + ), + format!( + "{:02}:{:02}", + track.arrival_time.hour(), + track.arrival_time.minute() % 60 + ), + format!( + "{:02}:{:02}", + track.duration.num_hours(), + track.duration.num_minutes() % 60 + ) + ); + } + println!("==========================================================="); } - println!("==========================================================="); } } @@ -192,6 +210,15 @@ fn is_service_active(gtfs: &Gtfs, service_id: &str, date: NaiveDate) -> bool { }; if weekday && date >= calendar.start_date && date <= calendar.end_date { + // this should never happen - but a check is for free + if let Some(calendar_dates) = gtfs.calendar_dates.get(service_id) { + for date_override in calendar_dates { + if date_override.date == date { + return !(date_override.exception_type + == gtfs_structures::Exception::Deleted); + } + } + } return true; } } From f78aeaf7e139f6c499491d5bed2154c0a8a10642 Mon Sep 17 00:00:00 2001 From: Gerard CL Date: Sun, 29 Sep 2024 13:51:23 +0200 Subject: [PATCH 5/6] more error handling and adding types --- src/cli.rs | 17 +++++++++-------- src/lib.rs | 4 +++- src/renfe.rs | 50 +++++++++++++++++++++++++++++++++++++------------- 3 files changed, 49 insertions(+), 22 deletions(-) diff --git a/src/cli.rs b/src/cli.rs index be8cd6a..12a1b1f 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -26,18 +26,19 @@ pub fn main() -> PyResult<()> { let mut renfe = Renfe::new()?; - let origin = renfe.filter_station(matches.opt_str("f").unwrap_or("".to_owned()))?; - let destination = renfe.filter_station(matches.opt_str("t").unwrap_or("".to_owned()))?; + let origin = renfe.filter_station(matches.opt_str("f").expect("Missing origin station"))?; + let destination = + renfe.filter_station(matches.opt_str("t").expect("Missing destination station"))?; let day = match matches.opt_str("d") { - Some(day) => day.parse().unwrap(), + Some(day) => day.parse()?, None => now.day(), }; let month = match matches.opt_str("m") { - Some(day) => day.parse().unwrap(), + Some(day) => day.parse()?, None => now.month(), }; let year = match matches.opt_str("y") { - Some(day) => day.parse().unwrap(), + Some(day) => day.parse()?, None => now.year(), }; let sorted: bool = matches.opt_present("s"); @@ -45,10 +46,10 @@ pub fn main() -> PyResult<()> { println!("Today is: {}-{}-{}", now.year(), now.month(), now.day()); println!("Searching timetable for date: {}-{}-{}", year, month, day); - renfe.set_train_schedules(&origin.1, &destination.1, day, month, year, sorted)?; + renfe.set_train_schedules(&origin.id, &destination.id, day, month, year, sorted)?; - println!("Origin station: {}", origin.0); - println!("Destination station: {}", destination.0); + println!("Origin station: {}", origin.name); + println!("Destination station: {}", destination.name); renfe.print_timetable(); diff --git a/src/lib.rs b/src/lib.rs index 824f41f..81fc71b 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1,7 +1,7 @@ use pyo3::prelude::*; mod renfe; -use renfe::Renfe; +use renfe::{Renfe, Schedule, Station}; mod cli; use cli::main; @@ -11,6 +11,8 @@ use cli::main; #[pymodule] fn renfe_cli(m: &Bound<'_, PyModule>) -> PyResult<()> { m.add_class::()?; + m.add_class::()?; + m.add_class::()?; m.add_function(wrap_pyfunction!(main, m)?)?; Ok(()) diff --git a/src/renfe.rs b/src/renfe.rs index 09f25a1..218b4bb 100644 --- a/src/renfe.rs +++ b/src/renfe.rs @@ -12,13 +12,21 @@ pub struct Renfe { #[pyclass] pub struct Schedule { train_type: String, - origin_stop_name: String, - destination_stop_name: String, + // origin_stop_name: String, + // destination_stop_name: String, departure_time: NaiveTime, arrival_time: NaiveTime, duration: TimeDelta, } +// Struct to hold the station name and ID +#[pyclass] +#[derive(Debug, Clone)] +pub struct Station { + pub name: String, + pub id: String, +} + #[pymethods] impl Renfe { #[new] @@ -37,8 +45,21 @@ impl Renfe { }) } - pub fn stations_match(&self, station: String) -> PyResult> { - let found: Vec<(String, String)> = self + pub fn all_stations(&self) -> PyResult> { + let stations: Vec = self + .gtfs + .stops + .iter() + .map(|s| Station { + name: s.1.name.clone().unwrap(), + id: s.1.id.clone(), + }) + .collect(); + Ok(stations) + } + + pub fn stations_match(&self, station: String) -> PyResult> { + let found: Vec = self .gtfs .stops .iter() @@ -49,17 +70,20 @@ impl Renfe { .to_lowercase() .contains(&station.to_lowercase()) }) - .map(|s| (s.1.name.clone().unwrap(), s.1.id.clone())) + .map(|s| Station { + name: s.1.name.clone().unwrap(), + id: s.1.id.clone(), + }) .collect(); Ok(found) } - pub fn filter_station(&self, station: String) -> PyResult<(String, String)> { + pub fn filter_station(&self, station: String) -> PyResult { match self.stations_match(station.clone()) { Ok(v) if v.len() == 1 => { println!( "Provided input '{}' does a match with '{}'", - station, v[0].0 + station, v[0].name ); Ok(v[0].clone()) } @@ -132,11 +156,11 @@ impl Renfe { .short_name .clone() .unwrap(), - origin_stop_name: gtfs.stops[&origin.stop.id].name.clone().unwrap(), - destination_stop_name: gtfs.stops[&destination.stop.id] - .name - .clone() - .unwrap(), + // origin_stop_name: gtfs.stops[&origin.stop.id].name.clone().unwrap(), + // destination_stop_name: gtfs.stops[&destination.stop.id] + // .name + // .clone() + // .unwrap(), departure_time, arrival_time, duration, @@ -160,7 +184,7 @@ impl Renfe { } pub fn print_timetable(&self) { - if self.schedules.len() == 0 { + if self.schedules.is_empty() { println!("\nNo schedules available...won't print timetable."); } else { println!("\n=========================TIMETABLE========================="); From a55ca20f1faeeead5c4563ce5e2d3bb9a3d4f1a4 Mon Sep 17 00:00:00 2001 From: Gerard CL Date: Sun, 29 Sep 2024 15:17:59 +0200 Subject: [PATCH 6/6] no openssl requirements, update Readme and usability - release! --- .github/workflows/CICD.yml | 2 +- CHANGELOG.md | 6 + Cargo.lock | 757 ++++++++++++++++--------------------- Cargo.toml | 3 +- README.md | 150 +++----- pyproject.toml | 2 +- src/cli.rs | 16 +- src/renfe.rs | 17 +- 8 files changed, 397 insertions(+), 556 deletions(-) diff --git a/.github/workflows/CICD.yml b/.github/workflows/CICD.yml index af636f0..be48d18 100644 --- a/.github/workflows/CICD.yml +++ b/.github/workflows/CICD.yml @@ -12,7 +12,7 @@ on: tags: - '*' pull_request: - branches: [ master ] + branches: [ main ] workflow_dispatch: permissions: diff --git a/CHANGELOG.md b/CHANGELOG.md index ab4a657..293299a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,11 @@ # Changelog +## v5.0.0 (2024-09-29) + +* Major refactor using GTFS data from Renfe online datasets. No more scrapping required + * [#194](https://github.com/gerardcl/renfe-cli/issues/194) + * [#198](https://github.com/gerardcl/renfe-cli/issues/198) + ## v4.3.2 (2024-04-21) * General dependencies maintenance with rustls focus [#196](https://github.com/gerardcl/renfe-cli/issues/196) diff --git a/Cargo.lock b/Cargo.lock index 4e5995b..2bf6596 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -45,9 +45,9 @@ dependencies = [ [[package]] name = "autocfg" -version = "1.3.0" +version = "1.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0c4b4d0bd25bd0b74681c0ad21497610ce1b7c91b1022cd21c80c6fbdd9476b0" +checksum = "ace50bade8e6234aa140d9a2f552bbee1db4d353f69b8217bc503490fc1a9f26" [[package]] name = "backtrace" @@ -61,14 +61,14 @@ dependencies = [ "miniz_oxide", "object", "rustc-demangle", - "windows-targets 0.52.6", + "windows-targets", ] [[package]] name = "base64" -version = "0.21.7" +version = "0.22.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9d297deb1925b89f2ccc13d7635fa0714f12c87adce1c75356b39ca9b7178567" +checksum = "72b3254f16251a8381aa12e40e3c4d2f0199f8c6508fbecb9d91f575e0fbb8c6" [[package]] name = "base64ct" @@ -76,18 +76,6 @@ version = "1.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8c3c1a368f70d6cf7302d78f8f7093da241fb8e8807c05cc9e51a125895a6d5b" -[[package]] -name = "bitflags" -version = "1.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" - -[[package]] -name = "bitflags" -version = "2.6.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b048fb63fd8b5923fc5aa7b340d8e156aec7ec02f0c78fa8a6ddc2613f6f71de" - [[package]] name = "block-buffer" version = "0.10.4" @@ -144,9 +132,9 @@ dependencies = [ [[package]] name = "cc" -version = "1.1.21" +version = "1.1.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "07b1695e2c7e8fc85310cde85aeaab7e3097f593c91d209d3f9df76c928100f0" +checksum = "9540e661f81799159abee814118cc139a2004b3a3aa3ea37724a1b66530b90e0" dependencies = [ "jobserver", "libc", @@ -170,7 +158,7 @@ dependencies = [ "js-sys", "num-traits", "wasm-bindgen", - "windows-targets 0.52.6", + "windows-targets", ] [[package]] @@ -189,16 +177,6 @@ version = "0.1.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "245097e9a4535ee1e3e3931fcfcd55a796a44c643e8596ff6566d68f09b87bbc" -[[package]] -name = "core-foundation" -version = "0.9.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "91e195e091a93c46f7102ec7818a2aa394e1e1771c3ab4825963fa03e45afb8f" -dependencies = [ - "core-foundation-sys", - "libc", -] - [[package]] name = "core-foundation-sys" version = "0.8.7" @@ -297,42 +275,11 @@ version = "1.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "60b1af1c220855b6ceac025d3f6ecdd2b7c4894bfe9cd9bda4fbb4bc7c0d4cf0" -[[package]] -name = "encoding_rs" -version = "0.8.34" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b45de904aa0b010bce2ab45264d0631681847fa7b6f2eaa7dab7619943bc4f59" -dependencies = [ - "cfg-if", -] - -[[package]] -name = "equivalent" -version = "1.0.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" - -[[package]] -name = "errno" -version = "0.3.9" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "534c5cf6194dfab3db3242765c03bbe257cf92f22b38f6bc0c58d59108a820ba" -dependencies = [ - "libc", - "windows-sys 0.52.0", -] - -[[package]] -name = "fastrand" -version = "2.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e8c02a5121d4ea3eb16a80748c74f5549a5665e4c21333c6098f283870fbdea6" - [[package]] name = "flate2" -version = "1.0.33" +version = "1.0.34" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "324a1be68054ef05ad64b861cc9eaf1d623d2d8cb25b4bf2cb9cdd902b4bf253" +checksum = "a1b589b4dc103969ad3cf85c950899926ec64300a1a46d76c03a6072957036f0" dependencies = [ "crc32fast", "miniz_oxide", @@ -344,21 +291,6 @@ version = "1.0.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" -[[package]] -name = "foreign-types" -version = "0.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f6f339eb8adc052cd2ca78910fda869aefa38d22d5cb648e6485e4d3fc06f3b1" -dependencies = [ - "foreign-types-shared", -] - -[[package]] -name = "foreign-types-shared" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" - [[package]] name = "form_urlencoded" version = "1.2.1" @@ -368,21 +300,6 @@ dependencies = [ "percent-encoding", ] -[[package]] -name = "futures" -version = "0.3.30" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "645c6916888f6cb6350d2550b80fb63e734897a8498abe35cfb732b6487804b0" -dependencies = [ - "futures-channel", - "futures-core", - "futures-executor", - "futures-io", - "futures-sink", - "futures-task", - "futures-util", -] - [[package]] name = "futures-channel" version = "0.3.30" @@ -399,34 +316,12 @@ version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dfc6580bb841c5a68e9ef15c77ccc837b40a7504914d52e47b8b0e9bbda25a1d" -[[package]] -name = "futures-executor" -version = "0.3.30" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a576fc72ae164fca6b9db127eaa9a9dda0d61316034f33a0a0d4eda41f02b01d" -dependencies = [ - "futures-core", - "futures-task", - "futures-util", -] - [[package]] name = "futures-io" version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a44623e20b9681a318efdd71c299b6b222ed6f231972bfe2f224ebad6311f0c1" -[[package]] -name = "futures-macro" -version = "0.3.30" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.77", -] - [[package]] name = "futures-sink" version = "0.3.30" @@ -445,10 +340,8 @@ version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3d6401deb83407ab3da39eba7e33987a73c3df0c82b4bb5813ee871c19c41d48" dependencies = [ - "futures-channel", "futures-core", "futures-io", - "futures-macro", "futures-sink", "futures-task", "memchr", @@ -476,6 +369,17 @@ dependencies = [ "unicode-width", ] +[[package]] +name = "getrandom" +version = "0.2.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c4567c8db10ae91089c99af84c68c38da3ec2f087c3f82960bcdbf3656b6f4d7" +dependencies = [ + "cfg-if", + "libc", + "wasi", +] + [[package]] name = "gimli" version = "0.31.0" @@ -492,9 +396,7 @@ dependencies = [ "chrono", "csv", "derivative", - "futures", "itertools", - "reqwest", "rgb", "serde", "serde_derive", @@ -503,31 +405,6 @@ dependencies = [ "zip", ] -[[package]] -name = "h2" -version = "0.3.26" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "81fe527a889e1532da5c525686d96d4c2e74cdd345badf8dfef9f6b39dd5f5e8" -dependencies = [ - "bytes", - "fnv", - "futures-core", - "futures-sink", - "futures-util", - "http", - "indexmap", - "slab", - "tokio", - "tokio-util", - "tracing", -] - -[[package]] -name = "hashbrown" -version = "0.14.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e5274423e17b7c9fc20b6e7e208532f9b19825d82dfd615708b70edd83df41f1" - [[package]] name = "heck" version = "0.5.0" @@ -551,9 +428,9 @@ dependencies = [ [[package]] name = "http" -version = "0.2.12" +version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "601cbb57e577e2f5ef5be8e7b83f0f63994f25aa94d673e54a92d5c516d101f1" +checksum = "21b9ddb458710bc376481b842f5da65cdf31522de232c1ca8146abce2a358258" dependencies = [ "bytes", "fnv", @@ -562,12 +439,24 @@ dependencies = [ [[package]] name = "http-body" -version = "0.4.6" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1efedce1fb8e6913f23e0c92de8e62cd5b772a67e7b3946df930a62566c93184" +dependencies = [ + "bytes", + "http", +] + +[[package]] +name = "http-body-util" +version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7ceab25649e9960c0311ea418d17bee82c0dcec1bd053b5f9a66e265a693bed2" +checksum = "793429d76616a256bcb62c2a2ec2bed781c8307e797e2598c50010f2bee2544f" dependencies = [ "bytes", + "futures-util", "http", + "http-body", "pin-project-lite", ] @@ -577,47 +466,60 @@ version = "1.9.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0fcc0b4a115bf80b728eb8ea024ad5bd707b615bfed49e0665b6e0f86fd082d9" -[[package]] -name = "httpdate" -version = "1.0.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "df3b46402a9d5adb4c86a0cf463f42e19994e3ee891101b1841f30a545cb49a9" - [[package]] name = "hyper" -version = "0.14.30" +version = "1.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a152ddd61dfaec7273fe8419ab357f33aee0d914c5f4efbf0d96fa749eea5ec9" +checksum = "50dfd22e0e76d0f662d429a5f80fcaf3855009297eab6a0a9f8543834744ba05" dependencies = [ "bytes", "futures-channel", - "futures-core", "futures-util", - "h2", "http", "http-body", "httparse", - "httpdate", "itoa", "pin-project-lite", - "socket2", + "smallvec", "tokio", - "tower-service", - "tracing", "want", ] [[package]] -name = "hyper-tls" -version = "0.5.0" +name = "hyper-rustls" +version = "0.27.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d6183ddfa99b85da61a140bea0efc93fdf56ceaa041b37d553518030827f9905" +checksum = "08afdbb5c31130e3034af566421053ab03787c640246a446327f550d11bcb333" +dependencies = [ + "futures-util", + "http", + "hyper", + "hyper-util", + "rustls", + "rustls-pki-types", + "tokio", + "tokio-rustls", + "tower-service", + "webpki-roots", +] + +[[package]] +name = "hyper-util" +version = "0.1.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "41296eb09f183ac68eec06e03cdbea2e759633d4067b2f6552fc2e009bcad08b" dependencies = [ "bytes", + "futures-channel", + "futures-util", + "http", + "http-body", "hyper", - "native-tls", + "pin-project-lite", + "socket2", "tokio", - "tokio-native-tls", + "tower-service", + "tracing", ] [[package]] @@ -653,16 +555,6 @@ dependencies = [ "unicode-normalization", ] -[[package]] -name = "indexmap" -version = "2.5.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "68b900aa2f7301e21c36462b170ee99994de34dff39a4a6a528e80e7376d07e5" -dependencies = [ - "equivalent", - "hashbrown", -] - [[package]] name = "indoc" version = "2.0.5" @@ -719,15 +611,9 @@ dependencies = [ [[package]] name = "libc" -version = "0.2.158" +version = "0.2.159" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d8adc4bb1803a324070e64a98ae98f38934d91957a99cfb3a43dcbc01bc56439" - -[[package]] -name = "linux-raw-sys" -version = "0.4.14" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "78b3ae25bc7c8c38cec158d1f2757ee79e9b3740fbc7ccf0e59e4b08d793fa89" +checksum = "561d97a539a36e26a9a5fad1ea11a3039a67714694aaa379433e580854bc3dc5" [[package]] name = "log" @@ -777,23 +663,6 @@ dependencies = [ "windows-sys 0.52.0", ] -[[package]] -name = "native-tls" -version = "0.2.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a8614eb2c83d59d1c8cc974dd3f920198647674a0a035e1af1fa58707e317466" -dependencies = [ - "libc", - "log", - "openssl", - "openssl-probe", - "openssl-sys", - "schannel", - "security-framework", - "security-framework-sys", - "tempfile", -] - [[package]] name = "num-conv" version = "0.1.0" @@ -824,50 +693,6 @@ version = "1.19.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92" -[[package]] -name = "openssl" -version = "0.10.66" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9529f4786b70a3e8c61e11179af17ab6188ad8d0ded78c5529441ed39d4bd9c1" -dependencies = [ - "bitflags 2.6.0", - "cfg-if", - "foreign-types", - "libc", - "once_cell", - "openssl-macros", - "openssl-sys", -] - -[[package]] -name = "openssl-macros" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.77", -] - -[[package]] -name = "openssl-probe" -version = "0.1.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" - -[[package]] -name = "openssl-sys" -version = "0.9.103" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7f9e8deee91df40a943c71b917e5874b951d32a802526c85721ce3b776c929d6" -dependencies = [ - "cc", - "libc", - "pkg-config", - "vcpkg", -] - [[package]] name = "password-hash" version = "0.4.2" @@ -911,15 +736,15 @@ checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" [[package]] name = "pkg-config" -version = "0.3.30" +version = "0.3.31" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d231b230927b5e4ad203db57bbcbee2802f6bce620b1e4a9024a07d94e2907ec" +checksum = "953ec861398dccce10c670dfeaf3ec4911ca479e9c02154b3a215178c5f566f2" [[package]] name = "portable-atomic" -version = "1.8.0" +version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d30538d42559de6b034bc76fd6dd4c38961b1ee5c6c56e3808c50128fdbc22ce" +checksum = "cc9c68a3f6da06753e9335d63e27f6b9754dd1920d941135b7ea8224f141adb2" [[package]] name = "powerfmt" @@ -927,6 +752,15 @@ version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391" +[[package]] +name = "ppv-lite86" +version = "0.2.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "77957b295656769bb8ad2b6a6b09d897d94f05c41b069aede1fcdaa675eaea04" +dependencies = [ + "zerocopy", +] + [[package]] name = "proc-macro2" version = "1.0.86" @@ -983,7 +817,7 @@ dependencies = [ "proc-macro2", "pyo3-macros-backend", "quote", - "syn 2.0.77", + "syn 2.0.79", ] [[package]] @@ -996,7 +830,55 @@ dependencies = [ "proc-macro2", "pyo3-build-config", "quote", - "syn 2.0.77", + "syn 2.0.79", +] + +[[package]] +name = "quinn" +version = "0.11.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8c7c5fdde3cdae7203427dc4f0a68fe0ed09833edc525a03456b153b79828684" +dependencies = [ + "bytes", + "pin-project-lite", + "quinn-proto", + "quinn-udp", + "rustc-hash", + "rustls", + "socket2", + "thiserror", + "tokio", + "tracing", +] + +[[package]] +name = "quinn-proto" +version = "0.11.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fadfaed2cd7f389d0161bb73eeb07b7b78f8691047a6f3e73caaeae55310a4a6" +dependencies = [ + "bytes", + "rand", + "ring", + "rustc-hash", + "rustls", + "slab", + "thiserror", + "tinyvec", + "tracing", +] + +[[package]] +name = "quinn-udp" +version = "0.5.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4fe68c2e9e1a1234e218683dbdf9f9dfcb094113c5ac2b938dfcb9bab4c4140b" +dependencies = [ + "libc", + "once_cell", + "socket2", + "tracing", + "windows-sys 0.59.0", ] [[package]] @@ -1008,11 +890,35 @@ dependencies = [ "proc-macro2", ] +[[package]] +name = "rand" +version = "0.8.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "34af8d1a0e25924bc5b7c43c079c942339d8f0a8b57c39049bef581b46327404" +dependencies = [ + "libc", + "rand_chacha", + "rand_core", +] + +[[package]] +name = "rand_chacha" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e6c10a63a0fa32252be49d21e7709d4d4baf8d231c2dbce1eaa8141b9b127d88" +dependencies = [ + "ppv-lite86", + "rand_core", +] + [[package]] name = "rand_core" version = "0.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ec0be4795e2f6a28069bec0b5ff3e2ac9bafc99e6a9a7dc3547996c5c816922c" +dependencies = [ + "getrandom", +] [[package]] name = "renfe-cli" @@ -1022,46 +928,50 @@ dependencies = [ "getopts", "gtfs-structures", "pyo3", + "reqwest", ] [[package]] name = "reqwest" -version = "0.11.27" +version = "0.12.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dd67538700a17451e7cba03ac727fb961abb7607553461627b97de0b89cf4a62" +checksum = "f8f4955649ef5c38cc7f9e8aa41761d48fb9677197daea9984dc54f56aad5e63" dependencies = [ "base64", "bytes", - "encoding_rs", + "futures-channel", "futures-core", "futures-util", - "h2", "http", "http-body", + "http-body-util", "hyper", - "hyper-tls", + "hyper-rustls", + "hyper-util", "ipnet", "js-sys", "log", "mime", - "native-tls", "once_cell", "percent-encoding", "pin-project-lite", + "quinn", + "rustls", "rustls-pemfile", + "rustls-pki-types", "serde", "serde_json", "serde_urlencoded", "sync_wrapper", - "system-configuration", "tokio", - "tokio-native-tls", + "tokio-rustls", "tower-service", "url", "wasm-bindgen", "wasm-bindgen-futures", "web-sys", - "winreg", + "webpki-roots", + "windows-registry", ] [[package]] @@ -1073,6 +983,21 @@ dependencies = [ "bytemuck", ] +[[package]] +name = "ring" +version = "0.17.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c17fa4cb658e3583423e915b9f3acc01cceaee1860e33d59ebae66adc3a2dc0d" +dependencies = [ + "cc", + "cfg-if", + "getrandom", + "libc", + "spin", + "untrusted", + "windows-sys 0.52.0", +] + [[package]] name = "rustc-demangle" version = "0.1.24" @@ -1080,64 +1005,57 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "719b953e2095829ee67db738b3bfa9fa368c94900df327b3f07fe6e794d2fe1f" [[package]] -name = "rustix" -version = "0.38.37" +name = "rustc-hash" +version = "2.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "583034fd73374156e66797ed8e5b0d5690409c9226b22d87cb7f19821c05d152" + +[[package]] +name = "rustls" +version = "0.23.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8acb788b847c24f28525660c4d7758620a7210875711f79e7f663cc152726811" +checksum = "f2dabaac7466917e566adb06783a81ca48944c6898a1b08b9374106dd671f4c8" dependencies = [ - "bitflags 2.6.0", - "errno", - "libc", - "linux-raw-sys", - "windows-sys 0.52.0", + "once_cell", + "ring", + "rustls-pki-types", + "rustls-webpki", + "subtle", + "zeroize", ] [[package]] name = "rustls-pemfile" -version = "1.0.4" +version = "2.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1c74cae0a4cf6ccbbf5f359f08efdf8ee7e1dc532573bf0db71968cb56b1448c" +checksum = "196fe16b00e106300d3e45ecfcb764fa292a535d7326a29a5875c579c7417425" dependencies = [ "base64", + "rustls-pki-types", ] [[package]] -name = "ryu" -version = "1.0.18" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f3cb5ba0dc43242ce17de99c180e96db90b235b8a9fdc9543c96d2209116bd9f" - -[[package]] -name = "schannel" -version = "0.1.24" +name = "rustls-pki-types" +version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e9aaafd5a2b6e3d657ff009d82fbd630b6bd54dd4eb06f21693925cdf80f9b8b" -dependencies = [ - "windows-sys 0.59.0", -] +checksum = "0e696e35370c65c9c541198af4543ccd580cf17fc25d8e05c5a242b202488c55" [[package]] -name = "security-framework" -version = "2.11.1" +name = "rustls-webpki" +version = "0.102.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "897b2245f0b511c87893af39b033e5ca9cce68824c4d7e7630b5a1d339658d02" +checksum = "64ca1bc8749bd4cf37b5ce386cc146580777b4e8572c7b97baf22c83f444bee9" dependencies = [ - "bitflags 2.6.0", - "core-foundation", - "core-foundation-sys", - "libc", - "security-framework-sys", + "ring", + "rustls-pki-types", + "untrusted", ] [[package]] -name = "security-framework-sys" -version = "2.12.0" +name = "ryu" +version = "1.0.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ea4a292869320c0272d7bc55a5a6aafaff59b4f63404a003887b679a2e05b4b6" -dependencies = [ - "core-foundation-sys", - "libc", -] +checksum = "f3cb5ba0dc43242ce17de99c180e96db90b235b8a9fdc9543c96d2209116bd9f" [[package]] name = "serde" @@ -1156,7 +1074,7 @@ checksum = "243902eda00fad750862fc144cea25caca5e20d615af0a81bee94ca738f1df1f" dependencies = [ "proc-macro2", "quote", - "syn 2.0.77", + "syn 2.0.79", ] [[package]] @@ -1220,6 +1138,12 @@ dependencies = [ "autocfg", ] +[[package]] +name = "smallvec" +version = "1.13.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c5e1a9a646d36c3599cd173a41282daf47c44583ad367b8e6837255952e5c67" + [[package]] name = "socket2" version = "0.5.7" @@ -1230,6 +1154,12 @@ dependencies = [ "windows-sys 0.52.0", ] +[[package]] +name = "spin" +version = "0.9.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6980e8d7511241f8acf4aebddbb1ff938df5eebe98691418c4468d0b72a96a67" + [[package]] name = "subtle" version = "2.6.1" @@ -1249,9 +1179,9 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.77" +version = "2.0.79" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9f35bcdf61fd8e7be6caf75f429fdca8beb3ed76584befb503b1569faee373ed" +checksum = "89132cd0bf050864e1d38dc3bbc07a0eb8e7530af26344d3d2bbbef83499f590" dependencies = [ "proc-macro2", "quote", @@ -1260,29 +1190,11 @@ dependencies = [ [[package]] name = "sync_wrapper" -version = "0.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2047c6ded9c721764247e62cd3b03c09ffc529b2ba5b10ec482ae507a4a70160" - -[[package]] -name = "system-configuration" -version = "0.5.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ba3a3adc5c275d719af8cb4272ea1c4a6d668a777f37e115f6d11ddbc1c8e0e7" -dependencies = [ - "bitflags 1.3.2", - "core-foundation", - "system-configuration-sys", -] - -[[package]] -name = "system-configuration-sys" -version = "0.5.0" +version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a75fb188eb626b924683e3b95e3a48e63551fcfb51949de2f06a9d91dbee93c9" +checksum = "a7065abeca94b6a8a577f9bd45aa0867a2238b74e8eb67cf10d492bc39351394" dependencies = [ - "core-foundation-sys", - "libc", + "futures-core", ] [[package]] @@ -1291,37 +1203,24 @@ version = "0.12.16" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "61c41af27dd6d1e27b1b16b489db798443478cef1f06a660c96db617ba5de3b1" -[[package]] -name = "tempfile" -version = "3.12.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "04cbcdd0c794ebb0d4cf35e88edd2f7d2c4c3e9a5a6dab322839b321c6a87a64" -dependencies = [ - "cfg-if", - "fastrand", - "once_cell", - "rustix", - "windows-sys 0.59.0", -] - [[package]] name = "thiserror" -version = "1.0.63" +version = "1.0.64" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c0342370b38b6a11b6cc11d6a805569958d54cfa061a29969c3b5ce2ea405724" +checksum = "d50af8abc119fb8bb6dbabcfa89656f46f84aa0ac7688088608076ad2b459a84" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.63" +version = "1.0.64" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a4558b58466b9ad7ca0f102865eccc95938dca1a74a856f2b57b6629050da261" +checksum = "08904e7672f5eb876eaaf87e0ce17857500934f4981c4a0ab2b4aa98baac7fc3" dependencies = [ "proc-macro2", "quote", - "syn 2.0.77", + "syn 2.0.79", ] [[package]] @@ -1374,25 +1273,13 @@ dependencies = [ ] [[package]] -name = "tokio-native-tls" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bbae76ab933c85776efabc971569dd6119c580d8f5d448769dec1764bf796ef2" -dependencies = [ - "native-tls", - "tokio", -] - -[[package]] -name = "tokio-util" -version = "0.7.12" +name = "tokio-rustls" +version = "0.26.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61e7c3654c13bcd040d4a03abee2c75b1d14a37b423cf5a813ceae1cc903ec6a" +checksum = "0c7bc40d0e5a97695bb96e27995cd3a08538541b0a846f65bba7a359f36700d4" dependencies = [ - "bytes", - "futures-core", - "futures-sink", - "pin-project-lite", + "rustls", + "rustls-pki-types", "tokio", ] @@ -1466,6 +1353,12 @@ version = "0.2.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c7de7d73e1754487cb58364ee906a499937a0dfabd86bcb980fa99ec8c8fa2ce" +[[package]] +name = "untrusted" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8ecb6da28b8a351d773b68d5825ac39017e680750f980f3a1a85cd8dd28a47c1" + [[package]] name = "url" version = "2.5.2" @@ -1477,12 +1370,6 @@ dependencies = [ "percent-encoding", ] -[[package]] -name = "vcpkg" -version = "0.2.15" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" - [[package]] name = "version_check" version = "0.9.5" @@ -1526,7 +1413,7 @@ dependencies = [ "once_cell", "proc-macro2", "quote", - "syn 2.0.77", + "syn 2.0.79", "wasm-bindgen-shared", ] @@ -1560,7 +1447,7 @@ checksum = "afc340c74d9005395cf9dd098506f7f44e38f2b4a21c6aaacf9a105ea5e1e836" dependencies = [ "proc-macro2", "quote", - "syn 2.0.77", + "syn 2.0.79", "wasm-bindgen-backend", "wasm-bindgen-shared", ] @@ -1581,55 +1468,70 @@ dependencies = [ "wasm-bindgen", ] +[[package]] +name = "webpki-roots" +version = "0.26.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "841c67bff177718f1d4dfefde8d8f0e78f9b6589319ba88312f567fc5841a958" +dependencies = [ + "rustls-pki-types", +] + [[package]] name = "windows-core" version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" dependencies = [ - "windows-targets 0.52.6", + "windows-targets", ] [[package]] -name = "windows-sys" -version = "0.48.0" +name = "windows-registry" +version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" +checksum = "e400001bb720a623c1c69032f8e3e4cf09984deec740f007dd2b03ec864804b0" dependencies = [ - "windows-targets 0.48.5", + "windows-result", + "windows-strings", + "windows-targets", ] [[package]] -name = "windows-sys" -version = "0.52.0" +name = "windows-result" +version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" +checksum = "1d1043d8214f791817bab27572aaa8af63732e11bf84aa21a45a78d6c317ae0e" dependencies = [ - "windows-targets 0.52.6", + "windows-targets", +] + +[[package]] +name = "windows-strings" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4cd9b125c486025df0eabcb585e62173c6c9eddcec5d117d3b6e8c30e2ee4d10" +dependencies = [ + "windows-result", + "windows-targets", ] [[package]] name = "windows-sys" -version = "0.59.0" +version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1e38bc4d79ed67fd075bcc251a1c39b32a1776bbe92e5bef1f0bf1f8c531853b" +checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" dependencies = [ - "windows-targets 0.52.6", + "windows-targets", ] [[package]] -name = "windows-targets" -version = "0.48.5" +name = "windows-sys" +version = "0.59.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" +checksum = "1e38bc4d79ed67fd075bcc251a1c39b32a1776bbe92e5bef1f0bf1f8c531853b" dependencies = [ - "windows_aarch64_gnullvm 0.48.5", - "windows_aarch64_msvc 0.48.5", - "windows_i686_gnu 0.48.5", - "windows_i686_msvc 0.48.5", - "windows_x86_64_gnu 0.48.5", - "windows_x86_64_gnullvm 0.48.5", - "windows_x86_64_msvc 0.48.5", + "windows-targets", ] [[package]] @@ -1638,46 +1540,28 @@ version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973" dependencies = [ - "windows_aarch64_gnullvm 0.52.6", - "windows_aarch64_msvc 0.52.6", - "windows_i686_gnu 0.52.6", + "windows_aarch64_gnullvm", + "windows_aarch64_msvc", + "windows_i686_gnu", "windows_i686_gnullvm", - "windows_i686_msvc 0.52.6", - "windows_x86_64_gnu 0.52.6", - "windows_x86_64_gnullvm 0.52.6", - "windows_x86_64_msvc 0.52.6", + "windows_i686_msvc", + "windows_x86_64_gnu", + "windows_x86_64_gnullvm", + "windows_x86_64_msvc", ] -[[package]] -name = "windows_aarch64_gnullvm" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" - [[package]] name = "windows_aarch64_gnullvm" version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3" -[[package]] -name = "windows_aarch64_msvc" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" - [[package]] name = "windows_aarch64_msvc" version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469" -[[package]] -name = "windows_i686_gnu" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" - [[package]] name = "windows_i686_gnu" version = "0.52.6" @@ -1690,36 +1574,18 @@ version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66" -[[package]] -name = "windows_i686_msvc" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" - [[package]] name = "windows_i686_msvc" version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66" -[[package]] -name = "windows_x86_64_gnu" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" - [[package]] name = "windows_x86_64_gnu" version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78" -[[package]] -name = "windows_x86_64_gnullvm" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" - [[package]] name = "windows_x86_64_gnullvm" version = "0.52.6" @@ -1728,26 +1594,37 @@ checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d" [[package]] name = "windows_x86_64_msvc" -version = "0.48.5" +version = "0.52.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" +checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec" [[package]] -name = "windows_x86_64_msvc" -version = "0.52.6" +name = "zerocopy" +version = "0.7.35" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec" +checksum = "1b9b4fd18abc82b8136838da5d50bae7bdea537c574d8dc1a34ed098d6c166f0" +dependencies = [ + "byteorder", + "zerocopy-derive", +] [[package]] -name = "winreg" -version = "0.50.0" +name = "zerocopy-derive" +version = "0.7.35" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "524e57b2c537c0f9b1e69f1965311ec12182b4122e45035b1508cd24d2adadb1" +checksum = "fa4f8080344d4671fb4e831a13ad1e68092748387dfc4f55e356242fae12ce3e" dependencies = [ - "cfg-if", - "windows-sys 0.48.0", + "proc-macro2", + "quote", + "syn 2.0.79", ] +[[package]] +name = "zeroize" +version = "1.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ced3678a2879b30306d323f4542626697a464a97c0a07c9aebf7ebca65cd4dde" + [[package]] name = "zip" version = "0.6.6" diff --git a/Cargo.toml b/Cargo.toml index 27cf382..9bda8fd 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -19,4 +19,5 @@ crate-type = ["cdylib"] pyo3 = { version = "0.22", features = ["abi3-py37"] } getopts = "0.2" chrono = "0.4" -gtfs-structures = "0.41" +gtfs-structures = { version = "0.41", default-features = false } +reqwest = { version = "0.12", default-features = false, features = ["blocking", "rustls-tls"] } diff --git a/README.md b/README.md index 550409d..1c14ac8 100644 --- a/README.md +++ b/README.md @@ -11,6 +11,8 @@ See the [changelog](https://github.com/gerardcl/renfe-cli/blob/master/CHANGELOG. **NOTE** since I am more often using Rodalies trains I have created [rodalies-cli](https://github.com/gerardcl/rodalies-cli). I hope you like it too! + **DISCLAIMER**: Renfe's GTFS dataset might not be in sync with autonomic train schedules (e.g. Rodalies de la Generalitat de Catalunya), hence Renfe Cercanias train types (e.g.: REGIONAL or MD type) might not be accurate. For that, please use autonomic data/apps (.e.g: [rodalies-cli](https://github.com/gerardcl/rodalies-cli)). + ## Installation Install Python CLI package [renfe-cli](https://pypi.org/project/renfe-cli/) @@ -21,18 +23,7 @@ pip install renfe-cli --upgrade ## Usage (CLI) -This CLI behaves as a person/bot going through the official renfe.com search site, using headless chrome browser. -If the headless chrome browser is not found it will be downloaded. - -The navigation through the site happens in the following steps: - -1. Writes down and selects origin station -2. Writes down and selects destination station -3. Writes down and selects the day to search for -4. Writes down and selects the month to search for -5. Writes down and selects the year to search for -6. Clicks on search button -7. Parses the HTML data, optionally sorts the connections and prints the timetable +The CLI uses the official and latest Renfe's GTFS dataset, from [Horarios de alta velocidad, larga distancia y media distancia](https://data.renfe.com/dataset/horarios-de-alta-velocidad-larga-distancia-y-media-distancia). ```bash $ renfe-cli -h @@ -41,10 +32,9 @@ Usage: renfe-cli [options] Options: -f ORIGIN Set From origin station -t DESTINATION Set To destination station - -d, --day DAY Set Day to search timetable for (default: today) - -m, --month MONTH Set Month to search timetable for (default: today's month) - -y, --year YEAR Set Year to search timetable for (default: today's year) - -w, --wait SECONDS Set Wait time in seconds for Renfe search result page (default: 2) + -d, --day DAY Set the Day (default: today's day) + -m, --month MONTH Set the Month (default: today's month) + -y, --year YEAR Set the Year (default: today's year) -s, --sort Option to sort the timetable by Duration -h, --help Print this help menu ``` @@ -54,83 +44,29 @@ Options: Let's show an example of minimal inputs (origin and destination stations) with specific date: ```bash -$ renfe-cli -f Barc -t Mad -d 27 -Loading stations from Renfe web -Provided input 'Barc' station matches with 'Barcelona (ALL) '...continue -Provided input 'Mad' station matches with 'Madrid (ALL) '...continue -Today is: 2023-11-26 -Searching timetable for date: 2023-11-27 -loading headless chrome browser -navigating to renfe timetable search page -waiting for search page -adding origin station -adding destination station -adding day -adding month -adding year -searching timetable -got timetable page -loading timetable +$ renfe-cli -f girona -t "puerta de atocha" -d 30 +Loading GTFS data from Renfe web +Provided input 'girona' does a match with 'Estación de tren Girona' +Provided input 'puerta de atocha' does a match with 'Estación de tren Madrid-Puerta de Atocha' +Today is: 2024-9-29 +Searching timetable for date: 2024-9-30 +Origin station: Estación de tren Girona +Destination station: Estación de tren Madrid-Puerta de Atocha + =========================TIMETABLE========================= -Train | Departure | Arrival | Duration ------------------------------------------------------------ -AVE | 05.50 | 09.10 | 3 h. 20 min. ------------------------------------------------------------ -AVE | 06.20 | 08.50 | 2 h. 30 min. ------------------------------------------------------------ -AVLO | 06.35 | 09.20 | 2 h. 45 min. ------------------------------------------------------------ -AVE | 07.00 | 09.30 | 2 h. 30 min. ------------------------------------------------------------ -AVE | 07.40 | 10.10 | 2 h. 30 min. ------------------------------------------------------------ -LD-AVE | 07.45 | 15.35 | 7 h. 50 min. ------------------------------------------------------------ -AVE | 08.00 | 11.12 | 3 h. 12 min. ------------------------------------------------------------ -AVE | 08.25 | 10.55 | 2 h. 30 min. ------------------------------------------------------------ -REG.EXP. | 08.43 | 18.09 | 9 h. 26 min. ------------------------------------------------------------ -AVE | 09.00 | 11.45 | 2 h. 45 min. ------------------------------------------------------------ -AVLO | 10.00 | 13.17 | 3 h. 17 min. ------------------------------------------------------------ -AVE | 11.00 | 13.45 | 2 h. 45 min. ------------------------------------------------------------ -AVE | 12.00 | 15.12 | 3 h. 12 min. ------------------------------------------------------------ -AVE INT | 12.50 | 15.45 | 2 h. 55 min. + Train | Departure | Arrival | Duration ----------------------------------------------------------- -AVE | 13.25 | 15.54 | 2 h. 29 min. + AVLO | 05:46 | 09:20 | 03:34 ----------------------------------------------------------- -AVE | 14.00 | 17.12 | 3 h. 12 min. + AVE | 06:41 | 10:10 | 03:29 ----------------------------------------------------------- -AVLO | 15.00 | 17.45 | 2 h. 45 min. + AVE | 08:11 | 11:45 | 03:34 ----------------------------------------------------------- -AVE | 15.25 | 17.55 | 2 h. 30 min. + AVE INT | 11:59 | 15:45 | 03:46 ----------------------------------------------------------- -AVE | 16.00 | 19.12 | 3 h. 12 min. + AVE | 15:11 | 19:12 | 04:01 ----------------------------------------------------------- -AVE | 16.25 | 18.55 | 2 h. 30 min. ------------------------------------------------------------ -AVE | 17.00 | 19.45 | 2 h. 45 min. ------------------------------------------------------------ -AVE | 17.25 | 19.55 | 2 h. 30 min. ------------------------------------------------------------ -AVE | 18.00 | 21.12 | 3 h. 12 min. ------------------------------------------------------------ -AVE | 18.25 | 20.55 | 2 h. 30 min. ------------------------------------------------------------ -AVE | 18.40 | 21.45 | 3 h. 5 min. ------------------------------------------------------------ -AVE | 19.25 | 21.55 | 2 h. 30 min. ------------------------------------------------------------ -AVE | 20.00 | 23.12 | 3 h. 12 min. ------------------------------------------------------------ -AVLO | 21.00 | 23.45 | 2 h. 45 min. ------------------------------------------------------------ -AVE | 21.25 | 23.55 | 2 h. 30 min. + AVE | 17:51 | 21:45 | 03:54 =========================================================== ``` @@ -140,25 +76,49 @@ AVE | 21.25 | 23.55 | 2 h. 30 min. ```bash $ python -Python 3.8.18 (default, Aug 25 2023, 13:20:30) -[GCC 11.4.0] on linux +Python 3.12.6 (main, Sep 8 2024, 13:18:56) [GCC 14.2.1 20240805] on linux Type "help", "copyright", "credits" or "license" for more information. >>> import renfe_cli >>> renfe = renfe_cli. -renfe_cli.Renfe( renfe_cli.main( renfe_cli.print_timetable( renfe_cli.renfe_cli renfe_cli.search_timetable( +renfe_cli.Renfe() renfe_cli.Schedule( renfe_cli.Station( renfe_cli.main() renfe_cli.renfe_cli >>> renfe = renfe_cli.Renfe() -Loading stations from Renfe web ->>> renfe. -renfe.filter_station( renfe.stations_match( ->>> renfe.stations_match("Bar") -['Barcelona (ALL) ', 'Padrón-Barbanza'] +Loading GTFS data from Renfe web +>>> renfe.filter_station("madrid") +Traceback (most recent call last): + File "", line 1, in +ValueError: Provided input 'madrid' does match with '[Station { name: "Estación de tren Madrid-Puerta de Atocha", id: "60000" }, Station { name: "Estación de tren Madrid - Atocha Cercanias", id: "18000" }, Station { name: "Estación de tren Madrid-Principe Pio", id: "10000" }, Station { name: "Estación de tren Madrid-Ramon Y Cajal", id: "97201" }, Station { name: "Estación de tren Madrid-Nuevos Ministerios", id: "18002" }, Station { name: "Estación de tren Madrid-Chamartin", id: "17000" }, Station { name: "Estación de tren Madrid-Recoletos", id: "18001" }]' -> There must be ONLY one match +>>> renfe.filter_station("girona") +Provided input 'girona' does a match with 'Station { name: "Estación de tren Girona", id: "79300" }' + +>>> renfe.print_timetable() + +No schedules available...won't print timetable. +>>> renfe.set_train_schedules("79300", "60000", 30, 9, 2024, False) +>>> renfe.print_timetable() + +=========================TIMETABLE========================= + Train | Departure | Arrival | Duration +----------------------------------------------------------- + AVLO | 05:46 | 09:20 | 03:34 +----------------------------------------------------------- + AVE | 06:41 | 10:10 | 03:29 +----------------------------------------------------------- + AVE | 08:11 | 11:45 | 03:34 +----------------------------------------------------------- + AVE INT | 11:59 | 15:45 | 03:46 +----------------------------------------------------------- + AVE | 15:11 | 19:12 | 04:01 +----------------------------------------------------------- + AVE | 17:51 | 21:45 | 03:54 +=========================================================== +>>> ... ``` --- ## Contribute or Report with Issues -If Renfe's website is changed or you find any issue to be fixed or nice enhancements to have, please: [create an issue](https://github.com/gerardcl/renfe-cli/issues). +If Renfe's GTFS dataset is being kept not up to date or you find any issue to be fixed or nice enhancements to have, please: [create an issue](https://github.com/gerardcl/renfe-cli/issues). ### Development diff --git a/pyproject.toml b/pyproject.toml index 8896a73..46d9993 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -14,7 +14,7 @@ maintainers = [ description = "Get faster Renfe Spanish Trains timetables in your terminal." readme = "README.md" license = {file = "LICENSE"} -keywords = ["timetables", "trains", "renfe", "cli", "rust", "pyo3", "maturin"] +keywords = ["timetables", "schedules", "trains", "renfe", "cli", "rust", "python", "pyo3", "maturin"] classifiers = [ "Programming Language :: Rust", "Programming Language :: Python :: Implementation :: CPython", diff --git a/src/cli.rs b/src/cli.rs index 12a1b1f..f93fc1c 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -65,24 +65,14 @@ fn set_opts() -> Options { let mut opts = Options::new(); opts.optopt("f", "", "Set From origin station", "ORIGIN"); opts.optopt("t", "", "Set To destination station", "DESTINATION"); - opts.optopt( - "d", - "day", - "Set Day to search timetable for (default: today)", - "DAY", - ); + opts.optopt("d", "day", "Set the Day (default: today's day)", "DAY"); opts.optopt( "m", "month", - "Set Month to search timetable for (default: today's month)", + "Set the Month (default: today's month)", "MONTH", ); - opts.optopt( - "y", - "year", - "Set Year to search timetable for (default: today's year)", - "YEAR", - ); + opts.optopt("y", "year", "Set the Year (default: today's year)", "YEAR"); opts.optflag("s", "sort", "Option to sort the timetable by Duration"); opts.optflag("h", "help", "Print this help menu"); diff --git a/src/renfe.rs b/src/renfe.rs index 218b4bb..4e88ddd 100644 --- a/src/renfe.rs +++ b/src/renfe.rs @@ -1,3 +1,5 @@ +use std::io::Read; + use chrono::{Datelike, NaiveDate, NaiveTime, TimeDelta, Timelike}; use gtfs_structures::Gtfs; use pyo3::{exceptions::PyValueError, pyclass, pymethods, PyResult}; @@ -32,11 +34,16 @@ impl Renfe { #[new] pub fn new() -> PyResult { println!("Loading GTFS data from Renfe web"); - let gtfs_zip_path = "./google_transit.zip"; // path to the GTFS zip file - let gtfs = Gtfs::from_path(gtfs_zip_path) // from_url("https://ssl.renfe.com/gtransit/Fichero_AV_LD/google_transit.zip") - .expect("Error parsing GTFS zip"); + let mut res = reqwest::blocking::get( + "https://ssl.renfe.com/gtransit/Fichero_AV_LD/google_transit.zip", + ) + .expect("Error downloading GTFS zip file"); + let mut body = Vec::new(); + res.read_to_end(&mut body)?; + let cursor = std::io::Cursor::new(body); + let gtfs = Gtfs::from_reader(cursor).expect("Error parsing GTFS zip"); // gtfs.print_stats(); Ok(Renfe { @@ -82,8 +89,8 @@ impl Renfe { match self.stations_match(station.clone()) { Ok(v) if v.len() == 1 => { println!( - "Provided input '{}' does a match with '{}'", - station, v[0].name + "Provided input '{}' does a match with '{:?}'", + station, v[0] ); Ok(v[0].clone()) }