Skip to content

davenicoll/platform-engineering-toolkit

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Platform Engineering Toolkit
Platform Engineering Toolkit

We are the Slalom Build Platform Engineering capability, and these are our container images with the tools we use for building, maintaining and securing infrastructure as code.

There are two different flavors, depending on your needs; standard and full. Standard contains most of the tools required for IaC projects, while Full contains additional languages and tools, such as Node, Go and Python.

Images are updated weekly (at least), and more frequently when tooling updates occur.

Getting started

To use an image in your pipeline, pull from one of these URLs:

ghcr.io/slalombuild/pe-toolkit-standard-alpine-amd64:latest
ghcr.io/slalombuild/pe-toolkit-standard-ubuntu-amd64:latest
ghcr.io/slalombuild/pe-toolkit-full-alpine-amd64:latest
ghcr.io/slalombuild/pe-toolkit-full-ubuntu-amd64:latest

(All images are listed here)

Or to use an image locally (assuming you already have docker setup), run:

docker pull ghcr.io/slalombuild/pe-toolkit-standard-ubuntu-amd64:latest

FAQ

What tools do the Standard and Full images contain?

Standard Full
terraform
atmos
curl
bash
jq
yq
figlet
unzip
zip
git
shellcheck
nano
tflint
tfsec
opa
everything in standard
hadolint
terraform-docs
node and npm
python and pip
go

I'd like the image(s) to include x, can I add it?

Sure, go ahead and submit a PR. Some considerations when adding a tool -

  • Should it be in Standard and/or Full?
  • Tools should be added to all versions of the base OS. I.e. if it's added to full-alpine-amd64, it should also be added to full-ubuntu-amd64.
  • If the tool significantly increases the image size, is it something we want in our toolkit, or something we'd run in a pipeline using an official image for the tool?
  • Standard is intended to be lightweight, mainly used in pipelines, and Full is intended for development environments

I've made some changes and they don't work, how do I debug the problem?

  1. Attempt to build the problematic image. Change to the relevant folder containing a Dockerfile under images and run
    docker build -t test:latest .   
  2. View the output for any errors.
  3. If the container image builds successfully, start a shell in the container using
    docker run --rm -it --entrypoint /bin/bash test
    and perform further debugging steps.

Which versions of binaries do we use?

We use the latest version of each tool at the time of building of the image.

Which base OS do we use?

We offer two options (currently); Alpine (latest) and Ubuntu (latest).

Which architectures do we support?

amd64. If there's an architecture you'd like an image for, please submit a PR.

Contributions

If you'd like a tool added to the images, a different base OS, or a different architecture, please submit a PR. For bugs/security issues, please create a new issue and follow the instructions. Thanks.

About

Container images for your pipelines and IaC development.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Dockerfile 100.0%