diff options
author | Matthew Holt <mholt@users.noreply.github.com> | 2019-06-26 10:45:34 -0600 |
---|---|---|
committer | Matthew Holt <mholt@users.noreply.github.com> | 2019-06-26 10:45:34 -0600 |
commit | 6000855c82fc1bdc5c256480b4161511f91ed703 (patch) | |
tree | bc1a7664021c9ebfa04b95c4d3ff63ca4da0c94f | |
parent | 38677aaa58eb76a416fa42146956f3e3a5981e75 (diff) |
Fix panics by disallowing explicitly-defined null modules in config
-rw-r--r-- | context.go | 9 |
1 files changed, 9 insertions, 0 deletions
@@ -100,6 +100,15 @@ func (ctx Context) LoadModule(name string, rawMsg json.RawMessage) (interface{}, } } + if val == nil { + // returned module values are almost always type-asserted + // before being used, so a nil value would panic; and there + // is no good reason to explicitly declare null modules in + // a config; it might be because the user is trying to + // achieve a result they aren't expecting, which is a smell + return nil, fmt.Errorf("module value cannot be null") + } + if prov, ok := val.(Provisioner); ok { err := prov.Provision(ctx) if err != nil { |