// Copyright 2024 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.v18.resources; import "google/ads/googleads/v18/common/dates.proto"; import "google/ads/googleads/v18/enums/invoice_type.proto"; import "google/ads/googleads/v18/enums/month_of_year.proto"; import "google/api/field_behavior.proto"; import "google/api/resource.proto"; option csharp_namespace = "Google.Ads.GoogleAds.V18.Resources"; option go_package = "google.golang.org/genproto/googleapis/ads/googleads/v18/resources;resources"; option java_multiple_files = true; option java_outer_classname = "InvoiceProto"; option java_package = "com.google.ads.googleads.v18.resources"; option objc_class_prefix = "GAA"; option php_namespace = "Google\\Ads\\GoogleAds\\V18\\Resources"; option ruby_package = "Google::Ads::GoogleAds::V18::Resources"; // Proto file describing the Invoice resource. // An invoice. All invoice information is snapshotted to match the PDF invoice. // For invoices older than the launch of InvoiceService, the snapshotted // information may not match the PDF invoice. message Invoice { option (google.api.resource) = { type: "googleads.googleapis.com/Invoice" pattern: "customers/{customer_id}/invoices/{invoice_id}" }; // Represents a summarized view at account level. message AccountSummary { // Output only. The account associated with the account summary. string customer = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Pretax billing correction subtotal amount, in micros. int64 billing_correction_subtotal_amount_micros = 2 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Tax on billing correction, in micros. int64 billing_correction_tax_amount_micros = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Total billing correction amount, in micros. int64 billing_correction_total_amount_micros = 4 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Pretax coupon adjustment subtotal amount, in micros. int64 coupon_adjustment_subtotal_amount_micros = 5 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Tax on coupon adjustment, in micros. int64 coupon_adjustment_tax_amount_micros = 6 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Total coupon adjustment amount, in micros. int64 coupon_adjustment_total_amount_micros = 7 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Pretax excess credit adjustment subtotal amount, in micros. int64 excess_credit_adjustment_subtotal_amount_micros = 8 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Tax on excess credit adjustment, in micros. int64 excess_credit_adjustment_tax_amount_micros = 9 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Total excess credit adjustment amount, in micros. int64 excess_credit_adjustment_total_amount_micros = 10 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Pretax regulatory costs subtotal amount, in micros. int64 regulatory_costs_subtotal_amount_micros = 11 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Tax on regulatory costs, in micros. int64 regulatory_costs_tax_amount_micros = 12 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Total regulatory costs amount, in micros. int64 regulatory_costs_total_amount_micros = 13 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Pretax export charge subtotal amount, in micros. int64 export_charge_subtotal_amount_micros = 17 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Tax on export charge, in micros. int64 export_charge_tax_amount_micros = 18 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Total export charge amount, in micros. int64 export_charge_total_amount_micros = 19 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Total pretax subtotal amount attributable to the account // during the service period, in micros. int64 subtotal_amount_micros = 14 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Total tax amount attributable to the account during the // service period, in micros. int64 tax_amount_micros = 15 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Total amount attributable to the account during the service // period, in micros. This equals the sum of the subtotal_amount_micros and // tax_amount_micros. int64 total_amount_micros = 16 [(google.api.field_behavior) = OUTPUT_ONLY]; } // Represents a summarized account budget billable cost. message AccountBudgetSummary { // Output only. The resource name of the customer associated with this // account budget. This contains the customer ID, which appears on the // invoice PDF as "Account ID". Customer resource names have the form: // // `customers/{customer_id}` string customer = 10 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The descriptive name of the account budget's customer. It // appears on the invoice PDF as "Account". string customer_descriptive_name = 11 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The resource name of the account budget associated with this // summarized billable cost. AccountBudget resource names have the form: // // `customers/{customer_id}/accountBudgets/{account_budget_id}` string account_budget = 12 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The name of the account budget. It appears on the invoice // PDF as "Account budget". string account_budget_name = 13 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The purchase order number of the account budget. It appears // on the invoice PDF as "Purchase order". string purchase_order_number = 14 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The pretax subtotal amount attributable to this budget // during the service period, in micros. int64 subtotal_amount_micros = 15 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The tax amount attributable to this budget during the // service period, in micros. int64 tax_amount_micros = 16 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The total amount attributable to this budget during the // service period, in micros. This equals the sum of the account budget // subtotal amount and the account budget tax amount. int64 total_amount_micros = 17 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The billable activity date range of the account budget, // within the service date range of this invoice. The end date is inclusive. // This can be different from the account budget's start and end time. google.ads.googleads.v18.common.DateRange billable_activity_date_range = 9 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The pretax served amount attributable to this budget during // the service period, in micros. This is only useful to reconcile invoice // and delivery data. int64 served_amount_micros = 18 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The pretax billed amount attributable to this budget during // the service period, in micros. This does not account for any adjustments. int64 billed_amount_micros = 19 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The pretax overdelivery amount attributable to this budget // during the service period, in micros (negative value). int64 overdelivery_amount_micros = 20 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The pretax invalid activity amount attributable to this // budget in previous months, in micros (negative value). int64 invalid_activity_amount_micros = 21 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The list of summarized invalid activity credits with // original linkages. repeated InvalidActivitySummary invalid_activity_summaries = 22 [(google.api.field_behavior) = OUTPUT_ONLY]; } // Details about the invalid activity for the invoice that contain // additional details about invoice against which corrections are made. message InvalidActivitySummary { // Output only. Original month of service related to this invalid activity // credit. google.ads.googleads.v18.enums.MonthOfYearEnum.MonthOfYear original_month_of_service = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Original year of service related to this invalid activity // credit. string original_year_of_service = 2 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Original invoice number related to this invalid activity // credit. string original_invoice_id = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Original account budget name related to this invalid // activity credit. string original_account_budget_name = 4 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Original purchase order number related to this invalid // activity credit. string original_purchase_order_number = 5 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Invalid activity amount in micros. int64 amount_micros = 6 [(google.api.field_behavior) = OUTPUT_ONLY]; } // Output only. The resource name of the invoice. Multiple customers can share // a given invoice, so multiple resource names may point to the same invoice. // Invoice resource names have the form: // // `customers/{customer_id}/invoices/{invoice_id}` string resource_name = 1 [ (google.api.field_behavior) = OUTPUT_ONLY, (google.api.resource_reference) = { type: "googleads.googleapis.com/Invoice" } ]; // Output only. The ID of the invoice. It appears on the invoice PDF as // "Invoice number". string id = 25 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The type of invoice. google.ads.googleads.v18.enums.InvoiceTypeEnum.InvoiceType type = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The resource name of this invoice's billing setup. // // `customers/{customer_id}/billingSetups/{billing_setup_id}` string billing_setup = 26 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. A 16 digit ID used to identify the payments account associated // with the billing setup, for example, "1234-5678-9012-3456". It appears on // the invoice PDF as "Billing Account Number". string payments_account_id = 27 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. A 12 digit ID used to identify the payments profile associated // with the billing setup, for example, "1234-5678-9012". It appears on the // invoice PDF as "Billing ID". string payments_profile_id = 28 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The issue date in yyyy-mm-dd format. It appears on the invoice // PDF as either "Issue date" or "Invoice date". string issue_date = 29 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The due date in yyyy-mm-dd format. string due_date = 30 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The service period date range of this invoice. The end date is // inclusive. google.ads.googleads.v18.common.DateRange service_date_range = 9 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The currency code. All costs are returned in this currency. A // subset of the currency codes derived from the ISO 4217 standard is // supported. string currency_code = 31 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The pretax subtotal amount of invoice level adjustments, in // micros. int64 adjustments_subtotal_amount_micros = 19 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The sum of taxes on the invoice level adjustments, in micros. int64 adjustments_tax_amount_micros = 20 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The total amount of invoice level adjustments, in micros. int64 adjustments_total_amount_micros = 21 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The pretax subtotal amount of invoice level regulatory costs, // in micros. int64 regulatory_costs_subtotal_amount_micros = 22 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The sum of taxes on the invoice level regulatory costs, in // micros. int64 regulatory_costs_tax_amount_micros = 23 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The total amount of invoice level regulatory costs, in micros. int64 regulatory_costs_total_amount_micros = 24 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The pretax subtotal amount of invoice level export charges, in // micros. int64 export_charge_subtotal_amount_micros = 40 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The sum of taxes on the invoice level export charges, in // micros. int64 export_charge_tax_amount_micros = 41 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The total amount of invoice level export charges, in micros. int64 export_charge_total_amount_micros = 42 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The pretax subtotal amount, in micros. This is equal to the // sum of the AccountBudgetSummary subtotal amounts and // Invoice.adjustments_subtotal_amount_micros. int64 subtotal_amount_micros = 33 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The sum of all taxes on the invoice, in micros. This equals // the sum of the AccountBudgetSummary tax amounts, plus taxes not associated // with a specific account budget. int64 tax_amount_micros = 34 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The total amount, in micros. This equals the sum of // Invoice.subtotal_amount_micros, Invoice.tax_amount_micros, // Invoice.regulatory_costs_subtotal_amount_micros, and // Invoice.export_charge_subtotal_amount_micros (which is separated into a // separate line item starting with V14.1). int64 total_amount_micros = 35 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The resource name of the original invoice corrected, wrote // off, or canceled by this invoice, if applicable. If `corrected_invoice` is // set, `replaced_invoices` will not be set. Invoice resource names have the // form: // // `customers/{customer_id}/invoices/{invoice_id}` string corrected_invoice = 36 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The resource name of the original invoice(s) being rebilled or // replaced by this invoice, if applicable. There might be multiple replaced // invoices due to invoice consolidation. The replaced invoices may not belong // to the same payments account. If `replaced_invoices` is set, // `corrected_invoice` will not be set. Invoice resource names have the form: // // `customers/{customer_id}/invoices/{invoice_id}` repeated string replaced_invoices = 37 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The URL to a PDF copy of the invoice. Users need to pass in // their OAuth token to request the PDF with this URL. string pdf_url = 38 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The list of summarized account budget information associated // with this invoice. repeated AccountBudgetSummary account_budget_summaries = 18 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. The list of summarized account information associated with // this invoice. repeated AccountSummary account_summaries = 39 [(google.api.field_behavior) = OUTPUT_ONLY]; }