#docker-compose #compose #yaml #serialization #deserialize #strongly-typed #file

docker-compose-types

Deserialization and Serialization of docker-compose.yml files in a relatively strongly typed fashion

24 releases

0.7.2 Mar 1, 2024
0.7.0 Dec 12, 2023
0.6.1 Nov 13, 2023
0.5.2 Jul 31, 2023
0.1.5 Jul 5, 2021

#211 in Data structures

Download history 155/week @ 2023-12-07 295/week @ 2023-12-14 87/week @ 2023-12-21 55/week @ 2023-12-28 159/week @ 2024-01-04 197/week @ 2024-01-11 199/week @ 2024-01-18 324/week @ 2024-01-25 319/week @ 2024-02-01 186/week @ 2024-02-08 98/week @ 2024-02-15 381/week @ 2024-02-22 491/week @ 2024-02-29 364/week @ 2024-03-07 337/week @ 2024-03-14 126/week @ 2024-03-21

1,412 downloads per month
Used in 3 crates

MIT/Apache

34KB
816 lines

Docker Compose Types

crates.io

Contributions are very welcome, the idea behind this crate is to allow for safe serialization of docker-compose files with as little room for error as possible.

Example Usage

Parsing a docker-compose file

use docker_compose_types::Compose;

fn main() {
    let file_payload =
        std::fs::read_to_string("tests/fixtures/v3-full/docker-compose.yml").unwrap();
    let compose_content = match serde_yaml::from_str::<Compose>(&file_payload) {
        Ok(c) => c,
        Err(e) => panic!("Failed to parse docker-compose file: {}", e),
    };
    println!("Parsed docker-compose file: {:#?}", compose_content);
}

Creating a docker-compose file from the crate's types

use docker_compose_types::{Compose, Service, Services, SingleService};
use serde_yaml;

fn main() {
    let compose_content = Compose {
        version: Some("3.8".to_string()),
        services: {
            let mut services = indexmap::IndexMap::new();
            services.insert(
                "web".to_string(),
                Some(Service {
                    image: Some("nginx:latest".to_string()),
                    ..Default::default()
                }),
            );
            Some(Services(services))
        },
        ..Default::default()
    };

    let target_file = std::path::Path::new("docker-compose.yml");
    // serialize to string
    let serialized = match serde_yaml::to_string(&compose_content) {
        Ok(s) => s,
        Err(e) => panic!("Failed to serialize docker-compose file: {}", e),
    };
    // serialize to file
    std::fs::write(target_file, serialized).unwrap();
}

License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~2.4–3MB
~68K SLoC