From 26ed8ff731829b2ad4eda05ea18874e39756fba7 Mon Sep 17 00:00:00 2001 From: Quentin Pradet Date: Thu, 28 Nov 2024 15:29:36 +0400 Subject: [PATCH 1/5] Allow reading OpenAPI files in YAML format --- compiler-rs/Cargo.lock | 568 ++++++++++++++++++ compiler-rs/Cargo.toml | 1 + .../openapi_to_clients_schema/Cargo.toml | 1 + .../fixtures/enterprise-search.json | 0 .../openapi_to_clients_schema/src/main.rs | 39 +- 5 files changed, 594 insertions(+), 15 deletions(-) delete mode 100644 compiler-rs/openapi_to_clients_schema/fixtures/enterprise-search.json diff --git a/compiler-rs/Cargo.lock b/compiler-rs/Cargo.lock index ce6fcb2943..25c46faaff 100644 --- a/compiler-rs/Cargo.lock +++ b/compiler-rs/Cargo.lock @@ -2,6 +2,30 @@ # It is not intended for manual editing. version = 3 +[[package]] +name = "addr2line" +version = "0.24.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dfbe277e56a376000877090da837660b4427aad530e3028d44e0bffe4f89a1c1" +dependencies = [ + "gimli", +] + +[[package]] +name = "adler2" +version = "2.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "512761e0bb2578dd7380c6baaa0f4ce03e84f95e960231d1dec8bf4d7d6e2627" + +[[package]] +name = "aho-corasick" +version = "1.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8e60d3430d3a69478ad0993f19238d2df97c507009a52b3c10addcd7f6bcb916" +dependencies = [ + "memchr", +] + [[package]] name = "anstream" version = "0.6.15" @@ -66,12 +90,51 @@ dependencies = [ "serde", ] +[[package]] +name = "autocfg" +version = "1.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ace50bade8e6234aa140d9a2f552bbee1db4d353f69b8217bc503490fc1a9f26" + +[[package]] +name = "backtrace" +version = "0.3.74" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8d82cb332cdfaed17ae235a638438ac4d4839913cc2af585c3c6746e8f8bee1a" +dependencies = [ + "addr2line", + "cfg-if", + "libc", + "miniz_oxide", + "object", + "rustc-demangle", + "windows-targets", +] + +[[package]] +name = "bitflags" +version = "2.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b048fb63fd8b5923fc5aa7b340d8e156aec7ec02f0c78fa8a6ddc2613f6f71de" + [[package]] name = "bumpalo" version = "3.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "79296716171880943b8470b5f8d03aa55eb2e645a4874bdbb28adb49162e012c" +[[package]] +name = "byteorder" +version = "1.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b" + +[[package]] +name = "bytes" +version = "1.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9ac0150caa2ae65ca5bd83f25c7de183dea78d4d366469f148435e2acfbad0da" + [[package]] name = "cc" version = "1.1.18" @@ -207,6 +270,15 @@ dependencies = [ "libm", ] +[[package]] +name = "deranged" +version = "0.3.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b42b6fa04a440b495c8b04d0e71b707c585f83cb9cb28cf8cd0d976c315e31b4" +dependencies = [ + "powerfmt", +] + [[package]] name = "derive_more" version = "1.0.0" @@ -238,12 +310,80 @@ dependencies = [ "syn", ] +[[package]] +name = "dtt" +version = "0.0.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d6b2dd9ee2d76888dc4c17d6da74629fa11b3cb1e8094fdc159b7f8ff259fc88" +dependencies = [ + "regex", + "serde", + "time", +] + +[[package]] +name = "dtt" +version = "0.0.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "21191da49ce48aa9200e9ac040032d680b3b71a158fbecaa1a99282821c3c251" +dependencies = [ + "regex", + "serde", + "time", +] + +[[package]] +name = "env_filter" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4f2c92ceda6ceec50f43169f9ee8424fe2db276791afde7b2cd8bc084cb376ab" +dependencies = [ + "log", + "regex", +] + +[[package]] +name = "env_logger" +version = "0.11.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e13fa619b91fb2381732789fc5de83b45675e882f66623b7d8cb4f643017018d" +dependencies = [ + "anstream", + "anstyle", + "env_filter", + "humantime", + "log", +] + [[package]] name = "equivalent" version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" +[[package]] +name = "figlet-rs" +version = "0.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4742a071cd9694fc86f9fa1a08fa3e53d40cc899d7ee532295da2d085639fbc5" + +[[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.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "07e28edb80900c19c28f1072f2e8aeca7fa06b23cd4169cefe1af5aa3260783f" + [[package]] name = "hashbrown" version = "0.14.5" @@ -256,6 +396,40 @@ 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 = "d231dfb89cfffdbc30e7fc41579ed6066ad03abda9e567ccafae602b97ec5024" + +[[package]] +name = "hostname" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c731c3e10504cc8ed35cfe2f1db4c9274c3d35fa486e3b31df46f068ef3e867" +dependencies = [ + "libc", + "match_cfg", + "winapi", +] + +[[package]] +name = "hostname" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f9c7c7c8ac16c798734b8a24560c1362120597c40d5e1459f09498f8f6c8f2ba" +dependencies = [ + "cfg-if", + "libc", + "windows", +] + +[[package]] +name = "humantime" +version = "2.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9a3a5bfb195931eeb336b2a7b4d761daec841b97f947d34394601737a7bba5e4" + [[package]] name = "icu_collections" version = "1.5.0" @@ -368,24 +542,52 @@ version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bbd2bcb4c963f2ddae06a2efc7e9f3591312473c50c6685e1f298068316e66fe" +[[package]] +name = "libc" +version = "0.2.166" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c2ccc108bbc0b1331bd061864e7cd823c0cab660bbe6970e66e2c0614decde36" + [[package]] name = "libm" version = "0.2.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4ec2a862134d2a7d32d7983ddcdd1c4923530833c9f2ea1a44fc5fa473989058" +[[package]] +name = "libyml" +version = "0.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1303532258de1fbe263b4daaaba0e17e3d502b8de57b7845928b92398fb4afd1" + [[package]] name = "litemap" version = "0.7.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "643cb0b8d4fcc284004d5fd0d67ccf61dfffadb7f75e1e71bc420f4688a3a704" +[[package]] +name = "lock_api" +version = "0.4.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "07af8b9cdd281b7915f413fa73f29ebd5d55d0d3f0155584dade1ff18cea1b17" +dependencies = [ + "autocfg", + "scopeguard", +] + [[package]] name = "log" version = "0.4.22" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a7a70ba024b9dc04c27ea2f0c0548feb474ec5c54bba33a7f72f873a39d07b24" +[[package]] +name = "match_cfg" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ffbee8634e0d45d258acb448e7eaab3fce7a0a467395d4d9f228e3c1f01fb2e4" + [[package]] name = "memchr" version = "2.7.4" @@ -402,6 +604,27 @@ dependencies = [ "walkdir", ] +[[package]] +name = "miniz_oxide" +version = "0.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e2d80299ef12ff69b16a84bb182e3b9df68b5a91574d3d4fa6e41b65deec4df1" +dependencies = [ + "adler2", +] + +[[package]] +name = "mio" +version = "1.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "80e04d1dcff3aae0704555fe5fee3bcfaf3d1fdf8a7e521d5b9d2b42acb52cec" +dependencies = [ + "hermit-abi", + "libc", + "wasi", + "windows-sys 0.52.0", +] + [[package]] name = "nu-ansi-term" version = "0.46.0" @@ -412,6 +635,21 @@ dependencies = [ "winapi", ] +[[package]] +name = "num-conv" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "51d515d32fb182ee37cda2ccdcb92950d6a3c2893aa280e540671c2cd0f3b1d9" + +[[package]] +name = "object" +version = "0.36.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "aedf0a2d09c573ed1d8d85b30c119153926a2b36dce0ab28322c09a117a4683e" +dependencies = [ + "memchr", +] + [[package]] name = "once_cell" version = "1.19.0" @@ -429,6 +667,7 @@ dependencies = [ "openapiv3", "serde_ignored", "serde_json", + "serde_yml", "tracing", "tracing-subscriber", ] @@ -450,12 +689,50 @@ version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b15813163c1d831bf4a13c3610c05c0d03b39feb07f7e09fa234dac9b15aaf39" +[[package]] +name = "parking_lot" +version = "0.12.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f1bf18183cf54e8d6059647fc3063646a1801cf30896933ec2311622cc4b9a27" +dependencies = [ + "lock_api", + "parking_lot_core", +] + +[[package]] +name = "parking_lot_core" +version = "0.9.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e401f977ab385c9e4e3ab30627d6f26d00e2c73eef317493c4ec6d468726cf8" +dependencies = [ + "cfg-if", + "libc", + "redox_syscall", + "smallvec", + "windows-targets", +] + [[package]] name = "pin-project-lite" version = "0.2.14" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bda66fc9667c18cb2758a2ac84d1167245054bcf85d5d1aaa6923f45801bdd02" +[[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.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "77957b295656769bb8ad2b6a6b09d897d94f05c41b069aede1fcdaa675eaea04" +dependencies = [ + "zerocopy", +] + [[package]] name = "proc-macro2" version = "1.0.86" @@ -474,6 +751,108 @@ 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.5.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9b6dfecf2c74bce2466cabf93f6664d6998a69eb21e39f4207930065b27b771f" +dependencies = [ + "bitflags", +] + +[[package]] +name = "regex" +version = "1.11.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b544ef1b4eac5dc2db33ea63606ae9ffcfac26c1416a2806ae0bf5f56b201191" +dependencies = [ + "aho-corasick", + "memchr", + "regex-automata", + "regex-syntax", +] + +[[package]] +name = "regex-automata" +version = "0.4.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "809e8dc61f6de73b46c85f4c96486310fe304c434cfa43669d7b40f711150908" +dependencies = [ + "aho-corasick", + "memchr", + "regex-syntax", +] + +[[package]] +name = "regex-syntax" +version = "0.8.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2b15c43186be67a4fd63bee50d0303afffcef381492ebe2c5d87f324e1b8815c" + +[[package]] +name = "rlg" +version = "0.0.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9e02c717e23f67b23032a4acb01cf63534d6259938d592e6d2451c02f09fc368" +dependencies = [ + "dtt 0.0.5", + "hostname 0.3.1", + "serde_json", + "tokio", + "vrd 0.0.5", +] + +[[package]] +name = "rlg" +version = "0.0.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fa9550dfcf50ac8601b165168e8825d66e45db390f7740a3d45c640946c4a971" +dependencies = [ + "dtt 0.0.6", + "hostname 0.4.0", + "serde", + "serde_json", + "tokio", + "version_check", + "vrd 0.0.7", +] + +[[package]] +name = "rustc-demangle" +version = "0.1.24" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "719b953e2095829ee67db738b3bfa9fa368c94900df327b3f07fe6e794d2fe1f" + [[package]] name = "ryu" version = "1.0.18" @@ -495,6 +874,12 @@ version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e1cf6437eb19a8f4a6cc0f7dca544973b0b78843adbfeb3683d1a94a0024a294" +[[package]] +name = "scopeguard" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" + [[package]] name = "serde" version = "1.0.210" @@ -504,6 +889,15 @@ dependencies = [ "serde_derive", ] +[[package]] +name = "serde-big-array" +version = "0.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "11fc7cc2c76d73e0f27ee52abbd64eec84d46f370c88371120433196934e4b7f" +dependencies = [ + "serde", +] + [[package]] name = "serde_derive" version = "1.0.210" @@ -546,6 +940,25 @@ dependencies = [ "serde", ] +[[package]] +name = "serde_yml" +version = "0.0.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f53d8fd7970792e971b5f9ae55d8175bb47364137cdee38e8fbd915400931f89" +dependencies = [ + "dtt 0.0.6", + "env_logger", + "figlet-rs", + "indexmap", + "itoa", + "libyml", + "log", + "rlg 0.0.4", + "ryu", + "serde", + "uuid", +] + [[package]] name = "sharded-slab" version = "0.1.7" @@ -561,12 +974,31 @@ version = "1.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0fda2ff0d084019ba4d7c6f371c95d8fd75ce3524c3cb8fb653a3023f6323e64" +[[package]] +name = "signal-hook-registry" +version = "1.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a9e9e0b4211b72e7b8b6e85c807d36c212bdb33ea8587f7569562a84df5465b1" +dependencies = [ + "libc", +] + [[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" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ce305eb0b4296696835b71df73eb912e0f1ffd2556a501fcede6e0c50349191c" +dependencies = [ + "libc", + "windows-sys 0.52.0", +] + [[package]] name = "stable_deref_trait" version = "1.2.0" @@ -617,6 +1049,25 @@ dependencies = [ "once_cell", ] +[[package]] +name = "time" +version = "0.3.36" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5dfd88e563464686c916c7e46e623e520ddc6d79fa6641390f2e3fa86e83e885" +dependencies = [ + "deranged", + "num-conv", + "powerfmt", + "serde", + "time-core", +] + +[[package]] +name = "time-core" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ef927ca75afb808a4d64dd374f00a2adf8d0fcff8e7b184af886c3c87ec4a3f3" + [[package]] name = "tinystr" version = "0.7.6" @@ -626,6 +1077,35 @@ dependencies = [ "displaydoc", ] +[[package]] +name = "tokio" +version = "1.41.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "22cfb5bee7a6a52939ca9224d6ac897bb669134078daa8735560897f69de4d33" +dependencies = [ + "backtrace", + "bytes", + "libc", + "mio", + "parking_lot", + "pin-project-lite", + "signal-hook-registry", + "socket2", + "tokio-macros", + "windows-sys 0.52.0", +] + +[[package]] +name = "tokio-macros" +version = "2.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "693d596312e88961bc67d7f1f97af8a70227d9f90c31bba5806eec004978d752" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + [[package]] name = "tracing" version = "0.1.40" @@ -707,12 +1187,54 @@ version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "06abde3611657adf66d383f00b093d7faecc7fa57071cce2578660c9f1010821" +[[package]] +name = "uuid" +version = "1.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f8c5f0a0af699448548ad1a2fbf920fb4bee257eae39953ba95cb84891a0446a" +dependencies = [ + "getrandom", +] + [[package]] name = "valuable" version = "0.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "830b7e5d4d90034032940e4ace0d9a9a057e7a45cd94e6c007832e39edb82f6d" +[[package]] +name = "version_check" +version = "0.9.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b928f33d975fc6ad9f86c8f283853ad26bdd5b10b7f1542aa2fa15e2289105a" + +[[package]] +name = "vrd" +version = "0.0.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ee1067b8d17481f5be71b59d11c329e955ffe36348907e0a4a41b619682bb4af" +dependencies = [ + "rand", + "serde", +] + +[[package]] +name = "vrd" +version = "0.0.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "08fd4c00822f48600521b6dfa7ed8103e9f38c720e198ff4db0400c925414c80" +dependencies = [ + "bitflags", + "dtt 0.0.5", + "rand", + "rlg 0.0.3", + "serde", + "serde-big-array", + "serde_json", + "tokio", + "uuid", +] + [[package]] name = "walkdir" version = "2.5.0" @@ -723,6 +1245,12 @@ dependencies = [ "winapi-util", ] +[[package]] +name = "wasi" +version = "0.11.0+wasi-snapshot-preview1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" + [[package]] name = "wasm-bindgen" version = "0.2.93" @@ -857,6 +1385,25 @@ version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" +[[package]] +name = "windows" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e48a53791691ab099e5e2ad123536d0fff50652600abaf43bbf952894110d0be" +dependencies = [ + "windows-core", + "windows-targets", +] + +[[package]] +name = "windows-core" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" +dependencies = [ + "windows-targets", +] + [[package]] name = "windows-sys" version = "0.52.0" @@ -969,6 +1516,27 @@ dependencies = [ "synstructure", ] +[[package]] +name = "zerocopy" +version = "0.7.35" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1b9b4fd18abc82b8136838da5d50bae7bdea537c574d8dc1a34ed098d6c166f0" +dependencies = [ + "byteorder", + "zerocopy-derive", +] + +[[package]] +name = "zerocopy-derive" +version = "0.7.35" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fa4f8080344d4671fb4e831a13ad1e68092748387dfc4f55e356242fae12ce3e" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + [[package]] name = "zerofrom" version = "0.1.4" diff --git a/compiler-rs/Cargo.toml b/compiler-rs/Cargo.toml index 8cf079dcb1..2145b82873 100644 --- a/compiler-rs/Cargo.toml +++ b/compiler-rs/Cargo.toml @@ -25,6 +25,7 @@ serde = "1" serde_ignored = "0.1" serde_json = "1" serde_path_to_error = "0.1" +serde_yml = "0.0.6" testresult = "0.4" tracing = "0.1" tracing-subscriber = "0.3" diff --git a/compiler-rs/openapi_to_clients_schema/Cargo.toml b/compiler-rs/openapi_to_clients_schema/Cargo.toml index 77cbaa49c0..4ecbaa258f 100644 --- a/compiler-rs/openapi_to_clients_schema/Cargo.toml +++ b/compiler-rs/openapi_to_clients_schema/Cargo.toml @@ -11,6 +11,7 @@ clients_schema = {path="../clients_schema"} serde_json = { workspace = true } serde_ignored = { workspace = true } +serde_yml = { workspace = true } openapiv3 = { workspace = true } anyhow = { workspace = true } indexmap = { workspace = true } diff --git a/compiler-rs/openapi_to_clients_schema/fixtures/enterprise-search.json b/compiler-rs/openapi_to_clients_schema/fixtures/enterprise-search.json deleted file mode 100644 index e69de29bb2..0000000000 diff --git a/compiler-rs/openapi_to_clients_schema/src/main.rs b/compiler-rs/openapi_to_clients_schema/src/main.rs index 0405ac91ad..68a08a3e6b 100644 --- a/compiler-rs/openapi_to_clients_schema/src/main.rs +++ b/compiler-rs/openapi_to_clients_schema/src/main.rs @@ -15,8 +15,8 @@ // specific language governing permissions and limitations // under the License. -use std::collections::BTreeSet; use std::path::PathBuf; +use std::{collections::BTreeSet, path::Path}; use openapi_to_clients_schema::openapi::OpenAPI; use tracing::{info, Level}; @@ -26,31 +26,40 @@ fn main() -> anyhow::Result<()> { let subscriber = FmtSubscriber::builder().with_max_level(Level::TRACE).finish(); tracing::subscriber::set_global_default(subscriber)?; - // let file = "../../ent-search/swagger/v1/enterprise-search.json"; - // let file = "../../ent-search/swagger/v1/workplace-search.json"; - let file = "./openapi_to_clients_schema/fixtures/workplace-search.json"; + // let path = "../../../ent-search/swagger/enterprise-search.json"; + let path = "./fixtures/kibana.serverless.yaml"; - let src = PathBuf::from(file); - let dest = src.with_extension("schema.json"); - - info!("Loading OpenAPI from {file}"); - - let file = std::fs::File::open(file)?; - - let json_deser = &mut serde_json::Deserializer::from_reader(file); + info!("Loading OpenAPI from {path}"); + let file = std::fs::File::open(path)?; // Track unused fields, to find any additional stuff the OpenAPI model would miss let mut unused = BTreeSet::new(); - let open_api: openapiv3::OpenAPI = serde_ignored::deserialize(json_deser, |path| { - unused.insert(path.to_string()); - })?; + let open_api = match Path::new(path).extension() { + Some(ext) if ext == "json" => { + let deser = &mut serde_json::Deserializer::from_reader(file); + serde_ignored::deserialize(deser, |path| { + unused.insert(path.to_string()); + }) + .map_err(|err| From::from(err)) + } + Some(ext) if ext == "yml" || ext == "yaml" => { + let deser = serde_yml::Deserializer::from_reader(file); + serde_ignored::deserialize(deser, |path| { + unused.insert(path.to_string()); + }) + .map_err(|err| From::from(err)) + } + _ => Err(anyhow::anyhow!(format!("Unsupported file extension {:?}", path))), + }?; if !unused.is_empty() { println!("Unused fields in the OpenAPI schema: {:?}", unused); } let sch_json = openapi_to_clients_schema::generate(&OpenAPI(open_api))?; + + let dest = PathBuf::from(path).with_extension("schema.json"); let output = std::fs::File::create(dest)?; serde_json::to_writer_pretty(output, &sch_json)?; From 3c71575ce85f99a09d8639c624f8993470c39bc8 Mon Sep 17 00:00:00 2001 From: Quentin Pradet Date: Thu, 28 Nov 2024 15:34:47 +0400 Subject: [PATCH 2/5] Point to existing file by default --- compiler-rs/openapi_to_clients_schema/src/main.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/compiler-rs/openapi_to_clients_schema/src/main.rs b/compiler-rs/openapi_to_clients_schema/src/main.rs index 68a08a3e6b..7f971373d1 100644 --- a/compiler-rs/openapi_to_clients_schema/src/main.rs +++ b/compiler-rs/openapi_to_clients_schema/src/main.rs @@ -26,8 +26,8 @@ fn main() -> anyhow::Result<()> { let subscriber = FmtSubscriber::builder().with_max_level(Level::TRACE).finish(); tracing::subscriber::set_global_default(subscriber)?; - // let path = "../../../ent-search/swagger/enterprise-search.json"; - let path = "./fixtures/kibana.serverless.yaml"; + let path = "../../../ent-search/swagger/enterprise-search.json"; + // let path = "./fixtures/kibana.serverless.yaml"; info!("Loading OpenAPI from {path}"); let file = std::fs::File::open(path)?; From 17ca650923eb24e31a620c5b1d86e00617fd9997 Mon Sep 17 00:00:00 2001 From: Quentin Pradet Date: Thu, 28 Nov 2024 17:22:04 +0400 Subject: [PATCH 3/5] Address review comments --- compiler-rs/openapi_to_clients_schema/src/main.rs | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/compiler-rs/openapi_to_clients_schema/src/main.rs b/compiler-rs/openapi_to_clients_schema/src/main.rs index 7f971373d1..cf325bf2eb 100644 --- a/compiler-rs/openapi_to_clients_schema/src/main.rs +++ b/compiler-rs/openapi_to_clients_schema/src/main.rs @@ -30,25 +30,25 @@ fn main() -> anyhow::Result<()> { // let path = "./fixtures/kibana.serverless.yaml"; info!("Loading OpenAPI from {path}"); - let file = std::fs::File::open(path)?; + let data = std::fs::read_to_string(path)?; // Track unused fields, to find any additional stuff the OpenAPI model would miss let mut unused = BTreeSet::new(); let open_api = match Path::new(path).extension() { Some(ext) if ext == "json" => { - let deser = &mut serde_json::Deserializer::from_reader(file); - serde_ignored::deserialize(deser, |path| { + let mut deser = serde_json::Deserializer::from_str(&data); + serde_ignored::deserialize(&mut deser, |path| { unused.insert(path.to_string()); }) - .map_err(|err| From::from(err)) + .map_err(From::from) } Some(ext) if ext == "yml" || ext == "yaml" => { - let deser = serde_yml::Deserializer::from_reader(file); + let deser = serde_yml::Deserializer::from_str(&data); serde_ignored::deserialize(deser, |path| { unused.insert(path.to_string()); }) - .map_err(|err| From::from(err)) + .map_err(From::from) } _ => Err(anyhow::anyhow!(format!("Unsupported file extension {:?}", path))), }?; From 8cf465a83449971b079b260da3968b3b5583439a Mon Sep 17 00:00:00 2001 From: Quentin Pradet Date: Thu, 28 Nov 2024 17:35:21 +0400 Subject: [PATCH 4/5] Acccept input file as parameter --- compiler-rs/openapi_to_clients_schema/src/main.rs | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/compiler-rs/openapi_to_clients_schema/src/main.rs b/compiler-rs/openapi_to_clients_schema/src/main.rs index cf325bf2eb..47582b27a0 100644 --- a/compiler-rs/openapi_to_clients_schema/src/main.rs +++ b/compiler-rs/openapi_to_clients_schema/src/main.rs @@ -15,6 +15,7 @@ // specific language governing permissions and limitations // under the License. +use std::env; use std::path::PathBuf; use std::{collections::BTreeSet, path::Path}; @@ -26,8 +27,12 @@ fn main() -> anyhow::Result<()> { let subscriber = FmtSubscriber::builder().with_max_level(Level::TRACE).finish(); tracing::subscriber::set_global_default(subscriber)?; - let path = "../../../ent-search/swagger/enterprise-search.json"; - // let path = "./fixtures/kibana.serverless.yaml"; + let args: Vec = env::args().collect(); + let path = match args.len() - 1 { + 0 => "../../../ent-search/swagger/enterprise-search.json", + 1 => &args[1], + _ => panic!("expected a single argument"), + }; info!("Loading OpenAPI from {path}"); let data = std::fs::read_to_string(path)?; From cb3a01780af4a61f5a39f5b4d15dbaf1ff24c467 Mon Sep 17 00:00:00 2001 From: Quentin Pradet Date: Thu, 28 Nov 2024 17:59:22 +0400 Subject: [PATCH 5/5] Return an error instead of panicking --- compiler-rs/openapi_to_clients_schema/src/main.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/compiler-rs/openapi_to_clients_schema/src/main.rs b/compiler-rs/openapi_to_clients_schema/src/main.rs index 47582b27a0..1f7c2be6d7 100644 --- a/compiler-rs/openapi_to_clients_schema/src/main.rs +++ b/compiler-rs/openapi_to_clients_schema/src/main.rs @@ -31,7 +31,7 @@ fn main() -> anyhow::Result<()> { let path = match args.len() - 1 { 0 => "../../../ent-search/swagger/enterprise-search.json", 1 => &args[1], - _ => panic!("expected a single argument"), + _ => return Err(anyhow::anyhow!("expected a single argument")), }; info!("Loading OpenAPI from {path}");