// Copyright 2023 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.v13.errors;

option csharp_namespace = "Google.Ads.GoogleAds.V13.Errors";
option go_package = "google.golang.org/genproto/googleapis/ads/googleads/v13/errors;errors";
option java_multiple_files = true;
option java_outer_classname = "BillingSetupErrorProto";
option java_package = "com.google.ads.googleads.v13.errors";
option objc_class_prefix = "GAA";
option php_namespace = "Google\\Ads\\GoogleAds\\V13\\Errors";
option ruby_package = "Google::Ads::GoogleAds::V13::Errors";

// Proto file describing billing setup errors.

// Container for enum describing possible billing setup errors.
message BillingSetupErrorEnum {
  // Enum describing possible billing setup errors.
  enum BillingSetupError {
    // Enum unspecified.
    UNSPECIFIED = 0;

    // The received error code is not known in this version.
    UNKNOWN = 1;

    // Cannot specify both an existing payments account and a new payments
    // account when setting up billing.
    CANNOT_USE_EXISTING_AND_NEW_ACCOUNT = 2;

    // Cannot cancel an approved billing setup whose start time has passed.
    CANNOT_REMOVE_STARTED_BILLING_SETUP = 3;

    // Cannot perform a Change of Bill-To (CBT) to the same payments account.
    CANNOT_CHANGE_BILLING_TO_SAME_PAYMENTS_ACCOUNT = 4;

    // Billing setups can only be used by customers with ENABLED or DRAFT
    // status.
    BILLING_SETUP_NOT_PERMITTED_FOR_CUSTOMER_STATUS = 5;

    // Billing setups must either include a correctly formatted existing
    // payments account id, or a non-empty new payments account name.
    INVALID_PAYMENTS_ACCOUNT = 6;

    // Only billable and third-party customers can create billing setups.
    BILLING_SETUP_NOT_PERMITTED_FOR_CUSTOMER_CATEGORY = 7;

    // Billing setup creations can only use NOW for start time type.
    INVALID_START_TIME_TYPE = 8;

    // Billing setups can only be created for a third-party customer if they do
    // not already have a setup.
    THIRD_PARTY_ALREADY_HAS_BILLING = 9;

    // Billing setups cannot be created if there is already a pending billing in
    // progress.
    BILLING_SETUP_IN_PROGRESS = 10;

    // Billing setups can only be created by customers who have permission to
    // setup billings. Users can contact a representative for help setting up
    // permissions.
    NO_SIGNUP_PERMISSION = 11;

    // Billing setups cannot be created if there is already a future-approved
    // billing.
    CHANGE_OF_BILL_TO_IN_PROGRESS = 12;

    // Requested payments profile not found.
    PAYMENTS_PROFILE_NOT_FOUND = 13;

    // Requested payments account not found.
    PAYMENTS_ACCOUNT_NOT_FOUND = 14;

    // Billing setup creation failed because the payments profile is ineligible.
    PAYMENTS_PROFILE_INELIGIBLE = 15;

    // Billing setup creation failed because the payments account is ineligible.
    PAYMENTS_ACCOUNT_INELIGIBLE = 16;

    // Billing setup creation failed because the payments profile needs internal
    // approval.
    CUSTOMER_NEEDS_INTERNAL_APPROVAL = 17;

    // Billing setup creation failed because the user needs to accept master
    // service agreement on the payments profile.
    PAYMENTS_PROFILE_NEEDS_SERVICE_AGREEMENT_ACCEPTANCE = 18;

    // Payments account has different currency code than the current customer
    // and hence cannot be used to setup billing.
    PAYMENTS_ACCOUNT_INELIGIBLE_CURRENCY_CODE_MISMATCH = 19;

    // A start time in the future cannot be used because there is currently no
    // active billing setup for this customer.
    FUTURE_START_TIME_PROHIBITED = 20;

    // The payments account has maximum number of billing setups.
    TOO_MANY_BILLING_SETUPS_FOR_PAYMENTS_ACCOUNT = 21;
  }
}
