pulumi/pkg/resource/plugin/check.go
joeduffy d277dd5800 More progress on pulumi/lumi#90
This change refactors a number of aspects of the CLI's treatment of
steps, in line with the new scheme, and a number of other miscellaneous
and minor fixes.  It also regenerates all RPC code impacted by recent renames.
2017-06-13 07:10:13 -07:00

45 lines
1.6 KiB
Go

// Licensed to Pulumi Corporation ("Pulumi") under one or more
// contributor license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright ownership.
// Pulumi licenses this file to You under the Apache License, Version 2.0
// (the "License"); you may not use this file except in compliance with
// the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package plugin
import (
"github.com/pulumi/lumi/pkg/util/mapper"
"github.com/pulumi/lumi/sdk/go/pkg/lumirpc"
)
// NewCheckResponse produces a response with property validation failures from the given array of mapper failures.
func NewCheckResponse(err error) *lumirpc.CheckResponse {
var failures []*lumirpc.CheckFailure
if err != nil {
switch e := err.(type) {
case mapper.MappingError:
for _, failure := range e.Failures() {
switch f := failure.(type) {
case mapper.FieldError:
failures = append(failures, &lumirpc.CheckFailure{
Property: f.Field(),
Reason: f.Reason(),
})
default:
failures = append(failures, &lumirpc.CheckFailure{Reason: f.Error()})
}
}
default:
failures = append(failures, &lumirpc.CheckFailure{Reason: e.Error()})
}
}
return &lumirpc.CheckResponse{Failures: failures}
}