data-plane-api 0.1.1

Envoy xDS protobuf and gRPC definitions
Documentation
// Copyright 2022 Google LLC
//
// Licensed 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.

syntax = "proto3";

package google.cloud.cloudsetup.logging.v1;

import "google/api/resource.proto";
import "google/rpc/status.proto";

option go_package = "google.golang.org/genproto/googleapis/cloud/cloudsetup/logging/v1;logging";
option java_multiple_files = true;
option java_outer_classname = "CompleteDeploymentProto";
option java_package = "com.google.cloud.cloudsetup.logging.v1";
option csharp_namespace = "Google.Cloud.CloudSetup.Logging.V1";
option php_namespace = "Google\\Cloud\\CloudSetup\\Logging\\V1";
option ruby_package = "Google::Cloud::CloudSetup::Logging::V1";

// JSON payload for the Cloud Logging event:
// `organizations/[organizationId]/logs/cloudsetup.googleapis.com%2Fcomplete_deployment`.
// This event gets emitted upon completion of a config deployment as part of the
// Cloud Setup Checklist.
//
// The deployment can fail even if it returns a
// `config.googleapis.com/Deployment`. The state of that message will be
// `FAILED`. Hence, if there is a `value` present, the `state` can still be,
// `FAILED`. The message for the error or failure will be on the `error` or the
// `value` if the Operation results in an error or if the `state` of the
// Deployment is `FAILED`, respectively.
message CompleteDeploymentEvent {
  // State of the completed deployment.
  enum State {
    // The zero value. It is applied when `state` is unset. Do not use.
    STATE_UNSPECIFIED = 0;

    // Indicates that a Deployment value was present when the config deployment
    // finished and the State was anything other than FAILED.
    SUCCEEDED = 1;

    // Indicates that the Operation result was an error or the Deployment
    // `state` was FAILED.
    FAILED = 2;
  }

  oneof result {
    // Result of the Deployment recorded upon completion.
    CompleteDeploymentResult value = 1;

    // Result of the Deployment if the `Operation` results in an error.
    google.rpc.Status error = 2;
  }

  // The `state` of this deployment completion event.
  State state = 3;

  // Flag to indicate if deployment is preview only.
  bool preview_only = 4;
}

// This message is used when the CompleteDeploymentEvent has a value.
message CompleteDeploymentResult {
  // This is the Deployment that completed.
  // Format is projects/{project}/locations/{location}/deployments/{name}.
  string deployment = 1 [(google.api.resource_reference) = {
    type: "config.googleapis.com/Deployment"
  }];

  // This is the Preview that completed.
  // Format is projects/{project}/locations/{location}/previews/{preview}
  string preview = 3 [
    (google.api.resource_reference) = { type: "config.googleapis.com/Preview" }
  ];

  // The message that is returned when a deployment completes. This **can** be
  // an error message if the `Deployment` `state` is `FAILED`.
  string message = 2;
}