Merge pull request #2030 from Random-Liu/print-plugin-default-config

Print default plugin config.
This commit is contained in:
Michael Crosby 2018-01-22 11:12:20 -05:00 committed by GitHub
commit 4812f4be8f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 36 additions and 16 deletions

View File

@ -1,11 +1,26 @@
package main package main
import ( import (
"io"
"os" "os"
"github.com/BurntSushi/toml"
"github.com/containerd/containerd/server"
"github.com/urfave/cli" "github.com/urfave/cli"
) )
// Config is a wrapper of server config for printing out.
type Config struct {
*server.Config
// Plugins overrides `Plugins map[string]toml.Primitive` in server config.
Plugins map[string]interface{} `toml:"plugins"`
}
// WriteTo marshals the config to the provided writer
func (c *Config) WriteTo(w io.Writer) (int64, error) {
return 0, toml.NewEncoder(w).Encode(c)
}
var configCommand = cli.Command{ var configCommand = cli.Command{
Name: "config", Name: "config",
Usage: "information on the containerd config", Usage: "information on the containerd config",
@ -14,7 +29,23 @@ var configCommand = cli.Command{
Name: "default", Name: "default",
Usage: "see the output of the default config", Usage: "see the output of the default config",
Action: func(context *cli.Context) error { Action: func(context *cli.Context) error {
_, err := defaultConfig().WriteTo(os.Stdout) config := &Config{
Config: defaultConfig(),
}
plugins, err := server.LoadPlugins(config.Config)
if err != nil {
return err
}
if len(plugins) != 0 {
config.Plugins = make(map[string]interface{})
for _, p := range plugins {
if p.Config == nil {
continue
}
config.Plugins[p.ID] = p.Config
}
}
_, err = config.WriteTo(os.Stdout)
return err return err
}, },
}, },

View File

@ -1,9 +1,6 @@
package server package server
import ( import (
"bytes"
"io"
"github.com/BurntSushi/toml" "github.com/BurntSushi/toml"
"github.com/containerd/containerd/errdefs" "github.com/containerd/containerd/errdefs"
"github.com/pkg/errors" "github.com/pkg/errors"
@ -69,16 +66,6 @@ func (c *Config) Decode(id string, v interface{}) (interface{}, error) {
return v, nil return v, nil
} }
// WriteTo marshals the config to the provided writer
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)
}
// LoadConfig loads the containerd server config from the provided path // LoadConfig loads the containerd server config from the provided path
func LoadConfig(path string, v *Config) error { func LoadConfig(path string, v *Config) error {
if v == nil { if v == nil {

View File

@ -45,7 +45,7 @@ func New(ctx context.Context, config *Config) (*Server, error) {
if err := apply(ctx, config); err != nil { if err := apply(ctx, config); err != nil {
return nil, err return nil, err
} }
plugins, err := loadPlugins(config) plugins, err := LoadPlugins(config)
if err != nil { if err != nil {
return nil, err return nil, err
} }
@ -158,7 +158,9 @@ func (s *Server) Stop() {
s.rpc.Stop() s.rpc.Stop()
} }
func loadPlugins(config *Config) ([]*plugin.Registration, error) { // LoadPlugins loads all plugins into containerd and generates an ordered graph
// of all plugins.
func LoadPlugins(config *Config) ([]*plugin.Registration, error) {
// load all plugins into containerd // load all plugins into containerd
if err := plugin.Load(filepath.Join(config.Root, "plugins")); err != nil { if err := plugin.Load(filepath.Join(config.Root, "plugins")); err != nil {
return nil, err return nil, err