3 unstable releases

0.2.1 Dec 27, 2024
0.2.0 Dec 13, 2024
0.1.0 Dec 12, 2024

#683 in Development tools

Download history 258/week @ 2024-12-11 10/week @ 2024-12-18 157/week @ 2024-12-25 3/week @ 2025-01-01 10/week @ 2025-01-08

183 downloads per month

MIT license

18KB
348 lines

packer_rs

A simple Rust wrapper around HashiCorp Packer CLI. This lets you run Packer commands from your Rust code without dealing with raw command line stuff.

Basic Usage

First, make sure you have the Packer CLI installed and available in your project directory (as packer on Linux/Mac or packer.exe on Windows).

Add this to your Cargo.toml:

[dependencies]
packer_rs = "0.1"

Here's a quick example:

use packer_rs::{Packer, BuildOptionsBuilder};

fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Create a new Packer instance
    let packer = Packer::new()?;
    
    // Set up some build options
    let options = BuildOptionsBuilder::default()
        .debug(true)
        .vars(vec![("region", "us-west-2")])
        .build()?;
    
    // Build your template
    packer.build("template.pkr.hcl", &options)?;
    
    Ok(())
}

What You Can Do

The wrapper supports the main Packer commands:

  • build: Build images from a template
  • init: Set up a new template
  • validate: Check if a template is valid
  • inspect: Look at template details
  • fix: Fix old templates
  • console: Start Packer console
  • plugin: Manage Packer plugins

Build Options

When building templates, you can set various options using BuildOptionsBuilder:

let options = BuildOptionsBuilder::default()
    .debug(true)                // Enable debug mode
    .force(true)               // Force builds
    .parallel_builds(2)        // Run 2 builds at once
    .timestamp_ui(true)        // Show timestamps
    .vars(vec![                // Set variables
        ("region", "us-west-2"),
        ("instance_type", "t2.micro")
    ])
    .var_files(vec!["vars.json".into()])  // Load vars from files
    .build()?;

Working Directory

You can set a different working directory for commands:

let packer = Packer::new()?
    .with_working_dir("./my-templates");

Error Handling

The wrapper returns proper Rust errors that tell you what went wrong. Main error types:

  • NotFound: Can't find the Packer executable
  • ExecutionError: Command failed to run
  • ConfigError: Something wrong with the configuration
  • IoError: File system problems

Contributing

Feel free to open issues or send pull requests if you find bugs or want to add features.

License

MIT licensed. Do what you want with it.

Dependencies

~7.5MB
~133K SLoC