Merge pull request #2030 from Random-Liu/print-plugin-default-config
Print default plugin config.
This commit is contained in:
commit
4812f4be8f
@ -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
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -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 {
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user