containerd: add access to default config
when wanting to craft a custom config, but based on the default config, add a route to output the containerd config to a tempfile. Signed-off-by: Vincent Batts <vbatts@hashbangbash.com>
This commit is contained in:
parent
8affca40bb
commit
28d012ea00
2 changed files with 30 additions and 2 deletions
|
@ -1,6 +1,11 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import "github.com/BurntSushi/toml"
|
import (
|
||||||
|
"bytes"
|
||||||
|
"io"
|
||||||
|
|
||||||
|
"github.com/BurntSushi/toml"
|
||||||
|
)
|
||||||
|
|
||||||
func defaultConfig() *config {
|
func defaultConfig() *config {
|
||||||
return &config{
|
return &config{
|
||||||
|
@ -58,6 +63,15 @@ func (c *config) decodePlugin(name string, v interface{}) error {
|
||||||
return c.md.PrimitiveDecode(p, v)
|
return c.md.PrimitiveDecode(p, v)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *config) WriteTo(w io.Writer) (int64, error) {
|
||||||
|
buf := bytes.NewBuffer(nil)
|
||||||
|
e := toml.NewEncoder(buf)
|
||||||
|
if err := e.Encode(c); err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
return io.Copy(w, buf)
|
||||||
|
}
|
||||||
|
|
||||||
type grpcConfig struct {
|
type grpcConfig struct {
|
||||||
Socket string `toml:"socket"`
|
Socket string `toml:"socket"`
|
||||||
Uid int `toml:"uid"`
|
Uid int `toml:"uid"`
|
||||||
|
|
|
@ -3,6 +3,7 @@ package main
|
||||||
import (
|
import (
|
||||||
_ "expvar"
|
_ "expvar"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
_ "net/http/pprof"
|
_ "net/http/pprof"
|
||||||
"os"
|
"os"
|
||||||
|
@ -60,7 +61,7 @@ func main() {
|
||||||
app.Flags = []cli.Flag{
|
app.Flags = []cli.Flag{
|
||||||
cli.StringFlag{
|
cli.StringFlag{
|
||||||
Name: "config,c",
|
Name: "config,c",
|
||||||
Usage: "path to the configuration file",
|
Usage: "path to the configuration file (Use 'default' to output the default toml)",
|
||||||
Value: "/etc/containerd/config.toml",
|
Value: "/etc/containerd/config.toml",
|
||||||
},
|
},
|
||||||
cli.StringFlag{
|
cli.StringFlag{
|
||||||
|
@ -148,6 +149,19 @@ func main() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func before(context *cli.Context) error {
|
func before(context *cli.Context) error {
|
||||||
|
if context.GlobalString("config") == "default" {
|
||||||
|
fh, err := ioutil.TempFile("", "containerd-config.toml.")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if _, err := conf.WriteTo(fh); err != nil {
|
||||||
|
fh.Close()
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
fh.Close()
|
||||||
|
log.G(global).Infof("containerd default config written to %q", fh.Name())
|
||||||
|
os.Exit(0)
|
||||||
|
}
|
||||||
if err := loadConfig(context.GlobalString("config")); err != nil &&
|
if err := loadConfig(context.GlobalString("config")); err != nil &&
|
||||||
!os.IsNotExist(err) {
|
!os.IsNotExist(err) {
|
||||||
return err
|
return err
|
||||||
|
|
Loading…
Add table
Reference in a new issue