/fcct

Fedora CoreOS Config Transpiler

Primary LanguageGoApache License 2.0Apache-2.0

Fedora CoreOS Config Transpiler

The Fedora CoreOS Config Transpiler (FCCT) translates human readable Fedora CoreOS Configs (FCCs) into machine readable Ignition Configs. See the getting started guide for how to use FCCT and the configuration spec for everything FCCs support.

Project Layout

Each config spec is composed of a base and distro component. The base components roughly mirror the Ignition spec and are distro agnostic. The distro components contain sugar for common configuration of the host (e.g. etcd) and are not distro-independent.

Each distro and base component are versioned independently with each new version getting it's own package. These versions are not exposed to the user.

Each fcos config version has it's own version which is independent of the versions of the base and distro components that compose it. However a major or minor bump of either component necessitates a corresponding bump in the fcos config version.

internal/ main, non-exported code

base/ Contains distro-agnostic code. Each package here targets only one Ignition spec versions.

distro/ Contains distro-specific code. Each package here can target multiple Ignition versions if it makes sense.

config/ Contains the top level Translate() function that determines which version to parse and emit.

config/common/ Contains the common bits and functions for all spec versions. This means the (un)marshaling helpers and the version+variant struct to be included in every user facing spec

config/vX_Y/ Contains user facing definitions of the spec. Each is composed by combining a base and distro package with the common version+variant. Each of the defines their own translate function to be registered in the config/ package.