// Copyright 2020 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.data.v1alpha; option go_package = "google.golang.org/genproto/googleapis/analytics/data/v1alpha;data"; option java_multiple_files = true; option java_outer_classname = "ReportingApiProto"; option java_package = "com.google.analytics.data.v1alpha"; // A contiguous set of days: startDate, startDate + 1, ..., endDate. Requests // are allowed up to 4 date ranges. message DateRange { // The inclusive start date for the query in the format `YYYY-MM-DD`. Cannot // be after `end_date`. The format `NdaysAgo`, `yesterday`, or `today` is also // accepted, and in that case, the date is inferred based on the property's // reporting time zone. string start_date = 1; // The inclusive end date for the query in the format `YYYY-MM-DD`. Cannot // be before `start_date`. The format `NdaysAgo`, `yesterday`, or `today` is // also accepted, and in that case, the date is inferred based on the // property's reporting time zone. string end_date = 2; // Assigns a name to this date range. The dimension `dateRange` is valued to // this name in a report response. If set, cannot begin with `date_range_` or // `RESERVED_`. If not set, date ranges are named by their zero based index in // the request: `date_range_0`, `date_range_1`, etc. string name = 3; } // The unique identifier of the property whose events are tracked. message Entity { // A Google Analytics GA4 property id. To learn more, see [where to find your // Property // ID](https://developers.google.com/analytics/devguides/reporting/data/v1/property-id). string property_id = 1; } // Dimensions are attributes of your data. For example, the dimension city // indicates the city from which an event originates. Dimension values in report // responses are strings; for example, city could be "Paris" or "New York". // Requests are allowed up to 8 dimensions. message Dimension { // The name of the dimension. See the [API // Dimensions](https://developers.google.com/analytics/devguides/reporting/data/v1/api-schema#dimensions) // for the list of dimension names. // // If `dimensionExpression` is specified, `name` can be any string that you // would like. For example if a `dimensionExpression` concatenates `country` // and `city`, you could call that dimension `countryAndCity`. // // Dimensions are referenced by `name` in `dimensionFilter`, `orderBys`, // `dimensionExpression`, and `pivots`. string name = 1; // One dimension can be the result of an expression of multiple dimensions. // For example, dimension "country, city": concatenate(country, ", ", city). DimensionExpression dimension_expression = 2; } // Used to express a dimension which is the result of a formula of multiple // dimensions. Example usages: // 1) lower_case(dimension) // 2) concatenate(dimension1, symbol, dimension2). message DimensionExpression { // Used to convert a dimension value to a single case. message CaseExpression { // Name of a dimension. The name must refer back to a name in dimensions // field of the request. string dimension_name = 1; } // Used to combine dimension values to a single dimension. message ConcatenateExpression { // Names of dimensions. The names must refer back to names in the dimensions // field of the request. repeated string dimension_names = 1; // The delimiter placed between dimension names. // // Delimiters are often single characters such as "|" or "," but can be // longer strings. If a dimension value contains the delimiter, both will be // present in response with no distinction. For example if dimension 1 value // = "US,FR", dimension 2 value = "JP", and delimiter = ",", then the // response will contain "US,FR,JP". string delimiter = 2; } // Specify one type of dimension expression for `DimensionExpression`. oneof one_expression { // Used to convert a dimension value to lower case. CaseExpression lower_case = 4; // Used to convert a dimension value to upper case. CaseExpression upper_case = 5; // Used to combine dimension values to a single dimension. // For example, dimension "country, city": concatenate(country, ", ", city). ConcatenateExpression concatenate = 6; } } // The quantitative measurements of a report. For example, the metric // `eventCount` is the total number of events. Requests are allowed up to 10 // metrics. message Metric { // The name of the metric. See the [API // Metrics](https://developers.google.com/analytics/devguides/reporting/data/v1/api-schema#metrics) // for the list of metric names. // // If `expression` is specified, `name` can be any string that you would like. // For example if `expression` is `screenPageViews/sessions`, you could call // that metric's name = `viewsPerSession`. // // Metrics are referenced by `name` in `metricFilter`, `orderBys`, and metric // `expression`. string name = 1; // A mathematical expression for derived metrics. For example, the metric // Event count per user is `eventCount/totalUsers`. string expression = 2; // Indicates if a metric is invisible in the report response. If a metric is // invisible, the metric will not produce a column in the response, but can be // used in `metricFilter`, `orderBys`, or a metric `expression`. bool invisible = 3; } // To express dimension or metric filters. // The fields in the same FilterExpression need to be either all dimensions or // all metrics. message FilterExpression { // Specify one type of filter expression for `FilterExpression`. oneof expr { // The FilterExpressions in and_group have an AND relationship. FilterExpressionList and_group = 1; // The FilterExpressions in or_group have an OR relationship. FilterExpressionList or_group = 2; // The FilterExpression is NOT of not_expression. FilterExpression not_expression = 3; // A primitive filter. // All fields in filter in same FilterExpression needs to be either all // dimensions or metrics. Filter filter = 4; } } // A list of filter expressions. message FilterExpressionList { // A list of filter expressions. repeated FilterExpression expressions = 1; } // An expression to filter dimension or metric values. message Filter { // The filter for string message StringFilter { // The match type of a string filter enum MatchType { // Unspecified MATCH_TYPE_UNSPECIFIED = 0; // Exact match of the string value. EXACT = 1; // Begins with the string value. BEGINS_WITH = 2; // Ends with the string value. ENDS_WITH = 3; // Contains the string value. CONTAINS = 4; // Full regular expression match with the string value. FULL_REGEXP = 5; // Partial regular expression match with the string value. PARTIAL_REGEXP = 6; } // The match type for this filter. MatchType match_type = 1; // The string value used for the matching. string value = 2; // If true, the string value is case sensitive. bool case_sensitive = 3; } // The result needs to be in a list of string values. message InListFilter { // The list of string values. // Must be non-empty. repeated string values = 1; // If true, the string value is case sensitive. bool case_sensitive = 2; } // Filters for numeric or date values. message NumericFilter { // The operation applied to a numeric filter enum Operation { // Unspecified. OPERATION_UNSPECIFIED = 0; // Equal EQUAL = 1; // Less than LESS_THAN = 2; // Less than or equal LESS_THAN_OR_EQUAL = 3; // Greater than GREATER_THAN = 4; // Greater than or equal GREATER_THAN_OR_EQUAL = 5; } // The operation type for this filter. Operation operation = 1; // A numeric value or a date value. NumericValue value = 2; } // To express that the result needs to be between two numbers (inclusive). message BetweenFilter { // Begins with this number. NumericValue from_value = 1; // Ends with this number. NumericValue to_value = 2; } // The dimension name or metric name. Must be a name defined in dimensions // or metrics. string field_name = 1; // Specify one type of filter for `Filter`. oneof one_filter { // A filter for null values. If True, a null dimension value is matched by // this filter. Null filter is commonly used inside a NOT filter // expression. For example, a NOT expression of a null filter removes rows // when a dimension is null. bool null_filter = 2; // Strings related filter. StringFilter string_filter = 3; // A filter for in list values. InListFilter in_list_filter = 4; // A filter for numeric or date values. NumericFilter numeric_filter = 5; // A filter for two values. BetweenFilter between_filter = 6; } } // The sort options. message OrderBy { // Sorts by metric values. message MetricOrderBy { // A metric name in the request to order by. string metric_name = 1; } // Sorts by dimension values. message DimensionOrderBy { // Rule to order the string dimension values by. enum OrderType { // Unspecified. ORDER_TYPE_UNSPECIFIED = 0; // Alphanumeric sort by Unicode code point. For example, "2" < "A" < "X" < // "b" < "z". ALPHANUMERIC = 1; // Case insensitive alphanumeric sort by lower case Unicode code point. // For example, "2" < "A" < "b" < "X" < "z". CASE_INSENSITIVE_ALPHANUMERIC = 2; // Dimension values are converted to numbers before sorting. For example // in NUMERIC sort, "25" < "100", and in `ALPHANUMERIC` sort, "100" < // "25". Non-numeric dimension values all have equal ordering value below // all numeric values. NUMERIC = 3; } // A dimension name in the request to order by. string dimension_name = 1; // Controls the rule for dimension value ordering. OrderType order_type = 2; } // Sorts by a pivot column group. message PivotOrderBy { // A pair of dimension names and values. Rows with this dimension pivot pair // are ordered by the metric's value. // // For example if pivots = {{"browser", "Chrome"}} and // metric_name = "Sessions", // then the rows will be sorted based on Sessions in Chrome. // // ---------|----------|----------------|----------|---------------- // | Chrome | Chrome | Safari | Safari // ---------|----------|----------------|----------|---------------- // Country | Sessions | Pages/Sessions | Sessions | Pages/Sessions // ---------|----------|----------------|----------|---------------- // US | 2 | 2 | 3 | 1 // ---------|----------|----------------|----------|---------------- // Canada | 3 | 1 | 4 | 1 // ---------|----------|----------------|----------|---------------- message PivotSelection { // Must be a dimension name from the request. string dimension_name = 1; // Order by only when the named dimension is this value. string dimension_value = 2; } // In the response to order by, order rows by this column. Must be a metric // name from the request. string metric_name = 1; // Used to select a dimension name and value pivot. If multiple pivot // selections are given, the sort occurs on rows where all pivot selection // dimension name and value pairs match the row's dimension name and value // pair. repeated PivotSelection pivot_selections = 2; } // Specify one type of order by for `OrderBy`. oneof one_order_by { // Sorts results by a metric's values. MetricOrderBy metric = 1; // Sorts results by a dimension's values. DimensionOrderBy dimension = 2; // Sorts results by a metric's values within a pivot column group. PivotOrderBy pivot = 3; } // If true, sorts by descending order. bool desc = 4; } // Describes the visible dimension columns and rows in the report response. message Pivot { // Dimension names for visible columns in the report response. Including // "dateRange" produces a date range column; for each row in the response, // dimension values in the date range column will indicate the corresponding // date range from the request. repeated string field_names = 1; // Specifies how dimensions are ordered in the pivot. In the first Pivot, the // OrderBys determine Row and PivotDimensionHeader ordering; in subsequent // Pivots, the OrderBys determine only PivotDimensionHeader ordering. // Dimensions specified in these OrderBys must be a subset of // Pivot.field_names. repeated OrderBy order_bys = 2; // The row count of the start row. The first row is counted as row 0. int64 offset = 3; // The number of rows to return in this pivot. If unspecified, 10 rows are // returned. If -1, all rows are returned. int64 limit = 4; // Aggregate the metrics by dimensions in this pivot using the specified // metric_aggregations. repeated MetricAggregation metric_aggregations = 5; } // Specification of cohorts for a cohort report. // Cohort reports can be used for example to create a time series of user // retention for the cohort. For example, you could select the cohort of users // that were acquired in the first week of September and follow that cohort for // the next six weeks. Selecting the users acquired in the first week of // September cohort is specified in the `cohort` object. Following that // cohort for the next six weeks is specified in the `cohortsRange` object. // // The report response could show a weekly time series where say your app has // retained 60% of this cohort after three weeks and 25% of this cohort after // six weeks. These two percentages can be calculated by the metric // `cohortActiveUsers/cohortTotalUsers` and will be separate rows in the report. message CohortSpec { // Defines the selection criteria to group users into cohorts. // // Most cohort reports define only a single cohort. If multiple cohorts are // specified, each cohort can be recognized in the report by their name. repeated Cohort cohorts = 1; // Cohort reports follow cohorts over an extended reporting date range. This // range specifies an offset duration to follow the cohorts over. CohortsRange cohorts_range = 2; // Optional settings for a cohort report. CohortReportSettings cohort_report_settings = 3; } // Defines a cohort selection criteria. A cohort is a group of users who share // a common characteristic. For example, users with the same `firstTouchDate` // belong to the same cohort. message Cohort { // Assigns a name to this cohort. The dimension `cohort` is valued to this // name in a report response. If set, cannot begin with `cohort_` or // `RESERVED_`. If not set, cohorts are named by their zero based index // `cohort_0`, `cohort_1`, etc. string name = 1; // Dimension used by the cohort. Required and only supports `firstTouchDate`. string dimension = 2; // The cohort selects users whose first touch date is between start date and // end date defined in the `dateRange`. This `dateRange` does not specify the // full date range of event data that is present in a cohort report. In a // cohort report, this `dateRange` is extended by the granularity and offset // present in the `cohortsRange`; event data for the extended reporting date // range is present in a cohort report. // // In a cohort request, this `dateRange` is required and the `dateRanges` in // the `RunReportRequest` or `RunPivotReportRequest` must be unspecified. // // This `dateRange` should generally be aligned with the cohort's granularity. // If `CohortsRange` uses daily granularity, this `dateRange` can be a single // day. If `CohortsRange` uses weekly granularity, this `dateRange` can be // aligned to a week boundary, starting at Sunday and ending Saturday. If // `CohortsRange` uses monthly granularity, this `dateRange` can be aligned to // a month, starting at the first and ending on the last day of the month. DateRange date_range = 3; } // Configures the extended reporting date range for a cohort report. Specifies // an offset duration to follow the cohorts over. message CohortsRange { // The granularity used to interpret the `startOffset` and `endOffset` for the // extended reporting date range for a cohort report. enum Granularity { // Should never be specified. GRANULARITY_UNSPECIFIED = 0; // Daily granularity. Commonly used if the cohort's `dateRange` is a single // day and the request contains `cohortNthDay`. DAILY = 1; // Weekly granularity. Commonly used if the cohort's `dateRange` is a week // in duration (starting on Sunday and ending on Saturday) and the request // contains `cohortNthWeek`. WEEKLY = 2; // Monthly granularity. Commonly used if the cohort's `dateRange` is a month // in duration and the request contains `cohortNthMonth`. MONTHLY = 3; } // The granularity used to interpret the `startOffset` and `endOffset` for the // extended reporting date range for a cohort report. Granularity granularity = 1; // `startOffset` specifies the start date of the extended reporting date range // for a cohort report. `startOffset` is commonly set to 0 so that reports // contain data from the acquisition of the cohort forward. // // If `granularity` is `DAILY`, the `startDate` of the extended reporting date // range is `startDate` of the cohort plus `startOffset` days. // // If `granularity` is `WEEKLY`, the `startDate` of the extended reporting // date range is `startDate` of the cohort plus `startOffset * 7` days. // // If `granularity` is `MONTHLY`, the `startDate` of the extended reporting // date range is `startDate` of the cohort plus `startOffset * 30` days. int32 start_offset = 2; // `endOffset` specifies the end date of the extended reporting date range // for a cohort report. `endOffset` can be any positive integer but is // commonly set to 5 to 10 so that reports contain data on the cohort for the // next several granularity time periods. // // If `granularity` is `DAILY`, the `endDate` of the extended reporting date // range is `endDate` of the cohort plus `endOffset` days. // // If `granularity` is `WEEKLY`, the `endDate` of the extended reporting date // range is `endDate` of the cohort plus `endOffset * 7` days. // // If `granularity` is `MONTHLY`, the `endDate` of the extended reporting date // range is `endDate` of the cohort plus `endOffset * 30` days. int32 end_offset = 3; } // Optional settings of a cohort report. message CohortReportSettings { // If true, accumulates the result from first touch day to the end day. Not // supported in `RunReportRequest`. bool accumulate = 1; } // Response's metadata carrying additional information about the report content. message ResponseMetaData { // If true, indicates some buckets of dimension combinations are rolled into // "(other)" row. This can happen for high cardinality reports. bool data_loss_from_other_row = 3; } // Describes a dimension column in the report. Dimensions requested in a report // produce column entries within rows and DimensionHeaders. However, dimensions // used exclusively within filters or expressions do not produce columns in a // report; correspondingly, those dimensions do not produce headers. message DimensionHeader { // The dimension's name. string name = 1; } // Describes a metric column in the report. Visible metrics requested in a // report produce column entries within rows and MetricHeaders. However, // metrics used exclusively within filters or expressions do not produce columns // in a report; correspondingly, those metrics do not produce headers. message MetricHeader { // The metric's name. string name = 1; // The metric's data type. MetricType type = 2; } // Dimensions' values in a single pivot. message PivotHeader { // The size is the same as the cardinality of the corresponding dimension // combinations. repeated PivotDimensionHeader pivot_dimension_headers = 1; // The cardinality of the pivot as if offset = 0 and limit = -1. The total // number of rows for this pivot's fields regardless of how the parameters // offset and limit are specified in the request. int32 row_count = 2; } // Summarizes dimension values from a row for this pivot. message PivotDimensionHeader { // Values of multiple dimensions in a pivot. repeated DimensionValue dimension_values = 1; } // Report data for each row. // For example if RunReportRequest contains: // // ```none // "dimensions": [ // { // "name": "eventName" // }, // { // "name": "countryId" // } // ], // "metrics": [ // { // "name": "eventCount" // } // ] // ``` // // One row with 'in_app_purchase' as the eventName, 'JP' as the countryId, and // 15 as the eventCount, would be: // // ```none // "dimensionValues": [ // { // "value": "in_app_purchase" // }, // { // "value": "JP" // } // ], // "metricValues": [ // { // "value": "15" // } // ] // ``` message Row { // List of requested dimension values. In a PivotReport, dimension_values // are only listed for dimensions included in a pivot. repeated DimensionValue dimension_values = 1; // List of requested visible metric values. repeated MetricValue metric_values = 2; } // The value of a dimension. message DimensionValue { // One kind of dimension value oneof one_value { // Value as a string if the dimension type is a string. string value = 1; } } // The value of a metric. message MetricValue { // One of metric value oneof one_value { // Measurement value. See MetricHeader for type. string value = 4; } } // To represent a number. message NumericValue { // One of a numeric value oneof one_value { // Integer value int64 int64_value = 1; // Double value double double_value = 2; } } // Current state of all quotas for this Analytics Property. If any quota for a // property is exhausted, all requests to that property will return Resource // Exhausted errors. message PropertyQuota { // Standard Analytics Properties can use up to 25,000 tokens per day; // Analytics 360 Properties can use 250,000 tokens per day. Most requests // consume fewer than 10 tokens. QuotaStatus tokens_per_day = 1; // Standard Analytics Properties can use up to 5,000 tokens per day; Analytics // 360 Properties can use 50,000 tokens per day. An API request consumes a // single number of tokens, and that number is deducted from both the hourly // and daily quotas. QuotaStatus tokens_per_hour = 2; // Standard Analytics Properties can send up to 10 concurrent requests; // Analytics 360 Properties can use up to 50 concurrent requests. QuotaStatus concurrent_requests = 3; // Standard Analytics Properties and cloud project pairs can have up to 10 // server errors per hour; Analytics 360 Properties and cloud project pairs // can have up to 50 server errors per hour. QuotaStatus server_errors_per_project_per_hour = 4; } // Current state for a particular quota group. message QuotaStatus { // Quota consumed by this request. int32 consumed = 1; // Quota remaining after this request. int32 remaining = 2; } // Explains a dimension. message DimensionMetadata { // This dimension's name. Useable in [Dimension](#Dimension)'s `name`. For // example, `eventName`. string api_name = 1; // This dimension's name within the Google Analytics user interface. For // example, `Event name`. string ui_name = 2; // Description of how this dimension is used and calculated. string description = 3; // Still usable but deprecated names for this dimension. If populated, this // dimension is available by either `apiName` or one of `deprecatedApiNames` // for a period of time. After the deprecation period, the dimension will be // available only by `apiName`. repeated string deprecated_api_names = 4; // True if the dimension is a custom dimension for this property. bool custom_definition = 5; } // Explains a metric. message MetricMetadata { // A metric name. Useable in [Metric](#Metric)'s `name`. For example, // `eventCount`. string api_name = 1; // This metric's name within the Google Analytics user interface. For example, // `Event count`. string ui_name = 2; // Description of how this metric is used and calculated. string description = 3; // Still usable but deprecated names for this metric. If populated, this // metric is available by either `apiName` or one of `deprecatedApiNames` // for a period of time. After the deprecation period, the metric will be // available only by `apiName`. repeated string deprecated_api_names = 4; // The type of this metric. MetricType type = 5; // The mathematical expression for this derived metric. Can be used in // [Metric](#Metric)'s `expression` field for equivalent reports. Most metrics // are not expressions, and for non-expressions, this field is empty. string expression = 6; // True if the metric is a custom metric for this property. bool custom_definition = 7; } // Represents aggregation of metrics. enum MetricAggregation { // Unspecified operator. METRIC_AGGREGATION_UNSPECIFIED = 0; // SUM operator. TOTAL = 1; // Minimum operator. MINIMUM = 5; // Maximum operator. MAXIMUM = 6; // Count operator. COUNT = 4; } // A metric's value type. enum MetricType { // Unspecified type. METRIC_TYPE_UNSPECIFIED = 0; // Integer type. TYPE_INTEGER = 1; // Floating point type. TYPE_FLOAT = 2; // A duration of seconds; a special floating point type. TYPE_SECONDS = 4; // A duration in milliseconds; a special floating point type. TYPE_MILLISECONDS = 5; // A duration in minutes; a special floating point type. TYPE_MINUTES = 6; // A duration in hours; a special floating point type. TYPE_HOURS = 7; // A custom metric of standard type; a special floating point type. TYPE_STANDARD = 8; // An amount of money; a special floating point type. TYPE_CURRENCY = 9; // A length in feet; a special floating point type. TYPE_FEET = 10; // A length in miles; a special floating point type. TYPE_MILES = 11; // A length in meters; a special floating point type. TYPE_METERS = 12; // A length in kilometers; a special floating point type. TYPE_KILOMETERS = 13; }