Skip to content

Commit

Permalink
Reflect changes to the compatibility attrs design (#24)
Browse files Browse the repository at this point in the history
  • Loading branch information
zerospiel authored Oct 25, 2024
1 parent d8d2b92 commit 72fe01c
Showing 1 changed file with 65 additions and 70 deletions.
135 changes: 65 additions & 70 deletions docs/template/main.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
# Templates system

By default, 2A delivers a set of default `ProviderTemplate`, `ClusterTemplate` and `SystemTemplate` objects:

* `ProviderTemplate`
The template containing the configuration of the provider, ex. k0smotron. Cluster-scoped.
* `ClusterTemplate`
Expand All @@ -19,7 +20,7 @@ Here are the instructions on how to bring your own Template to HMC:
external Helm repository. Label it with `hmc.mirantis.com/managed: "true"`.
2. Create a [HelmChart](https://fluxcd.io/flux/components/source/helmcharts/) object referencing the `HelmRepository` as a
`sourceRef`, specifying the name and version of your Helm chart. Label it with `hmc.mirantis.com/managed: "true"`.
3. Create a `ClusterTemplate`, `ServiceTemplate` or `ProviderTemplate` object referencing this helm chart in
3. Create a `ClusterTemplate`, `ServiceTemplate` or `ProviderTemplate` object referencing this helm chart in
`spec.helm.chartRef`. `chartRef` is a field of the
[CrossNamespaceSourceReference](https://fluxcd.io/flux/components/helm/api/v2/#helm.toolkit.fluxcd.io/v2.CrossNamespaceSourceReference) kind.
For `ClusterTemplate` and `ServiceTemplate` configure the namespace where this template should reside
Expand Down Expand Up @@ -92,51 +93,46 @@ spec:
The `*Template` should follow the rules mentioned below:

1. `spec.providers` should contain the list of required Cluster API providers: `infrastructure`, `bootstrap` and
`controlPlane`. As an alternative, the referenced helm chart may contain the specific annotations in the `Chart.yaml`
(value is a list of providers divided by semicolon). These fields are only used for validation. For example:
`spec.providers` should contain the list of required Cluster API providers: `infrastructure`, `bootstrap` and
`control-plane`. As an alternative, the referenced helm chart may contain the specific annotations in the `Chart.yaml`
(value is a list of providers divided by comma). These fields are only used for validation. For example:

`ClusterTemplate` spec:
`ClusterTemplate` spec:

```yaml
spec:
providers:
infrastructure:
- aws
bootstrap:
- k0s
controlPlane:
- k0smotron
```
```yaml
spec:
providers:
- bootstrap-k0smotron
- control-plane-k0smotron
- infrastructure-aws
```

`Chart.yaml`:
`Chart.yaml`:

```bash
annotations:
hmc.mirantis.com/infrastructure-providers: aws
hmc.mirantis.com/control-plane-providers: k0s; k0smotron
hmc.mirantis.com/bootstrap-providers: k0s
```
```bash
annotations:
cluster.x-k8s.io/provider: infrastructure-aws, control-plane-k0smotron, bootstrap-k0smotron
```

## Compatibility attributes

Each of the `*Template` resources has compatibility versions attributes, including exact versions or version constraints.
Both must be set in the Semantic Version format. Each attribute can be set either via the corresponding `.spec` fields or via the annotations.
Each of the `*Template` resources has compatibility versions attributes to constraint the core `CAPI`, `CAPI` provider or Kubernetes versions.
CAPI-related version constraints must be set in the [`CAPI` contract format](https://cluster-api.sigs.k8s.io/developer/providers/contracts).
Kubernetes version constraints must be set in the Semantic Version format.
Each attribute can be set either via the corresponding `.spec` fields or via the annotations.
Values set via the `.spec` have precedence over the values set via the annotations.

> NOTE:
> All of the compatibility attributes are optional, and validation checks only take place
> if **both** of the corresponding type attributes
> (version and constraint, (e.g. `k8sVersion` and `k8sConstraint`)) are set.

1. The `ProviderTemplate` resource has dedicated fields to set an exact compatible `CAPI` version along
with the core `CAPI` version constraints, and exact compatibility versions for each
of the `infrastructure`, `bootstrap` and `controlPlane` providers type.
Given compatibility values will be then set accordingly in the `.status` field.
> (e.g. provider contract versions in both `ProviderTemplate` and `ClusterTemplate`) are set.

The exact `CAPI` version must be only set for the core `CAPI` `ProviderTemplate`,
and the `CAPI` constraint must be set for other `ProviderTemplate` objects. **The attributes
are mutually exclusive**.
1. The `ProviderTemplate` resource has dedicated fields to set compatible `CAPI` contract versions along
with CRDs contract versions supported by the provider.
Given contract versions will be then set accordingly in the `.status` field.
Compatibility contract versions are key-value pairs, where the key is **the core `CAPI` contract version**,
and the value is an underscore-delimited (_) list of provider contract versions supported by the core `CAPI`.
For the core `CAPI` Template values should be empty.

Example with the `.spec`:

Expand All @@ -145,36 +141,35 @@ Given compatibility values will be then set accordingly in the `.status` field.
kind: ProviderTemplate
# ...
spec:
# capiVersion makes sense only for the core CAPI template
# capiVersion: 1.7.3 # only exact version is applicable
capiVersionConstraint: ~1.7.0 # only version constraints are applicable
providers:
bootstrap:
- name: k0s
versionOrConstraint: 1.0.0 # only exact version is applicable
controlPlane:
- name: k0smotron
versionOrConstraint: 1.34.0 # only exact version is applicable
infrastructure:
- name: aws
versionOrConstraint: 1.2.3 # only exact version is applicable
- infrastructure-aws
capiContracts:
# commented is the example exclusively for the core CAPI Template
# v1alpha3: ""
# v1alpha4: ""
# v1beta1: ""
v1alpha3: v1alpha3
v1alpha4: v1alpha4
v1beta1: v1beta1_v1beta2
```

Example with the `annotations` in the `Chart.yaml`:
Example with the `annotations` in the `Chart.yaml` with the same logic
as in the `.spec`:

```yaml
# hmc.mirantis.com/capi-version makes sense only for the core CAPI template
# hmc.mirantis.com/capi-version: 1.7.3
hmc.mirantis.com/capi-version-constraint: ~1.7.0
hmc.mirantis.com/bootstrap-providers: k0s 1.0.0 # space-separated semicolon-separated list, e.g. k0s 1.0.0; k0s 1.0.1
hmc.mirantis.com/control-plane-providers: k0smotron 1.34.0 # space-separated semicolon-separated list, e.g. k0s 1.0.0; k0smotron 1.34.5
hmc.mirantis.com/infrastructure-providers: aws 1.2.3 # space-separated semicolon-separated list
annotations:
cluster.x-k8s.io/provider: infrastructure-aws
cluster.x-k8s.io/v1alpha3: v1alpha3
cluster.x-k8s.io/v1alpha4: v1alpha4
cluster.x-k8s.io/v1beta1: v1beta1_v1beta2
```

1. The `ClusterTemplate` resource has dedicated fields to set an exact compatible Kubernetes version
along with compatibility constrained versions for each of the `infrastructure`, `bootstrap`
and `controlPlane` providers type to match against the related `ProviderTemplate` objects.
Given compatibility values will be then set accordingly in the `.status` field.
in the Semantic Version format and required contract versions per each provider to match against
the related `ProviderTemplate` objects.
Given compatibility attributes will be then set accordingly in the `.status` field.
Compatibility contract versions are key-value pairs, where the key is **the name of the provider**,
and the value is the provider contract version required to be supported by the provider.

Example with the `spec`:

Expand All @@ -183,26 +178,26 @@ Given compatibility values will be then set accordingly in the `.status` field.
kind: ClusterTemplate
# ...
spec:
k8sVersion: 1.30.0 # only exact version is applicable
k8sVersion: 1.30.0 # only exact semantic version is applicable
providers:
bootstrap:
- name: k0s
versionOrConstraint: ">=1.0.0" # only version constraints are applicable
controlPlane:
- name: k0smotron
versionOrConstraint: ">=1.34.0 <2.0.0-0" # only version constraints are applicable
infrastructure:
- name: aws
versionOrConstraint: "~1.2.3" # only version constraints are applicable
- bootstrap-k0smotron
- control-plane-k0smotron
- infrastructure-aws
providerContracts:
bootstrap-k0smotron: v1beta1 # only a single contract version is applicable
control-plane-k0smotron: v1beta1
infrastructure-aws: v1beta2
```

Example with the `annotations` in the `Chart.yaml`:

```yaml
hmc.mirantis.com/k8s-version: 1.30.0
hmc.mirantis.com/bootstrap-providers: k0s >=1.0.0 # space-separated semicolon-separated list
hmc.mirantis.com/control-plane-providers: k0smotron >=1.34.0 <2.0.0-0 # space-separated semicolon-separated list, e.g. k0s >=1.0.0; k0smotron ~1.34.0
hmc.mirantis.com/infrastructure-providers: aws ~1.2.3 # space-separated semicolon-separated list
annotations:
cluster.x-k8s.io/provider: infrastructure-aws, control-plane-k0smotron, bootstrap-k0smotron
cluster.x-k8s.io/bootstrap-k0smotron: v1beta1
cluster.x-k8s.io/control-plane-k0smotron: v1beta1
cluster.x-k8s.io/infrastructure-aws: v1beta2
hmc.mirantis.com/k8s-version: 1.30.0
```

1. The `ServiceTemplate` resource has dedicated fields to set an compatibility constrained
Expand All @@ -216,7 +211,7 @@ Given compatibility values will be then set accordingly in the `.status` field.
kind: ServiceTemplate
# ...
spec:
k8sConstraint: "^1.30.0" # only version constraints are applicable
k8sConstraint: "^1.30.0" # only semantic version constraints are applicable
```

Example with the `annotations` in the `Chart.yaml`:
Expand Down

0 comments on commit 72fe01c

Please sign in to comment.