pulumi/sdk/proto/analyzer.proto
joeduffy 705880cb7f Add the ability to specify analyzers
This change adds the ability to specify analyzers in two ways:

1) By listing them in the project file, for example:

        analyzers:
            - acmecorp/security
            - acmecorp/gitflow

2) By explicitly listing them on the CLI, as a "one off":

        $ coco deploy <env> \
            --analyzer=acmecorp/security \
            --analyzer=acmecorp/gitflow

This closes out pulumi/coconut#119.
2017-03-11 10:07:34 -08:00

44 lines
1.5 KiB
Protocol Buffer

// Copyright 2016 Pulumi, Inc. All rights reserved.
syntax = "proto3";
import "google/protobuf/struct.proto";
package cocorpc;
// Analyzer is a pluggable service that checks entire projects/stacks/snapshots, and/or individual resources,
// for arbitrary issues. These might be style, policy, correctness, security, or performance related.
service Analyzer {
// Analyze analyzes an entire project/stack/snapshot, and returns any errors that it finds.
rpc Analyze(AnalyzeRequest) returns (AnalyzeResponse) {}
// AnalyzeResource analyzes a single resource object, and returns any errors that it finds.
rpc AnalyzeResource(AnalyzeResourceRequest) returns (AnalyzeResourceResponse) {}
}
message AnalyzeRequest {
string pkg = 1; // the fully resolved package URL being deployed.
}
message AnalyzeResponse {
repeated AnalyzeFailure failures = 1; // the failures (or empty if none).
}
message AnalyzeFailure {
string reason = 1; // the reason that the analyzer rejected the request.
}
message AnalyzeResourceRequest {
string type = 1; // the type token of the resource.
google.protobuf.Struct properties = 2; // the full properties to use for validation.
}
message AnalyzeResourceResponse {
repeated AnalyzeResourceFailure failures = 1; // the failures (or empty if none).
}
message AnalyzeResourceFailure {
string property = 1; // the property that the analyzer rejected (or "" if general).
string reason = 2; // the reason that the analyzer rejected the request.
}