Skip to content

Commit

Permalink
rpc: use a transport that supports nil pointers
Browse files Browse the repository at this point in the history
  • Loading branch information
mitchellh committed Jun 13, 2014
1 parent c10eed7 commit 7980aa9
Showing 1 changed file with 11 additions and 3 deletions.
14 changes: 11 additions & 3 deletions rpc/resource_provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,11 @@ type ResourceProvider struct {

func (p *ResourceProvider) Validate(c *terraform.ResourceConfig) ([]string, []error) {
var resp ResourceProviderValidateResponse
err := p.Client.Call(p.Name+".Validate", c, &resp)
args := ResourceProviderValidateArgs{
Config: c,
}

err := p.Client.Call(p.Name+".Validate", &args, &resp)
if err != nil {
return nil, []error{err}
}
Expand Down Expand Up @@ -95,15 +99,19 @@ type ResourceProviderDiffResponse struct {
Error *BasicError
}

type ResourceProviderValidateArgs struct {
Config *terraform.ResourceConfig
}

type ResourceProviderValidateResponse struct {
Warnings []string
Errors []*BasicError
}

func (s *ResourceProviderServer) Validate(
config *terraform.ResourceConfig,
args *ResourceProviderValidateArgs,
reply *ResourceProviderValidateResponse) error {
warns, errs := s.Provider.Validate(config)
warns, errs := s.Provider.Validate(args.Config)
berrs := make([]*BasicError, len(errs))
for i, err := range errs {
berrs[i] = NewBasicError(err)
Expand Down

0 comments on commit 7980aa9

Please sign in to comment.