123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876 |
- // Copyright 2022 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.cloud.bigquery.datatransfer.v1;
- import "google/api/annotations.proto";
- import "google/api/client.proto";
- import "google/api/field_behavior.proto";
- import "google/api/resource.proto";
- import "google/cloud/bigquery/datatransfer/v1/transfer.proto";
- import "google/protobuf/duration.proto";
- import "google/protobuf/empty.proto";
- import "google/protobuf/field_mask.proto";
- import "google/protobuf/timestamp.proto";
- import "google/protobuf/wrappers.proto";
- option csharp_namespace = "Google.Cloud.BigQuery.DataTransfer.V1";
- option go_package = "google.golang.org/genproto/googleapis/cloud/bigquery/datatransfer/v1;datatransfer";
- option java_multiple_files = true;
- option java_outer_classname = "DataTransferProto";
- option java_package = "com.google.cloud.bigquery.datatransfer.v1";
- option php_namespace = "Google\\Cloud\\BigQuery\\DataTransfer\\V1";
- option ruby_package = "Google::Cloud::Bigquery::DataTransfer::V1";
- // This API allows users to manage their data transfers into BigQuery.
- service DataTransferService {
- option (google.api.default_host) = "bigquerydatatransfer.googleapis.com";
- option (google.api.oauth_scopes) = "https://www.googleapis.com/auth/cloud-platform";
- // Retrieves a supported data source and returns its settings.
- rpc GetDataSource(GetDataSourceRequest) returns (DataSource) {
- option (google.api.http) = {
- get: "/v1/{name=projects/*/locations/*/dataSources/*}"
- additional_bindings {
- get: "/v1/{name=projects/*/dataSources/*}"
- }
- };
- option (google.api.method_signature) = "name";
- }
- // Lists supported data sources and returns their settings.
- rpc ListDataSources(ListDataSourcesRequest) returns (ListDataSourcesResponse) {
- option (google.api.http) = {
- get: "/v1/{parent=projects/*/locations/*}/dataSources"
- additional_bindings {
- get: "/v1/{parent=projects/*}/dataSources"
- }
- };
- option (google.api.method_signature) = "parent";
- }
- // Creates a new data transfer configuration.
- rpc CreateTransferConfig(CreateTransferConfigRequest) returns (TransferConfig) {
- option (google.api.http) = {
- post: "/v1/{parent=projects/*/locations/*}/transferConfigs"
- body: "transfer_config"
- additional_bindings {
- post: "/v1/{parent=projects/*}/transferConfigs"
- body: "transfer_config"
- }
- };
- option (google.api.method_signature) = "parent,transfer_config";
- }
- // Updates a data transfer configuration.
- // All fields must be set, even if they are not updated.
- rpc UpdateTransferConfig(UpdateTransferConfigRequest) returns (TransferConfig) {
- option (google.api.http) = {
- patch: "/v1/{transfer_config.name=projects/*/locations/*/transferConfigs/*}"
- body: "transfer_config"
- additional_bindings {
- patch: "/v1/{transfer_config.name=projects/*/transferConfigs/*}"
- body: "transfer_config"
- }
- };
- option (google.api.method_signature) = "transfer_config,update_mask";
- }
- // Deletes a data transfer configuration, including any associated transfer
- // runs and logs.
- rpc DeleteTransferConfig(DeleteTransferConfigRequest) returns (google.protobuf.Empty) {
- option (google.api.http) = {
- delete: "/v1/{name=projects/*/locations/*/transferConfigs/*}"
- additional_bindings {
- delete: "/v1/{name=projects/*/transferConfigs/*}"
- }
- };
- option (google.api.method_signature) = "name";
- }
- // Returns information about a data transfer config.
- rpc GetTransferConfig(GetTransferConfigRequest) returns (TransferConfig) {
- option (google.api.http) = {
- get: "/v1/{name=projects/*/locations/*/transferConfigs/*}"
- additional_bindings {
- get: "/v1/{name=projects/*/transferConfigs/*}"
- }
- };
- option (google.api.method_signature) = "name";
- }
- // Returns information about all transfer configs owned by a project in the
- // specified location.
- rpc ListTransferConfigs(ListTransferConfigsRequest) returns (ListTransferConfigsResponse) {
- option (google.api.http) = {
- get: "/v1/{parent=projects/*/locations/*}/transferConfigs"
- additional_bindings {
- get: "/v1/{parent=projects/*}/transferConfigs"
- }
- };
- option (google.api.method_signature) = "parent";
- }
- // Creates transfer runs for a time range [start_time, end_time].
- // For each date - or whatever granularity the data source supports - in the
- // range, one transfer run is created.
- // Note that runs are created per UTC time in the time range.
- // DEPRECATED: use StartManualTransferRuns instead.
- rpc ScheduleTransferRuns(ScheduleTransferRunsRequest) returns (ScheduleTransferRunsResponse) {
- option deprecated = true;
- option (google.api.http) = {
- post: "/v1/{parent=projects/*/locations/*/transferConfigs/*}:scheduleRuns"
- body: "*"
- additional_bindings {
- post: "/v1/{parent=projects/*/transferConfigs/*}:scheduleRuns"
- body: "*"
- }
- };
- option (google.api.method_signature) = "parent,start_time,end_time";
- }
- // Start manual transfer runs to be executed now with schedule_time equal to
- // current time. The transfer runs can be created for a time range where the
- // run_time is between start_time (inclusive) and end_time (exclusive), or for
- // a specific run_time.
- rpc StartManualTransferRuns(StartManualTransferRunsRequest) returns (StartManualTransferRunsResponse) {
- option (google.api.http) = {
- post: "/v1/{parent=projects/*/locations/*/transferConfigs/*}:startManualRuns"
- body: "*"
- additional_bindings {
- post: "/v1/{parent=projects/*/transferConfigs/*}:startManualRuns"
- body: "*"
- }
- };
- }
- // Returns information about the particular transfer run.
- rpc GetTransferRun(GetTransferRunRequest) returns (TransferRun) {
- option (google.api.http) = {
- get: "/v1/{name=projects/*/locations/*/transferConfigs/*/runs/*}"
- additional_bindings {
- get: "/v1/{name=projects/*/transferConfigs/*/runs/*}"
- }
- };
- option (google.api.method_signature) = "name";
- }
- // Deletes the specified transfer run.
- rpc DeleteTransferRun(DeleteTransferRunRequest) returns (google.protobuf.Empty) {
- option (google.api.http) = {
- delete: "/v1/{name=projects/*/locations/*/transferConfigs/*/runs/*}"
- additional_bindings {
- delete: "/v1/{name=projects/*/transferConfigs/*/runs/*}"
- }
- };
- option (google.api.method_signature) = "name";
- }
- // Returns information about running and completed transfer runs.
- rpc ListTransferRuns(ListTransferRunsRequest) returns (ListTransferRunsResponse) {
- option (google.api.http) = {
- get: "/v1/{parent=projects/*/locations/*/transferConfigs/*}/runs"
- additional_bindings {
- get: "/v1/{parent=projects/*/transferConfigs/*}/runs"
- }
- };
- option (google.api.method_signature) = "parent";
- }
- // Returns log messages for the transfer run.
- rpc ListTransferLogs(ListTransferLogsRequest) returns (ListTransferLogsResponse) {
- option (google.api.http) = {
- get: "/v1/{parent=projects/*/locations/*/transferConfigs/*/runs/*}/transferLogs"
- additional_bindings {
- get: "/v1/{parent=projects/*/transferConfigs/*/runs/*}/transferLogs"
- }
- };
- option (google.api.method_signature) = "parent";
- }
- // Returns true if valid credentials exist for the given data source and
- // requesting user.
- rpc CheckValidCreds(CheckValidCredsRequest) returns (CheckValidCredsResponse) {
- option (google.api.http) = {
- post: "/v1/{name=projects/*/locations/*/dataSources/*}:checkValidCreds"
- body: "*"
- additional_bindings {
- post: "/v1/{name=projects/*/dataSources/*}:checkValidCreds"
- body: "*"
- }
- };
- option (google.api.method_signature) = "name";
- }
- // Enroll data sources in a user project. This allows users to create transfer
- // configurations for these data sources. They will also appear in the
- // ListDataSources RPC and as such, will appear in the
- // [BigQuery UI](https://console.cloud.google.com/bigquery), and the documents
- // can be found in the public guide for
- // [BigQuery Web UI](https://cloud.google.com/bigquery/bigquery-web-ui) and
- // [Data Transfer
- // Service](https://cloud.google.com/bigquery/docs/working-with-transfers).
- rpc EnrollDataSources(EnrollDataSourcesRequest) returns (google.protobuf.Empty) {
- option (google.api.http) = {
- post: "/v1/{name=projects/*/locations/*}:enrollDataSources"
- body: "*"
- additional_bindings {
- post: "/v1/{name=projects/*}:enrollDataSources"
- body: "*"
- }
- };
- }
- }
- // A parameter used to define custom fields in a data source definition.
- message DataSourceParameter {
- // Parameter type.
- enum Type {
- // Type unspecified.
- TYPE_UNSPECIFIED = 0;
- // String parameter.
- STRING = 1;
- // Integer parameter (64-bits).
- // Will be serialized to json as string.
- INTEGER = 2;
- // Double precision floating point parameter.
- DOUBLE = 3;
- // Boolean parameter.
- BOOLEAN = 4;
- // Deprecated. This field has no effect.
- RECORD = 5;
- // Page ID for a Google+ Page.
- PLUS_PAGE = 6;
- }
- // Parameter identifier.
- string param_id = 1;
- // Parameter display name in the user interface.
- string display_name = 2;
- // Parameter description.
- string description = 3;
- // Parameter type.
- Type type = 4;
- // Is parameter required.
- bool required = 5;
- // Deprecated. This field has no effect.
- bool repeated = 6;
- // Regular expression which can be used for parameter validation.
- string validation_regex = 7;
- // All possible values for the parameter.
- repeated string allowed_values = 8;
- // For integer and double values specifies minimum allowed value.
- google.protobuf.DoubleValue min_value = 9;
- // For integer and double values specifies maximum allowed value.
- google.protobuf.DoubleValue max_value = 10;
- // Deprecated. This field has no effect.
- repeated DataSourceParameter fields = 11;
- // Description of the requirements for this field, in case the user input does
- // not fulfill the regex pattern or min/max values.
- string validation_description = 12;
- // URL to a help document to further explain the naming requirements.
- string validation_help_url = 13;
- // Cannot be changed after initial creation.
- bool immutable = 14;
- // Deprecated. This field has no effect.
- bool recurse = 15;
- // If true, it should not be used in new transfers, and it should not be
- // visible to users.
- bool deprecated = 20;
- }
- // Defines the properties and custom parameters for a data source.
- message DataSource {
- option (google.api.resource) = {
- type: "bigquerydatatransfer.googleapis.com/DataSource"
- pattern: "projects/{project}/dataSources/{data_source}"
- pattern: "projects/{project}/locations/{location}/dataSources/{data_source}"
- };
- // The type of authorization needed for this data source.
- enum AuthorizationType {
- // Type unspecified.
- AUTHORIZATION_TYPE_UNSPECIFIED = 0;
- // Use OAuth 2 authorization codes that can be exchanged
- // for a refresh token on the backend.
- AUTHORIZATION_CODE = 1;
- // Return an authorization code for a given Google+ page that can then be
- // exchanged for a refresh token on the backend.
- GOOGLE_PLUS_AUTHORIZATION_CODE = 2;
- // Use First Party OAuth.
- FIRST_PARTY_OAUTH = 3;
- }
- // Represents how the data source supports data auto refresh.
- enum DataRefreshType {
- // The data source won't support data auto refresh, which is default value.
- DATA_REFRESH_TYPE_UNSPECIFIED = 0;
- // The data source supports data auto refresh, and runs will be scheduled
- // for the past few days. Does not allow custom values to be set for each
- // transfer config.
- SLIDING_WINDOW = 1;
- // The data source supports data auto refresh, and runs will be scheduled
- // for the past few days. Allows custom values to be set for each transfer
- // config.
- CUSTOM_SLIDING_WINDOW = 2;
- }
- // Output only. Data source resource name.
- string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
- // Data source id.
- string data_source_id = 2;
- // User friendly data source name.
- string display_name = 3;
- // User friendly data source description string.
- string description = 4;
- // Data source client id which should be used to receive refresh token.
- string client_id = 5;
- // Api auth scopes for which refresh token needs to be obtained. These are
- // scopes needed by a data source to prepare data and ingest them into
- // BigQuery, e.g., https://www.googleapis.com/auth/bigquery
- repeated string scopes = 6;
- // Deprecated. This field has no effect.
- TransferType transfer_type = 7 [deprecated = true];
- // Deprecated. This field has no effect.
- bool supports_multiple_transfers = 8 [deprecated = true];
- // The number of seconds to wait for an update from the data source
- // before the Data Transfer Service marks the transfer as FAILED.
- int32 update_deadline_seconds = 9;
- // Default data transfer schedule.
- // Examples of valid schedules include:
- // `1st,3rd monday of month 15:30`,
- // `every wed,fri of jan,jun 13:15`, and
- // `first sunday of quarter 00:00`.
- string default_schedule = 10;
- // Specifies whether the data source supports a user defined schedule, or
- // operates on the default schedule.
- // When set to `true`, user can override default schedule.
- bool supports_custom_schedule = 11;
- // Data source parameters.
- repeated DataSourceParameter parameters = 12;
- // Url for the help document for this data source.
- string help_url = 13;
- // Indicates the type of authorization.
- AuthorizationType authorization_type = 14;
- // Specifies whether the data source supports automatic data refresh for the
- // past few days, and how it's supported.
- // For some data sources, data might not be complete until a few days later,
- // so it's useful to refresh data automatically.
- DataRefreshType data_refresh_type = 15;
- // Default data refresh window on days.
- // Only meaningful when `data_refresh_type` = `SLIDING_WINDOW`.
- int32 default_data_refresh_window_days = 16;
- // Disables backfilling and manual run scheduling
- // for the data source.
- bool manual_runs_disabled = 17;
- // The minimum interval for scheduler to schedule runs.
- google.protobuf.Duration minimum_schedule_interval = 18;
- }
- // A request to get data source info.
- message GetDataSourceRequest {
- // Required. The field will contain name of the resource requested, for example:
- // `projects/{project_id}/dataSources/{data_source_id}` or
- // `projects/{project_id}/locations/{location_id}/dataSources/{data_source_id}`
- string name = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "bigquerydatatransfer.googleapis.com/DataSource"
- }
- ];
- }
- // Request to list supported data sources and their data transfer settings.
- message ListDataSourcesRequest {
- // Required. The BigQuery project id for which data sources should be returned.
- // Must be in the form: `projects/{project_id}` or
- // `projects/{project_id}/locations/{location_id}`
- string parent = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- child_type: "bigquerydatatransfer.googleapis.com/DataSource"
- }
- ];
- // Pagination token, which can be used to request a specific page
- // of `ListDataSourcesRequest` list results. For multiple-page
- // results, `ListDataSourcesResponse` outputs
- // a `next_page` token, which can be used as the
- // `page_token` value to request the next page of list results.
- string page_token = 3;
- // Page size. The default page size is the maximum value of 1000 results.
- int32 page_size = 4;
- }
- // Returns list of supported data sources and their metadata.
- message ListDataSourcesResponse {
- // List of supported data sources and their transfer settings.
- repeated DataSource data_sources = 1;
- // Output only. The next-pagination token. For multiple-page list results,
- // this token can be used as the
- // `ListDataSourcesRequest.page_token`
- // to request the next page of list results.
- string next_page_token = 2 [(google.api.field_behavior) = OUTPUT_ONLY];
- }
- // A request to create a data transfer configuration. If new credentials are
- // needed for this transfer configuration, authorization info must be provided.
- // If authorization info is provided, the transfer configuration will be
- // associated with the user id corresponding to the authorization info.
- // Otherwise, the transfer configuration will be associated with the calling
- // user.
- message CreateTransferConfigRequest {
- // Required. The BigQuery project id where the transfer configuration should be created.
- // Must be in the format projects/{project_id}/locations/{location_id} or
- // projects/{project_id}. If specified location and location of the
- // destination bigquery dataset do not match - the request will fail.
- string parent = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- child_type: "bigquerydatatransfer.googleapis.com/TransferConfig"
- }
- ];
- // Required. Data transfer configuration to create.
- TransferConfig transfer_config = 2 [(google.api.field_behavior) = REQUIRED];
- // Optional OAuth2 authorization code to use with this transfer configuration.
- // This is required only if `transferConfig.dataSourceId` is 'youtube_channel'
- // and new credentials are needed, as indicated by `CheckValidCreds`. In order
- // to obtain authorization_code, make a request to the following URL:
- // <pre class="prettyprint" suppresswarning="true">
- // https://www.gstatic.com/bigquerydatatransfer/oauthz/auth?redirect_uri=urn:ietf:wg:oauth:2.0:oob&response_type=authorization_code&client_id=<var>client_id</var>&scope=<var>data_source_scopes</var>
- // </pre>
- // * The <var>client_id</var> is the OAuth client_id of the a data source as
- // returned by ListDataSources method.
- // * <var>data_source_scopes</var> are the scopes returned by ListDataSources
- // method.
- //
- // Note that this should not be set when `service_account_name` is used to
- // create the transfer config.
- string authorization_code = 3;
- // Optional version info. This is required only if
- // `transferConfig.dataSourceId` is not 'youtube_channel' and new credentials
- // are needed, as indicated by `CheckValidCreds`. In order to obtain version
- // info, make a request to the following URL:
- // <pre class="prettyprint" suppresswarning="true">
- // https://www.gstatic.com/bigquerydatatransfer/oauthz/auth?redirect_uri=urn:ietf:wg:oauth:2.0:oob&response_type=version_info&client_id=<var>client_id</var>&scope=<var>data_source_scopes</var>
- // </pre>
- // * The <var>client_id</var> is the OAuth client_id of the a data source as
- // returned by ListDataSources method.
- // * <var>data_source_scopes</var> are the scopes returned by ListDataSources
- // method.
- //
- // Note that this should not be set when `service_account_name` is used to
- // create the transfer config.
- string version_info = 5;
- // Optional service account name. If this field is set, the transfer config
- // will be created with this service account's credentials. It requires that
- // the requesting user calling this API has permissions to act as this service
- // account.
- //
- // Note that not all data sources support service account credentials when
- // creating a transfer config. For the latest list of data sources, read about
- // [using service
- // accounts](https://cloud.google.com/bigquery-transfer/docs/use-service-accounts).
- string service_account_name = 6;
- }
- // A request to update a transfer configuration. To update the user id of the
- // transfer configuration, authorization info needs to be provided.
- message UpdateTransferConfigRequest {
- // Required. Data transfer configuration to create.
- TransferConfig transfer_config = 1 [(google.api.field_behavior) = REQUIRED];
- // Optional OAuth2 authorization code to use with this transfer configuration.
- // This is required only if `transferConfig.dataSourceId` is 'youtube_channel'
- // and new credentials are needed, as indicated by `CheckValidCreds`. In order
- // to obtain authorization_code, make a request to the following URL:
- // <pre class="prettyprint" suppresswarning="true">
- // https://www.gstatic.com/bigquerydatatransfer/oauthz/auth?redirect_uri=urn:ietf:wg:oauth:2.0:oob&response_type=authorization_code&client_id=<var>client_id</var>&scope=<var>data_source_scopes</var>
- // </pre>
- // * The <var>client_id</var> is the OAuth client_id of the a data source as
- // returned by ListDataSources method.
- // * <var>data_source_scopes</var> are the scopes returned by ListDataSources
- // method.
- //
- // Note that this should not be set when `service_account_name` is used to
- // update the transfer config.
- string authorization_code = 3;
- // Required. Required list of fields to be updated in this request.
- google.protobuf.FieldMask update_mask = 4 [(google.api.field_behavior) = REQUIRED];
- // Optional version info. This is required only if
- // `transferConfig.dataSourceId` is not 'youtube_channel' and new credentials
- // are needed, as indicated by `CheckValidCreds`. In order to obtain version
- // info, make a request to the following URL:
- // <pre class="prettyprint" suppresswarning="true">
- // https://www.gstatic.com/bigquerydatatransfer/oauthz/auth?redirect_uri=urn:ietf:wg:oauth:2.0:oob&response_type=version_info&client_id=<var>client_id</var>&scope=<var>data_source_scopes</var>
- // </pre>
- // * The <var>client_id</var> is the OAuth client_id of the a data source as
- // returned by ListDataSources method.
- // * <var>data_source_scopes</var> are the scopes returned by ListDataSources
- // method.
- //
- // Note that this should not be set when `service_account_name` is used to
- // update the transfer config.
- string version_info = 5;
- // Optional service account name. If this field is set, the transfer config
- // will be created with this service account's credentials. It requires that
- // the requesting user calling this API has permissions to act as this service
- // account.
- //
- // Note that not all data sources support service account credentials when
- // creating a transfer config. For the latest list of data sources, read about
- // [using service
- // accounts](https://cloud.google.com/bigquery-transfer/docs/use-service-accounts).
- string service_account_name = 6;
- }
- // A request to get data transfer information.
- message GetTransferConfigRequest {
- // Required. The field will contain name of the resource requested, for example:
- // `projects/{project_id}/transferConfigs/{config_id}` or
- // `projects/{project_id}/locations/{location_id}/transferConfigs/{config_id}`
- string name = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "bigquerydatatransfer.googleapis.com/TransferConfig"
- }
- ];
- }
- // A request to delete data transfer information. All associated transfer runs
- // and log messages will be deleted as well.
- message DeleteTransferConfigRequest {
- // Required. The field will contain name of the resource requested, for example:
- // `projects/{project_id}/transferConfigs/{config_id}` or
- // `projects/{project_id}/locations/{location_id}/transferConfigs/{config_id}`
- string name = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "bigquerydatatransfer.googleapis.com/TransferConfig"
- }
- ];
- }
- // A request to get data transfer run information.
- message GetTransferRunRequest {
- // Required. The field will contain name of the resource requested, for example:
- // `projects/{project_id}/transferConfigs/{config_id}/runs/{run_id}` or
- // `projects/{project_id}/locations/{location_id}/transferConfigs/{config_id}/runs/{run_id}`
- string name = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "bigquerydatatransfer.googleapis.com/Run"
- }
- ];
- }
- // A request to delete data transfer run information.
- message DeleteTransferRunRequest {
- // Required. The field will contain name of the resource requested, for example:
- // `projects/{project_id}/transferConfigs/{config_id}/runs/{run_id}` or
- // `projects/{project_id}/locations/{location_id}/transferConfigs/{config_id}/runs/{run_id}`
- string name = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "bigquerydatatransfer.googleapis.com/Run"
- }
- ];
- }
- // A request to list data transfers configured for a BigQuery project.
- message ListTransferConfigsRequest {
- // Required. The BigQuery project id for which transfer configs
- // should be returned: `projects/{project_id}` or
- // `projects/{project_id}/locations/{location_id}`
- string parent = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- child_type: "bigquerydatatransfer.googleapis.com/TransferConfig"
- }
- ];
- // When specified, only configurations of requested data sources are returned.
- repeated string data_source_ids = 2;
- // Pagination token, which can be used to request a specific page
- // of `ListTransfersRequest` list results. For multiple-page
- // results, `ListTransfersResponse` outputs
- // a `next_page` token, which can be used as the
- // `page_token` value to request the next page of list results.
- string page_token = 3;
- // Page size. The default page size is the maximum value of 1000 results.
- int32 page_size = 4;
- }
- // The returned list of pipelines in the project.
- message ListTransferConfigsResponse {
- // Output only. The stored pipeline transfer configurations.
- repeated TransferConfig transfer_configs = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
- // Output only. The next-pagination token. For multiple-page list results,
- // this token can be used as the
- // `ListTransferConfigsRequest.page_token`
- // to request the next page of list results.
- string next_page_token = 2 [(google.api.field_behavior) = OUTPUT_ONLY];
- }
- // A request to list data transfer runs.
- message ListTransferRunsRequest {
- // Represents which runs should be pulled.
- enum RunAttempt {
- // All runs should be returned.
- RUN_ATTEMPT_UNSPECIFIED = 0;
- // Only latest run per day should be returned.
- LATEST = 1;
- }
- // Required. Name of transfer configuration for which transfer runs should be retrieved.
- // Format of transfer configuration resource name is:
- // `projects/{project_id}/transferConfigs/{config_id}` or
- // `projects/{project_id}/locations/{location_id}/transferConfigs/{config_id}`.
- string parent = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- child_type: "bigquerydatatransfer.googleapis.com/Run"
- }
- ];
- // When specified, only transfer runs with requested states are returned.
- repeated TransferState states = 2;
- // Pagination token, which can be used to request a specific page
- // of `ListTransferRunsRequest` list results. For multiple-page
- // results, `ListTransferRunsResponse` outputs
- // a `next_page` token, which can be used as the
- // `page_token` value to request the next page of list results.
- string page_token = 3;
- // Page size. The default page size is the maximum value of 1000 results.
- int32 page_size = 4;
- // Indicates how run attempts are to be pulled.
- RunAttempt run_attempt = 5;
- }
- // The returned list of pipelines in the project.
- message ListTransferRunsResponse {
- // Output only. The stored pipeline transfer runs.
- repeated TransferRun transfer_runs = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
- // Output only. The next-pagination token. For multiple-page list results,
- // this token can be used as the
- // `ListTransferRunsRequest.page_token`
- // to request the next page of list results.
- string next_page_token = 2 [(google.api.field_behavior) = OUTPUT_ONLY];
- }
- // A request to get user facing log messages associated with data transfer run.
- message ListTransferLogsRequest {
- // Required. Transfer run name in the form:
- // `projects/{project_id}/transferConfigs/{config_id}/runs/{run_id}` or
- // `projects/{project_id}/locations/{location_id}/transferConfigs/{config_id}/runs/{run_id}`
- string parent = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "bigquerydatatransfer.googleapis.com/Run"
- }
- ];
- // Pagination token, which can be used to request a specific page
- // of `ListTransferLogsRequest` list results. For multiple-page
- // results, `ListTransferLogsResponse` outputs
- // a `next_page` token, which can be used as the
- // `page_token` value to request the next page of list results.
- string page_token = 4;
- // Page size. The default page size is the maximum value of 1000 results.
- int32 page_size = 5;
- // Message types to return. If not populated - INFO, WARNING and ERROR
- // messages are returned.
- repeated TransferMessage.MessageSeverity message_types = 6;
- }
- // The returned list transfer run messages.
- message ListTransferLogsResponse {
- // Output only. The stored pipeline transfer messages.
- repeated TransferMessage transfer_messages = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
- // Output only. The next-pagination token. For multiple-page list results,
- // this token can be used as the
- // `GetTransferRunLogRequest.page_token`
- // to request the next page of list results.
- string next_page_token = 2 [(google.api.field_behavior) = OUTPUT_ONLY];
- }
- // A request to determine whether the user has valid credentials. This method
- // is used to limit the number of OAuth popups in the user interface. The
- // user id is inferred from the API call context.
- // If the data source has the Google+ authorization type, this method
- // returns false, as it cannot be determined whether the credentials are
- // already valid merely based on the user id.
- message CheckValidCredsRequest {
- // Required. The data source in the form:
- // `projects/{project_id}/dataSources/{data_source_id}` or
- // `projects/{project_id}/locations/{location_id}/dataSources/{data_source_id}`.
- string name = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "bigquerydatatransfer.googleapis.com/DataSource"
- }
- ];
- }
- // A response indicating whether the credentials exist and are valid.
- message CheckValidCredsResponse {
- // If set to `true`, the credentials exist and are valid.
- bool has_valid_creds = 1;
- }
- // A request to schedule transfer runs for a time range.
- message ScheduleTransferRunsRequest {
- // Required. Transfer configuration name in the form:
- // `projects/{project_id}/transferConfigs/{config_id}` or
- // `projects/{project_id}/locations/{location_id}/transferConfigs/{config_id}`.
- string parent = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "bigquerydatatransfer.googleapis.com/TransferConfig"
- }
- ];
- // Required. Start time of the range of transfer runs. For example,
- // `"2017-05-25T00:00:00+00:00"`.
- google.protobuf.Timestamp start_time = 2 [(google.api.field_behavior) = REQUIRED];
- // Required. End time of the range of transfer runs. For example,
- // `"2017-05-30T00:00:00+00:00"`.
- google.protobuf.Timestamp end_time = 3 [(google.api.field_behavior) = REQUIRED];
- }
- // A response to schedule transfer runs for a time range.
- message ScheduleTransferRunsResponse {
- // The transfer runs that were scheduled.
- repeated TransferRun runs = 1;
- }
- // A request to start manual transfer runs.
- message StartManualTransferRunsRequest {
- // A specification for a time range, this will request transfer runs with
- // run_time between start_time (inclusive) and end_time (exclusive).
- message TimeRange {
- // Start time of the range of transfer runs. For example,
- // `"2017-05-25T00:00:00+00:00"`. The start_time must be strictly less than
- // the end_time. Creates transfer runs where run_time is in the range
- // between start_time (inclusive) and end_time (exclusive).
- google.protobuf.Timestamp start_time = 1;
- // End time of the range of transfer runs. For example,
- // `"2017-05-30T00:00:00+00:00"`. The end_time must not be in the future.
- // Creates transfer runs where run_time is in the range between start_time
- // (inclusive) and end_time (exclusive).
- google.protobuf.Timestamp end_time = 2;
- }
- // Transfer configuration name in the form:
- // `projects/{project_id}/transferConfigs/{config_id}` or
- // `projects/{project_id}/locations/{location_id}/transferConfigs/{config_id}`.
- string parent = 1 [(google.api.resource_reference) = {
- type: "bigquerydatatransfer.googleapis.com/TransferConfig"
- }];
- // The requested time specification - this can be a time range or a specific
- // run_time.
- oneof time {
- // Time range for the transfer runs that should be started.
- TimeRange requested_time_range = 3;
- // Specific run_time for a transfer run to be started. The
- // requested_run_time must not be in the future.
- google.protobuf.Timestamp requested_run_time = 4;
- }
- }
- // A response to start manual transfer runs.
- message StartManualTransferRunsResponse {
- // The transfer runs that were created.
- repeated TransferRun runs = 1;
- }
- // A request to enroll a set of data sources so they are visible in the
- // BigQuery UI's `Transfer` tab.
- message EnrollDataSourcesRequest {
- // The name of the project resource in the form: `projects/{project_id}`
- string name = 1;
- // Data sources that are enrolled. It is required to provide at least one
- // data source id.
- repeated string data_source_ids = 2;
- }
|