Andrey Smirnov b3c3ef29bd
feat: install system extensions
Fixes #4815

This implements the following steps:

* machine configuration updates
* pulling and unpacking system extension images
* validating, listing system extensions
* re-packing system extensions
* preserving installed extensions in `/etc/extensions.yaml`

Once extension is enabled, raw information can be queried with:

```
$ talosctl -n 172.20.0.2 cat /etc/extensions.yaml
layers:
    - image: 000.ghcr.io-smira-gvisor-c927b54-dirty.sqsh
      metadata:
        name: gvisor
        version: 20220117.0-v1.0.0
        author: Andrew Rynhard
        description: |
            This system extension provides gVisor using containerd's runtime handler.
        compatibility:
            talos:
                version: '> v0.15.0-alpha.1'
```

This was tested with the `gvisor` system extension.

Signed-off-by: Andrey Smirnov <andrey.smirnov@talos-systems.com>
2022-01-26 16:24:28 +03:00

47 lines
956 B
Go

// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
package extensions
import (
"os"
"gopkg.in/yaml.v3"
)
// Config specifies Talos installer extensions configuration.
type Config struct {
Layers []*Layer `yaml:"layers"`
}
// Layer defines overlay mount layer.
type Layer struct {
Image string `yaml:"image"`
Metadata Metadata `yaml:"metadata"`
}
// Read extensions config from a file.
func (cfg *Config) Read(path string) error {
f, err := os.Open(path)
if err != nil {
return err
}
defer f.Close() //nolint:errcheck
return yaml.NewDecoder(f).Decode(cfg)
}
// Write extensions config to a file.
func (cfg *Config) Write(path string) error {
f, err := os.Create(path)
if err != nil {
return err
}
defer f.Close() //nolint:errcheck
return yaml.NewEncoder(f).Encode(cfg)
}