googleapis
Version:
Google APIs Client Library for Node.js
1,522 lines (1,521 loc) • 117 kB
TypeScript
/// <reference types="node" />
import { OAuth2Client, JWT, Compute, UserRefreshClient, BaseExternalAccountClient, GaxiosPromise, GoogleConfigurable, MethodOptions, StreamMethodOptions, GlobalOptions, GoogleAuth, BodyResponseCallback, APIRequestContext } from 'googleapis-common';
import { Readable } from 'stream';
export declare namespace datastream_v1 {
export interface Options extends GlobalOptions {
version: 'v1';
}
interface StandardParameters {
/**
* Auth client or API Key for the request
*/
auth?: string | OAuth2Client | JWT | Compute | UserRefreshClient | BaseExternalAccountClient | GoogleAuth;
/**
* V1 error format.
*/
'$.xgafv'?: string;
/**
* OAuth access token.
*/
access_token?: string;
/**
* Data format for response.
*/
alt?: string;
/**
* JSONP
*/
callback?: string;
/**
* Selector specifying which fields to include in a partial response.
*/
fields?: string;
/**
* API key. Your API key identifies your project and provides you with API access, quota, and reports. Required unless you provide an OAuth 2.0 token.
*/
key?: string;
/**
* OAuth 2.0 token for the current user.
*/
oauth_token?: string;
/**
* Returns response with indentations and line breaks.
*/
prettyPrint?: boolean;
/**
* Available to use for quota purposes for server-side applications. Can be any arbitrary string assigned to a user, but should not exceed 40 characters.
*/
quotaUser?: string;
/**
* Legacy upload protocol for media (e.g. "media", "multipart").
*/
uploadType?: string;
/**
* Upload protocol for media (e.g. "raw", "multipart").
*/
upload_protocol?: string;
}
/**
* Datastream API
*
*
*
* @example
* ```js
* const {google} = require('googleapis');
* const datastream = google.datastream('v1');
* ```
*/
export class Datastream {
context: APIRequestContext;
projects: Resource$Projects;
constructor(options: GlobalOptions, google?: GoogleConfigurable);
}
/**
* AVRO file format configuration.
*/
export interface Schema$AvroFileFormat {
}
/**
* Backfill strategy to automatically backfill the Stream's objects. Specific objects can be excluded.
*/
export interface Schema$BackfillAllStrategy {
/**
* MySQL data source objects to avoid backfilling.
*/
mysqlExcludedObjects?: Schema$MysqlRdbms;
/**
* Oracle data source objects to avoid backfilling.
*/
oracleExcludedObjects?: Schema$OracleRdbms;
/**
* PostgreSQL data source objects to avoid backfilling.
*/
postgresqlExcludedObjects?: Schema$PostgresqlRdbms;
}
/**
* Represents a backfill job on a specific stream object.
*/
export interface Schema$BackfillJob {
/**
* Output only. Errors which caused the backfill job to fail.
*/
errors?: Schema$Error[];
/**
* Output only. Backfill job's end time.
*/
lastEndTime?: string | null;
/**
* Output only. Backfill job's start time.
*/
lastStartTime?: string | null;
/**
* Output only. Backfill job state.
*/
state?: string | null;
/**
* Backfill job's triggering reason.
*/
trigger?: string | null;
}
/**
* Backfill strategy to disable automatic backfill for the Stream's objects.
*/
export interface Schema$BackfillNoneStrategy {
}
/**
* BigQuery destination configuration
*/
export interface Schema$BigQueryDestinationConfig {
/**
* The guaranteed data freshness (in seconds) when querying tables created by the stream. Editing this field will only affect new tables created in the future, but existing tables will not be impacted. Lower values mean that queries will return fresher data, but may result in higher cost.
*/
dataFreshness?: string | null;
/**
* Single destination dataset.
*/
singleTargetDataset?: Schema$SingleTargetDataset;
/**
* Source hierarchy datasets.
*/
sourceHierarchyDatasets?: Schema$SourceHierarchyDatasets;
}
/**
* BigQuery warehouse profile.
*/
export interface Schema$BigQueryProfile {
}
/**
* The request message for Operations.CancelOperation.
*/
export interface Schema$CancelOperationRequest {
}
/**
* The strategy that the stream uses for CDC replication.
*/
export interface Schema$CdcStrategy {
/**
* Optional. Start replicating from the most recent position in the source.
*/
mostRecentStartPosition?: Schema$MostRecentStartPosition;
/**
* Optional. Resume replication from the next available position in the source.
*/
nextAvailableStartPosition?: Schema$NextAvailableStartPosition;
/**
* Optional. Start replicating from a specific position in the source.
*/
specificStartPosition?: Schema$SpecificStartPosition;
}
/**
* A set of reusable connection configurations to be used as a source or destination for a stream.
*/
export interface Schema$ConnectionProfile {
/**
* BigQuery Connection Profile configuration.
*/
bigqueryProfile?: Schema$BigQueryProfile;
/**
* Output only. The create time of the resource.
*/
createTime?: string | null;
/**
* Required. Display name.
*/
displayName?: string | null;
/**
* Forward SSH tunnel connectivity.
*/
forwardSshConnectivity?: Schema$ForwardSshTunnelConnectivity;
/**
* Cloud Storage ConnectionProfile configuration.
*/
gcsProfile?: Schema$GcsProfile;
/**
* Labels.
*/
labels?: {
[key: string]: string;
} | null;
/**
* MySQL ConnectionProfile configuration.
*/
mysqlProfile?: Schema$MysqlProfile;
/**
* Output only. The resource's name.
*/
name?: string | null;
/**
* Oracle ConnectionProfile configuration.
*/
oracleProfile?: Schema$OracleProfile;
/**
* PostgreSQL Connection Profile configuration.
*/
postgresqlProfile?: Schema$PostgresqlProfile;
/**
* Private connectivity.
*/
privateConnectivity?: Schema$PrivateConnectivity;
/**
* Static Service IP connectivity.
*/
staticServiceIpConnectivity?: Schema$StaticServiceIpConnectivity;
/**
* Output only. The update time of the resource.
*/
updateTime?: string | null;
}
/**
* Dataset template used for dynamic dataset creation.
*/
export interface Schema$DatasetTemplate {
/**
* If supplied, every created dataset will have its name prefixed by the provided value. The prefix and name will be separated by an underscore. i.e. _.
*/
datasetIdPrefix?: string | null;
/**
* Describes the Cloud KMS encryption key that will be used to protect destination BigQuery table. The BigQuery Service Account associated with your project requires access to this encryption key. i.e. projects/{project\}/locations/{location\}/keyRings/{key_ring\}/cryptoKeys/{cryptoKey\}. See https://cloud.google.com/bigquery/docs/customer-managed-encryption for more information.
*/
kmsKeyName?: string | null;
/**
* Required. The geographic location where the dataset should reside. See https://cloud.google.com/bigquery/docs/locations for supported locations.
*/
location?: string | null;
}
/**
* The configuration of the stream destination.
*/
export interface Schema$DestinationConfig {
/**
* BigQuery destination configuration.
*/
bigqueryDestinationConfig?: Schema$BigQueryDestinationConfig;
/**
* Required. Destination connection profile resource. Format: `projects/{project\}/locations/{location\}/connectionProfiles/{name\}`
*/
destinationConnectionProfile?: string | null;
/**
* A configuration for how data should be loaded to Cloud Storage.
*/
gcsDestinationConfig?: Schema$GcsDestinationConfig;
}
/**
* Request message for 'discover' ConnectionProfile request.
*/
export interface Schema$DiscoverConnectionProfileRequest {
/**
* An ad-hoc connection profile configuration.
*/
connectionProfile?: Schema$ConnectionProfile;
/**
* A reference to an existing connection profile.
*/
connectionProfileName?: string | null;
/**
* Whether to retrieve the full hierarchy of data objects (TRUE) or only the current level (FALSE).
*/
fullHierarchy?: boolean | null;
/**
* The number of hierarchy levels below the current level to be retrieved.
*/
hierarchyDepth?: number | null;
/**
* MySQL RDBMS to enrich with child data objects and metadata.
*/
mysqlRdbms?: Schema$MysqlRdbms;
/**
* Oracle RDBMS to enrich with child data objects and metadata.
*/
oracleRdbms?: Schema$OracleRdbms;
/**
* PostgreSQL RDBMS to enrich with child data objects and metadata.
*/
postgresqlRdbms?: Schema$PostgresqlRdbms;
}
/**
* Response from a discover request.
*/
export interface Schema$DiscoverConnectionProfileResponse {
/**
* Enriched MySQL RDBMS object.
*/
mysqlRdbms?: Schema$MysqlRdbms;
/**
* Enriched Oracle RDBMS object.
*/
oracleRdbms?: Schema$OracleRdbms;
/**
* Enriched PostgreSQL RDBMS object.
*/
postgresqlRdbms?: Schema$PostgresqlRdbms;
}
/**
* Configuration to drop large object values.
*/
export interface Schema$DropLargeObjects {
}
/**
* A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); \}
*/
export interface Schema$Empty {
}
/**
* Represent a user-facing Error.
*/
export interface Schema$Error {
/**
* Additional information about the error.
*/
details?: {
[key: string]: string;
} | null;
/**
* The time when the error occurred.
*/
errorTime?: string | null;
/**
* A unique identifier for this specific error, allowing it to be traced throughout the system in logs and API responses.
*/
errorUuid?: string | null;
/**
* A message containing more information about the error that occurred.
*/
message?: string | null;
/**
* A title that explains the reason for the error.
*/
reason?: string | null;
}
/**
* Response message for a 'FetchStaticIps' response.
*/
export interface Schema$FetchStaticIpsResponse {
/**
* A token that can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.
*/
nextPageToken?: string | null;
/**
* list of static ips by account
*/
staticIps?: string[] | null;
}
/**
* Forward SSH Tunnel connectivity.
*/
export interface Schema$ForwardSshTunnelConnectivity {
/**
* Required. Hostname for the SSH tunnel.
*/
hostname?: string | null;
/**
* Input only. SSH password.
*/
password?: string | null;
/**
* Port for the SSH tunnel, default value is 22.
*/
port?: number | null;
/**
* Input only. SSH private key.
*/
privateKey?: string | null;
/**
* Required. Username for the SSH tunnel.
*/
username?: string | null;
}
/**
* Google Cloud Storage destination configuration
*/
export interface Schema$GcsDestinationConfig {
/**
* AVRO file format configuration.
*/
avroFileFormat?: Schema$AvroFileFormat;
/**
* The maximum duration for which new events are added before a file is closed and a new file is created. Values within the range of 15-60 seconds are allowed.
*/
fileRotationInterval?: string | null;
/**
* The maximum file size to be saved in the bucket.
*/
fileRotationMb?: number | null;
/**
* JSON file format configuration.
*/
jsonFileFormat?: Schema$JsonFileFormat;
/**
* Path inside the Cloud Storage bucket to write data to.
*/
path?: string | null;
}
/**
* Cloud Storage bucket profile.
*/
export interface Schema$GcsProfile {
/**
* Required. The Cloud Storage bucket name.
*/
bucket?: string | null;
/**
* The root path inside the Cloud Storage bucket.
*/
rootPath?: string | null;
}
/**
* JSON file format configuration.
*/
export interface Schema$JsonFileFormat {
/**
* Compression of the loaded JSON file.
*/
compression?: string | null;
/**
* The schema file format along JSON data files.
*/
schemaFileFormat?: string | null;
}
/**
* Response message for listing connection profiles.
*/
export interface Schema$ListConnectionProfilesResponse {
/**
* List of connection profiles.
*/
connectionProfiles?: Schema$ConnectionProfile[];
/**
* A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.
*/
nextPageToken?: string | null;
/**
* Locations that could not be reached.
*/
unreachable?: string[] | null;
}
/**
* The response message for Locations.ListLocations.
*/
export interface Schema$ListLocationsResponse {
/**
* A list of locations that matches the specified filter in the request.
*/
locations?: Schema$Location[];
/**
* The standard List next-page token.
*/
nextPageToken?: string | null;
}
/**
* The response message for Operations.ListOperations.
*/
export interface Schema$ListOperationsResponse {
/**
* The standard List next-page token.
*/
nextPageToken?: string | null;
/**
* A list of operations that matches the specified filter in the request.
*/
operations?: Schema$Operation[];
}
/**
* Response containing a list of private connection configurations.
*/
export interface Schema$ListPrivateConnectionsResponse {
/**
* A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.
*/
nextPageToken?: string | null;
/**
* List of private connectivity configurations.
*/
privateConnections?: Schema$PrivateConnection[];
/**
* Locations that could not be reached.
*/
unreachable?: string[] | null;
}
/**
* Route list response.
*/
export interface Schema$ListRoutesResponse {
/**
* A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.
*/
nextPageToken?: string | null;
/**
* List of Routes.
*/
routes?: Schema$Route[];
/**
* Locations that could not be reached.
*/
unreachable?: string[] | null;
}
/**
* Response containing the objects for a stream.
*/
export interface Schema$ListStreamObjectsResponse {
/**
* A token, which can be sent as `page_token` to retrieve the next page.
*/
nextPageToken?: string | null;
/**
* List of stream objects.
*/
streamObjects?: Schema$StreamObject[];
}
/**
* Response message for listing streams.
*/
export interface Schema$ListStreamsResponse {
/**
* A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.
*/
nextPageToken?: string | null;
/**
* List of streams
*/
streams?: Schema$Stream[];
/**
* Locations that could not be reached.
*/
unreachable?: string[] | null;
}
/**
* A resource that represents a Google Cloud location.
*/
export interface Schema$Location {
/**
* The friendly name for this location, typically a nearby city name. For example, "Tokyo".
*/
displayName?: string | null;
/**
* Cross-service attributes for the location. For example {"cloud.googleapis.com/region": "us-east1"\}
*/
labels?: {
[key: string]: string;
} | null;
/**
* The canonical id for this location. For example: `"us-east1"`.
*/
locationId?: string | null;
/**
* Service-specific metadata. For example the available capacity at the given location.
*/
metadata?: {
[key: string]: any;
} | null;
/**
* Resource name for the location, which may vary between implementations. For example: `"projects/example-project/locations/us-east1"`
*/
name?: string | null;
}
/**
* Request for looking up a specific stream object by its source object identifier.
*/
export interface Schema$LookupStreamObjectRequest {
/**
* Required. The source object identifier which maps to the stream object.
*/
sourceObjectIdentifier?: Schema$SourceObjectIdentifier;
}
/**
* CDC strategy to start replicating from the most recent position in the source.
*/
export interface Schema$MostRecentStartPosition {
}
/**
* MySQL Column.
*/
export interface Schema$MysqlColumn {
/**
* Column collation.
*/
collation?: string | null;
/**
* Column name.
*/
column?: string | null;
/**
* The MySQL data type. Full data types list can be found here: https://dev.mysql.com/doc/refman/8.0/en/data-types.html
*/
dataType?: string | null;
/**
* Column length.
*/
length?: number | null;
/**
* Whether or not the column can accept a null value.
*/
nullable?: boolean | null;
/**
* The ordinal position of the column in the table.
*/
ordinalPosition?: number | null;
/**
* Column precision.
*/
precision?: number | null;
/**
* Whether or not the column represents a primary key.
*/
primaryKey?: boolean | null;
/**
* Column scale.
*/
scale?: number | null;
}
/**
* MySQL database.
*/
export interface Schema$MysqlDatabase {
/**
* Database name.
*/
database?: string | null;
/**
* Tables in the database.
*/
mysqlTables?: Schema$MysqlTable[];
}
/**
* MySQL log position
*/
export interface Schema$MysqlLogPosition {
/**
* The binary log file name.
*/
logFile?: string | null;
/**
* The position within the binary log file. Default is head of file.
*/
logPosition?: number | null;
}
/**
* Mysql data source object identifier.
*/
export interface Schema$MysqlObjectIdentifier {
/**
* Required. The database name.
*/
database?: string | null;
/**
* Required. The table name.
*/
table?: string | null;
}
/**
* MySQL database profile.
*/
export interface Schema$MysqlProfile {
/**
* Required. Hostname for the MySQL connection.
*/
hostname?: string | null;
/**
* Required. Input only. Password for the MySQL connection.
*/
password?: string | null;
/**
* Port for the MySQL connection, default value is 3306.
*/
port?: number | null;
/**
* SSL configuration for the MySQL connection.
*/
sslConfig?: Schema$MysqlSslConfig;
/**
* Required. Username for the MySQL connection.
*/
username?: string | null;
}
/**
* MySQL database structure
*/
export interface Schema$MysqlRdbms {
/**
* Mysql databases on the server
*/
mysqlDatabases?: Schema$MysqlDatabase[];
}
/**
* MySQL source configuration
*/
export interface Schema$MysqlSourceConfig {
/**
* MySQL objects to exclude from the stream.
*/
excludeObjects?: Schema$MysqlRdbms;
/**
* MySQL objects to retrieve from the source.
*/
includeObjects?: Schema$MysqlRdbms;
/**
* Maximum number of concurrent backfill tasks. The number should be non negative. If not set (or set to 0), the system's default value will be used.
*/
maxConcurrentBackfillTasks?: number | null;
/**
* Maximum number of concurrent CDC tasks. The number should be non negative. If not set (or set to 0), the system's default value will be used.
*/
maxConcurrentCdcTasks?: number | null;
}
/**
* MySQL SSL configuration information.
*/
export interface Schema$MysqlSslConfig {
/**
* Input only. PEM-encoded certificate of the CA that signed the source database server's certificate.
*/
caCertificate?: string | null;
/**
* Output only. Indicates whether the ca_certificate field is set.
*/
caCertificateSet?: boolean | null;
/**
* Input only. PEM-encoded certificate that will be used by the replica to authenticate against the source database server. If this field is used then the 'client_key' and the 'ca_certificate' fields are mandatory.
*/
clientCertificate?: string | null;
/**
* Output only. Indicates whether the client_certificate field is set.
*/
clientCertificateSet?: boolean | null;
/**
* Input only. PEM-encoded private key associated with the Client Certificate. If this field is used then the 'client_certificate' and the 'ca_certificate' fields are mandatory.
*/
clientKey?: string | null;
/**
* Output only. Indicates whether the client_key field is set.
*/
clientKeySet?: boolean | null;
}
/**
* MySQL table.
*/
export interface Schema$MysqlTable {
/**
* MySQL columns in the database. When unspecified as part of include/exclude objects, includes/excludes everything.
*/
mysqlColumns?: Schema$MysqlColumn[];
/**
* Table name.
*/
table?: string | null;
}
/**
* CDC strategy to resume replication from the next available position in the source.
*/
export interface Schema$NextAvailableStartPosition {
}
/**
* This resource represents a long-running operation that is the result of a network API call.
*/
export interface Schema$Operation {
/**
* If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.
*/
done?: boolean | null;
/**
* The error result of the operation in case of failure or cancellation.
*/
error?: Schema$Status;
/**
* Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.
*/
metadata?: {
[key: string]: any;
} | null;
/**
* The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id\}`.
*/
name?: string | null;
/**
* The normal response of the operation in case of success. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.
*/
response?: {
[key: string]: any;
} | null;
}
/**
* Represents the metadata of the long-running operation.
*/
export interface Schema$OperationMetadata {
/**
* Output only. API version used to start the operation.
*/
apiVersion?: string | null;
/**
* Output only. The time the operation was created.
*/
createTime?: string | null;
/**
* Output only. The time the operation finished running.
*/
endTime?: string | null;
/**
* Output only. Identifies whether the user has requested cancellation of the operation. Operations that have successfully been cancelled have Operation.error value with a google.rpc.Status.code of 1, corresponding to `Code.CANCELLED`.
*/
requestedCancellation?: boolean | null;
/**
* Output only. Human-readable status of the operation, if any.
*/
statusMessage?: string | null;
/**
* Output only. Server-defined resource path for the target of the operation.
*/
target?: string | null;
/**
* Output only. Results of executed validations if there are any.
*/
validationResult?: Schema$ValidationResult;
/**
* Output only. Name of the verb executed by the operation.
*/
verb?: string | null;
}
/**
* Oracle Column.
*/
export interface Schema$OracleColumn {
/**
* Column name.
*/
column?: string | null;
/**
* The Oracle data type.
*/
dataType?: string | null;
/**
* Column encoding.
*/
encoding?: string | null;
/**
* Column length.
*/
length?: number | null;
/**
* Whether or not the column can accept a null value.
*/
nullable?: boolean | null;
/**
* The ordinal position of the column in the table.
*/
ordinalPosition?: number | null;
/**
* Column precision.
*/
precision?: number | null;
/**
* Whether or not the column represents a primary key.
*/
primaryKey?: boolean | null;
/**
* Column scale.
*/
scale?: number | null;
}
/**
* Oracle data source object identifier.
*/
export interface Schema$OracleObjectIdentifier {
/**
* Required. The schema name.
*/
schema?: string | null;
/**
* Required. The table name.
*/
table?: string | null;
}
/**
* Oracle database profile.
*/
export interface Schema$OracleProfile {
/**
* Connection string attributes
*/
connectionAttributes?: {
[key: string]: string;
} | null;
/**
* Required. Database for the Oracle connection.
*/
databaseService?: string | null;
/**
* Required. Hostname for the Oracle connection.
*/
hostname?: string | null;
/**
* Required. Password for the Oracle connection.
*/
password?: string | null;
/**
* Port for the Oracle connection, default value is 1521.
*/
port?: number | null;
/**
* Required. Username for the Oracle connection.
*/
username?: string | null;
}
/**
* Oracle database structure.
*/
export interface Schema$OracleRdbms {
/**
* Oracle schemas/databases in the database server.
*/
oracleSchemas?: Schema$OracleSchema[];
}
/**
* Oracle schema.
*/
export interface Schema$OracleSchema {
/**
* Tables in the schema.
*/
oracleTables?: Schema$OracleTable[];
/**
* Schema name.
*/
schema?: string | null;
}
/**
* Oracle data source configuration
*/
export interface Schema$OracleSourceConfig {
/**
* Drop large object values.
*/
dropLargeObjects?: Schema$DropLargeObjects;
/**
* Oracle objects to exclude from the stream.
*/
excludeObjects?: Schema$OracleRdbms;
/**
* Oracle objects to include in the stream.
*/
includeObjects?: Schema$OracleRdbms;
/**
* Maximum number of concurrent backfill tasks. The number should be non-negative. If not set (or set to 0), the system's default value is used.
*/
maxConcurrentBackfillTasks?: number | null;
/**
* Maximum number of concurrent CDC tasks. The number should be non-negative. If not set (or set to 0), the system's default value is used.
*/
maxConcurrentCdcTasks?: number | null;
/**
* Stream large object values. NOTE: This feature is currently experimental.
*/
streamLargeObjects?: Schema$StreamLargeObjects;
}
/**
* Oracle table.
*/
export interface Schema$OracleTable {
/**
* Oracle columns in the schema. When unspecified as part of include/exclude objects, includes/excludes everything.
*/
oracleColumns?: Schema$OracleColumn[];
/**
* Table name.
*/
table?: string | null;
}
/**
* PostgreSQL Column.
*/
export interface Schema$PostgresqlColumn {
/**
* Column name.
*/
column?: string | null;
/**
* The PostgreSQL data type.
*/
dataType?: string | null;
/**
* Column length.
*/
length?: number | null;
/**
* Whether or not the column can accept a null value.
*/
nullable?: boolean | null;
/**
* The ordinal position of the column in the table.
*/
ordinalPosition?: number | null;
/**
* Column precision.
*/
precision?: number | null;
/**
* Whether or not the column represents a primary key.
*/
primaryKey?: boolean | null;
/**
* Column scale.
*/
scale?: number | null;
}
/**
* PostgreSQL data source object identifier.
*/
export interface Schema$PostgresqlObjectIdentifier {
/**
* Required. The schema name.
*/
schema?: string | null;
/**
* Required. The table name.
*/
table?: string | null;
}
/**
* PostgreSQL database profile.
*/
export interface Schema$PostgresqlProfile {
/**
* Required. Database for the PostgreSQL connection.
*/
database?: string | null;
/**
* Required. Hostname for the PostgreSQL connection.
*/
hostname?: string | null;
/**
* Required. Password for the PostgreSQL connection.
*/
password?: string | null;
/**
* Port for the PostgreSQL connection, default value is 5432.
*/
port?: number | null;
/**
* Required. Username for the PostgreSQL connection.
*/
username?: string | null;
}
/**
* PostgreSQL database structure.
*/
export interface Schema$PostgresqlRdbms {
/**
* PostgreSQL schemas in the database server.
*/
postgresqlSchemas?: Schema$PostgresqlSchema[];
}
/**
* PostgreSQL schema.
*/
export interface Schema$PostgresqlSchema {
/**
* Tables in the schema.
*/
postgresqlTables?: Schema$PostgresqlTable[];
/**
* Schema name.
*/
schema?: string | null;
}
/**
* PostgreSQL data source configuration
*/
export interface Schema$PostgresqlSourceConfig {
/**
* PostgreSQL objects to exclude from the stream.
*/
excludeObjects?: Schema$PostgresqlRdbms;
/**
* PostgreSQL objects to include in the stream.
*/
includeObjects?: Schema$PostgresqlRdbms;
/**
* Maximum number of concurrent backfill tasks. The number should be non negative. If not set (or set to 0), the system's default value will be used.
*/
maxConcurrentBackfillTasks?: number | null;
/**
* Required. The name of the publication that includes the set of all tables that are defined in the stream's include_objects.
*/
publication?: string | null;
/**
* Required. Immutable. The name of the logical replication slot that's configured with the pgoutput plugin.
*/
replicationSlot?: string | null;
}
/**
* PostgreSQL table.
*/
export interface Schema$PostgresqlTable {
/**
* PostgreSQL columns in the schema. When unspecified as part of include/exclude objects, includes/excludes everything.
*/
postgresqlColumns?: Schema$PostgresqlColumn[];
/**
* Table name.
*/
table?: string | null;
}
/**
* The PrivateConnection resource is used to establish private connectivity between Datastream and a customer's network.
*/
export interface Schema$PrivateConnection {
/**
* Output only. The create time of the resource.
*/
createTime?: string | null;
/**
* Required. Display name.
*/
displayName?: string | null;
/**
* Output only. In case of error, the details of the error in a user-friendly format.
*/
error?: Schema$Error;
/**
* Labels.
*/
labels?: {
[key: string]: string;
} | null;
/**
* Output only. The resource's name.
*/
name?: string | null;
/**
* Output only. The state of the Private Connection.
*/
state?: string | null;
/**
* Output only. The update time of the resource.
*/
updateTime?: string | null;
/**
* VPC Peering Config.
*/
vpcPeeringConfig?: Schema$VpcPeeringConfig;
}
/**
* Private Connectivity
*/
export interface Schema$PrivateConnectivity {
/**
* Required. A reference to a private connection resource. Format: `projects/{project\}/locations/{location\}/privateConnections/{name\}`
*/
privateConnection?: string | null;
}
/**
* The route resource is the child of the private connection resource, used for defining a route for a private connection.
*/
export interface Schema$Route {
/**
* Output only. The create time of the resource.
*/
createTime?: string | null;
/**
* Required. Destination address for connection
*/
destinationAddress?: string | null;
/**
* Destination port for connection
*/
destinationPort?: number | null;
/**
* Required. Display name.
*/
displayName?: string | null;
/**
* Labels.
*/
labels?: {
[key: string]: string;
} | null;
/**
* Output only. The resource's name.
*/
name?: string | null;
/**
* Output only. The update time of the resource.
*/
updateTime?: string | null;
}
/**
* Request message for running a stream.
*/
export interface Schema$RunStreamRequest {
/**
* Optional. The CDC strategy of the stream. If not set, the system's default value will be used.
*/
cdcStrategy?: Schema$CdcStrategy;
}
/**
* A single target dataset to which all data will be streamed.
*/
export interface Schema$SingleTargetDataset {
/**
* The dataset ID of the target dataset. DatasetIds allowed characters: https://cloud.google.com/bigquery/docs/reference/rest/v2/datasets#datasetreference.
*/
datasetId?: string | null;
}
/**
* The configuration of the stream source.
*/
export interface Schema$SourceConfig {
/**
* MySQL data source configuration.
*/
mysqlSourceConfig?: Schema$MysqlSourceConfig;
/**
* Oracle data source configuration.
*/
oracleSourceConfig?: Schema$OracleSourceConfig;
/**
* PostgreSQL data source configuration.
*/
postgresqlSourceConfig?: Schema$PostgresqlSourceConfig;
/**
* Required. Source connection profile resoource. Format: `projects/{project\}/locations/{location\}/connectionProfiles/{name\}`
*/
sourceConnectionProfile?: string | null;
}
/**
* Destination datasets are created so that hierarchy of the destination data objects matches the source hierarchy.
*/
export interface Schema$SourceHierarchyDatasets {
/**
* The dataset template to use for dynamic dataset creation.
*/
datasetTemplate?: Schema$DatasetTemplate;
}
/**
* Represents an identifier of an object in the data source.
*/
export interface Schema$SourceObjectIdentifier {
/**
* Mysql data source object identifier.
*/
mysqlIdentifier?: Schema$MysqlObjectIdentifier;
/**
* Oracle data source object identifier.
*/
oracleIdentifier?: Schema$OracleObjectIdentifier;
/**
* PostgreSQL data source object identifier.
*/
postgresqlIdentifier?: Schema$PostgresqlObjectIdentifier;
}
/**
* CDC strategy to start replicating from a specific position in the source.
*/
export interface Schema$SpecificStartPosition {
/**
* MySQL specific log position to start replicating from.
*/
mysqlLogPosition?: Schema$MysqlLogPosition;
}
/**
* Request for manually initiating a backfill job for a specific stream object.
*/
export interface Schema$StartBackfillJobRequest {
}
/**
* Response for manually initiating a backfill job for a specific stream object.
*/
export interface Schema$StartBackfillJobResponse {
/**
* The stream object resource a backfill job was started for.
*/
object?: Schema$StreamObject;
}
/**
* Static IP address connectivity. Used when the source database is configured to allow incoming connections from the Datastream public IP addresses for the region specified in the connection profile.
*/
export interface Schema$StaticServiceIpConnectivity {
}
/**
* The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).
*/
export interface Schema$Status {
/**
* The status code, which should be an enum value of google.rpc.Code.
*/
code?: number | null;
/**
* A list of messages that carry the error details. There is a common set of message types for APIs to use.
*/
details?: Array<{
[key: string]: any;
}> | null;
/**
* A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client.
*/
message?: string | null;
}
/**
* Request for manually stopping a running backfill job for a specific stream object.
*/
export interface Schema$StopBackfillJobRequest {
}
/**
* Response for manually stop a backfill job for a specific stream object.
*/
export interface Schema$StopBackfillJobResponse {
/**
* The stream object resource the backfill job was stopped for.
*/
object?: Schema$StreamObject;
}
/**
* A resource representing streaming data from a source to a destination.
*/
export interface Schema$Stream {
/**
* Automatically backfill objects included in the stream source configuration. Specific objects can be excluded.
*/
backfillAll?: Schema$BackfillAllStrategy;
/**
* Do not automatically backfill any objects.
*/
backfillNone?: Schema$BackfillNoneStrategy;
/**
* Output only. The creation time of the stream.
*/
createTime?: string | null;
/**
* Immutable. A reference to a KMS encryption key. If provided, it will be used to encrypt the data. If left blank, data will be encrypted using an internal Stream-specific encryption key provisioned through KMS.
*/
customerManagedEncryptionKey?: string | null;
/**
* Required. Destination connection profile configuration.
*/
destinationConfig?: Schema$DestinationConfig;
/**
* Required. Display name.
*/
displayName?: string | null;
/**
* Output only. Errors on the Stream.
*/
errors?: Schema$Error[];
/**
* Labels.
*/
labels?: {
[key: string]: string;
} | null;
/**
* Output only. The stream's name.
*/
name?: string | null;
/**
* Required. Source connection profile configuration.
*/
sourceConfig?: Schema$SourceConfig;
/**
* The state of the stream.
*/
state?: string | null;
/**
* Output only. The last update time of the stream.
*/
updateTime?: string | null;
}
/**
* Configuration to stream large object values.
*/
export interface Schema$StreamLargeObjects {
}
/**
* A specific stream object (e.g a specific DB table).
*/
export interface Schema$StreamObject {
/**
* The latest backfill job that was initiated for the stream object.
*/
backfillJob?: Schema$BackfillJob;
/**
* Output only. The creation time of the object.
*/
createTime?: string | null;
/**
* Required. Display name.
*/
displayName?: string | null;
/**
* Output only. Active errors on the object.
*/
errors?: Schema$Error[];
/**
* Output only. The object resource's name.
*/
name?: string | null;
/**
* The object identifier in the data source.
*/
sourceObject?: Schema$SourceObjectIdentifier;
/**
* Output only. The last update time of the object.
*/
updateTime?: string | null;
}
/**
* A validation to perform on a stream.
*/
export interface Schema$Validation {
/**
* A custom code identifying this validation.
*/
code?: string | null;
/**
* A short description of the validation.
*/
description?: string | null;
/**
* Messages reflecting the validation results.
*/
message?: Schema$ValidationMessage[];
/**
* Output only. Validation execution status.
*/
state?: string | null;
}
/**
* Represent user-facing validation result message.
*/
export interface Schema$ValidationMessage {
/**
* A custom code identifying this specific message.
*/
code?: string | null;
/**
* Message severity level (warning or error).
*/
level?: string | null;
/**
* The result of the validation.
*/
message?: string | null;
/**
* Additional metadata related to the result.
*/
metadata?: {
[key: string]: string;
} | null;
}
/**
* Contains the current validation results.
*/
export interface Schema$ValidationResult {
/**
* A list of validations (includes both executed as well as not executed validations).
*/
validations?: Schema$Validation[];
}
/**
* The VPC Peering configuration is used to create VPC peering between Datastream and the consumer's VPC.
*/
export interface Schema$VpcPeeringConfig {
/**
* Required. A free subnet for peering. (CIDR of /29)
*/
subnet?: string | null;
/**
* Required. Fully qualified name of the VPC that Datastream will peer to. Format: `projects/{project\}/global/{networks\}/{name\}`
*/
vpc?: string | null;
}
export class Resource$Projects {
context: APIRequestContext;
locations: Resource$Projects$Locations;
constructor(context: APIRequestContext);
}
export class Resource$Projects$Locations {
context: APIRequestContext;
connectionProfiles: Resource$Projects$Locations$Connectionprofiles;
operations: Resource$Projects$Locations$Operations;
privateConnections: Resource$Projects$Locations$Privateconnections;
streams: Resource$Projects$Locations$Streams;
constructor(context: APIRequestContext);
/**
* The FetchStaticIps API call exposes the static IP addresses used by Datastream.
*
* @param params - Parameters for request
* @param options - Optionally override request options, such as `url`, `method`, and `encoding`.
* @param callback - Optional callback that handles the response.
* @returns A promise if used with async/await, or void if used with a callback.
*/
fetchStaticIps(params: Params$Resource$Projects$Locations$Fetchstaticips, options: StreamMethodOptions): GaxiosPromise<Readable>;
fetchStaticIps(params?: Params$Resource$Projects$Locations$Fetchstaticips, options?: MethodOptions): GaxiosPromise<Schema$FetchStaticIpsResponse>;
fetchStaticIps(params: Params$Resource$Projects$Locations$Fetchstaticips, options: StreamMethodOptions | BodyResponseCallback<Readable>, callback: BodyResponseCallback<Readable>): void;
fetchStaticIps(params: Params$Resource$Projects$Locations$Fetchstaticips, options: MethodOptions | BodyResponseCallback<Schema$FetchStaticIpsResponse>, callback: BodyResponseCallback<Schema$FetchStaticIpsResponse>): void;
fetchStaticIps(params: Params$Resource$Projects$Locations$Fetchstaticips, callback: BodyResponseCallback<Schema$FetchStaticIpsResponse>): void;
fetchStaticIps(callback: BodyResponseCallback<Schema$FetchStaticIpsResponse>): void;
/**
* Gets information about a location.
*
* @param params - Parameters for request
* @param options - Optionally override request options, such as `url`, `method`, and `encoding`.
* @param callback - Optional callback that handles the response.
* @returns A promise if used with async/await, or void if used with a callback.