blob: f879413f7f973172e62af818142d917913b1f75b [file] [log] [blame]
// This is a generated file (see the discoveryapis_generator project).
library googleapis.bigquery.v2;
import 'dart:core' as core;
import 'dart:collection' as collection;
import 'dart:async' as async;
import 'dart:convert' as convert;
import 'package:_discoveryapis_commons/_discoveryapis_commons.dart' as commons;
import 'package:http/http.dart' as http;
export 'package:_discoveryapis_commons/_discoveryapis_commons.dart' show
ApiRequestError, DetailedApiRequestError, Media, UploadOptions,
ResumableUploadOptions, DownloadOptions, PartialDownloadOptions,
ByteRange;
const core.String USER_AGENT = 'dart-api-client bigquery/v2';
/** A data platform for customers to create, manage, share and query data. */
class BigqueryApi {
/** View and manage your data in Google BigQuery */
static const BigqueryScope = "https://www.googleapis.com/auth/bigquery";
/** Insert data into Google BigQuery */
static const BigqueryInsertdataScope = "https://www.googleapis.com/auth/bigquery.insertdata";
/** View and manage your data across Google Cloud Platform services */
static const CloudPlatformScope = "https://www.googleapis.com/auth/cloud-platform";
/** View your data across Google Cloud Platform services */
static const CloudPlatformReadOnlyScope = "https://www.googleapis.com/auth/cloud-platform.read-only";
/** Manage your data and permissions in Google Cloud Storage */
static const DevstorageFullControlScope = "https://www.googleapis.com/auth/devstorage.full_control";
/** View your data in Google Cloud Storage */
static const DevstorageReadOnlyScope = "https://www.googleapis.com/auth/devstorage.read_only";
/** Manage your data in Google Cloud Storage */
static const DevstorageReadWriteScope = "https://www.googleapis.com/auth/devstorage.read_write";
final commons.ApiRequester _requester;
DatasetsResourceApi get datasets => new DatasetsResourceApi(_requester);
JobsResourceApi get jobs => new JobsResourceApi(_requester);
ProjectsResourceApi get projects => new ProjectsResourceApi(_requester);
TabledataResourceApi get tabledata => new TabledataResourceApi(_requester);
TablesResourceApi get tables => new TablesResourceApi(_requester);
BigqueryApi(http.Client client, {core.String rootUrl: "https://www.googleapis.com/", core.String servicePath: "bigquery/v2/"}) :
_requester = new commons.ApiRequester(client, rootUrl, servicePath, USER_AGENT);
}
class DatasetsResourceApi {
final commons.ApiRequester _requester;
DatasetsResourceApi(commons.ApiRequester client) :
_requester = client;
/**
* Deletes the dataset specified by the datasetId value. Before you can delete
* a dataset, you must delete all its tables, either manually or by specifying
* deleteContents. Immediately after deletion, you can create another dataset
* with the same name.
*
* Request parameters:
*
* [projectId] - Project ID of the dataset being deleted
*
* [datasetId] - Dataset ID of dataset being deleted
*
* [deleteContents] - If True, delete all the tables in the dataset. If False
* and the dataset contains tables, the request will fail. Default is False
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future delete(core.String projectId, core.String datasetId, {core.bool deleteContents}) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
if (deleteContents != null) {
_queryParams["deleteContents"] = ["${deleteContents}"];
}
_downloadOptions = null;
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId');
var _response = _requester.request(_url,
"DELETE",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => null);
}
/**
* Returns the dataset specified by datasetID.
*
* Request parameters:
*
* [projectId] - Project ID of the requested dataset
*
* [datasetId] - Dataset ID of the requested dataset
*
* Completes with a [Dataset].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<Dataset> get(core.String projectId, core.String datasetId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId');
var _response = _requester.request(_url,
"GET",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new Dataset.fromJson(data));
}
/**
* Creates a new empty dataset.
*
* [request] - The metadata request object.
*
* Request parameters:
*
* [projectId] - Project ID of the new dataset
*
* Completes with a [Dataset].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<Dataset> insert(Dataset request, core.String projectId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (request != null) {
_body = convert.JSON.encode((request).toJson());
}
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets';
var _response = _requester.request(_url,
"POST",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new Dataset.fromJson(data));
}
/**
* Lists all datasets in the specified project to which you have been granted
* the READER dataset role.
*
* Request parameters:
*
* [projectId] - Project ID of the datasets to be listed
*
* [all] - Whether to list all datasets, including hidden ones
*
* [filter] - An expression for filtering the results of the request by label.
* The syntax is "labels.<name>[:<value>]". Multiple filters can be ANDed
* together by connecting with a space. Example: "labels.department:receiving
* labels.active". See Filtering datasets using labels for details.
*
* [maxResults] - The maximum number of results to return
*
* [pageToken] - Page token, returned by a previous call, to request the next
* page of results
*
* Completes with a [DatasetList].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<DatasetList> list(core.String projectId, {core.bool all, core.String filter, core.int maxResults, core.String pageToken}) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (all != null) {
_queryParams["all"] = ["${all}"];
}
if (filter != null) {
_queryParams["filter"] = [filter];
}
if (maxResults != null) {
_queryParams["maxResults"] = ["${maxResults}"];
}
if (pageToken != null) {
_queryParams["pageToken"] = [pageToken];
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets';
var _response = _requester.request(_url,
"GET",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new DatasetList.fromJson(data));
}
/**
* Updates information in an existing dataset. The update method replaces the
* entire dataset resource, whereas the patch method only replaces fields that
* are provided in the submitted dataset resource. This method supports patch
* semantics.
*
* [request] - The metadata request object.
*
* Request parameters:
*
* [projectId] - Project ID of the dataset being updated
*
* [datasetId] - Dataset ID of the dataset being updated
*
* Completes with a [Dataset].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<Dataset> patch(Dataset request, core.String projectId, core.String datasetId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (request != null) {
_body = convert.JSON.encode((request).toJson());
}
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId');
var _response = _requester.request(_url,
"PATCH",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new Dataset.fromJson(data));
}
/**
* Updates information in an existing dataset. The update method replaces the
* entire dataset resource, whereas the patch method only replaces fields that
* are provided in the submitted dataset resource.
*
* [request] - The metadata request object.
*
* Request parameters:
*
* [projectId] - Project ID of the dataset being updated
*
* [datasetId] - Dataset ID of the dataset being updated
*
* Completes with a [Dataset].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<Dataset> update(Dataset request, core.String projectId, core.String datasetId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (request != null) {
_body = convert.JSON.encode((request).toJson());
}
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId');
var _response = _requester.request(_url,
"PUT",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new Dataset.fromJson(data));
}
}
class JobsResourceApi {
final commons.ApiRequester _requester;
JobsResourceApi(commons.ApiRequester client) :
_requester = client;
/**
* Requests that a job be cancelled. This call will return immediately, and
* the client will need to poll for the job status to see if the cancel
* completed successfully. Cancelled jobs may still incur costs.
*
* Request parameters:
*
* [projectId] - [Required] Project ID of the job to cancel
*
* [jobId] - [Required] Job ID of the job to cancel
*
* Completes with a [JobCancelResponse].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<JobCancelResponse> cancel(core.String projectId, core.String jobId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (jobId == null) {
throw new core.ArgumentError("Parameter jobId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/jobs/' + commons.Escaper.ecapeVariable('$jobId') + '/cancel';
var _response = _requester.request(_url,
"POST",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new JobCancelResponse.fromJson(data));
}
/**
* Returns information about a specific job. Job information is available for
* a six month period after creation. Requires that you're the person who ran
* the job, or have the Is Owner project role.
*
* Request parameters:
*
* [projectId] - [Required] Project ID of the requested job
*
* [jobId] - [Required] Job ID of the requested job
*
* Completes with a [Job].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<Job> get(core.String projectId, core.String jobId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (jobId == null) {
throw new core.ArgumentError("Parameter jobId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/jobs/' + commons.Escaper.ecapeVariable('$jobId');
var _response = _requester.request(_url,
"GET",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new Job.fromJson(data));
}
/**
* Retrieves the results of a query job.
*
* Request parameters:
*
* [projectId] - [Required] Project ID of the query job
*
* [jobId] - [Required] Job ID of the query job
*
* [maxResults] - Maximum number of results to read
*
* [pageToken] - Page token, returned by a previous call, to request the next
* page of results
*
* [startIndex] - Zero-based index of the starting row
*
* [timeoutMs] - How long to wait for the query to complete, in milliseconds,
* before returning. Default is 10 seconds. If the timeout passes before the
* job completes, the 'jobComplete' field in the response will be false
*
* Completes with a [GetQueryResultsResponse].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<GetQueryResultsResponse> getQueryResults(core.String projectId, core.String jobId, {core.int maxResults, core.String pageToken, core.String startIndex, core.int timeoutMs}) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (jobId == null) {
throw new core.ArgumentError("Parameter jobId is required.");
}
if (maxResults != null) {
_queryParams["maxResults"] = ["${maxResults}"];
}
if (pageToken != null) {
_queryParams["pageToken"] = [pageToken];
}
if (startIndex != null) {
_queryParams["startIndex"] = [startIndex];
}
if (timeoutMs != null) {
_queryParams["timeoutMs"] = ["${timeoutMs}"];
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/queries/' + commons.Escaper.ecapeVariable('$jobId');
var _response = _requester.request(_url,
"GET",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new GetQueryResultsResponse.fromJson(data));
}
/**
* Starts a new asynchronous job. Requires the Can View project role.
*
* [request] - The metadata request object.
*
* Request parameters:
*
* [projectId] - Project ID of the project that will be billed for the job
*
* [uploadMedia] - The media to upload.
*
* [uploadOptions] - Options for the media upload. Streaming Media without the
* length being known ahead of time is only supported via resumable uploads.
*
* Completes with a [Job].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<Job> insert(Job request, core.String projectId, {commons.UploadOptions uploadOptions : commons.UploadOptions.Default, commons.Media uploadMedia}) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (request != null) {
_body = convert.JSON.encode((request).toJson());
}
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
_uploadMedia = uploadMedia;
_uploadOptions = uploadOptions;
if (_uploadMedia == null) {
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/jobs';
} else if (_uploadOptions is commons.ResumableUploadOptions) {
_url = '/resumable/upload/bigquery/v2/projects/' + commons.Escaper.ecapeVariable('$projectId') + '/jobs';
} else {
_url = '/upload/bigquery/v2/projects/' + commons.Escaper.ecapeVariable('$projectId') + '/jobs';
}
var _response = _requester.request(_url,
"POST",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new Job.fromJson(data));
}
/**
* Lists all jobs that you started in the specified project. Job information
* is available for a six month period after creation. The job list is sorted
* in reverse chronological order, by job creation time. Requires the Can View
* project role, or the Is Owner project role if you set the allUsers
* property.
*
* Request parameters:
*
* [projectId] - Project ID of the jobs to list
*
* [allUsers] - Whether to display jobs owned by all users in the project.
* Default false
*
* [maxResults] - Maximum number of results to return
*
* [pageToken] - Page token, returned by a previous call, to request the next
* page of results
*
* [projection] - Restrict information returned to a set of selected fields
* Possible string values are:
* - "full" : Includes all job data
* - "minimal" : Does not include the job configuration
*
* [stateFilter] - Filter for job state
*
* Completes with a [JobList].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<JobList> list(core.String projectId, {core.bool allUsers, core.int maxResults, core.String pageToken, core.String projection, core.List<core.String> stateFilter}) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (allUsers != null) {
_queryParams["allUsers"] = ["${allUsers}"];
}
if (maxResults != null) {
_queryParams["maxResults"] = ["${maxResults}"];
}
if (pageToken != null) {
_queryParams["pageToken"] = [pageToken];
}
if (projection != null) {
_queryParams["projection"] = [projection];
}
if (stateFilter != null) {
_queryParams["stateFilter"] = stateFilter;
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/jobs';
var _response = _requester.request(_url,
"GET",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new JobList.fromJson(data));
}
/**
* Runs a BigQuery SQL query synchronously and returns query results if the
* query completes within a specified timeout.
*
* [request] - The metadata request object.
*
* Request parameters:
*
* [projectId] - Project ID of the project billed for the query
*
* Completes with a [QueryResponse].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<QueryResponse> query(QueryRequest request, core.String projectId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (request != null) {
_body = convert.JSON.encode((request).toJson());
}
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/queries';
var _response = _requester.request(_url,
"POST",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new QueryResponse.fromJson(data));
}
}
class ProjectsResourceApi {
final commons.ApiRequester _requester;
ProjectsResourceApi(commons.ApiRequester client) :
_requester = client;
/**
* Lists all projects to which you have been granted any project role.
*
* Request parameters:
*
* [maxResults] - Maximum number of results to return
*
* [pageToken] - Page token, returned by a previous call, to request the next
* page of results
*
* Completes with a [ProjectList].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<ProjectList> list({core.int maxResults, core.String pageToken}) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (maxResults != null) {
_queryParams["maxResults"] = ["${maxResults}"];
}
if (pageToken != null) {
_queryParams["pageToken"] = [pageToken];
}
_url = 'projects';
var _response = _requester.request(_url,
"GET",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new ProjectList.fromJson(data));
}
}
class TabledataResourceApi {
final commons.ApiRequester _requester;
TabledataResourceApi(commons.ApiRequester client) :
_requester = client;
/**
* Streams data into BigQuery one record at a time without needing to run a
* load job. Requires the WRITER dataset role.
*
* [request] - The metadata request object.
*
* Request parameters:
*
* [projectId] - Project ID of the destination table.
*
* [datasetId] - Dataset ID of the destination table.
*
* [tableId] - Table ID of the destination table.
*
* Completes with a [TableDataInsertAllResponse].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<TableDataInsertAllResponse> insertAll(TableDataInsertAllRequest request, core.String projectId, core.String datasetId, core.String tableId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (request != null) {
_body = convert.JSON.encode((request).toJson());
}
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
if (tableId == null) {
throw new core.ArgumentError("Parameter tableId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId') + '/tables/' + commons.Escaper.ecapeVariable('$tableId') + '/insertAll';
var _response = _requester.request(_url,
"POST",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new TableDataInsertAllResponse.fromJson(data));
}
/**
* Retrieves table data from a specified set of rows. Requires the READER
* dataset role.
*
* Request parameters:
*
* [projectId] - Project ID of the table to read
*
* [datasetId] - Dataset ID of the table to read
*
* [tableId] - Table ID of the table to read
*
* [maxResults] - Maximum number of results to return
*
* [pageToken] - Page token, returned by a previous call, identifying the
* result set
*
* [selectedFields] - List of fields to return (comma-separated). If
* unspecified, all fields are returned
*
* [startIndex] - Zero-based index of the starting row to read
*
* Completes with a [TableDataList].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<TableDataList> list(core.String projectId, core.String datasetId, core.String tableId, {core.int maxResults, core.String pageToken, core.String selectedFields, core.String startIndex}) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
if (tableId == null) {
throw new core.ArgumentError("Parameter tableId is required.");
}
if (maxResults != null) {
_queryParams["maxResults"] = ["${maxResults}"];
}
if (pageToken != null) {
_queryParams["pageToken"] = [pageToken];
}
if (selectedFields != null) {
_queryParams["selectedFields"] = [selectedFields];
}
if (startIndex != null) {
_queryParams["startIndex"] = [startIndex];
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId') + '/tables/' + commons.Escaper.ecapeVariable('$tableId') + '/data';
var _response = _requester.request(_url,
"GET",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new TableDataList.fromJson(data));
}
}
class TablesResourceApi {
final commons.ApiRequester _requester;
TablesResourceApi(commons.ApiRequester client) :
_requester = client;
/**
* Deletes the table specified by tableId from the dataset. If the table
* contains data, all the data will be deleted.
*
* Request parameters:
*
* [projectId] - Project ID of the table to delete
*
* [datasetId] - Dataset ID of the table to delete
*
* [tableId] - Table ID of the table to delete
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future delete(core.String projectId, core.String datasetId, core.String tableId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
if (tableId == null) {
throw new core.ArgumentError("Parameter tableId is required.");
}
_downloadOptions = null;
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId') + '/tables/' + commons.Escaper.ecapeVariable('$tableId');
var _response = _requester.request(_url,
"DELETE",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => null);
}
/**
* Gets the specified table resource by table ID. This method does not return
* the data in the table, it only returns the table resource, which describes
* the structure of this table.
*
* Request parameters:
*
* [projectId] - Project ID of the requested table
*
* [datasetId] - Dataset ID of the requested table
*
* [tableId] - Table ID of the requested table
*
* [selectedFields] - List of fields to return (comma-separated). If
* unspecified, all fields are returned
*
* Completes with a [Table].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<Table> get(core.String projectId, core.String datasetId, core.String tableId, {core.String selectedFields}) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
if (tableId == null) {
throw new core.ArgumentError("Parameter tableId is required.");
}
if (selectedFields != null) {
_queryParams["selectedFields"] = [selectedFields];
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId') + '/tables/' + commons.Escaper.ecapeVariable('$tableId');
var _response = _requester.request(_url,
"GET",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new Table.fromJson(data));
}
/**
* Creates a new, empty table in the dataset.
*
* [request] - The metadata request object.
*
* Request parameters:
*
* [projectId] - Project ID of the new table
*
* [datasetId] - Dataset ID of the new table
*
* Completes with a [Table].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<Table> insert(Table request, core.String projectId, core.String datasetId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (request != null) {
_body = convert.JSON.encode((request).toJson());
}
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId') + '/tables';
var _response = _requester.request(_url,
"POST",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new Table.fromJson(data));
}
/**
* Lists all tables in the specified dataset. Requires the READER dataset
* role.
*
* Request parameters:
*
* [projectId] - Project ID of the tables to list
*
* [datasetId] - Dataset ID of the tables to list
*
* [maxResults] - Maximum number of results to return
*
* [pageToken] - Page token, returned by a previous call, to request the next
* page of results
*
* Completes with a [TableList].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<TableList> list(core.String projectId, core.String datasetId, {core.int maxResults, core.String pageToken}) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
if (maxResults != null) {
_queryParams["maxResults"] = ["${maxResults}"];
}
if (pageToken != null) {
_queryParams["pageToken"] = [pageToken];
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId') + '/tables';
var _response = _requester.request(_url,
"GET",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new TableList.fromJson(data));
}
/**
* Updates information in an existing table. The update method replaces the
* entire table resource, whereas the patch method only replaces fields that
* are provided in the submitted table resource. This method supports patch
* semantics.
*
* [request] - The metadata request object.
*
* Request parameters:
*
* [projectId] - Project ID of the table to update
*
* [datasetId] - Dataset ID of the table to update
*
* [tableId] - Table ID of the table to update
*
* Completes with a [Table].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<Table> patch(Table request, core.String projectId, core.String datasetId, core.String tableId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (request != null) {
_body = convert.JSON.encode((request).toJson());
}
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
if (tableId == null) {
throw new core.ArgumentError("Parameter tableId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId') + '/tables/' + commons.Escaper.ecapeVariable('$tableId');
var _response = _requester.request(_url,
"PATCH",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new Table.fromJson(data));
}
/**
* Updates information in an existing table. The update method replaces the
* entire table resource, whereas the patch method only replaces fields that
* are provided in the submitted table resource.
*
* [request] - The metadata request object.
*
* Request parameters:
*
* [projectId] - Project ID of the table to update
*
* [datasetId] - Dataset ID of the table to update
*
* [tableId] - Table ID of the table to update
*
* Completes with a [Table].
*
* Completes with a [commons.ApiRequestError] if the API endpoint returned an
* error.
*
* If the used [http.Client] completes with an error when making a REST call,
* this method will complete with the same error.
*/
async.Future<Table> update(Table request, core.String projectId, core.String datasetId, core.String tableId) {
var _url = null;
var _queryParams = new core.Map();
var _uploadMedia = null;
var _uploadOptions = null;
var _downloadOptions = commons.DownloadOptions.Metadata;
var _body = null;
if (request != null) {
_body = convert.JSON.encode((request).toJson());
}
if (projectId == null) {
throw new core.ArgumentError("Parameter projectId is required.");
}
if (datasetId == null) {
throw new core.ArgumentError("Parameter datasetId is required.");
}
if (tableId == null) {
throw new core.ArgumentError("Parameter tableId is required.");
}
_url = 'projects/' + commons.Escaper.ecapeVariable('$projectId') + '/datasets/' + commons.Escaper.ecapeVariable('$datasetId') + '/tables/' + commons.Escaper.ecapeVariable('$tableId');
var _response = _requester.request(_url,
"PUT",
body: _body,
queryParams: _queryParams,
uploadOptions: _uploadOptions,
uploadMedia: _uploadMedia,
downloadOptions: _downloadOptions);
return _response.then((data) => new Table.fromJson(data));
}
}
class BigtableColumn {
/**
* [Optional] The encoding of the values when the type is not STRING.
* Acceptable encoding values are: TEXT - indicates values are alphanumeric
* text strings. BINARY - indicates values are encoded using HBase
* Bytes.toBytes family of functions. 'encoding' can also be set at the column
* family level. However, the setting at this level takes precedence if
* 'encoding' is set at both levels.
*/
core.String encoding;
/**
* [Optional] If the qualifier is not a valid BigQuery field identifier i.e.
* does not match [a-zA-Z][a-zA-Z0-9_]*, a valid identifier must be provided
* as the column field name and is used as field name in queries.
*/
core.String fieldName;
/**
* [Optional] If this is set, only the latest version of value in this column
* are exposed. 'onlyReadLatest' can also be set at the column family level.
* However, the setting at this level takes precedence if 'onlyReadLatest' is
* set at both levels.
*/
core.bool onlyReadLatest;
/**
* [Required] Qualifier of the column. Columns in the parent column family
* that has this exact qualifier are exposed as . field. If the qualifier is
* valid UTF-8 string, it can be specified in the qualifier_string field.
* Otherwise, a base-64 encoded value must be set to qualifier_encoded. The
* column field name is the same as the column qualifier. However, if the
* qualifier is not a valid BigQuery field identifier i.e. does not match
* [a-zA-Z][a-zA-Z0-9_]*, a valid identifier must be provided as field_name.
*/
core.String qualifierEncoded;
core.List<core.int> get qualifierEncodedAsBytes {
return convert.BASE64.decode(qualifierEncoded);
}
void set qualifierEncodedAsBytes(core.List<core.int> _bytes) {
qualifierEncoded = convert.BASE64.encode(_bytes).replaceAll("/", "_").replaceAll("+", "-");
}
core.String qualifierString;
/**
* [Optional] The type to convert the value in cells of this column. The
* values are expected to be encoded using HBase Bytes.toBytes function when
* using the BINARY encoding value. Following BigQuery types are allowed
* (case-sensitive) - BYTES STRING INTEGER FLOAT BOOLEAN Default type is
* BYTES. 'type' can also be set at the column family level. However, the
* setting at this level takes precedence if 'type' is set at both levels.
*/
core.String type;
BigtableColumn();
BigtableColumn.fromJson(core.Map _json) {
if (_json.containsKey("encoding")) {
encoding = _json["encoding"];
}
if (_json.containsKey("fieldName")) {
fieldName = _json["fieldName"];
}
if (_json.containsKey("onlyReadLatest")) {
onlyReadLatest = _json["onlyReadLatest"];
}
if (_json.containsKey("qualifierEncoded")) {
qualifierEncoded = _json["qualifierEncoded"];
}
if (_json.containsKey("qualifierString")) {
qualifierString = _json["qualifierString"];
}
if (_json.containsKey("type")) {
type = _json["type"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (encoding != null) {
_json["encoding"] = encoding;
}
if (fieldName != null) {
_json["fieldName"] = fieldName;
}
if (onlyReadLatest != null) {
_json["onlyReadLatest"] = onlyReadLatest;
}
if (qualifierEncoded != null) {
_json["qualifierEncoded"] = qualifierEncoded;
}
if (qualifierString != null) {
_json["qualifierString"] = qualifierString;
}
if (type != null) {
_json["type"] = type;
}
return _json;
}
}
class BigtableColumnFamily {
/**
* [Optional] Lists of columns that should be exposed as individual fields as
* opposed to a list of (column name, value) pairs. All columns whose
* qualifier matches a qualifier in this list can be accessed as .. Other
* columns can be accessed as a list through .Column field.
*/
core.List<BigtableColumn> columns;
/**
* [Optional] The encoding of the values when the type is not STRING.
* Acceptable encoding values are: TEXT - indicates values are alphanumeric
* text strings. BINARY - indicates values are encoded using HBase
* Bytes.toBytes family of functions. This can be overridden for a specific
* column by listing that column in 'columns' and specifying an encoding for
* it.
*/
core.String encoding;
/** Identifier of the column family. */
core.String familyId;
/**
* [Optional] If this is set only the latest version of value are exposed for
* all columns in this column family. This can be overridden for a specific
* column by listing that column in 'columns' and specifying a different
* setting for that column.
*/
core.bool onlyReadLatest;
/**
* [Optional] The type to convert the value in cells of this column family.
* The values are expected to be encoded using HBase Bytes.toBytes function
* when using the BINARY encoding value. Following BigQuery types are allowed
* (case-sensitive) - BYTES STRING INTEGER FLOAT BOOLEAN Default type is
* BYTES. This can be overridden for a specific column by listing that column
* in 'columns' and specifying a type for it.
*/
core.String type;
BigtableColumnFamily();
BigtableColumnFamily.fromJson(core.Map _json) {
if (_json.containsKey("columns")) {
columns = _json["columns"].map((value) => new BigtableColumn.fromJson(value)).toList();
}
if (_json.containsKey("encoding")) {
encoding = _json["encoding"];
}
if (_json.containsKey("familyId")) {
familyId = _json["familyId"];
}
if (_json.containsKey("onlyReadLatest")) {
onlyReadLatest = _json["onlyReadLatest"];
}
if (_json.containsKey("type")) {
type = _json["type"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (columns != null) {
_json["columns"] = columns.map((value) => (value).toJson()).toList();
}
if (encoding != null) {
_json["encoding"] = encoding;
}
if (familyId != null) {
_json["familyId"] = familyId;
}
if (onlyReadLatest != null) {
_json["onlyReadLatest"] = onlyReadLatest;
}
if (type != null) {
_json["type"] = type;
}
return _json;
}
}
class BigtableOptions {
/**
* [Optional] List of column families to expose in the table schema along with
* their types. This list restricts the column families that can be referenced
* in queries and specifies their value types. You can use this list to do
* type conversions - see the 'type' field for more details. If you leave this
* list empty, all column families are present in the table schema and their
* values are read as BYTES. During a query only the column families
* referenced in that query are read from Bigtable.
*/
core.List<BigtableColumnFamily> columnFamilies;
/**
* [Optional] If field is true, then the column families that are not
* specified in columnFamilies list are not exposed in the table schema.
* Otherwise, they are read with BYTES type values. The default value is
* false.
*/
core.bool ignoreUnspecifiedColumnFamilies;
/**
* [Optional] If field is true, then the rowkey column families will be read
* and converted to string. Otherwise they are read with BYTES type values and
* users need to manually cast them with CAST if necessary. The default value
* is false.
*/
core.bool readRowkeyAsString;
BigtableOptions();
BigtableOptions.fromJson(core.Map _json) {
if (_json.containsKey("columnFamilies")) {
columnFamilies = _json["columnFamilies"].map((value) => new BigtableColumnFamily.fromJson(value)).toList();
}
if (_json.containsKey("ignoreUnspecifiedColumnFamilies")) {
ignoreUnspecifiedColumnFamilies = _json["ignoreUnspecifiedColumnFamilies"];
}
if (_json.containsKey("readRowkeyAsString")) {
readRowkeyAsString = _json["readRowkeyAsString"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (columnFamilies != null) {
_json["columnFamilies"] = columnFamilies.map((value) => (value).toJson()).toList();
}
if (ignoreUnspecifiedColumnFamilies != null) {
_json["ignoreUnspecifiedColumnFamilies"] = ignoreUnspecifiedColumnFamilies;
}
if (readRowkeyAsString != null) {
_json["readRowkeyAsString"] = readRowkeyAsString;
}
return _json;
}
}
class CsvOptions {
/**
* [Optional] Indicates if BigQuery should accept rows that are missing
* trailing optional columns. If true, BigQuery treats missing trailing
* columns as null values. If false, records with missing trailing columns are
* treated as bad records, and if there are too many bad records, an invalid
* error is returned in the job result. The default value is false.
*/
core.bool allowJaggedRows;
/**
* [Optional] Indicates if BigQuery should allow quoted data sections that
* contain newline characters in a CSV file. The default value is false.
*/
core.bool allowQuotedNewlines;
/**
* [Optional] The character encoding of the data. The supported values are
* UTF-8 or ISO-8859-1. The default value is UTF-8. BigQuery decodes the data
* after the raw, binary data has been split using the values of the quote and
* fieldDelimiter properties.
*/
core.String encoding;
/**
* [Optional] The separator for fields in a CSV file. BigQuery converts the
* string to ISO-8859-1 encoding, and then uses the first byte of the encoded
* string to split the data in its raw, binary state. BigQuery also supports
* the escape sequence "\t" to specify a tab separator. The default value is a
* comma (',').
*/
core.String fieldDelimiter;
/**
* [Optional] The value that is used to quote data sections in a CSV file.
* BigQuery converts the string to ISO-8859-1 encoding, and then uses the
* first byte of the encoded string to split the data in its raw, binary
* state. The default value is a double-quote ('"'). If your data does not
* contain quoted sections, set the property value to an empty string. If your
* data contains quoted newline characters, you must also set the
* allowQuotedNewlines property to true.
*/
core.String quote;
/**
* [Optional] The number of rows at the top of a CSV file that BigQuery will
* skip when reading the data. The default value is 0. This property is useful
* if you have header rows in the file that should be skipped.
*/
core.String skipLeadingRows;
CsvOptions();
CsvOptions.fromJson(core.Map _json) {
if (_json.containsKey("allowJaggedRows")) {
allowJaggedRows = _json["allowJaggedRows"];
}
if (_json.containsKey("allowQuotedNewlines")) {
allowQuotedNewlines = _json["allowQuotedNewlines"];
}
if (_json.containsKey("encoding")) {
encoding = _json["encoding"];
}
if (_json.containsKey("fieldDelimiter")) {
fieldDelimiter = _json["fieldDelimiter"];
}
if (_json.containsKey("quote")) {
quote = _json["quote"];
}
if (_json.containsKey("skipLeadingRows")) {
skipLeadingRows = _json["skipLeadingRows"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (allowJaggedRows != null) {
_json["allowJaggedRows"] = allowJaggedRows;
}
if (allowQuotedNewlines != null) {
_json["allowQuotedNewlines"] = allowQuotedNewlines;
}
if (encoding != null) {
_json["encoding"] = encoding;
}
if (fieldDelimiter != null) {
_json["fieldDelimiter"] = fieldDelimiter;
}
if (quote != null) {
_json["quote"] = quote;
}
if (skipLeadingRows != null) {
_json["skipLeadingRows"] = skipLeadingRows;
}
return _json;
}
}
class DatasetAccess {
/**
* [Pick one] A domain to grant access to. Any users signed in with the domain
* specified will be granted the specified access. Example: "example.com".
*/
core.String domain;
/** [Pick one] An email address of a Google Group to grant access to. */
core.String groupByEmail;
/**
* [Required] Describes the rights granted to the user specified by the other
* member of the access object. The following string values are supported:
* READER, WRITER, OWNER.
*/
core.String role;
/**
* [Pick one] A special group to grant access to. Possible values include:
* projectOwners: Owners of the enclosing project. projectReaders: Readers of
* the enclosing project. projectWriters: Writers of the enclosing project.
* allAuthenticatedUsers: All authenticated BigQuery users.
*/
core.String specialGroup;
/**
* [Pick one] An email address of a user to grant access to. For example:
* fred@example.com.
*/
core.String userByEmail;
/**
* [Pick one] A view from a different dataset to grant access to. Queries
* executed against that view will have read access to tables in this dataset.
* The role field is not required when this field is set. If that view is
* updated by any user, access to the view needs to be granted again via an
* update operation.
*/
TableReference view;
DatasetAccess();
DatasetAccess.fromJson(core.Map _json) {
if (_json.containsKey("domain")) {
domain = _json["domain"];
}
if (_json.containsKey("groupByEmail")) {
groupByEmail = _json["groupByEmail"];
}
if (_json.containsKey("role")) {
role = _json["role"];
}
if (_json.containsKey("specialGroup")) {
specialGroup = _json["specialGroup"];
}
if (_json.containsKey("userByEmail")) {
userByEmail = _json["userByEmail"];
}
if (_json.containsKey("view")) {
view = new TableReference.fromJson(_json["view"]);
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (domain != null) {
_json["domain"] = domain;
}
if (groupByEmail != null) {
_json["groupByEmail"] = groupByEmail;
}
if (role != null) {
_json["role"] = role;
}
if (specialGroup != null) {
_json["specialGroup"] = specialGroup;
}
if (userByEmail != null) {
_json["userByEmail"] = userByEmail;
}
if (view != null) {
_json["view"] = (view).toJson();
}
return _json;
}
}
class Dataset {
/**
* [Optional] An array of objects that define dataset access for one or more
* entities. You can set this property when inserting or updating a dataset in
* order to control who is allowed to access the data. If unspecified at
* dataset creation time, BigQuery adds default dataset access for the
* following entities: access.specialGroup: projectReaders; access.role:
* READER; access.specialGroup: projectWriters; access.role: WRITER;
* access.specialGroup: projectOwners; access.role: OWNER; access.userByEmail:
* [dataset creator email]; access.role: OWNER;
*/
core.List<DatasetAccess> access;
/**
* [Output-only] The time when this dataset was created, in milliseconds since
* the epoch.
*/
core.String creationTime;
/** [Required] A reference that identifies the dataset. */
DatasetReference datasetReference;
/**
* [Optional] The default lifetime of all tables in the dataset, in
* milliseconds. The minimum value is 3600000 milliseconds (one hour). Once
* this property is set, all newly-created tables in the dataset will have an
* expirationTime property set to the creation time plus the value in this
* property, and changing the value will only affect new tables, not existing
* ones. When the expirationTime for a given table is reached, that table will
* be deleted automatically. If a table's expirationTime is modified or
* removed before the table expires, or if you provide an explicit
* expirationTime when creating a table, that value takes precedence over the
* default expiration time indicated by this property.
*/
core.String defaultTableExpirationMs;
/** [Optional] A user-friendly description of the dataset. */
core.String description;
/** [Output-only] A hash of the resource. */
core.String etag;
/** [Optional] A descriptive name for the dataset. */
core.String friendlyName;
/**
* [Output-only] The fully-qualified unique name of the dataset in the format
* projectId:datasetId. The dataset name without the project name is given in
* the datasetId field. When creating a new dataset, leave this field blank,
* and instead specify the datasetId field.
*/
core.String id;
/** [Output-only] The resource type. */
core.String kind;
/**
* The labels associated with this dataset. You can use these to organize and
* group your datasets. You can set this property when inserting or updating a
* dataset. See Labeling Datasets for more information.
*/
core.Map<core.String, core.String> labels;
/**
* [Output-only] The date when this dataset or any of its tables was last
* modified, in milliseconds since the epoch.
*/
core.String lastModifiedTime;
/**
* The geographic location where the dataset should reside. Possible values
* include EU and US. The default value is US.
*/
core.String location;
/**
* [Output-only] A URL that can be used to access the resource again. You can
* use this URL in Get or Update requests to the resource.
*/
core.String selfLink;
Dataset();
Dataset.fromJson(core.Map _json) {
if (_json.containsKey("access")) {
access = _json["access"].map((value) => new DatasetAccess.fromJson(value)).toList();
}
if (_json.containsKey("creationTime")) {
creationTime = _json["creationTime"];
}
if (_json.containsKey("datasetReference")) {
datasetReference = new DatasetReference.fromJson(_json["datasetReference"]);
}
if (_json.containsKey("defaultTableExpirationMs")) {
defaultTableExpirationMs = _json["defaultTableExpirationMs"];
}
if (_json.containsKey("description")) {
description = _json["description"];
}
if (_json.containsKey("etag")) {
etag = _json["etag"];
}
if (_json.containsKey("friendlyName")) {
friendlyName = _json["friendlyName"];
}
if (_json.containsKey("id")) {
id = _json["id"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("labels")) {
labels = _json["labels"];
}
if (_json.containsKey("lastModifiedTime")) {
lastModifiedTime = _json["lastModifiedTime"];
}
if (_json.containsKey("location")) {
location = _json["location"];
}
if (_json.containsKey("selfLink")) {
selfLink = _json["selfLink"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (access != null) {
_json["access"] = access.map((value) => (value).toJson()).toList();
}
if (creationTime != null) {
_json["creationTime"] = creationTime;
}
if (datasetReference != null) {
_json["datasetReference"] = (datasetReference).toJson();
}
if (defaultTableExpirationMs != null) {
_json["defaultTableExpirationMs"] = defaultTableExpirationMs;
}
if (description != null) {
_json["description"] = description;
}
if (etag != null) {
_json["etag"] = etag;
}
if (friendlyName != null) {
_json["friendlyName"] = friendlyName;
}
if (id != null) {
_json["id"] = id;
}
if (kind != null) {
_json["kind"] = kind;
}
if (labels != null) {
_json["labels"] = labels;
}
if (lastModifiedTime != null) {
_json["lastModifiedTime"] = lastModifiedTime;
}
if (location != null) {
_json["location"] = location;
}
if (selfLink != null) {
_json["selfLink"] = selfLink;
}
return _json;
}
}
class DatasetListDatasets {
/**
* The dataset reference. Use this property to access specific parts of the
* dataset's ID, such as project ID or dataset ID.
*/
DatasetReference datasetReference;
/** A descriptive name for the dataset, if one exists. */
core.String friendlyName;
/** The fully-qualified, unique, opaque ID of the dataset. */
core.String id;
/**
* The resource type. This property always returns the value
* "bigquery#dataset".
*/
core.String kind;
/**
* The labels associated with this dataset. You can use these to organize and
* group your datasets.
*/
core.Map<core.String, core.String> labels;
DatasetListDatasets();
DatasetListDatasets.fromJson(core.Map _json) {
if (_json.containsKey("datasetReference")) {
datasetReference = new DatasetReference.fromJson(_json["datasetReference"]);
}
if (_json.containsKey("friendlyName")) {
friendlyName = _json["friendlyName"];
}
if (_json.containsKey("id")) {
id = _json["id"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("labels")) {
labels = _json["labels"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (datasetReference != null) {
_json["datasetReference"] = (datasetReference).toJson();
}
if (friendlyName != null) {
_json["friendlyName"] = friendlyName;
}
if (id != null) {
_json["id"] = id;
}
if (kind != null) {
_json["kind"] = kind;
}
if (labels != null) {
_json["labels"] = labels;
}
return _json;
}
}
class DatasetList {
/**
* An array of the dataset resources in the project. Each resource contains
* basic information. For full information about a particular dataset
* resource, use the Datasets: get method. This property is omitted when there
* are no datasets in the project.
*/
core.List<DatasetListDatasets> datasets;
/**
* A hash value of the results page. You can use this property to determine if
* the page has changed since the last request.
*/
core.String etag;
/**
* The list type. This property always returns the value
* "bigquery#datasetList".
*/
core.String kind;
/**
* A token that can be used to request the next results page. This property is
* omitted on the final results page.
*/
core.String nextPageToken;
DatasetList();
DatasetList.fromJson(core.Map _json) {
if (_json.containsKey("datasets")) {
datasets = _json["datasets"].map((value) => new DatasetListDatasets.fromJson(value)).toList();
}
if (_json.containsKey("etag")) {
etag = _json["etag"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("nextPageToken")) {
nextPageToken = _json["nextPageToken"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (datasets != null) {
_json["datasets"] = datasets.map((value) => (value).toJson()).toList();
}
if (etag != null) {
_json["etag"] = etag;
}
if (kind != null) {
_json["kind"] = kind;
}
if (nextPageToken != null) {
_json["nextPageToken"] = nextPageToken;
}
return _json;
}
}
class DatasetReference {
/**
* [Required] A unique ID for this dataset, without the project name. The ID
* must contain only letters (a-z, A-Z), numbers (0-9), or underscores (_).
* The maximum length is 1,024 characters.
*/
core.String datasetId;
/** [Optional] The ID of the project containing this dataset. */
core.String projectId;
DatasetReference();
DatasetReference.fromJson(core.Map _json) {
if (_json.containsKey("datasetId")) {
datasetId = _json["datasetId"];
}
if (_json.containsKey("projectId")) {
projectId = _json["projectId"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (datasetId != null) {
_json["datasetId"] = datasetId;
}
if (projectId != null) {
_json["projectId"] = projectId;
}
return _json;
}
}
class ErrorProto {
/**
* Debugging information. This property is internal to Google and should not
* be used.
*/
core.String debugInfo;
/** Specifies where the error occurred, if present. */
core.String location;
/** A human-readable description of the error. */
core.String message;
/** A short error code that summarizes the error. */
core.String reason;
ErrorProto();
ErrorProto.fromJson(core.Map _json) {
if (_json.containsKey("debugInfo")) {
debugInfo = _json["debugInfo"];
}
if (_json.containsKey("location")) {
location = _json["location"];
}
if (_json.containsKey("message")) {
message = _json["message"];
}
if (_json.containsKey("reason")) {
reason = _json["reason"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (debugInfo != null) {
_json["debugInfo"] = debugInfo;
}
if (location != null) {
_json["location"] = location;
}
if (message != null) {
_json["message"] = message;
}
if (reason != null) {
_json["reason"] = reason;
}
return _json;
}
}
class ExplainQueryStage {
/** Relative amount of time the average shard spent on CPU-bound tasks. */
core.double computeRatioAvg;
/** Relative amount of time the slowest shard spent on CPU-bound tasks. */
core.double computeRatioMax;
/** Unique ID for stage within plan. */
core.String id;
/** Human-readable name for stage. */
core.String name;
/** Relative amount of time the average shard spent reading input. */
core.double readRatioAvg;
/** Relative amount of time the slowest shard spent reading input. */
core.double readRatioMax;
/** Number of records read into the stage. */
core.String recordsRead;
/** Number of records written by the stage. */
core.String recordsWritten;
/** Current status for the stage. */
core.String status;
/**
* List of operations within the stage in dependency order (approximately
* chronological).
*/
core.List<ExplainQueryStep> steps;
/**
* Relative amount of time the average shard spent waiting to be scheduled.
*/
core.double waitRatioAvg;
/**
* Relative amount of time the slowest shard spent waiting to be scheduled.
*/
core.double waitRatioMax;
/** Relative amount of time the average shard spent on writing output. */
core.double writeRatioAvg;
/** Relative amount of time the slowest shard spent on writing output. */
core.double writeRatioMax;
ExplainQueryStage();
ExplainQueryStage.fromJson(core.Map _json) {
if (_json.containsKey("computeRatioAvg")) {
computeRatioAvg = _json["computeRatioAvg"];
}
if (_json.containsKey("computeRatioMax")) {
computeRatioMax = _json["computeRatioMax"];
}
if (_json.containsKey("id")) {
id = _json["id"];
}
if (_json.containsKey("name")) {
name = _json["name"];
}
if (_json.containsKey("readRatioAvg")) {
readRatioAvg = _json["readRatioAvg"];
}
if (_json.containsKey("readRatioMax")) {
readRatioMax = _json["readRatioMax"];
}
if (_json.containsKey("recordsRead")) {
recordsRead = _json["recordsRead"];
}
if (_json.containsKey("recordsWritten")) {
recordsWritten = _json["recordsWritten"];
}
if (_json.containsKey("status")) {
status = _json["status"];
}
if (_json.containsKey("steps")) {
steps = _json["steps"].map((value) => new ExplainQueryStep.fromJson(value)).toList();
}
if (_json.containsKey("waitRatioAvg")) {
waitRatioAvg = _json["waitRatioAvg"];
}
if (_json.containsKey("waitRatioMax")) {
waitRatioMax = _json["waitRatioMax"];
}
if (_json.containsKey("writeRatioAvg")) {
writeRatioAvg = _json["writeRatioAvg"];
}
if (_json.containsKey("writeRatioMax")) {
writeRatioMax = _json["writeRatioMax"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (computeRatioAvg != null) {
_json["computeRatioAvg"] = computeRatioAvg;
}
if (computeRatioMax != null) {
_json["computeRatioMax"] = computeRatioMax;
}
if (id != null) {
_json["id"] = id;
}
if (name != null) {
_json["name"] = name;
}
if (readRatioAvg != null) {
_json["readRatioAvg"] = readRatioAvg;
}
if (readRatioMax != null) {
_json["readRatioMax"] = readRatioMax;
}
if (recordsRead != null) {
_json["recordsRead"] = recordsRead;
}
if (recordsWritten != null) {
_json["recordsWritten"] = recordsWritten;
}
if (status != null) {
_json["status"] = status;
}
if (steps != null) {
_json["steps"] = steps.map((value) => (value).toJson()).toList();
}
if (waitRatioAvg != null) {
_json["waitRatioAvg"] = waitRatioAvg;
}
if (waitRatioMax != null) {
_json["waitRatioMax"] = waitRatioMax;
}
if (writeRatioAvg != null) {
_json["writeRatioAvg"] = writeRatioAvg;
}
if (writeRatioMax != null) {
_json["writeRatioMax"] = writeRatioMax;
}
return _json;
}
}
class ExplainQueryStep {
/** Machine-readable operation type. */
core.String kind;
/** Human-readable stage descriptions. */
core.List<core.String> substeps;
ExplainQueryStep();
ExplainQueryStep.fromJson(core.Map _json) {
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("substeps")) {
substeps = _json["substeps"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (kind != null) {
_json["kind"] = kind;
}
if (substeps != null) {
_json["substeps"] = substeps;
}
return _json;
}
}
class ExternalDataConfiguration {
/**
* Try to detect schema and format options automatically. Any option specified
* explicitly will be honored.
*/
core.bool autodetect;
/** [Optional] Additional options if sourceFormat is set to BIGTABLE. */
BigtableOptions bigtableOptions;
/**
* [Optional] The compression type of the data source. Possible values include
* GZIP and NONE. The default value is NONE. This setting is ignored for
* Google Cloud Bigtable, Google Cloud Datastore backups and Avro formats.
*/
core.String compression;
/** Additional properties to set if sourceFormat is set to CSV. */
CsvOptions csvOptions;
/** [Optional] Additional options if sourceFormat is set to GOOGLE_SHEETS. */
GoogleSheetsOptions googleSheetsOptions;
/**
* [Optional] Indicates if BigQuery should allow extra values that are not
* represented in the table schema. If true, the extra values are ignored. If
* false, records with extra columns are treated as bad records, and if there
* are too many bad records, an invalid error is returned in the job result.
* The default value is false. The sourceFormat property determines what
* BigQuery treats as an extra value: CSV: Trailing columns JSON: Named values
* that don't match any column names Google Cloud Bigtable: This setting is
* ignored. Google Cloud Datastore backups: This setting is ignored. Avro:
* This setting is ignored.
*/
core.bool ignoreUnknownValues;
/**
* [Optional] The maximum number of bad records that BigQuery can ignore when
* reading data. If the number of bad records exceeds this value, an invalid
* error is returned in the job result. The default value is 0, which requires
* that all records are valid. This setting is ignored for Google Cloud
* Bigtable, Google Cloud Datastore backups and Avro formats.
*/
core.int maxBadRecords;
/**
* [Optional] The schema for the data. Schema is required for CSV and JSON
* formats. Schema is disallowed for Google Cloud Bigtable, Cloud Datastore
* backups, and Avro formats.
*/
TableSchema schema;
/**
* [Required] The data format. For CSV files, specify "CSV". For Google
* sheets, specify "GOOGLE_SHEETS". For newline-delimited JSON, specify
* "NEWLINE_DELIMITED_JSON". For Avro files, specify "AVRO". For Google Cloud
* Datastore backups, specify "DATASTORE_BACKUP". [Beta] For Google Cloud
* Bigtable, specify "BIGTABLE".
*/
core.String sourceFormat;
/**
* [Required] The fully-qualified URIs that point to your data in Google
* Cloud. For Google Cloud Storage URIs: Each URI can contain one '*' wildcard
* character and it must come after the 'bucket' name. Size limits related to
* load jobs apply to external data sources. For Google Cloud Bigtable URIs:
* Exactly one URI can be specified and it has be a fully specified and valid
* HTTPS URL for a Google Cloud Bigtable table. For Google Cloud Datastore
* backups, exactly one URI can be specified, and it must end with
* '.backup_info'. Also, the '*' wildcard character is not allowed.
*/
core.List<core.String> sourceUris;
ExternalDataConfiguration();
ExternalDataConfiguration.fromJson(core.Map _json) {
if (_json.containsKey("autodetect")) {
autodetect = _json["autodetect"];
}
if (_json.containsKey("bigtableOptions")) {
bigtableOptions = new BigtableOptions.fromJson(_json["bigtableOptions"]);
}
if (_json.containsKey("compression")) {
compression = _json["compression"];
}
if (_json.containsKey("csvOptions")) {
csvOptions = new CsvOptions.fromJson(_json["csvOptions"]);
}
if (_json.containsKey("googleSheetsOptions")) {
googleSheetsOptions = new GoogleSheetsOptions.fromJson(_json["googleSheetsOptions"]);
}
if (_json.containsKey("ignoreUnknownValues")) {
ignoreUnknownValues = _json["ignoreUnknownValues"];
}
if (_json.containsKey("maxBadRecords")) {
maxBadRecords = _json["maxBadRecords"];
}
if (_json.containsKey("schema")) {
schema = new TableSchema.fromJson(_json["schema"]);
}
if (_json.containsKey("sourceFormat")) {
sourceFormat = _json["sourceFormat"];
}
if (_json.containsKey("sourceUris")) {
sourceUris = _json["sourceUris"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (autodetect != null) {
_json["autodetect"] = autodetect;
}
if (bigtableOptions != null) {
_json["bigtableOptions"] = (bigtableOptions).toJson();
}
if (compression != null) {
_json["compression"] = compression;
}
if (csvOptions != null) {
_json["csvOptions"] = (csvOptions).toJson();
}
if (googleSheetsOptions != null) {
_json["googleSheetsOptions"] = (googleSheetsOptions).toJson();
}
if (ignoreUnknownValues != null) {
_json["ignoreUnknownValues"] = ignoreUnknownValues;
}
if (maxBadRecords != null) {
_json["maxBadRecords"] = maxBadRecords;
}
if (schema != null) {
_json["schema"] = (schema).toJson();
}
if (sourceFormat != null) {
_json["sourceFormat"] = sourceFormat;
}
if (sourceUris != null) {
_json["sourceUris"] = sourceUris;
}
return _json;
}
}
class GetQueryResultsResponse {
/** Whether the query result was fetched from the query cache. */
core.bool cacheHit;
/**
* [Output-only] The first errors or warnings encountered during the running
* of the job. The final message includes the number of errors that caused the
* process to stop. Errors here do not necessarily mean that the job has
* completed or was unsuccessful.
*/
core.List<ErrorProto> errors;
/** A hash of this response. */
core.String etag;
/**
* Whether the query has completed or not. If rows or totalRows are present,
* this will always be true. If this is false, totalRows will not be
* available.
*/
core.bool jobComplete;
/**
* Reference to the BigQuery Job that was created to run the query. This field
* will be present even if the original request timed out, in which case
* GetQueryResults can be used to read the results once the query has
* completed. Since this API only returns the first page of results,
* subsequent pages can be fetched via the same mechanism (GetQueryResults).
*/
JobReference jobReference;
/** The resource type of the response. */
core.String kind;
/**
* [Output-only] The number of rows affected by a DML statement. Present only
* for DML statements INSERT, UPDATE or DELETE.
*/
core.String numDmlAffectedRows;
/** A token used for paging results. */
core.String pageToken;
/**
* An object with as many results as can be contained within the maximum
* permitted reply size. To get any additional rows, you can call
* GetQueryResults and specify the jobReference returned above. Present only
* when the query completes successfully.
*/
core.List<TableRow> rows;
/**
* The schema of the results. Present only when the query completes
* successfully.
*/
TableSchema schema;
/** The total number of bytes processed for this query. */
core.String totalBytesProcessed;
/**
* The total number of rows in the complete query result set, which can be
* more than the number of rows in this single page of results. Present only
* when the query completes successfully.
*/
core.String totalRows;
GetQueryResultsResponse();
GetQueryResultsResponse.fromJson(core.Map _json) {
if (_json.containsKey("cacheHit")) {
cacheHit = _json["cacheHit"];
}
if (_json.containsKey("errors")) {
errors = _json["errors"].map((value) => new ErrorProto.fromJson(value)).toList();
}
if (_json.containsKey("etag")) {
etag = _json["etag"];
}
if (_json.containsKey("jobComplete")) {
jobComplete = _json["jobComplete"];
}
if (_json.containsKey("jobReference")) {
jobReference = new JobReference.fromJson(_json["jobReference"]);
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("numDmlAffectedRows")) {
numDmlAffectedRows = _json["numDmlAffectedRows"];
}
if (_json.containsKey("pageToken")) {
pageToken = _json["pageToken"];
}
if (_json.containsKey("rows")) {
rows = _json["rows"].map((value) => new TableRow.fromJson(value)).toList();
}
if (_json.containsKey("schema")) {
schema = new TableSchema.fromJson(_json["schema"]);
}
if (_json.containsKey("totalBytesProcessed")) {
totalBytesProcessed = _json["totalBytesProcessed"];
}
if (_json.containsKey("totalRows")) {
totalRows = _json["totalRows"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (cacheHit != null) {
_json["cacheHit"] = cacheHit;
}
if (errors != null) {
_json["errors"] = errors.map((value) => (value).toJson()).toList();
}
if (etag != null) {
_json["etag"] = etag;
}
if (jobComplete != null) {
_json["jobComplete"] = jobComplete;
}
if (jobReference != null) {
_json["jobReference"] = (jobReference).toJson();
}
if (kind != null) {
_json["kind"] = kind;
}
if (numDmlAffectedRows != null) {
_json["numDmlAffectedRows"] = numDmlAffectedRows;
}
if (pageToken != null) {
_json["pageToken"] = pageToken;
}
if (rows != null) {
_json["rows"] = rows.map((value) => (value).toJson()).toList();
}
if (schema != null) {
_json["schema"] = (schema).toJson();
}
if (totalBytesProcessed != null) {
_json["totalBytesProcessed"] = totalBytesProcessed;
}
if (totalRows != null) {
_json["totalRows"] = totalRows;
}
return _json;
}
}
class GoogleSheetsOptions {
/**
* [Optional] The number of rows at the top of a sheet that BigQuery will skip
* when reading the data. The default value is 0. This property is useful if
* you have header rows that should be skipped. When autodetect is on,
* behavior is the following: * skipLeadingRows unspecified - Autodetect tries
* to detect headers in the first row. If they are not detected, the row is
* read as data. Otherwise data is read starting from the second row. *
* skipLeadingRows is 0 - Instructs autodetect that there are no headers and
* data should be read starting from the first row. * skipLeadingRows = N > 0
* - Autodetect skips N-1 rows and tries to detect headers in row N. If
* headers are not detected, row N is just skipped. Otherwise row N is used to
* extract column names for the detected schema.
*/
core.String skipLeadingRows;
GoogleSheetsOptions();
GoogleSheetsOptions.fromJson(core.Map _json) {
if (_json.containsKey("skipLeadingRows")) {
skipLeadingRows = _json["skipLeadingRows"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (skipLeadingRows != null) {
_json["skipLeadingRows"] = skipLeadingRows;
}
return _json;
}
}
class Job {
/** [Required] Describes the job configuration. */
JobConfiguration configuration;
/** [Output-only] A hash of this resource. */
core.String etag;
/** [Output-only] Opaque ID field of the job */
core.String id;
/** [Optional] Reference describing the unique-per-user name of the job. */
JobReference jobReference;
/** [Output-only] The type of the resource. */
core.String kind;
/** [Output-only] A URL that can be used to access this resource again. */
core.String selfLink;
/**
* [Output-only] Information about the job, including starting time and ending
* time of the job.
*/
JobStatistics statistics;
/**
* [Output-only] The status of this job. Examine this value when polling an
* asynchronous job to see if the job is complete.
*/
JobStatus status;
/** [Output-only] Email address of the user who ran the job. */
core.String userEmail;
Job();
Job.fromJson(core.Map _json) {
if (_json.containsKey("configuration")) {
configuration = new JobConfiguration.fromJson(_json["configuration"]);
}
if (_json.containsKey("etag")) {
etag = _json["etag"];
}
if (_json.containsKey("id")) {
id = _json["id"];
}
if (_json.containsKey("jobReference")) {
jobReference = new JobReference.fromJson(_json["jobReference"]);
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("selfLink")) {
selfLink = _json["selfLink"];
}
if (_json.containsKey("statistics")) {
statistics = new JobStatistics.fromJson(_json["statistics"]);
}
if (_json.containsKey("status")) {
status = new JobStatus.fromJson(_json["status"]);
}
if (_json.containsKey("user_email")) {
userEmail = _json["user_email"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (configuration != null) {
_json["configuration"] = (configuration).toJson();
}
if (etag != null) {
_json["etag"] = etag;
}
if (id != null) {
_json["id"] = id;
}
if (jobReference != null) {
_json["jobReference"] = (jobReference).toJson();
}
if (kind != null) {
_json["kind"] = kind;
}
if (selfLink != null) {
_json["selfLink"] = selfLink;
}
if (statistics != null) {
_json["statistics"] = (statistics).toJson();
}
if (status != null) {
_json["status"] = (status).toJson();
}
if (userEmail != null) {
_json["user_email"] = userEmail;
}
return _json;
}
}
class JobCancelResponse {
/** The final state of the job. */
Job job;
/** The resource type of the response. */
core.String kind;
JobCancelResponse();
JobCancelResponse.fromJson(core.Map _json) {
if (_json.containsKey("job")) {
job = new Job.fromJson(_json["job"]);
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (job != null) {
_json["job"] = (job).toJson();
}
if (kind != null) {
_json["kind"] = kind;
}
return _json;
}
}
class JobConfiguration {
/** [Pick one] Copies a table. */
JobConfigurationTableCopy copy;
/**
* [Optional] If set, don't actually run this job. A valid query will return a
* mostly empty response with some processing statistics, while an invalid
* query will return the same error it would if it wasn't a dry run. Behavior
* of non-query jobs is undefined.
*/
core.bool dryRun;
/** [Pick one] Configures an extract job. */
JobConfigurationExtract extract;
/**
* [Experimental] The labels associated with this job. You can use these to
* organize and group your jobs. Label keys and values can be no longer than
* 63 characters, can only contain lowercase letters, numeric characters,
* underscores and dashes. International characters are allowed. Label values
* are optional. Label keys must start with a letter and each label in the
* list must have a different key.
*/
core.Map<core.String, core.String> labels;
/** [Pick one] Configures a load job. */
JobConfigurationLoad load;
/** [Pick one] Configures a query job. */
JobConfigurationQuery query;
JobConfiguration();
JobConfiguration.fromJson(core.Map _json) {
if (_json.containsKey("copy")) {
copy = new JobConfigurationTableCopy.fromJson(_json["copy"]);
}
if (_json.containsKey("dryRun")) {
dryRun = _json["dryRun"];
}
if (_json.containsKey("extract")) {
extract = new JobConfigurationExtract.fromJson(_json["extract"]);
}
if (_json.containsKey("labels")) {
labels = _json["labels"];
}
if (_json.containsKey("load")) {
load = new JobConfigurationLoad.fromJson(_json["load"]);
}
if (_json.containsKey("query")) {
query = new JobConfigurationQuery.fromJson(_json["query"]);
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (copy != null) {
_json["copy"] = (copy).toJson();
}
if (dryRun != null) {
_json["dryRun"] = dryRun;
}
if (extract != null) {
_json["extract"] = (extract).toJson();
}
if (labels != null) {
_json["labels"] = labels;
}
if (load != null) {
_json["load"] = (load).toJson();
}
if (query != null) {
_json["query"] = (query).toJson();
}
return _json;
}
}
class JobConfigurationExtract {
/**
* [Optional] The compression type to use for exported files. Possible values
* include GZIP and NONE. The default value is NONE.
*/
core.String compression;
/**
* [Optional] The exported file format. Possible values include CSV,
* NEWLINE_DELIMITED_JSON and AVRO. The default value is CSV. Tables with
* nested or repeated fields cannot be exported as CSV.
*/
core.String destinationFormat;
/**
* [Pick one] DEPRECATED: Use destinationUris instead, passing only one URI as
* necessary. The fully-qualified Google Cloud Storage URI where the extracted
* table should be written.
*/
core.String destinationUri;
/**
* [Pick one] A list of fully-qualified Google Cloud Storage URIs where the
* extracted table should be written.
*/
core.List<core.String> destinationUris;
/**
* [Optional] Delimiter to use between fields in the exported data. Default is
* ','
*/
core.String fieldDelimiter;
/**
* [Optional] Whether to print out a header row in the results. Default is
* true.
*/
core.bool printHeader;
/** [Required] A reference to the table being exported. */
TableReference sourceTable;
JobConfigurationExtract();
JobConfigurationExtract.fromJson(core.Map _json) {
if (_json.containsKey("compression")) {
compression = _json["compression"];
}
if (_json.containsKey("destinationFormat")) {
destinationFormat = _json["destinationFormat"];
}
if (_json.containsKey("destinationUri")) {
destinationUri = _json["destinationUri"];
}
if (_json.containsKey("destinationUris")) {
destinationUris = _json["destinationUris"];
}
if (_json.containsKey("fieldDelimiter")) {
fieldDelimiter = _json["fieldDelimiter"];
}
if (_json.containsKey("printHeader")) {
printHeader = _json["printHeader"];
}
if (_json.containsKey("sourceTable")) {
sourceTable = new TableReference.fromJson(_json["sourceTable"]);
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (compression != null) {
_json["compression"] = compression;
}
if (destinationFormat != null) {
_json["destinationFormat"] = destinationFormat;
}
if (destinationUri != null) {
_json["destinationUri"] = destinationUri;
}
if (destinationUris != null) {
_json["destinationUris"] = destinationUris;
}
if (fieldDelimiter != null) {
_json["fieldDelimiter"] = fieldDelimiter;
}
if (printHeader != null) {
_json["printHeader"] = printHeader;
}
if (sourceTable != null) {
_json["sourceTable"] = (sourceTable).toJson();
}
return _json;
}
}
class JobConfigurationLoad {
/**
* [Optional] Accept rows that are missing trailing optional columns. The
* missing values are treated as nulls. If false, records with missing
* trailing columns are treated as bad records, and if there are too many bad
* records, an invalid error is returned in the job result. The default value
* is false. Only applicable to CSV, ignored for other formats.
*/
core.bool allowJaggedRows;
/**
* Indicates if BigQuery should allow quoted data sections that contain
* newline characters in a CSV file. The default value is false.
*/
core.bool allowQuotedNewlines;
/**
* Indicates if we should automatically infer the options and schema for CSV
* and JSON sources.
*/
core.bool autodetect;
/**
* [Optional] Specifies whether the job is allowed to create new tables. The
* following values are supported: CREATE_IF_NEEDED: If the table does not
* exist, BigQuery creates the table. CREATE_NEVER: The table must already
* exist. If it does not, a 'notFound' error is returned in the job result.
* The default value is CREATE_IF_NEEDED. Creation, truncation and append
* actions occur as one atomic update upon job completion.
*/
core.String createDisposition;
/** [Required] The destination table to load the data into. */
TableReference destinationTable;
/**
* [Optional] The character encoding of the data. The supported values are
* UTF-8 or ISO-8859-1. The default value is UTF-8. BigQuery decodes the data
* after the raw, binary data has been split using the values of the quote and
* fieldDelimiter properties.
*/
core.String encoding;
/**
* [Optional] The separator for fields in a CSV file. The separator can be any
* ISO-8859-1 single-byte character. To use a character in the range 128-255,
* you must encode the character as UTF8. BigQuery converts the string to
* ISO-8859-1 encoding, and then uses the first byte of the encoded string to
* split the data in its raw, binary state. BigQuery also supports the escape
* sequence "\t" to specify a tab separator. The default value is a comma
* (',').
*/
core.String fieldDelimiter;
/**
* [Optional] Indicates if BigQuery should allow extra values that are not
* represented in the table schema. If true, the extra values are ignored. If
* false, records with extra columns are treated as bad records, and if there
* are too many bad records, an invalid error is returned in the job result.
* The default value is false. The sourceFormat property determines what
* BigQuery treats as an extra value: CSV: Trailing columns JSON: Named values
* that don't match any column names
*/
core.bool ignoreUnknownValues;
/**
* [Optional] The maximum number of bad records that BigQuery can ignore when
* running the job. If the number of bad records exceeds this value, an
* invalid error is returned in the job result. The default value is 0, which
* requires that all records are valid.
*/
core.int maxBadRecords;
/**
* [Optional] Specifies a string that represents a null value in a CSV file.
* For example, if you specify "\N", BigQuery interprets "\N" as a null value
* when loading a CSV file. The default value is the empty string. If you set
* this property to a custom value, BigQuery throws an error if an empty
* string is present for all data types except for STRING and BYTE. For STRING
* and BYTE columns, BigQuery interprets the empty string as an empty value.
*/
core.String nullMarker;
/**
* If sourceFormat is set to "DATASTORE_BACKUP", indicates which entity
* properties to load into BigQuery from a Cloud Datastore backup. Property
* names are case sensitive and must be top-level properties. If no properties
* are specified, BigQuery loads all properties. If any named property isn't
* found in the Cloud Datastore backup, an invalid error is returned in the
* job result.
*/
core.List<core.String> projectionFields;
/**
* [Optional] The value that is used to quote data sections in a CSV file.
* BigQuery converts the string to ISO-8859-1 encoding, and then uses the
* first byte of the encoded string to split the data in its raw, binary
* state. The default value is a double-quote ('"'). If your data does not
* contain quoted sections, set the property value to an empty string. If your
* data contains quoted newline characters, you must also set the
* allowQuotedNewlines property to true.
*/
core.String quote;
/**
* [Optional] The schema for the destination table. The schema can be omitted
* if the destination table already exists, or if you're loading data from
* Google Cloud Datastore.
*/
TableSchema schema;
/**
* [Deprecated] The inline schema. For CSV schemas, specify as
* "Field1:Type1[,Field2:Type2]*". For example, "foo:STRING, bar:INTEGER,
* baz:FLOAT".
*/
core.String schemaInline;
/** [Deprecated] The format of the schemaInline property. */
core.String schemaInlineFormat;
/**
* [Experimental] Allows the schema of the desitination table to be updated as
* a side effect of the load job. Schema update options are supported in two
* cases: when writeDisposition is WRITE_APPEND; when writeDisposition is
* WRITE_TRUNCATE and the destination table is a partition of a table,
* specified by partition decorators. For normal tables, WRITE_TRUNCATE will
* always overwrite the schema. One or more of the following values are
* specified: ALLOW_FIELD_ADDITION: allow adding a nullable field to the
* schema. ALLOW_FIELD_RELAXATION: allow relaxing a required field in the
* original schema to nullable.
*/
core.List<core.String> schemaUpdateOptions;
/**
* [Optional] The number of rows at the top of a CSV file that BigQuery will
* skip when loading the data. The default value is 0. This property is useful
* if you have header rows in the file that should be skipped.
*/
core.int skipLeadingRows;
/**
* [Optional] The format of the data files. For CSV files, specify "CSV". For
* datastore backups, specify "DATASTORE_BACKUP". For newline-delimited JSON,
* specify "NEWLINE_DELIMITED_JSON". For Avro, specify "AVRO". The default
* value is CSV.
*/
core.String sourceFormat;
/**
* [Required] The fully-qualified URIs that point to your data in Google Cloud
* Storage. Each URI can contain one '*' wildcard character and it must come
* after the 'bucket' name.
*/
core.List<core.String> sourceUris;
/**
* [Optional] Specifies the action that occurs if the destination table
* already exists. The following values are supported: WRITE_TRUNCATE: If the
* table already exists, BigQuery overwrites the table data. WRITE_APPEND: If
* the table already exists, BigQuery appends the data to the table.
* WRITE_EMPTY: If the table already exists and contains data, a 'duplicate'
* error is returned in the job result. The default value is WRITE_APPEND.
* Each action is atomic and only occurs if BigQuery is able to complete the
* job successfully. Creation, truncation and append actions occur as one
* atomic update upon job completion.
*/
core.String writeDisposition;
JobConfigurationLoad();
JobConfigurationLoad.fromJson(core.Map _json) {
if (_json.containsKey("allowJaggedRows")) {
allowJaggedRows = _json["allowJaggedRows"];
}
if (_json.containsKey("allowQuotedNewlines")) {
allowQuotedNewlines = _json["allowQuotedNewlines"];
}
if (_json.containsKey("autodetect")) {
autodetect = _json["autodetect"];
}
if (_json.containsKey("createDisposition")) {
createDisposition = _json["createDisposition"];
}
if (_json.containsKey("destinationTable")) {
destinationTable = new TableReference.fromJson(_json["destinationTable"]);
}
if (_json.containsKey("encoding")) {
encoding = _json["encoding"];
}
if (_json.containsKey("fieldDelimiter")) {
fieldDelimiter = _json["fieldDelimiter"];
}
if (_json.containsKey("ignoreUnknownValues")) {
ignoreUnknownValues = _json["ignoreUnknownValues"];
}
if (_json.containsKey("maxBadRecords")) {
maxBadRecords = _json["maxBadRecords"];
}
if (_json.containsKey("nullMarker")) {
nullMarker = _json["nullMarker"];
}
if (_json.containsKey("projectionFields")) {
projectionFields = _json["projectionFields"];
}
if (_json.containsKey("quote")) {
quote = _json["quote"];
}
if (_json.containsKey("schema")) {
schema = new TableSchema.fromJson(_json["schema"]);
}
if (_json.containsKey("schemaInline")) {
schemaInline = _json["schemaInline"];
}
if (_json.containsKey("schemaInlineFormat")) {
schemaInlineFormat = _json["schemaInlineFormat"];
}
if (_json.containsKey("schemaUpdateOptions")) {
schemaUpdateOptions = _json["schemaUpdateOptions"];
}
if (_json.containsKey("skipLeadingRows")) {
skipLeadingRows = _json["skipLeadingRows"];
}
if (_json.containsKey("sourceFormat")) {
sourceFormat = _json["sourceFormat"];
}
if (_json.containsKey("sourceUris")) {
sourceUris = _json["sourceUris"];
}
if (_json.containsKey("writeDisposition")) {
writeDisposition = _json["writeDisposition"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (allowJaggedRows != null) {
_json["allowJaggedRows"] = allowJaggedRows;
}
if (allowQuotedNewlines != null) {
_json["allowQuotedNewlines"] = allowQuotedNewlines;
}
if (autodetect != null) {
_json["autodetect"] = autodetect;
}
if (createDisposition != null) {
_json["createDisposition"] = createDisposition;
}
if (destinationTable != null) {
_json["destinationTable"] = (destinationTable).toJson();
}
if (encoding != null) {
_json["encoding"] = encoding;
}
if (fieldDelimiter != null) {
_json["fieldDelimiter"] = fieldDelimiter;
}
if (ignoreUnknownValues != null) {
_json["ignoreUnknownValues"] = ignoreUnknownValues;
}
if (maxBadRecords != null) {
_json["maxBadRecords"] = maxBadRecords;
}
if (nullMarker != null) {
_json["nullMarker"] = nullMarker;
}
if (projectionFields != null) {
_json["projectionFields"] = projectionFields;
}
if (quote != null) {
_json["quote"] = quote;
}
if (schema != null) {
_json["schema"] = (schema).toJson();
}
if (schemaInline != null) {
_json["schemaInline"] = schemaInline;
}
if (schemaInlineFormat != null) {
_json["schemaInlineFormat"] = schemaInlineFormat;
}
if (schemaUpdateOptions != null) {
_json["schemaUpdateOptions"] = schemaUpdateOptions;
}
if (skipLeadingRows != null) {
_json["skipLeadingRows"] = skipLeadingRows;
}
if (sourceFormat != null) {
_json["sourceFormat"] = sourceFormat;
}
if (sourceUris != null) {
_json["sourceUris"] = sourceUris;
}
if (writeDisposition != null) {
_json["writeDisposition"] = writeDisposition;
}
return _json;
}
}
class JobConfigurationQuery {
/**
* [Optional] If true and query uses legacy SQL dialect, allows the query to
* produce arbitrarily large result tables at a slight cost in performance.
* Requires destinationTable to be set. For standard SQL queries, this flag is
* ignored and large results are always allowed. However, you must still set
* destinationTable when result size exceeds the allowed maximum response
* size.
*/
core.bool allowLargeResults;
/**
* [Optional] Specifies whether the job is allowed to create new tables. The
* following values are supported: CREATE_IF_NEEDED: If the table does not
* exist, BigQuery creates the table. CREATE_NEVER: The table must already
* exist. If it does not, a 'notFound' error is returned in the job result.
* The default value is CREATE_IF_NEEDED. Creation, truncation and append
* actions occur as one atomic update upon job completion.
*/
core.String createDisposition;
/**
* [Optional] Specifies the default dataset to use for unqualified table names
* in the query.
*/
DatasetReference defaultDataset;
/**
* [Optional] Describes the table where the query results should be stored. If
* not present, a new table will be created to store the results. This
* property must be set for large results that exceed the maximum response
* size.
*/
TableReference destinationTable;
/**
* [Optional] If true and query uses legacy SQL dialect, flattens all nested
* and repeated fields in the query results. allowLargeResults must be true if
* this is set to false. For standard SQL queries, this flag is ignored and
* results are never flattened.
*/
core.bool flattenResults;
/**
* [Optional] Limits the billing tier for this job. Queries that have resource
* usage beyond this tier will fail (without incurring a charge). If
* unspecified, this will be set to your project default.
*/
core.int maximumBillingTier;
/**
* [Optional] Limits the bytes billed for this job. Queries that will have
* bytes billed beyond this limit will fail (without incurring a charge). If
* unspecified, this will be set to your project default.
*/
core.String maximumBytesBilled;
/**
* Standard SQL only. Set to POSITIONAL to use positional (?) query parameters
* or to NAMED to use named (@myparam) query parameters in this query.
*/
core.String parameterMode;
/** [Deprecated] This property is deprecated. */
core.bool preserveNulls;
/**
* [Optional] Specifies a priority for the query. Possible values include
* INTERACTIVE and BATCH. The default value is INTERACTIVE.
*/
core.String priority;
/**
* [Required] SQL query text to execute. The useLegacySql field can be used to
* indicate whether the query uses legacy SQL or standard SQL.
*/
core.String query;
/** Query parameters for standard SQL queries. */
core.List<QueryParameter> queryParameters;
/**
* [Experimental] Allows the schema of the destination table to be updated as
* a side effect of the query job. Schema update options are supported in two
* cases: when writeDisposition is WRITE_APPEND; when writeDisposition is
* WRITE_TRUNCATE and the destination table is a partition of a table,
* specified by partition decorators. For normal tables, WRITE_TRUNCATE will
* always overwrite the schema. One or more of the following values are
* specified: ALLOW_FIELD_ADDITION: allow adding a nullable field to the
* schema. ALLOW_FIELD_RELAXATION: allow relaxing a required field in the
* original schema to nullable.
*/
core.List<core.String> schemaUpdateOptions;
/**
* [Optional] If querying an external data source outside of BigQuery,
* describes the data format, location and other properties of the data
* source. By defining these properties, the data source can then be queried
* as if it were a standard BigQuery table.
*/
core.Map<core.String, ExternalDataConfiguration> tableDefinitions;
/**
* Specifies whether to use BigQuery's legacy SQL dialect for this query. The
* default value is true. If set to false, the query will use BigQuery's
* standard SQL: https://cloud.google.com/bigquery/sql-reference/ When
* useLegacySql is set to false, the values of allowLargeResults and
* flattenResults are ignored; query will be run as if allowLargeResults is
* true and flattenResults is false.
*/
core.bool useLegacySql;
/**
* [Optional] Whether to look for the result in the query cache. The query
* cache is a best-effort cache that will be flushed whenever tables in the
* query are modified. Moreover, the query cache is only available when a
* query does not have a destination table specified. The default value is
* true.
*/
core.bool useQueryCache;
/** Describes user-defined function resources used in the query. */
core.List<UserDefinedFunctionResource> userDefinedFunctionResources;
/**
* [Optional] Specifies the action that occurs if the destination table
* already exists. The following values are supported: WRITE_TRUNCATE: If the
* table already exists, BigQuery overwrites the table data. WRITE_APPEND: If
* the table already exists, BigQuery appends the data to the table.
* WRITE_EMPTY: If the table already exists and contains data, a 'duplicate'
* error is returned in the job result. The default value is WRITE_EMPTY. Each
* action is atomic and only occurs if BigQuery is able to complete the job
* successfully. Creation, truncation and append actions occur as one atomic
* update upon job completion.
*/
core.String writeDisposition;
JobConfigurationQuery();
JobConfigurationQuery.fromJson(core.Map _json) {
if (_json.containsKey("allowLargeResults")) {
allowLargeResults = _json["allowLargeResults"];
}
if (_json.containsKey("createDisposition")) {
createDisposition = _json["createDisposition"];
}
if (_json.containsKey("defaultDataset")) {
defaultDataset = new DatasetReference.fromJson(_json["defaultDataset"]);
}
if (_json.containsKey("destinationTable")) {
destinationTable = new TableReference.fromJson(_json["destinationTable"]);
}
if (_json.containsKey("flattenResults")) {
flattenResults = _json["flattenResults"];
}
if (_json.containsKey("maximumBillingTier")) {
maximumBillingTier = _json["maximumBillingTier"];
}
if (_json.containsKey("maximumBytesBilled")) {
maximumBytesBilled = _json["maximumBytesBilled"];
}
if (_json.containsKey("parameterMode")) {
parameterMode = _json["parameterMode"];
}
if (_json.containsKey("preserveNulls")) {
preserveNulls = _json["preserveNulls"];
}
if (_json.containsKey("priority")) {
priority = _json["priority"];
}
if (_json.containsKey("query")) {
query = _json["query"];
}
if (_json.containsKey("queryParameters")) {
queryParameters = _json["queryParameters"].map((value) => new QueryParameter.fromJson(value)).toList();
}
if (_json.containsKey("schemaUpdateOptions")) {
schemaUpdateOptions = _json["schemaUpdateOptions"];
}
if (_json.containsKey("tableDefinitions")) {
tableDefinitions = commons.mapMap<core.Map<core.String, core.Object>, ExternalDataConfiguration>(_json["tableDefinitions"], (core.Map<core.String, core.Object> item) => new ExternalDataConfiguration.fromJson(item));
}
if (_json.containsKey("useLegacySql")) {
useLegacySql = _json["useLegacySql"];
}
if (_json.containsKey("useQueryCache")) {
useQueryCache = _json["useQueryCache"];
}
if (_json.containsKey("userDefinedFunctionResources")) {
userDefinedFunctionResources = _json["userDefinedFunctionResources"].map((value) => new UserDefinedFunctionResource.fromJson(value)).toList();
}
if (_json.containsKey("writeDisposition")) {
writeDisposition = _json["writeDisposition"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (allowLargeResults != null) {
_json["allowLargeResults"] = allowLargeResults;
}
if (createDisposition != null) {
_json["createDisposition"] = createDisposition;
}
if (defaultDataset != null) {
_json["defaultDataset"] = (defaultDataset).toJson();
}
if (destinationTable != null) {
_json["destinationTable"] = (destinationTable).toJson();
}
if (flattenResults != null) {
_json["flattenResults"] = flattenResults;
}
if (maximumBillingTier != null) {
_json["maximumBillingTier"] = maximumBillingTier;
}
if (maximumBytesBilled != null) {
_json["maximumBytesBilled"] = maximumBytesBilled;
}
if (parameterMode != null) {
_json["parameterMode"] = parameterMode;
}
if (preserveNulls != null) {
_json["preserveNulls"] = preserveNulls;
}
if (priority != null) {
_json["priority"] = priority;
}
if (query != null) {
_json["query"] = query;
}
if (queryParameters != null) {
_json["queryParameters"] = queryParameters.map((value) => (value).toJson()).toList();
}
if (schemaUpdateOptions != null) {
_json["schemaUpdateOptions"] = schemaUpdateOptions;
}
if (tableDefinitions != null) {
_json["tableDefinitions"] = commons.mapMap<ExternalDataConfiguration, core.Map<core.String, core.Object>>(tableDefinitions, (ExternalDataConfiguration item) => (item).toJson());
}
if (useLegacySql != null) {
_json["useLegacySql"] = useLegacySql;
}
if (useQueryCache != null) {
_json["useQueryCache"] = useQueryCache;
}
if (userDefinedFunctionResources != null) {
_json["userDefinedFunctionResources"] = userDefinedFunctionResources.map((value) => (value).toJson()).toList();
}
if (writeDisposition != null) {
_json["writeDisposition"] = writeDisposition;
}
return _json;
}
}
class JobConfigurationTableCopy {
/**
* [Optional] Specifies whether the job is allowed to create new tables. The
* following values are supported: CREATE_IF_NEEDED: If the table does not
* exist, BigQuery creates the table. CREATE_NEVER: The table must already
* exist. If it does not, a 'notFound' error is returned in the job result.
* The default value is CREATE_IF_NEEDED. Creation, truncation and append
* actions occur as one atomic update upon job completion.
*/
core.String createDisposition;
/** [Required] The destination table */
TableReference destinationTable;
/** [Pick one] Source table to copy. */
TableReference sourceTable;
/** [Pick one] Source tables to copy. */
core.List<TableReference> sourceTables;
/**
* [Optional] Specifies the action that occurs if the destination table
* already exists. The following values are supported: WRITE_TRUNCATE: If the
* table already exists, BigQuery overwrites the table data. WRITE_APPEND: If
* the table already exists, BigQuery appends the data to the table.
* WRITE_EMPTY: If the table already exists and contains data, a 'duplicate'
* error is returned in the job result. The default value is WRITE_EMPTY. Each
* action is atomic and only occurs if BigQuery is able to complete the job
* successfully. Creation, truncation and append actions occur as one atomic
* update upon job completion.
*/
core.String writeDisposition;
JobConfigurationTableCopy();
JobConfigurationTableCopy.fromJson(core.Map _json) {
if (_json.containsKey("createDisposition")) {
createDisposition = _json["createDisposition"];
}
if (_json.containsKey("destinationTable")) {
destinationTable = new TableReference.fromJson(_json["destinationTable"]);
}
if (_json.containsKey("sourceTable")) {
sourceTable = new TableReference.fromJson(_json["sourceTable"]);
}
if (_json.containsKey("sourceTables")) {
sourceTables = _json["sourceTables"].map((value) => new TableReference.fromJson(value)).toList();
}
if (_json.containsKey("writeDisposition")) {
writeDisposition = _json["writeDisposition"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (createDisposition != null) {
_json["createDisposition"] = createDisposition;
}
if (destinationTable != null) {
_json["destinationTable"] = (destinationTable).toJson();
}
if (sourceTable != null) {
_json["sourceTable"] = (sourceTable).toJson();
}
if (sourceTables != null) {
_json["sourceTables"] = sourceTables.map((value) => (value).toJson()).toList();
}
if (writeDisposition != null) {
_json["writeDisposition"] = writeDisposition;
}
return _json;
}
}
class JobListJobs {
/** [Full-projection-only] Specifies the job configuration. */
JobConfiguration configuration;
/** A result object that will be present only if the job has failed. */
ErrorProto errorResult;
/** Unique opaque ID of the job. */
core.String id;
/** Job reference uniquely identifying the job. */
JobReference jobReference;
/** The resource type. */
core.String kind;
/**
* Running state of the job. When the state is DONE, errorResult can be
* checked to determine whether the job succeeded or failed.
*/
core.String state;
/**
* [Output-only] Information about the job, including starting time and ending
* time of the job.
*/
JobStatistics statistics;
/** [Full-projection-only] Describes the state of the job. */
JobStatus status;
/** [Full-projection-only] Email address of the user who ran the job. */
core.String userEmail;
JobListJobs();
JobListJobs.fromJson(core.Map _json) {
if (_json.containsKey("configuration")) {
configuration = new JobConfiguration.fromJson(_json["configuration"]);
}
if (_json.containsKey("errorResult")) {
errorResult = new ErrorProto.fromJson(_json["errorResult"]);
}
if (_json.containsKey("id")) {
id = _json["id"];
}
if (_json.containsKey("jobReference")) {
jobReference = new JobReference.fromJson(_json["jobReference"]);
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("state")) {
state = _json["state"];
}
if (_json.containsKey("statistics")) {
statistics = new JobStatistics.fromJson(_json["statistics"]);
}
if (_json.containsKey("status")) {
status = new JobStatus.fromJson(_json["status"]);
}
if (_json.containsKey("user_email")) {
userEmail = _json["user_email"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (configuration != null) {
_json["configuration"] = (configuration).toJson();
}
if (errorResult != null) {
_json["errorResult"] = (errorResult).toJson();
}
if (id != null) {
_json["id"] = id;
}
if (jobReference != null) {
_json["jobReference"] = (jobReference).toJson();
}
if (kind != null) {
_json["kind"] = kind;
}
if (state != null) {
_json["state"] = state;
}
if (statistics != null) {
_json["statistics"] = (statistics).toJson();
}
if (status != null) {
_json["status"] = (status).toJson();
}
if (userEmail != null) {
_json["user_email"] = userEmail;
}
return _json;
}
}
class JobList {
/** A hash of this page of results. */
core.String etag;
/** List of jobs that were requested. */
core.List<JobListJobs> jobs;
/** The resource type of the response. */
core.String kind;
/** A token to request the next page of results. */
core.String nextPageToken;
JobList();
JobList.fromJson(core.Map _json) {
if (_json.containsKey("etag")) {
etag = _json["etag"];
}
if (_json.containsKey("jobs")) {
jobs = _json["jobs"].map((value) => new JobListJobs.fromJson(value)).toList();
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("nextPageToken")) {
nextPageToken = _json["nextPageToken"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (etag != null) {
_json["etag"] = etag;
}
if (jobs != null) {
_json["jobs"] = jobs.map((value) => (value).toJson()).toList();
}
if (kind != null) {
_json["kind"] = kind;
}
if (nextPageToken != null) {
_json["nextPageToken"] = nextPageToken;
}
return _json;
}
}
class JobReference {
/**
* [Required] The ID of the job. The ID must contain only letters (a-z, A-Z),
* numbers (0-9), underscores (_), or dashes (-). The maximum length is 1,024
* characters.
*/
core.String jobId;
/** [Required] The ID of the project containing this job. */
core.String projectId;
JobReference();
JobReference.fromJson(core.Map _json) {
if (_json.containsKey("jobId")) {
jobId = _json["jobId"];
}
if (_json.containsKey("projectId")) {
projectId = _json["projectId"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (jobId != null) {
_json["jobId"] = jobId;
}
if (projectId != null) {
_json["projectId"] = projectId;
}
return _json;
}
}
class JobStatistics {
/**
* [Output-only] Creation time of this job, in milliseconds since the epoch.
* This field will be present on all jobs.
*/
core.String creationTime;
/**
* [Output-only] End time of this job, in milliseconds since the epoch. This
* field will be present whenever a job is in the DONE state.
*/
core.String endTime;
/** [Output-only] Statistics for an extract job. */
JobStatistics4 extract;
/** [Output-only] Statistics for a load job. */
JobStatistics3 load;
/** [Output-only] Statistics for a query job. */
JobStatistics2 query;
/**
* [Output-only] Start time of this job, in milliseconds since the epoch. This
* field will be present when the job transitions from the PENDING state to
* either RUNNING or DONE.
*/
core.String startTime;
/**
* [Output-only] [Deprecated] Use the bytes processed in the query statistics
* instead.
*/
core.String totalBytesProcessed;
JobStatistics();
JobStatistics.fromJson(core.Map _json) {
if (_json.containsKey("creationTime")) {
creationTime = _json["creationTime"];
}
if (_json.containsKey("endTime")) {
endTime = _json["endTime"];
}
if (_json.containsKey("extract")) {
extract = new JobStatistics4.fromJson(_json["extract"]);
}
if (_json.containsKey("load")) {
load = new JobStatistics3.fromJson(_json["load"]);
}
if (_json.containsKey("query")) {
query = new JobStatistics2.fromJson(_json["query"]);
}
if (_json.containsKey("startTime")) {
startTime = _json["startTime"];
}
if (_json.containsKey("totalBytesProcessed")) {
totalBytesProcessed = _json["totalBytesProcessed"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (creationTime != null) {
_json["creationTime"] = creationTime;
}
if (endTime != null) {
_json["endTime"] = endTime;
}
if (extract != null) {
_json["extract"] = (extract).toJson();
}
if (load != null) {
_json["load"] = (load).toJson();
}
if (query != null) {
_json["query"] = (query).toJson();
}
if (startTime != null) {
_json["startTime"] = startTime;
}
if (totalBytesProcessed != null) {
_json["totalBytesProcessed"] = totalBytesProcessed;
}
return _json;
}
}
class JobStatistics2 {
/** [Output-only] Billing tier for the job. */
core.int billingTier;
/**
* [Output-only] Whether the query result was fetched from the query cache.
*/
core.bool cacheHit;
/**
* [Output-only] The number of rows affected by a DML statement. Present only
* for DML statements INSERT, UPDATE or DELETE.
*/
core.String numDmlAffectedRows;
/** [Output-only] Describes execution plan for the query. */
core.List<ExplainQueryStage> queryPlan;
/**
* [Output-only, Experimental] Referenced tables for the job. Queries that
* reference more than 50 tables will not have a complete list.
*/
core.List<TableReference> referencedTables;
/**
* [Output-only, Experimental] The schema of the results. Present only for
* successful dry run of non-legacy SQL queries.
*/
TableSchema schema;
/** [Output-only, Experimental] The type of query statement, if valid. */
core.String statementType;
/** [Output-only] Total bytes billed for the job. */
core.String totalBytesBilled;
/** [Output-only] Total bytes processed for the job. */
core.String totalBytesProcessed;
/**
* [Output-only, Experimental] Standard SQL only: list of undeclared query
* parameters detected during a dry run validation.
*/
core.List<QueryParameter> undeclaredQueryParameters;
JobStatistics2();
JobStatistics2.fromJson(core.Map _json) {
if (_json.containsKey("billingTier")) {
billingTier = _json["billingTier"];
}
if (_json.containsKey("cacheHit")) {
cacheHit = _json["cacheHit"];
}
if (_json.containsKey("numDmlAffectedRows")) {
numDmlAffectedRows = _json["numDmlAffectedRows"];
}
if (_json.containsKey("queryPlan")) {
queryPlan = _json["queryPlan"].map((value) => new ExplainQueryStage.fromJson(value)).toList();
}
if (_json.containsKey("referencedTables")) {
referencedTables = _json["referencedTables"].map((value) => new TableReference.fromJson(value)).toList();
}
if (_json.containsKey("schema")) {
schema = new TableSchema.fromJson(_json["schema"]);
}
if (_json.containsKey("statementType")) {
statementType = _json["statementType"];
}
if (_json.containsKey("totalBytesBilled")) {
totalBytesBilled = _json["totalBytesBilled"];
}
if (_json.containsKey("totalBytesProcessed")) {
totalBytesProcessed = _json["totalBytesProcessed"];
}
if (_json.containsKey("undeclaredQueryParameters")) {
undeclaredQueryParameters = _json["undeclaredQueryParameters"].map((value) => new QueryParameter.fromJson(value)).toList();
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (billingTier != null) {
_json["billingTier"] = billingTier;
}
if (cacheHit != null) {
_json["cacheHit"] = cacheHit;
}
if (numDmlAffectedRows != null) {
_json["numDmlAffectedRows"] = numDmlAffectedRows;
}
if (queryPlan != null) {
_json["queryPlan"] = queryPlan.map((value) => (value).toJson()).toList();
}
if (referencedTables != null) {
_json["referencedTables"] = referencedTables.map((value) => (value).toJson()).toList();
}
if (schema != null) {
_json["schema"] = (schema).toJson();
}
if (statementType != null) {
_json["statementType"] = statementType;
}
if (totalBytesBilled != null) {
_json["totalBytesBilled"] = totalBytesBilled;
}
if (totalBytesProcessed != null) {
_json["totalBytesProcessed"] = totalBytesProcessed;
}
if (undeclaredQueryParameters != null) {
_json["undeclaredQueryParameters"] = undeclaredQueryParameters.map((value) => (value).toJson()).toList();
}
return _json;
}
}
class JobStatistics3 {
/** [Output-only] Number of bytes of source data in a load job. */
core.String inputFileBytes;
/** [Output-only] Number of source files in a load job. */
core.String inputFiles;
/**
* [Output-only] Size of the loaded data in bytes. Note that while a load job
* is in the running state, this value may change.
*/
core.String outputBytes;
/**
* [Output-only] Number of rows imported in a load job. Note that while an
* import job is in the running state, this value may change.
*/
core.String outputRows;
JobStatistics3();
JobStatistics3.fromJson(core.Map _json) {
if (_json.containsKey("inputFileBytes")) {
inputFileBytes = _json["inputFileBytes"];
}
if (_json.containsKey("inputFiles")) {
inputFiles = _json["inputFiles"];
}
if (_json.containsKey("outputBytes")) {
outputBytes = _json["outputBytes"];
}
if (_json.containsKey("outputRows")) {
outputRows = _json["outputRows"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (inputFileBytes != null) {
_json["inputFileBytes"] = inputFileBytes;
}
if (inputFiles != null) {
_json["inputFiles"] = inputFiles;
}
if (outputBytes != null) {
_json["outputBytes"] = outputBytes;
}
if (outputRows != null) {
_json["outputRows"] = outputRows;
}
return _json;
}
}
class JobStatistics4 {
/**
* [Output-only] Number of files per destination URI or URI pattern specified
* in the extract configuration. These values will be in the same order as the
* URIs specified in the 'destinationUris' field.
*/
core.List<core.String> destinationUriFileCounts;
JobStatistics4();
JobStatistics4.fromJson(core.Map _json) {
if (_json.containsKey("destinationUriFileCounts")) {
destinationUriFileCounts = _json["destinationUriFileCounts"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (destinationUriFileCounts != null) {
_json["destinationUriFileCounts"] = destinationUriFileCounts;
}
return _json;
}
}
class JobStatus {
/**
* [Output-only] Final error result of the job. If present, indicates that the
* job has completed and was unsuccessful.
*/
ErrorProto errorResult;
/**
* [Output-only] The first errors encountered during the running of the job.
* The final message includes the number of errors that caused the process to
* stop. Errors here do not necessarily mean that the job has completed or was
* unsuccessful.
*/
core.List<ErrorProto> errors;
/** [Output-only] Running state of the job. */
core.String state;
JobStatus();
JobStatus.fromJson(core.Map _json) {
if (_json.containsKey("errorResult")) {
errorResult = new ErrorProto.fromJson(_json["errorResult"]);
}
if (_json.containsKey("errors")) {
errors = _json["errors"].map((value) => new ErrorProto.fromJson(value)).toList();
}
if (_json.containsKey("state")) {
state = _json["state"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (errorResult != null) {
_json["errorResult"] = (errorResult).toJson();
}
if (errors != null) {
_json["errors"] = errors.map((value) => (value).toJson()).toList();
}
if (state != null) {
_json["state"] = state;
}
return _json;
}
}
/** Represents a single JSON object. */
class JsonObject
extends collection.MapBase<core.String, core.Object> {
final core.Map _innerMap = {};
JsonObject();
JsonObject.fromJson(core.Map _json) {
_json.forEach((core.String key, value) {
this[key] = value;
});
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = <core.String, core.Object>{};
this.forEach((core.String key, value) {
_json[key] = value;
});
return _json;
}
core.Object operator [](core.Object key)
=> _innerMap[key];
operator []=(core.String key, core.Object value) {
_innerMap[key] = value;
}
void clear() {
_innerMap.clear();
}
core.Iterable<core.String> get keys => _innerMap.keys;
core.Object remove(core.Object key) => _innerMap.remove(key);
}
class ProjectListProjects {
/** A descriptive name for this project. */
core.String friendlyName;
/** An opaque ID of this project. */
core.String id;
/** The resource type. */
core.String kind;
/** The numeric ID of this project. */
core.String numericId;
/** A unique reference to this project. */
ProjectReference projectReference;
ProjectListProjects();
ProjectListProjects.fromJson(core.Map _json) {
if (_json.containsKey("friendlyName")) {
friendlyName = _json["friendlyName"];
}
if (_json.containsKey("id")) {
id = _json["id"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("numericId")) {
numericId = _json["numericId"];
}
if (_json.containsKey("projectReference")) {
projectReference = new ProjectReference.fromJson(_json["projectReference"]);
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (friendlyName != null) {
_json["friendlyName"] = friendlyName;
}
if (id != null) {
_json["id"] = id;
}
if (kind != null) {
_json["kind"] = kind;
}
if (numericId != null) {
_json["numericId"] = numericId;
}
if (projectReference != null) {
_json["projectReference"] = (projectReference).toJson();
}
return _json;
}
}
class ProjectList {
/** A hash of the page of results */
core.String etag;
/** The type of list. */
core.String kind;
/** A token to request the next page of results. */
core.String nextPageToken;
/** Projects to which you have at least READ access. */
core.List<ProjectListProjects> projects;
/** The total number of projects in the list. */
core.int totalItems;
ProjectList();
ProjectList.fromJson(core.Map _json) {
if (_json.containsKey("etag")) {
etag = _json["etag"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("nextPageToken")) {
nextPageToken = _json["nextPageToken"];
}
if (_json.containsKey("projects")) {
projects = _json["projects"].map((value) => new ProjectListProjects.fromJson(value)).toList();
}
if (_json.containsKey("totalItems")) {
totalItems = _json["totalItems"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (etag != null) {
_json["etag"] = etag;
}
if (kind != null) {
_json["kind"] = kind;
}
if (nextPageToken != null) {
_json["nextPageToken"] = nextPageToken;
}
if (projects != null) {
_json["projects"] = projects.map((value) => (value).toJson()).toList();
}
if (totalItems != null) {
_json["totalItems"] = totalItems;
}
return _json;
}
}
class ProjectReference {
/**
* [Required] ID of the project. Can be either the numeric ID or the assigned
* ID of the project.
*/
core.String projectId;
ProjectReference();
ProjectReference.fromJson(core.Map _json) {
if (_json.containsKey("projectId")) {
projectId = _json["projectId"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (projectId != null) {
_json["projectId"] = projectId;
}
return _json;
}
}
class QueryParameter {
/**
* [Optional] If unset, this is a positional parameter. Otherwise, should be
* unique within a query.
*/
core.String name;
/** [Required] The type of this parameter. */
QueryParameterType parameterType;
/** [Required] The value of this parameter. */
QueryParameterValue parameterValue;
QueryParameter();
QueryParameter.fromJson(core.Map _json) {
if (_json.containsKey("name")) {
name = _json["name"];
}
if (_json.containsKey("parameterType")) {
parameterType = new QueryParameterType.fromJson(_json["parameterType"]);
}
if (_json.containsKey("parameterValue")) {
parameterValue = new QueryParameterValue.fromJson(_json["parameterValue"]);
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (name != null) {
_json["name"] = name;
}
if (parameterType != null) {
_json["parameterType"] = (parameterType).toJson();
}
if (parameterValue != null) {
_json["parameterValue"] = (parameterValue).toJson();
}
return _json;
}
}
class QueryParameterTypeStructTypes {
/** [Optional] Human-oriented description of the field. */
core.String description;
/** [Optional] The name of this field. */
core.String name;
/** [Required] The type of this field. */
QueryParameterType type;
QueryParameterTypeStructTypes();
QueryParameterTypeStructTypes.fromJson(core.Map _json) {
if (_json.containsKey("description")) {
description = _json["description"];
}
if (_json.containsKey("name")) {
name = _json["name"];
}
if (_json.containsKey("type")) {
type = new QueryParameterType.fromJson(_json["type"]);
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (description != null) {
_json["description"] = description;
}
if (name != null) {
_json["name"] = name;
}
if (type != null) {
_json["type"] = (type).toJson();
}
return _json;
}
}
class QueryParameterType {
/** [Optional] The type of the array's elements, if this is an array. */
QueryParameterType arrayType;
/**
* [Optional] The types of the fields of this struct, in order, if this is a
* struct.
*/
core.List<QueryParameterTypeStructTypes> structTypes;
/** [Required] The top level type of this field. */
core.String type;
QueryParameterType();
QueryParameterType.fromJson(core.Map _json) {
if (_json.containsKey("arrayType")) {
arrayType = new QueryParameterType.fromJson(_json["arrayType"]);
}
if (_json.containsKey("structTypes")) {
structTypes = _json["structTypes"].map((value) => new QueryParameterTypeStructTypes.fromJson(value)).toList();
}
if (_json.containsKey("type")) {
type = _json["type"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (arrayType != null) {
_json["arrayType"] = (arrayType).toJson();
}
if (structTypes != null) {
_json["structTypes"] = structTypes.map((value) => (value).toJson()).toList();
}
if (type != null) {
_json["type"] = type;
}
return _json;
}
}
class QueryParameterValue {
/** [Optional] The array values, if this is an array type. */
core.List<QueryParameterValue> arrayValues;
/**
* [Optional] The struct field values, in order of the struct type's
* declaration.
*/
core.Map<core.String, QueryParameterValue> structValues;
/** [Optional] The value of this value, if a simple scalar type. */
core.String value;
QueryParameterValue();
QueryParameterValue.fromJson(core.Map _json) {
if (_json.containsKey("arrayValues")) {
arrayValues = _json["arrayValues"].map((value) => new QueryParameterValue.fromJson(value)).toList();
}
if (_json.containsKey("structValues")) {
structValues = commons.mapMap<core.Map<core.String, core.Object>, QueryParameterValue>(_json["structValues"], (core.Map<core.String, core.Object> item) => new QueryParameterValue.fromJson(item));
}
if (_json.containsKey("value")) {
value = _json["value"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (arrayValues != null) {
_json["arrayValues"] = arrayValues.map((value) => (value).toJson()).toList();
}
if (structValues != null) {
_json["structValues"] = commons.mapMap<QueryParameterValue, core.Map<core.String, core.Object>>(structValues, (QueryParameterValue item) => (item).toJson());
}
if (value != null) {
_json["value"] = value;
}
return _json;
}
}
class QueryRequest {
/**
* [Optional] Specifies the default datasetId and projectId to assume for any
* unqualified table names in the query. If not set, all table names in the
* query string must be qualified in the format 'datasetId.tableId'.
*/
DatasetReference defaultDataset;
/**
* [Optional] If set to true, BigQuery doesn't run the job. Instead, if the
* query is valid, BigQuery returns statistics about the job such as how many
* bytes would be processed. If the query is invalid, an error returns. The
* default value is false.
*/
core.bool dryRun;
/** The resource type of the request. */
core.String kind;
/**
* [Optional] The maximum number of rows of data to return per page of
* results. Setting this flag to a small value such as 1000 and then paging
* through results might improve reliability when the query result set is
* large. In addition to this limit, responses are also limited to 10 MB. By
* default, there is no maximum row count, and only the byte limit applies.
*/
core.int maxResults;
/**
* Standard SQL only. Set to POSITIONAL to use positional (?) query parameters
* or to NAMED to use named (@myparam) query parameters in this query.
*/
core.String parameterMode;
/** [Deprecated] This property is deprecated. */
core.bool preserveNulls;
/**
* [Required] A query string, following the BigQuery query syntax, of the
* query to execute. Example: "SELECT count(f1) FROM
* [myProjectId:myDatasetId.myTableId]".
*/
core.String query;
/** Query parameters for Standard SQL queries. */
core.List<QueryParameter> queryParameters;
/**
* [Optional] How long to wait for the query to complete, in milliseconds,
* before the request times out and returns. Note that this is only a timeout
* for the request, not the query. If the query takes longer to run than the
* timeout value, the call returns without any results and with the
* 'jobComplete' flag set to false. You can call GetQueryResults() to wait for
* the query to complete and read the results. The default value is 10000
* milliseconds (10 seconds).
*/
core.int timeoutMs;
/**
* Specifies whether to use BigQuery's legacy SQL dialect for this query. The
* default value is true. If set to false, the query will use BigQuery's
* standard SQL: https://cloud.google.com/bigquery/sql-reference/ When
* useLegacySql is set to false, the values of allowLargeResults and
* flattenResults are ignored; query will be run as if allowLargeResults is
* true and flattenResults is false.
*/
core.bool useLegacySql;
/**
* [Optional] Whether to look for the result in the query cache. The query
* cache is a best-effort cache that will be flushed whenever tables in the
* query are modified. The default value is true.
*/
core.bool useQueryCache;
QueryRequest();
QueryRequest.fromJson(core.Map _json) {
if (_json.containsKey("defaultDataset")) {
defaultDataset = new DatasetReference.fromJson(_json["defaultDataset"]);
}
if (_json.containsKey("dryRun")) {
dryRun = _json["dryRun"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("maxResults")) {
maxResults = _json["maxResults"];
}
if (_json.containsKey("parameterMode")) {
parameterMode = _json["parameterMode"];
}
if (_json.containsKey("preserveNulls")) {
preserveNulls = _json["preserveNulls"];
}
if (_json.containsKey("query")) {
query = _json["query"];
}
if (_json.containsKey("queryParameters")) {
queryParameters = _json["queryParameters"].map((value) => new QueryParameter.fromJson(value)).toList();
}
if (_json.containsKey("timeoutMs")) {
timeoutMs = _json["timeoutMs"];
}
if (_json.containsKey("useLegacySql")) {
useLegacySql = _json["useLegacySql"];
}
if (_json.containsKey("useQueryCache")) {
useQueryCache = _json["useQueryCache"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (defaultDataset != null) {
_json["defaultDataset"] = (defaultDataset).toJson();
}
if (dryRun != null) {
_json["dryRun"] = dryRun;
}
if (kind != null) {
_json["kind"] = kind;
}
if (maxResults != null) {
_json["maxResults"] = maxResults;
}
if (parameterMode != null) {
_json["parameterMode"] = parameterMode;
}
if (preserveNulls != null) {
_json["preserveNulls"] = preserveNulls;
}
if (query != null) {
_json["query"] = query;
}
if (queryParameters != null) {
_json["queryParameters"] = queryParameters.map((value) => (value).toJson()).toList();
}
if (timeoutMs != null) {
_json["timeoutMs"] = timeoutMs;
}
if (useLegacySql != null) {
_json["useLegacySql"] = useLegacySql;
}
if (useQueryCache != null) {
_json["useQueryCache"] = useQueryCache;
}
return _json;
}
}
class QueryResponse {
/** Whether the query result was fetched from the query cache. */
core.bool cacheHit;
/**
* [Output-only] The first errors or warnings encountered during the running
* of the job. The final message includes the number of errors that caused the
* process to stop. Errors here do not necessarily mean that the job has
* completed or was unsuccessful.
*/
core.List<ErrorProto> errors;
/**
* Whether the query has completed or not. If rows or totalRows are present,
* this will always be true. If this is false, totalRows will not be
* available.
*/
core.bool jobComplete;
/**
* Reference to the Job that was created to run the query. This field will be
* present even if the original request timed out, in which case
* GetQueryResults can be used to read the results once the query has
* completed. Since this API only returns the first page of results,
* subsequent pages can be fetched via the same mechanism (GetQueryResults).
*/
JobReference jobReference;
/** The resource type. */
core.String kind;
/**
* [Output-only] The number of rows affected by a DML statement. Present only
* for DML statements INSERT, UPDATE or DELETE.
*/
core.String numDmlAffectedRows;
/** A token used for paging results. */
core.String pageToken;
/**
* An object with as many results as can be contained within the maximum
* permitted reply size. To get any additional rows, you can call
* GetQueryResults and specify the jobReference returned above.
*/
core.List<TableRow> rows;
/**
* The schema of the results. Present only when the query completes
* successfully.
*/
TableSchema schema;
/**
* The total number of bytes processed for this query. If this query was a dry
* run, this is the number of bytes that would be processed if the query were
* run.
*/
core.String totalBytesProcessed;
/**
* The total number of rows in the complete query result set, which can be
* more than the number of rows in this single page of results.
*/
core.String totalRows;
QueryResponse();
QueryResponse.fromJson(core.Map _json) {
if (_json.containsKey("cacheHit")) {
cacheHit = _json["cacheHit"];
}
if (_json.containsKey("errors")) {
errors = _json["errors"].map((value) => new ErrorProto.fromJson(value)).toList();
}
if (_json.containsKey("jobComplete")) {
jobComplete = _json["jobComplete"];
}
if (_json.containsKey("jobReference")) {
jobReference = new JobReference.fromJson(_json["jobReference"]);
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("numDmlAffectedRows")) {
numDmlAffectedRows = _json["numDmlAffectedRows"];
}
if (_json.containsKey("pageToken")) {
pageToken = _json["pageToken"];
}
if (_json.containsKey("rows")) {
rows = _json["rows"].map((value) => new TableRow.fromJson(value)).toList();
}
if (_json.containsKey("schema")) {
schema = new TableSchema.fromJson(_json["schema"]);
}
if (_json.containsKey("totalBytesProcessed")) {
totalBytesProcessed = _json["totalBytesProcessed"];
}
if (_json.containsKey("totalRows")) {
totalRows = _json["totalRows"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (cacheHit != null) {
_json["cacheHit"] = cacheHit;
}
if (errors != null) {
_json["errors"] = errors.map((value) => (value).toJson()).toList();
}
if (jobComplete != null) {
_json["jobComplete"] = jobComplete;
}
if (jobReference != null) {
_json["jobReference"] = (jobReference).toJson();
}
if (kind != null) {
_json["kind"] = kind;
}
if (numDmlAffectedRows != null) {
_json["numDmlAffectedRows"] = numDmlAffectedRows;
}
if (pageToken != null) {
_json["pageToken"] = pageToken;
}
if (rows != null) {
_json["rows"] = rows.map((value) => (value).toJson()).toList();
}
if (schema != null) {
_json["schema"] = (schema).toJson();
}
if (totalBytesProcessed != null) {
_json["totalBytesProcessed"] = totalBytesProcessed;
}
if (totalRows != null) {
_json["totalRows"] = totalRows;
}
return _json;
}
}
class Streamingbuffer {
/**
* [Output-only] A lower-bound estimate of the number of bytes currently in
* the streaming buffer.
*/
core.String estimatedBytes;
/**
* [Output-only] A lower-bound estimate of the number of rows currently in the
* streaming buffer.
*/
core.String estimatedRows;
/**
* [Output-only] Contains the timestamp of the oldest entry in the streaming
* buffer, in milliseconds since the epoch, if the streaming buffer is
* available.
*/
core.String oldestEntryTime;
Streamingbuffer();
Streamingbuffer.fromJson(core.Map _json) {
if (_json.containsKey("estimatedBytes")) {
estimatedBytes = _json["estimatedBytes"];
}
if (_json.containsKey("estimatedRows")) {
estimatedRows = _json["estimatedRows"];
}
if (_json.containsKey("oldestEntryTime")) {
oldestEntryTime = _json["oldestEntryTime"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (estimatedBytes != null) {
_json["estimatedBytes"] = estimatedBytes;
}
if (estimatedRows != null) {
_json["estimatedRows"] = estimatedRows;
}
if (oldestEntryTime != null) {
_json["oldestEntryTime"] = oldestEntryTime;
}
return _json;
}
}
class Table {
/**
* [Output-only] The time when this table was created, in milliseconds since
* the epoch.
*/
core.String creationTime;
/** [Optional] A user-friendly description of this table. */
core.String description;
/** [Output-only] A hash of this resource. */
core.String etag;
/**
* [Optional] The time when this table expires, in milliseconds since the
* epoch. If not present, the table will persist indefinitely. Expired tables
* will be deleted and their storage reclaimed.
*/
core.String expirationTime;
/**
* [Optional] Describes the data format, location, and other properties of a
* table stored outside of BigQuery. By defining these properties, the data
* source can then be queried as if it were a standard BigQuery table.
*/
ExternalDataConfiguration externalDataConfiguration;
/** [Optional] A descriptive name for this table. */
core.String friendlyName;
/** [Output-only] An opaque ID uniquely identifying the table. */
core.String id;
/** [Output-only] The type of the resource. */
core.String kind;
/**
* [Experimental] The labels associated with this table. You can use these to
* organize and group your tables. Label keys and values can be no longer than
* 63 characters, can only contain lowercase letters, numeric characters,
* underscores and dashes. International characters are allowed. Label values
* are optional. Label keys must start with a letter and each label in the
* list must have a different key.
*/
core.Map<core.String, core.String> labels;
/**
* [Output-only] The time when this table was last modified, in milliseconds
* since the epoch.
*/
core.String lastModifiedTime;
/**
* [Output-only] The geographic location where the table resides. This value
* is inherited from the dataset.
*/
core.String location;
/**
* [Output-only] The size of this table in bytes, excluding any data in the
* streaming buffer.
*/
core.String numBytes;
/**
* [Output-only] The number of bytes in the table that are considered
* "long-term storage".
*/
core.String numLongTermBytes;
/**
* [Output-only] The number of rows of data in this table, excluding any data
* in the streaming buffer.
*/
core.String numRows;
/** [Optional] Describes the schema of this table. */
TableSchema schema;
/** [Output-only] A URL that can be used to access this resource again. */
core.String selfLink;
/**
* [Output-only] Contains information regarding this table's streaming buffer,
* if one is present. This field will be absent if the table is not being
* streamed to or if there is no data in the streaming buffer.
*/
Streamingbuffer streamingBuffer;
/** [Required] Reference describing the ID of this table. */
TableReference tableReference;
/**
* [Experimental] If specified, configures time-based partitioning for this
* table.
*/
TimePartitioning timePartitioning;
/**
* [Output-only] Describes the table type. The following values are supported:
* TABLE: A normal BigQuery table. VIEW: A virtual table defined by a SQL
* query. EXTERNAL: A table that references data stored in an external storage
* system, such as Google Cloud Storage. The default value is TABLE.
*/
core.String type;
/** [Optional] The view definition. */
ViewDefinition view;
Table();
Table.fromJson(core.Map _json) {
if (_json.containsKey("creationTime")) {
creationTime = _json["creationTime"];
}
if (_json.containsKey("description")) {
description = _json["description"];
}
if (_json.containsKey("etag")) {
etag = _json["etag"];
}
if (_json.containsKey("expirationTime")) {
expirationTime = _json["expirationTime"];
}
if (_json.containsKey("externalDataConfiguration")) {
externalDataConfiguration = new ExternalDataConfiguration.fromJson(_json["externalDataConfiguration"]);
}
if (_json.containsKey("friendlyName")) {
friendlyName = _json["friendlyName"];
}
if (_json.containsKey("id")) {
id = _json["id"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("labels")) {
labels = _json["labels"];
}
if (_json.containsKey("lastModifiedTime")) {
lastModifiedTime = _json["lastModifiedTime"];
}
if (_json.containsKey("location")) {
location = _json["location"];
}
if (_json.containsKey("numBytes")) {
numBytes = _json["numBytes"];
}
if (_json.containsKey("numLongTermBytes")) {
numLongTermBytes = _json["numLongTermBytes"];
}
if (_json.containsKey("numRows")) {
numRows = _json["numRows"];
}
if (_json.containsKey("schema")) {
schema = new TableSchema.fromJson(_json["schema"]);
}
if (_json.containsKey("selfLink")) {
selfLink = _json["selfLink"];
}
if (_json.containsKey("streamingBuffer")) {
streamingBuffer = new Streamingbuffer.fromJson(_json["streamingBuffer"]);
}
if (_json.containsKey("tableReference")) {
tableReference = new TableReference.fromJson(_json["tableReference"]);
}
if (_json.containsKey("timePartitioning")) {
timePartitioning = new TimePartitioning.fromJson(_json["timePartitioning"]);
}
if (_json.containsKey("type")) {
type = _json["type"];
}
if (_json.containsKey("view")) {
view = new ViewDefinition.fromJson(_json["view"]);
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (creationTime != null) {
_json["creationTime"] = creationTime;
}
if (description != null) {
_json["description"] = description;
}
if (etag != null) {
_json["etag"] = etag;
}
if (expirationTime != null) {
_json["expirationTime"] = expirationTime;
}
if (externalDataConfiguration != null) {
_json["externalDataConfiguration"] = (externalDataConfiguration).toJson();
}
if (friendlyName != null) {
_json["friendlyName"] = friendlyName;
}
if (id != null) {
_json["id"] = id;
}
if (kind != null) {
_json["kind"] = kind;
}
if (labels != null) {
_json["labels"] = labels;
}
if (lastModifiedTime != null) {
_json["lastModifiedTime"] = lastModifiedTime;
}
if (location != null) {
_json["location"] = location;
}
if (numBytes != null) {
_json["numBytes"] = numBytes;
}
if (numLongTermBytes != null) {
_json["numLongTermBytes"] = numLongTermBytes;
}
if (numRows != null) {
_json["numRows"] = numRows;
}
if (schema != null) {
_json["schema"] = (schema).toJson();
}
if (selfLink != null) {
_json["selfLink"] = selfLink;
}
if (streamingBuffer != null) {
_json["streamingBuffer"] = (streamingBuffer).toJson();
}
if (tableReference != null) {
_json["tableReference"] = (tableReference).toJson();
}
if (timePartitioning != null) {
_json["timePartitioning"] = (timePartitioning).toJson();
}
if (type != null) {
_json["type"] = type;
}
if (view != null) {
_json["view"] = (view).toJson();
}
return _json;
}
}
class TableCell {
/**
*
*
* The values for Object must be JSON objects. It can consist of `num`,
* `String`, `bool` and `null` as well as `Map` and `List` values.
*/
core.Object v;
TableCell();
TableCell.fromJson(core.Map _json) {
if (_json.containsKey("v")) {
v = _json["v"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (v != null) {
_json["v"] = v;
}
return _json;
}
}
class TableDataInsertAllRequestRows {
/**
* [Optional] A unique ID for each row. BigQuery uses this property to detect
* duplicate insertion requests on a best-effort basis.
*/
core.String insertId;
/**
* [Required] A JSON object that contains a row of data. The object's
* properties and values must match the destination table's schema.
*/
JsonObject json;
TableDataInsertAllRequestRows();
TableDataInsertAllRequestRows.fromJson(core.Map _json) {
if (_json.containsKey("insertId")) {
insertId = _json["insertId"];
}
if (_json.containsKey("json")) {
json = new JsonObject.fromJson(_json["json"]);
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (insertId != null) {
_json["insertId"] = insertId;
}
if (json != null) {
_json["json"] = json;
}
return _json;
}
}
class TableDataInsertAllRequest {
/**
* [Optional] Accept rows that contain values that do not match the schema.
* The unknown values are ignored. Default is false, which treats unknown
* values as errors.
*/
core.bool ignoreUnknownValues;
/** The resource type of the response. */
core.String kind;
/** The rows to insert. */
core.List<TableDataInsertAllRequestRows> rows;
/**
* [Optional] Insert all valid rows of a request, even if invalid rows exist.
* The default value is false, which causes the entire request to fail if any
* invalid rows exist.
*/
core.bool skipInvalidRows;
/**
* [Experimental] If specified, treats the destination table as a base
* template, and inserts the rows into an instance table named
* "{destination}{templateSuffix}". BigQuery will manage creation of the
* instance table, using the schema of the base template table. See
* https://cloud.google.com/bigquery/streaming-data-into-bigquery#template-tables
* for considerations when working with templates tables.
*/
core.String templateSuffix;
TableDataInsertAllRequest();
TableDataInsertAllRequest.fromJson(core.Map _json) {
if (_json.containsKey("ignoreUnknownValues")) {
ignoreUnknownValues = _json["ignoreUnknownValues"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("rows")) {
rows = _json["rows"].map((value) => new TableDataInsertAllRequestRows.fromJson(value)).toList();
}
if (_json.containsKey("skipInvalidRows")) {
skipInvalidRows = _json["skipInvalidRows"];
}
if (_json.containsKey("templateSuffix")) {
templateSuffix = _json["templateSuffix"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (ignoreUnknownValues != null) {
_json["ignoreUnknownValues"] = ignoreUnknownValues;
}
if (kind != null) {
_json["kind"] = kind;
}
if (rows != null) {
_json["rows"] = rows.map((value) => (value).toJson()).toList();
}
if (skipInvalidRows != null) {
_json["skipInvalidRows"] = skipInvalidRows;
}
if (templateSuffix != null) {
_json["templateSuffix"] = templateSuffix;
}
return _json;
}
}
class TableDataInsertAllResponseInsertErrors {
/** Error information for the row indicated by the index property. */
core.List<ErrorProto> errors;
/** The index of the row that error applies to. */
core.int index;
TableDataInsertAllResponseInsertErrors();
TableDataInsertAllResponseInsertErrors.fromJson(core.Map _json) {
if (_json.containsKey("errors")) {
errors = _json["errors"].map((value) => new ErrorProto.fromJson(value)).toList();
}
if (_json.containsKey("index")) {
index = _json["index"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (errors != null) {
_json["errors"] = errors.map((value) => (value).toJson()).toList();
}
if (index != null) {
_json["index"] = index;
}
return _json;
}
}
class TableDataInsertAllResponse {
/** An array of errors for rows that were not inserted. */
core.List<TableDataInsertAllResponseInsertErrors> insertErrors;
/** The resource type of the response. */
core.String kind;
TableDataInsertAllResponse();
TableDataInsertAllResponse.fromJson(core.Map _json) {
if (_json.containsKey("insertErrors")) {
insertErrors = _json["insertErrors"].map((value) => new TableDataInsertAllResponseInsertErrors.fromJson(value)).toList();
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (insertErrors != null) {
_json["insertErrors"] = insertErrors.map((value) => (value).toJson()).toList();
}
if (kind != null) {
_json["kind"] = kind;
}
return _json;
}
}
class TableDataList {
/** A hash of this page of results. */
core.String etag;
/** The resource type of the response. */
core.String kind;
/**
* A token used for paging results. Providing this token instead of the
* startIndex parameter can help you retrieve stable results when an
* underlying table is changing.
*/
core.String pageToken;
/** Rows of results. */
core.List<TableRow> rows;
/** The total number of rows in the complete table. */
core.String totalRows;
TableDataList();
TableDataList.fromJson(core.Map _json) {
if (_json.containsKey("etag")) {
etag = _json["etag"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("pageToken")) {
pageToken = _json["pageToken"];
}
if (_json.containsKey("rows")) {
rows = _json["rows"].map((value) => new TableRow.fromJson(value)).toList();
}
if (_json.containsKey("totalRows")) {
totalRows = _json["totalRows"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (etag != null) {
_json["etag"] = etag;
}
if (kind != null) {
_json["kind"] = kind;
}
if (pageToken != null) {
_json["pageToken"] = pageToken;
}
if (rows != null) {
_json["rows"] = rows.map((value) => (value).toJson()).toList();
}
if (totalRows != null) {
_json["totalRows"] = totalRows;
}
return _json;
}
}
class TableFieldSchema {
/**
* [Optional] The field description. The maximum length is 1,024 characters.
*/
core.String description;
/**
* [Optional] Describes the nested schema fields if the type property is set
* to RECORD.
*/
core.List<TableFieldSchema> fields;
/**
* [Optional] The field mode. Possible values include NULLABLE, REQUIRED and
* REPEATED. The default value is NULLABLE.
*/
core.String mode;
/**
* [Required] The field name. The name must contain only letters (a-z, A-Z),
* numbers (0-9), or underscores (_), and must start with a letter or
* underscore. The maximum length is 128 characters.
*/
core.String name;
/**
* [Required] The field data type. Possible values include STRING, BYTES,
* INTEGER, INT64 (same as INTEGER), FLOAT, FLOAT64 (same as FLOAT), BOOLEAN,
* BOOL (same as BOOLEAN), TIMESTAMP, DATE, TIME, DATETIME, RECORD (where
* RECORD indicates that the field contains a nested schema) or STRUCT (same
* as RECORD).
*/
core.String type;
TableFieldSchema();
TableFieldSchema.fromJson(core.Map _json) {
if (_json.containsKey("description")) {
description = _json["description"];
}
if (_json.containsKey("fields")) {
fields = _json["fields"].map((value) => new TableFieldSchema.fromJson(value)).toList();
}
if (_json.containsKey("mode")) {
mode = _json["mode"];
}
if (_json.containsKey("name")) {
name = _json["name"];
}
if (_json.containsKey("type")) {
type = _json["type"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (description != null) {
_json["description"] = description;
}
if (fields != null) {
_json["fields"] = fields.map((value) => (value).toJson()).toList();
}
if (mode != null) {
_json["mode"] = mode;
}
if (name != null) {
_json["name"] = name;
}
if (type != null) {
_json["type"] = type;
}
return _json;
}
}
/** Additional details for a view. */
class TableListTablesView {
/**
* True if view is defined in legacy SQL dialect, false if in standard SQL.
*/
core.bool useLegacySql;
TableListTablesView();
TableListTablesView.fromJson(core.Map _json) {
if (_json.containsKey("useLegacySql")) {
useLegacySql = _json["useLegacySql"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (useLegacySql != null) {
_json["useLegacySql"] = useLegacySql;
}
return _json;
}
}
class TableListTables {
/** The user-friendly name for this table. */
core.String friendlyName;
/** An opaque ID of the table */
core.String id;
/** The resource type. */
core.String kind;
/**
* [Experimental] The labels associated with this table. You can use these to
* organize and group your tables.
*/
core.Map<core.String, core.String> labels;
/** A reference uniquely identifying the table. */
TableReference tableReference;
/** [Experimental] The time-based partitioning for this table. */
TimePartitioning timePartitioning;
/** The type of table. Possible values are: TABLE, VIEW. */
core.String type;
/** Additional details for a view. */
TableListTablesView view;
TableListTables();
TableListTables.fromJson(core.Map _json) {
if (_json.containsKey("friendlyName")) {
friendlyName = _json["friendlyName"];
}
if (_json.containsKey("id")) {
id = _json["id"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("labels")) {
labels = _json["labels"];
}
if (_json.containsKey("tableReference")) {
tableReference = new TableReference.fromJson(_json["tableReference"]);
}
if (_json.containsKey("timePartitioning")) {
timePartitioning = new TimePartitioning.fromJson(_json["timePartitioning"]);
}
if (_json.containsKey("type")) {
type = _json["type"];
}
if (_json.containsKey("view")) {
view = new TableListTablesView.fromJson(_json["view"]);
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (friendlyName != null) {
_json["friendlyName"] = friendlyName;
}
if (id != null) {
_json["id"] = id;
}
if (kind != null) {
_json["kind"] = kind;
}
if (labels != null) {
_json["labels"] = labels;
}
if (tableReference != null) {
_json["tableReference"] = (tableReference).toJson();
}
if (timePartitioning != null) {
_json["timePartitioning"] = (timePartitioning).toJson();
}
if (type != null) {
_json["type"] = type;
}
if (view != null) {
_json["view"] = (view).toJson();
}
return _json;
}
}
class TableList {
/** A hash of this page of results. */
core.String etag;
/** The type of list. */
core.String kind;
/** A token to request the next page of results. */
core.String nextPageToken;
/** Tables in the requested dataset. */
core.List<TableListTables> tables;
/** The total number of tables in the dataset. */
core.int totalItems;
TableList();
TableList.fromJson(core.Map _json) {
if (_json.containsKey("etag")) {
etag = _json["etag"];
}
if (_json.containsKey("kind")) {
kind = _json["kind"];
}
if (_json.containsKey("nextPageToken")) {
nextPageToken = _json["nextPageToken"];
}
if (_json.containsKey("tables")) {
tables = _json["tables"].map((value) => new TableListTables.fromJson(value)).toList();
}
if (_json.containsKey("totalItems")) {
totalItems = _json["totalItems"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (etag != null) {
_json["etag"] = etag;
}
if (kind != null) {
_json["kind"] = kind;
}
if (nextPageToken != null) {
_json["nextPageToken"] = nextPageToken;
}
if (tables != null) {
_json["tables"] = tables.map((value) => (value).toJson()).toList();
}
if (totalItems != null) {
_json["totalItems"] = totalItems;
}
return _json;
}
}
class TableReference {
/** [Required] The ID of the dataset containing this table. */
core.String datasetId;
/** [Required] The ID of the project containing this table. */
core.String projectId;
/**
* [Required] The ID of the table. The ID must contain only letters (a-z,
* A-Z), numbers (0-9), or underscores (_). The maximum length is 1,024
* characters.
*/
core.String tableId;
TableReference();
TableReference.fromJson(core.Map _json) {
if (_json.containsKey("datasetId")) {
datasetId = _json["datasetId"];
}
if (_json.containsKey("projectId")) {
projectId = _json["projectId"];
}
if (_json.containsKey("tableId")) {
tableId = _json["tableId"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (datasetId != null) {
_json["datasetId"] = datasetId;
}
if (projectId != null) {
_json["projectId"] = projectId;
}
if (tableId != null) {
_json["tableId"] = tableId;
}
return _json;
}
}
class TableRow {
/**
* Represents a single row in the result set, consisting of one or more
* fields.
*/
core.List<TableCell> f;
TableRow();
TableRow.fromJson(core.Map _json) {
if (_json.containsKey("f")) {
f = _json["f"].map((value) => new TableCell.fromJson(value)).toList();
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (f != null) {
_json["f"] = f.map((value) => (value).toJson()).toList();
}
return _json;
}
}
class TableSchema {
/** Describes the fields in a table. */
core.List<TableFieldSchema> fields;
TableSchema();
TableSchema.fromJson(core.Map _json) {
if (_json.containsKey("fields")) {
fields = _json["fields"].map((value) => new TableFieldSchema.fromJson(value)).toList();
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (fields != null) {
_json["fields"] = fields.map((value) => (value).toJson()).toList();
}
return _json;
}
}
class TimePartitioning {
/**
* [Optional] Number of milliseconds for which to keep the storage for a
* partition.
*/
core.String expirationMs;
/**
* [Required] The only type supported is DAY, which will generate one
* partition per day based on data loading time.
*/
core.String type;
TimePartitioning();
TimePartitioning.fromJson(core.Map _json) {
if (_json.containsKey("expirationMs")) {
expirationMs = _json["expirationMs"];
}
if (_json.containsKey("type")) {
type = _json["type"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (expirationMs != null) {
_json["expirationMs"] = expirationMs;
}
if (type != null) {
_json["type"] = type;
}
return _json;
}
}
class UserDefinedFunctionResource {
/**
* [Pick one] An inline resource that contains code for a user-defined
* function (UDF). Providing a inline code resource is equivalent to providing
* a URI for a file containing the same code.
*/
core.String inlineCode;
/**
* [Pick one] A code resource to load from a Google Cloud Storage URI
* (gs://bucket/path).
*/
core.String resourceUri;
UserDefinedFunctionResource();
UserDefinedFunctionResource.fromJson(core.Map _json) {
if (_json.containsKey("inlineCode")) {
inlineCode = _json["inlineCode"];
}
if (_json.containsKey("resourceUri")) {
resourceUri = _json["resourceUri"];
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (inlineCode != null) {
_json["inlineCode"] = inlineCode;
}
if (resourceUri != null) {
_json["resourceUri"] = resourceUri;
}
return _json;
}
}
class ViewDefinition {
/** [Required] A query that BigQuery executes when the view is referenced. */
core.String query;
/**
* Specifies whether to use BigQuery's legacy SQL for this view. The default
* value is true. If set to false, the view will use BigQuery's standard SQL:
* https://cloud.google.com/bigquery/sql-reference/ Queries and views that
* reference this view must use the same flag value.
*/
core.bool useLegacySql;
/** Describes user-defined function resources used in the query. */
core.List<UserDefinedFunctionResource> userDefinedFunctionResources;
ViewDefinition();
ViewDefinition.fromJson(core.Map _json) {
if (_json.containsKey("query")) {
query = _json["query"];
}
if (_json.containsKey("useLegacySql")) {
useLegacySql = _json["useLegacySql"];
}
if (_json.containsKey("userDefinedFunctionResources")) {
userDefinedFunctionResources = _json["userDefinedFunctionResources"].map((value) => new UserDefinedFunctionResource.fromJson(value)).toList();
}
}
core.Map<core.String, core.Object> toJson() {
final core.Map<core.String, core.Object> _json = new core.Map<core.String, core.Object>();
if (query != null) {
_json["query"] = query;
}
if (useLegacySql != null) {
_json["useLegacySql"] = useLegacySql;
}
if (userDefinedFunctionResources != null) {
_json["userDefinedFunctionResources"] = userDefinedFunctionResources.map((value) => (value).toJson()).toList();
}
return _json;
}
}