aboutsummaryrefslogtreecommitdiffstats
path: root/lib/warden-core/build.rs
diff options
context:
space:
mode:
authorrtkay123 <dev@kanjala.com>2025-08-08 08:01:13 +0200
committerrtkay123 <dev@kanjala.com>2025-08-08 08:01:13 +0200
commitfd81550cd9b49c138f384dd7c097729d66f1e0b0 (patch)
tree8566e9647715c9a5af09a3d7a6bace77f0c86f71 /lib/warden-core/build.rs
parent68a4edcdf7af5e8c5eef04b9b65683229644f29a (diff)
downloadwarden-fd81550cd9b49c138f384dd7c097729d66f1e0b0.tar.bz2
warden-fd81550cd9b49c138f384dd7c097729d66f1e0b0.zip
build(proto): compile time iso20022 types
Diffstat (limited to 'lib/warden-core/build.rs')
-rw-r--r--lib/warden-core/build.rs70
1 files changed, 65 insertions, 5 deletions
diff --git a/lib/warden-core/build.rs b/lib/warden-core/build.rs
index 024e9bb..be4f8f2 100644
--- a/lib/warden-core/build.rs
+++ b/lib/warden-core/build.rs
@@ -1,11 +1,71 @@
+#[cfg(feature = "iso20022")]
+enum Entity {
+ #[cfg(feature = "iso20022")]
+ ISO2022,
+}
+
+#[cfg(feature = "iso20022")]
+impl Entity {
+ fn protos(&self) -> Vec<&'static str> {
+ let mut res: Vec<&'static str> = vec![];
+
+ #[cfg(feature = "iso20022")]
+ fn iso20022_protos() -> Vec<&'static str> {
+ vec![
+ "proto/iso20022/pacs_008_001_12.proto",
+ "proto/iso20022/pacs_002_001_12.proto",
+ ]
+ }
+
+ match self {
+ #[cfg(feature = "iso20022")]
+ Entity::ISO2022 => {
+ res.extend(iso20022_protos());
+ }
+ }
+ res
+ }
+}
+
fn main() -> Result<(), Box<dyn std::error::Error>> {
- tonic_prost_build::configure()
- .build_server(false)
- //.out_dir("src/google") // you can change the generated code's location
+ println!("cargo:rerun-if-changed=../../proto");
+
+ #[cfg(feature = "iso20022")]
+ build_proto("iso20022", Entity::ISO2022)?;
+
+ Ok(())
+}
+
+#[cfg(feature = "iso20022")]
+fn build_proto(package: &str, entity: Entity) -> Result<(), Box<dyn std::error::Error>> {
+ let out_dir = std::path::PathBuf::from(std::env::var("OUT_DIR").unwrap());
+
+ let config = tonic_prost_build::configure()
+ .server_mod_attribute(
+ package,
+ format!("#[cfg(feature = \"rpc-server-{package}\")] #[cfg_attr(docsrs, doc(cfg(feature = \"rpc-server-{package}\")))]"),
+ )
+ .client_mod_attribute(
+ package,
+ format!("#[cfg(feature = \"rpc-client-{package}\")] #[cfg_attr(docsrs, doc(cfg(feature = \"rpc-client-{package}\")))]"),
+ );
+
+ config
+ .file_descriptor_set_path(out_dir.join(format!("{package}_descriptor.bin")))
+ .server_mod_attribute(
+ package,
+ format!("#[cfg(feature = \"rpc-server-{package}\")] #[cfg_attr(docsrs, doc(cfg(feature = \"rpc-server-{package}\")))]"),
+ )
+ .client_mod_attribute(
+ package,
+ format!("#[cfg(feature = \"rpc-client-{package}\")] #[cfg_attr(docsrs, doc(cfg(feature = \"rpc-client-{package}\")))]"),
+ )
.protoc_arg("-I=../..")
+ .compile_well_known_types(true)
.compile_protos(
- &["proto/googleapis/google/pubsub/v1/pubsub.proto"],
- &["../../proto/googleapis"], // specify the root location to search proto dependencies
+ &entity.protos(),
+ &["../../proto/googleapis", "../../proto"], // specify the root location to search proto dependencies
)?;
+
Ok(())
}