// Copyright 2021 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.analytics.admin.v1alpha; import "google/api/field_behavior.proto"; import "google/api/resource.proto"; import "google/protobuf/timestamp.proto"; import "google/protobuf/wrappers.proto"; option go_package = "google.golang.org/genproto/googleapis/analytics/admin/v1alpha;admin"; option java_multiple_files = true; option java_outer_classname = "ResourcesProto"; option java_package = "com.google.analytics.admin.v1alpha"; // Maximum access settings that Firebase user receive on the linked Analytics // property. enum MaximumUserAccess { // Unspecified maximum user access. MAXIMUM_USER_ACCESS_UNSPECIFIED = 0; // Firebase users have no access to the Analytics property. NO_ACCESS = 1; // Firebase users have Read & Analyze access to the Analytics property. READ_AND_ANALYZE = 2; // Firebase users have edit access to the Analytics property, but may not // manage the Firebase link. EDITOR_WITHOUT_LINK_MANAGEMENT = 3; // Firebase users have edit access to the Analytics property and may manage // the Firebase link. EDITOR_INCLUDING_LINK_MANAGEMENT = 4; } // The category selected for this property, used for industry benchmarking. enum IndustryCategory { // Industry category unspecified INDUSTRY_CATEGORY_UNSPECIFIED = 0; // Automotive AUTOMOTIVE = 1; // Business and industrial markets BUSINESS_AND_INDUSTRIAL_MARKETS = 2; // Finance FINANCE = 3; // Healthcare HEALTHCARE = 4; // Technology TECHNOLOGY = 5; // Travel TRAVEL = 6; // Other OTHER = 7; // Arts and entertainment ARTS_AND_ENTERTAINMENT = 8; // Beauty and fitness BEAUTY_AND_FITNESS = 9; // Books and literature BOOKS_AND_LITERATURE = 10; // Food and drink FOOD_AND_DRINK = 11; // Games GAMES = 12; // Hobbies and leisure HOBBIES_AND_LEISURE = 13; // Home and garden HOME_AND_GARDEN = 14; // Internet and telecom INTERNET_AND_TELECOM = 15; // Law and government LAW_AND_GOVERNMENT = 16; // News NEWS = 17; // Online communities ONLINE_COMMUNITIES = 18; // People and society PEOPLE_AND_SOCIETY = 19; // Pets and animals PETS_AND_ANIMALS = 20; // Real estate REAL_ESTATE = 21; // Reference REFERENCE = 22; // Science SCIENCE = 23; // Sports SPORTS = 24; // Jobs and education JOBS_AND_EDUCATION = 25; // Shopping SHOPPING = 26; } // A resource message representing a Google Analytics account. message Account { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/Account" pattern: "accounts/{account}" }; // Output only. Resource name of this account. // Format: accounts/{account} // Example: "accounts/100" string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when this account was originally created. google.protobuf.Timestamp create_time = 2 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when account payload fields were last updated. google.protobuf.Timestamp update_time = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; // Required. Human-readable display name for this account. string display_name = 4 [(google.api.field_behavior) = REQUIRED]; // Country of business. Must be a Unicode CLDR region code. string region_code = 5; // Output only. Indicates whether this Account is soft-deleted or not. Deleted // accounts are excluded from List results unless specifically requested. bool deleted = 6 [(google.api.field_behavior) = OUTPUT_ONLY]; } // A resource message representing a Google Analytics GA4 property. message Property { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/Property" pattern: "properties/{property}" }; // Output only. Resource name of this property. // Format: properties/{property_id} // Example: "properties/1000" string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when the entity was originally created. google.protobuf.Timestamp create_time = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when entity payload fields were last updated. google.protobuf.Timestamp update_time = 4 [(google.api.field_behavior) = OUTPUT_ONLY]; // Immutable. Resource name of this property's logical parent. // // Note: The Property-Moving UI can be used to change the parent. // Format: accounts/{account} // Example: "accounts/100" string parent = 2 [(google.api.field_behavior) = IMMUTABLE]; // Required. Human-readable display name for this property. // // The max allowed display name length is 100 UTF-16 code units. string display_name = 5 [(google.api.field_behavior) = REQUIRED]; // Industry associated with this property // Example: AUTOMOTIVE, FOOD_AND_DRINK IndustryCategory industry_category = 6; // Reporting Time Zone, used as the day boundary for reports, regardless of // where the data originates. If the time zone honors DST, Analytics will // automatically adjust for the changes. // // NOTE: Changing the time zone only affects data going forward, and is not // applied retroactively. // // Format: https://www.iana.org/time-zones // Example: "America/Los_Angeles" string time_zone = 7; // The currency type used in reports involving monetary values. // // // Format: https://en.wikipedia.org/wiki/ISO_4217 // Examples: "USD", "EUR", "JPY" string currency_code = 8; // Output only. Indicates whether this Property is soft-deleted or not. Deleted properties // are excluded from List results unless specifically requested. bool deleted = 9 [(google.api.field_behavior) = OUTPUT_ONLY]; } // A resource message representing a Google Analytics Android app stream. message AndroidAppDataStream { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/AndroidAppDataStream" pattern: "properties/{property}/androidAppDataStreams/{android_app_data_stream}" }; // Output only. Resource name of this Data Stream. // Format: properties/{property_id}/androidAppDataStreams/{stream_id} // Example: "properties/1000/androidAppDataStreams/2000" string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. ID of the corresponding Android app in Firebase, if any. // This ID can change if the Android app is deleted and recreated. string firebase_app_id = 2 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when this stream was originally created. google.protobuf.Timestamp create_time = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when stream payload fields were last updated. google.protobuf.Timestamp update_time = 4 [(google.api.field_behavior) = OUTPUT_ONLY]; // Immutable. The package name for the app being measured. // Example: "com.example.myandroidapp" string package_name = 5 [(google.api.field_behavior) = IMMUTABLE]; // Human-readable display name for the Data Stream. // // The max allowed display name length is 255 UTF-16 code units. string display_name = 6; } // A resource message representing a Google Analytics IOS app stream. message IosAppDataStream { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/IosAppDataStream" pattern: "properties/{property}/iosAppDataStreams/{ios_app_data_stream}" }; // Output only. Resource name of this Data Stream. // Format: properties/{property_id}/iosAppDataStreams/{stream_id} // Example: "properties/1000/iosAppDataStreams/2000" string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. ID of the corresponding iOS app in Firebase, if any. // This ID can change if the iOS app is deleted and recreated. string firebase_app_id = 2 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when this stream was originally created. google.protobuf.Timestamp create_time = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when stream payload fields were last updated. google.protobuf.Timestamp update_time = 4 [(google.api.field_behavior) = OUTPUT_ONLY]; // Required. Immutable. The Apple App Store Bundle ID for the app // Example: "com.example.myiosapp" string bundle_id = 5 [ (google.api.field_behavior) = IMMUTABLE, (google.api.field_behavior) = REQUIRED ]; // Human-readable display name for the Data Stream. // // The max allowed display name length is 255 UTF-16 code units. string display_name = 6; } // A resource message representing a Google Analytics web stream. message WebDataStream { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/WebDataStream" pattern: "properties/{property}/webDataStreams/{web_data_stream}" }; // Output only. Resource name of this Data Stream. // Format: properties/{property_id}/webDataStreams/{stream_id} // Example: "properties/1000/webDataStreams/2000" string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Analytics "Measurement ID", without the "G-" prefix. // Example: "G-1A2BCD345E" would just be "1A2BCD345E" string measurement_id = 2 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. ID of the corresponding web app in Firebase, if any. // This ID can change if the web app is deleted and recreated. string firebase_app_id = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when this stream was originally created. google.protobuf.Timestamp create_time = 4 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when stream payload fields were last updated. google.protobuf.Timestamp update_time = 5 [(google.api.field_behavior) = OUTPUT_ONLY]; // Immutable. Domain name of the web app being measured, or empty. // Example: "http://www.google.com", "https://www.google.com" string default_uri = 6 [(google.api.field_behavior) = IMMUTABLE]; // Required. Human-readable display name for the Data Stream. // // The max allowed display name length is 100 UTF-16 code units. string display_name = 7 [(google.api.field_behavior) = REQUIRED]; } // A resource message representing a user's permissions on an Account or // Property resource. message UserLink { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/UserLink" pattern: "accounts/{account}/userLinks/{user_link}" pattern: "properties/{property}/userLinks/{user_link}" }; // Example format: properties/1234/userLinks/5678 string name = 1; // Email address of the user to link string email_address = 2; // Roles directly assigned to this user for this account or property. // // Valid values: // predefinedRoles/read // predefinedRoles/collaborate // predefinedRoles/edit // predefinedRoles/manage-users // // Excludes roles that are inherited from a higher-level entity, group, // or organization admin role. // // A UserLink that is updated to have an empty list of direct_roles will be // deleted. repeated string direct_roles = 3; } // Read-only resource used to summarize a principal's effective roles. message AuditUserLink { // Example format: properties/1234/userLinks/5678 string name = 1; // Email address of the linked user string email_address = 2; // Roles directly assigned to this user for this entity. // // Format: predefinedRoles/read // // Excludes roles that are inherited from an account (if this is for a // property), group, or organization admin role. repeated string direct_roles = 3; // Union of all permissions a user has at this account or property (includes // direct permissions, group-inherited permissions, etc.). // // Format: predefinedRoles/read repeated string effective_roles = 4; } // Singleton resource under a WebDataStream, configuring measurement of // additional site interactions and content. message EnhancedMeasurementSettings { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/EnhancedMeasurementSettings" pattern: "properties/{property}/webDataStreams/{web_data_stream}/enhancedMeasurementSettings" }; // Output only. Resource name of this Data Stream. // Format: // properties/{property_id}/webDataStreams/{stream_id}/enhancedMeasurementSettings // Example: "properties/1000/webDataStreams/2000/enhancedMeasurementSettings" string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Indicates whether Enhanced Measurement Settings will be used to // automatically measure interactions and content on this web stream. // // Changing this value does not affect the settings themselves, but determines // whether they are respected. bool stream_enabled = 2; // Output only. If enabled, capture a page view event each time a page loads or the // website changes the browser history state. bool page_views_enabled = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; // If enabled, capture scroll events each time a visitor gets to the bottom of // a page. bool scrolls_enabled = 4; // If enabled, capture an outbound click event each time a visitor clicks a // link that leads them away from your domain. bool outbound_clicks_enabled = 5; // If enabled, capture a view search results event each time a visitor // performs a search on your site (based on a query parameter). bool site_search_enabled = 7; // If enabled, capture video play, progress, and complete events as visitors // view embedded videos on your site. bool video_engagement_enabled = 9; // If enabled, capture a file download event each time a link is clicked with // a common document, compressed file, application, video, or audio extension. bool file_downloads_enabled = 10; // Output only. If enabled, capture a page view event each time a page loads. bool page_loads_enabled = 12 [(google.api.field_behavior) = OUTPUT_ONLY]; // If enabled, capture a page view event each time the website changes the // browser history state. bool page_changes_enabled = 13; // Required. URL query parameters to interpret as site search parameters. // Max length is 1024 characters. Must not be empty. string search_query_parameter = 16 [(google.api.field_behavior) = REQUIRED]; // Additional URL query parameters. // Max length is 1024 characters. string uri_query_parameter = 17; } // A link between an GA4 property and a Firebase project. message FirebaseLink { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/FirebaseLink" pattern: "properties/{property}/firebaseLinks/{firebase_link}" }; // Output only. Example format: properties/1234/firebaseLinks/5678 string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Immutable. Firebase project resource name. When creating a FirebaseLink, you may // provide this resource name using either a project number or project ID. // Once this resource has been created, returned FirebaseLinks will always // have a project_name that contains a project number. // // Format: 'projects/{project number}' // Example: 'projects/1234' string project = 2 [(google.api.field_behavior) = IMMUTABLE]; // Output only. Time when this FirebaseLink was originally created. google.protobuf.Timestamp create_time = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; // Maximum user access to the GA4 property allowed to admins of // the linked Firebase project. MaximumUserAccess maximum_user_access = 4; } // Read-only resource with the tag for sending data from a website to a // WebDataStream. message GlobalSiteTag { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/GlobalSiteTag" pattern: "properties/{property}/globalSiteTag" }; // Output only. Resource name for this GlobalSiteTag resource. // Format: properties/{propertyId}/globalSiteTag string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Immutable. JavaScript code snippet to be pasted as the first item into the head tag of // every webpage to measure. string snippet = 2 [(google.api.field_behavior) = IMMUTABLE]; } // A link between an GA4 property and a Google Ads account. message GoogleAdsLink { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/GoogleAdsLink" pattern: "properties/{property}/googleAdsLinks/{google_ads_link}" }; // Output only. Format: properties/{propertyId}/googleAdsLinks/{googleAdsLinkId} // // Note: googleAdsLinkId is not the Google Ads customer ID. string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Immutable. Google Ads customer ID. string customer_id = 3 [(google.api.field_behavior) = IMMUTABLE]; // Output only. If true, this link is for a Google Ads manager account. bool can_manage_clients = 4 [(google.api.field_behavior) = OUTPUT_ONLY]; // Enable personalized advertising features with this integration. // Automatically publish my Google Analytics audience lists and Google // Analytics remarketing events/parameters to the linked Google Ads account. // If this field is not set on create/update it will be defaulted to true. google.protobuf.BoolValue ads_personalization_enabled = 5; // Output only. Email address of the user that created the link. // An empty string will be returned if the email address can't be retrieved. string email_address = 6 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when this link was originally created. google.protobuf.Timestamp create_time = 7 [(google.api.field_behavior) = OUTPUT_ONLY]; // Output only. Time when this link was last updated. google.protobuf.Timestamp update_time = 8 [(google.api.field_behavior) = OUTPUT_ONLY]; } // A resource message representing data sharing settings of a Google Analytics // account. message DataSharingSettings { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/DataSharingSettings" pattern: "accounts/{account}/dataSharingSettings" }; // Output only. Resource name. // Format: accounts/{account}/dataSharingSettings // Example: "accounts/1000/dataSharingSettings" string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY]; // Allows Google support to access the data in order to help troubleshoot // issues. bool sharing_with_google_support_enabled = 2; // Allows Google sales teams that are assigned to the customer to access the // data in order to suggest configuration changes to improve results. // Sales team restrictions still apply when enabled. bool sharing_with_google_assigned_sales_enabled = 3; // Allows any of Google sales to access the data in order to suggest // configuration changes to improve results. bool sharing_with_google_any_sales_enabled = 4; // Allows Google to use the data to improve other Google products or services. bool sharing_with_google_products_enabled = 5; // Allows Google to share the data anonymously in aggregate form with others. bool sharing_with_others_enabled = 6; } // A virtual resource representing an overview of an account and // all its child GA4 properties. message AccountSummary { option (google.api.resource) = { type: "analyticsadmin.googleapis.com/AccountSummary" pattern: "accountSummaries/{account_summary}" }; // Resource name for this account summary. // Format: accountSummaries/{account_id} // Example: "accountSummaries/1000" string name = 1; // Resource name of account referred to by this account summary // Format: accounts/{account_id} // Example: "accounts/1000" string account = 2 [(google.api.resource_reference) = { type: "analyticsadmin.googleapis.com/Account" }]; // Display name for the account referred to in this account summary. string display_name = 3; // List of summaries for child accounts of this account. repeated PropertySummary property_summaries = 4; } // A virtual resource representing metadata for an GA4 property. message PropertySummary { // Resource name of property referred to by this property summary // Format: properties/{property_id} // Example: "properties/1000" string property = 1 [(google.api.resource_reference) = { type: "analyticsadmin.googleapis.com/Property" }]; // Display name for the property referred to in this account summary. string display_name = 2; }