Skip to content

Latest commit

 

History

History
72 lines (49 loc) · 3.45 KB

README.md

File metadata and controls

72 lines (49 loc) · 3.45 KB

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.