Built motion from commit 6a09e18b.|2.6.11
[motion2.git] / legacy-libs / google-proto-files / google / ads / googleads / v1 / services / label_service.proto
diff --git a/legacy-libs/google-proto-files/google/ads/googleads/v1/services/label_service.proto b/legacy-libs/google-proto-files/google/ads/googleads/v1/services/label_service.proto
new file mode 100644 (file)
index 0000000..ca6c549
--- /dev/null
@@ -0,0 +1,116 @@
+// Copyright 2019 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.ads.googleads.v1.services;
+
+import "google/ads/googleads/v1/resources/label.proto";
+import "google/api/annotations.proto";
+import "google/protobuf/field_mask.proto";
+import "google/protobuf/wrappers.proto";
+import "google/rpc/status.proto";
+
+option csharp_namespace = "Google.Ads.GoogleAds.V1.Services";
+option go_package = "google.golang.org/genproto/googleapis/ads/googleads/v1/services;services";
+option java_multiple_files = true;
+option java_outer_classname = "LabelServiceProto";
+option java_package = "com.google.ads.googleads.v1.services";
+option objc_class_prefix = "GAA";
+option php_namespace = "Google\\Ads\\GoogleAds\\V1\\Services";
+option ruby_package = "Google::Ads::GoogleAds::V1::Services";
+
+
+// Service to manage labels.
+service LabelService {
+  // Returns the requested label in full detail.
+  rpc GetLabel(GetLabelRequest) returns (google.ads.googleads.v1.resources.Label) {
+    option (google.api.http) = {
+      get: "/v1/{resource_name=customers/*/labels/*}"
+    };
+  }
+
+  // Creates, updates, or removes labels. Operation statuses are returned.
+  rpc MutateLabels(MutateLabelsRequest) returns (MutateLabelsResponse) {
+    option (google.api.http) = {
+      post: "/v1/customers/{customer_id=*}/labels:mutate"
+      body: "*"
+    };
+  }
+}
+
+// Request message for [LabelService.GetLabel][google.ads.googleads.v1.services.LabelService.GetLabel].
+message GetLabelRequest {
+  // The resource name of the label to fetch.
+  string resource_name = 1;
+}
+
+// Request message for [LabelService.MutateLabels][google.ads.googleads.v1.services.LabelService.MutateLabels].
+message MutateLabelsRequest {
+  // ID of the customer whose labels are being modified.
+  string customer_id = 1;
+
+  // The list of operations to perform on labels.
+  repeated LabelOperation operations = 2;
+
+  // If true, successful operations will be carried out and invalid
+  // operations will return errors. If false, all operations will be carried
+  // out in one transaction if and only if they are all valid.
+  // Default is false.
+  bool partial_failure = 3;
+
+  // If true, the request is validated but not executed. Only errors are
+  // returned, not results.
+  bool validate_only = 4;
+}
+
+// A single operation (create, remove, update) on a label.
+message LabelOperation {
+  // FieldMask that determines which resource fields are modified in an update.
+  google.protobuf.FieldMask update_mask = 4;
+
+  // The mutate operation.
+  oneof operation {
+    // Create operation: No resource name is expected for the new label.
+    google.ads.googleads.v1.resources.Label create = 1;
+
+    // Update operation: The label is expected to have a valid resource name.
+    google.ads.googleads.v1.resources.Label update = 2;
+
+    // Remove operation: A resource name for the label being removed, in
+    // this format:
+    //
+    // `customers/{customer_id}/labels/{label_id}`
+    string remove = 3;
+  }
+}
+
+// Response message for a labels mutate.
+message MutateLabelsResponse {
+  // Errors that pertain to operation failures in the partial failure mode.
+  // Returned only when partial_failure = true and all errors occur inside the
+  // operations. If any errors occur outside the operations (e.g. auth errors),
+  // we return an RPC level error.
+  google.rpc.Status partial_failure_error = 3;
+
+  // All results for the mutate.
+  repeated MutateLabelResult results = 2;
+}
+
+// The result for a label mutate.
+message MutateLabelResult {
+  // Returned for successful operations.
+  string resource_name = 1;
+}