import type * as gax from 'google-gax';
import type { Callback, CallOptions, Descriptors, ClientOptions, LROperation, PaginationCallback } from 'google-gax';
import { Transform } from 'stream';
import * as protos from '../../protos/protos';
/**
 *  The TargetHttpsProxies API.
 * @class
 * @memberof v1beta
 */
export declare class TargetHttpsProxiesClient {
    private _terminated;
    private _opts;
    private _providedCustomServicePath;
    private _gaxModule;
    private _gaxGrpc;
    private _protos;
    private _defaults;
    private _universeDomain;
    private _servicePath;
    private _log;
    auth: gax.GoogleAuth;
    descriptors: Descriptors;
    warn: (code: string, message: string, warnType?: string) => void;
    innerApiCalls: {
        [name: string]: Function;
    };
    targetHttpsProxiesStub?: Promise<{
        [name: string]: Function;
    }>;
    /**
     * Construct an instance of TargetHttpsProxiesClient.
     *
     * @param {object} [options] - The configuration object.
     * The options accepted by the constructor are described in detail
     * in [this document](https://github.com/googleapis/gax-nodejs/blob/main/client-libraries.md#creating-the-client-instance).
     * The common options are:
     * @param {object} [options.credentials] - Credentials object.
     * @param {string} [options.credentials.client_email]
     * @param {string} [options.credentials.private_key]
     * @param {string} [options.email] - Account email address. Required when
     *     using a .pem or .p12 keyFilename.
     * @param {string} [options.keyFilename] - Full path to the a .json, .pem, or
     *     .p12 key downloaded from the Google Developers Console. If you provide
     *     a path to a JSON file, the projectId option below is not necessary.
     *     NOTE: .pem and .p12 require you to specify options.email as well.
     * @param {number} [options.port] - The port on which to connect to
     *     the remote host.
     * @param {string} [options.projectId] - The project ID from the Google
     *     Developer's Console, e.g. 'grape-spaceship-123'. We will also check
     *     the environment variable GCLOUD_PROJECT for your project ID. If your
     *     app is running in an environment which supports
     *     {@link https://cloud.google.com/docs/authentication/application-default-credentials Application Default Credentials},
     *     your project ID will be detected automatically.
     * @param {string} [options.apiEndpoint] - The domain name of the
     *     API remote host.
     * @param {gax.ClientConfig} [options.clientConfig] - Client configuration override.
     *     Follows the structure of {@link gapicConfig}.
     * @param {boolean} [options.fallback] - Use HTTP/1.1 REST mode.
     *     For more information, please check the
     *     {@link https://github.com/googleapis/gax-nodejs/blob/main/client-libraries.md#http11-rest-api-mode documentation}.
     * @param {gax} [gaxInstance]: loaded instance of `google-gax`. Useful if you
     *     need to avoid loading the default gRPC version and want to use the fallback
     *     HTTP implementation. Load only fallback version and pass it to the constructor:
     *     ```
     *     const gax = require('google-gax/build/src/fallback'); // avoids loading google-gax with gRPC
     *     const client = new TargetHttpsProxiesClient({fallback: true}, gax);
     *     ```
     */
    constructor(opts?: ClientOptions, gaxInstance?: typeof gax | typeof gax.fallback);
    /**
     * Initialize the client.
     * Performs asynchronous operations (such as authentication) and prepares the client.
     * This function will be called automatically when any class method is called for the
     * first time, but if you need to initialize it before calling an actual method,
     * feel free to call initialize() directly.
     *
     * You can await on this method if you want to make sure the client is initialized.
     *
     * @returns {Promise} A promise that resolves to an authenticated service stub.
     */
    initialize(): Promise<{
        [name: string]: Function;
    }>;
    /**
     * The DNS address for this API service.
     * @deprecated Use the apiEndpoint method of the client instance.
     * @returns {string} The DNS address for this service.
     */
    static get servicePath(): string;
    /**
     * The DNS address for this API service - same as servicePath.
     * @deprecated Use the apiEndpoint method of the client instance.
     * @returns {string} The DNS address for this service.
     */
    static get apiEndpoint(): string;
    /**
     * The DNS address for this API service.
     * @returns {string} The DNS address for this service.
     */
    get apiEndpoint(): string;
    get universeDomain(): string;
    /**
     * The port for this API service.
     * @returns {number} The default port for this service.
     */
    static get port(): number;
    /**
     * The scopes needed to make gRPC calls for every method defined
     * in this service.
     * @returns {string[]} List of default scopes.
     */
    static get scopes(): string[];
    getProjectId(): Promise<string>;
    getProjectId(callback: Callback<string, undefined, undefined>): void;
    /**
     * Deletes the specified TargetHttpsProxy resource.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {string} request.requestId
     *   An optional request ID to identify requests. Specify a unique request ID so
     *   that if you must retry your request, the server will know to ignore the
     *   request if it has already been completed.
     *
     *   For example, consider a situation where you make an initial request and
     *   the request times out. If you make the request again with the same
     *   request ID, the server can check if original operation with the same
     *   request ID was received, and if so, will ignore the second request. This
     *   prevents clients from accidentally creating duplicate commitments.
     *
     *   The request ID must be
     *   a valid UUID with the exception that zero UUID is not supported
     *   (00000000-0000-0000-0000-000000000000).
     * @param {string} request.targetHttpsProxy
     *   Name of the TargetHttpsProxy resource to delete.
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Promise} - The promise which resolves to an array.
     *   The first element of the array is an object representing
     *   a long running operation.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation }
     *   for more details and examples.
     *   This method is considered to be in beta. This means while
     *   stable it is still a work-in-progress and under active development,
     *   and might get backwards-incompatible changes at any time.
     *   `.promise()` is not supported yet.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.delete.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_Delete_async
     */
    delete(request?: protos.google.cloud.compute.v1beta.IDeleteTargetHttpsProxyRequest, options?: CallOptions): Promise<[
        LROperation<protos.google.cloud.compute.v1beta.IOperation, null>,
        protos.google.cloud.compute.v1beta.IOperation | undefined,
        {} | undefined
    ]>;
    delete(request: protos.google.cloud.compute.v1beta.IDeleteTargetHttpsProxyRequest, options: CallOptions, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.IDeleteTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    delete(request: protos.google.cloud.compute.v1beta.IDeleteTargetHttpsProxyRequest, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.IDeleteTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Returns the specified TargetHttpsProxy resource.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {string} request.targetHttpsProxy
     *   Name of the TargetHttpsProxy resource to return.
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Promise} - The promise which resolves to an array.
     *   The first element of the array is an object representing {@link protos.google.cloud.compute.v1beta.TargetHttpsProxy|TargetHttpsProxy}.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation }
     *   for more details and examples.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.get.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_Get_async
     */
    get(request?: protos.google.cloud.compute.v1beta.IGetTargetHttpsProxyRequest, options?: CallOptions): Promise<[
        protos.google.cloud.compute.v1beta.ITargetHttpsProxy,
        protos.google.cloud.compute.v1beta.IGetTargetHttpsProxyRequest | undefined,
        {} | undefined
    ]>;
    get(request: protos.google.cloud.compute.v1beta.IGetTargetHttpsProxyRequest, options: CallOptions, callback: Callback<protos.google.cloud.compute.v1beta.ITargetHttpsProxy, protos.google.cloud.compute.v1beta.IGetTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    get(request: protos.google.cloud.compute.v1beta.IGetTargetHttpsProxyRequest, callback: Callback<protos.google.cloud.compute.v1beta.ITargetHttpsProxy, protos.google.cloud.compute.v1beta.IGetTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Creates a TargetHttpsProxy resource in the specified
     * project using the data included in the request.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {string} request.requestId
     *   An optional request ID to identify requests. Specify a unique request ID so
     *   that if you must retry your request, the server will know to ignore the
     *   request if it has already been completed.
     *
     *   For example, consider a situation where you make an initial request and
     *   the request times out. If you make the request again with the same
     *   request ID, the server can check if original operation with the same
     *   request ID was received, and if so, will ignore the second request. This
     *   prevents clients from accidentally creating duplicate commitments.
     *
     *   The request ID must be
     *   a valid UUID with the exception that zero UUID is not supported
     *   (00000000-0000-0000-0000-000000000000).
     * @param {google.cloud.compute.v1beta.TargetHttpsProxy} request.targetHttpsProxyResource
     *   The body resource for this request
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Promise} - The promise which resolves to an array.
     *   The first element of the array is an object representing
     *   a long running operation.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation }
     *   for more details and examples.
     *   This method is considered to be in beta. This means while
     *   stable it is still a work-in-progress and under active development,
     *   and might get backwards-incompatible changes at any time.
     *   `.promise()` is not supported yet.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.insert.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_Insert_async
     */
    insert(request?: protos.google.cloud.compute.v1beta.IInsertTargetHttpsProxyRequest, options?: CallOptions): Promise<[
        LROperation<protos.google.cloud.compute.v1beta.IOperation, null>,
        protos.google.cloud.compute.v1beta.IOperation | undefined,
        {} | undefined
    ]>;
    insert(request: protos.google.cloud.compute.v1beta.IInsertTargetHttpsProxyRequest, options: CallOptions, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.IInsertTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    insert(request: protos.google.cloud.compute.v1beta.IInsertTargetHttpsProxyRequest, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.IInsertTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Patches the specified TargetHttpsProxy resource with the data included in
     * the request. This method supports PATCH
     * semantics and usesJSON merge
     * patch format and processing rules.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {string} request.requestId
     *   An optional request ID to identify requests. Specify a unique request ID so
     *   that if you must retry your request, the server will know to ignore the
     *   request if it has already been completed.
     *
     *   For example, consider a situation where you make an initial request and
     *   the request times out. If you make the request again with the same
     *   request ID, the server can check if original operation with the same
     *   request ID was received, and if so, will ignore the second request. This
     *   prevents clients from accidentally creating duplicate commitments.
     *
     *   The request ID must be
     *   a valid UUID with the exception that zero UUID is not supported
     *   (00000000-0000-0000-0000-000000000000).
     * @param {string} request.targetHttpsProxy
     *   Name of the TargetHttpsProxy resource to patch.
     * @param {google.cloud.compute.v1beta.TargetHttpsProxy} request.targetHttpsProxyResource
     *   The body resource for this request
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Promise} - The promise which resolves to an array.
     *   The first element of the array is an object representing
     *   a long running operation.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation }
     *   for more details and examples.
     *   This method is considered to be in beta. This means while
     *   stable it is still a work-in-progress and under active development,
     *   and might get backwards-incompatible changes at any time.
     *   `.promise()` is not supported yet.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.patch.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_Patch_async
     */
    patch(request?: protos.google.cloud.compute.v1beta.IPatchTargetHttpsProxyRequest, options?: CallOptions): Promise<[
        LROperation<protos.google.cloud.compute.v1beta.IOperation, null>,
        protos.google.cloud.compute.v1beta.IOperation | undefined,
        {} | undefined
    ]>;
    patch(request: protos.google.cloud.compute.v1beta.IPatchTargetHttpsProxyRequest, options: CallOptions, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.IPatchTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    patch(request: protos.google.cloud.compute.v1beta.IPatchTargetHttpsProxyRequest, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.IPatchTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Changes the Certificate Map for TargetHttpsProxy.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {string} request.requestId
     *   An optional request ID to identify requests. Specify a unique request ID so
     *   that if you must retry your request, the server will know to ignore the
     *   request if it has already been completed.
     *
     *   For example, consider a situation where you make an initial request and
     *   the request times out. If you make the request again with the same
     *   request ID, the server can check if original operation with the same
     *   request ID was received, and if so, will ignore the second request. This
     *   prevents clients from accidentally creating duplicate commitments.
     *
     *   The request ID must be
     *   a valid UUID with the exception that zero UUID is not supported
     *   (00000000-0000-0000-0000-000000000000).
     * @param {google.cloud.compute.v1beta.TargetHttpsProxiesSetCertificateMapRequest} request.targetHttpsProxiesSetCertificateMapRequestResource
     *   The body resource for this request
     * @param {string} request.targetHttpsProxy
     *   Name of the TargetHttpsProxy resource whose CertificateMap is
     *   to be set. The name must be 1-63 characters long, and comply with RFC1035.
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Promise} - The promise which resolves to an array.
     *   The first element of the array is an object representing
     *   a long running operation.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation }
     *   for more details and examples.
     *   This method is considered to be in beta. This means while
     *   stable it is still a work-in-progress and under active development,
     *   and might get backwards-incompatible changes at any time.
     *   `.promise()` is not supported yet.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.set_certificate_map.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_SetCertificateMap_async
     */
    setCertificateMap(request?: protos.google.cloud.compute.v1beta.ISetCertificateMapTargetHttpsProxyRequest, options?: CallOptions): Promise<[
        LROperation<protos.google.cloud.compute.v1beta.IOperation, null>,
        protos.google.cloud.compute.v1beta.IOperation | undefined,
        {} | undefined
    ]>;
    setCertificateMap(request: protos.google.cloud.compute.v1beta.ISetCertificateMapTargetHttpsProxyRequest, options: CallOptions, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.ISetCertificateMapTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    setCertificateMap(request: protos.google.cloud.compute.v1beta.ISetCertificateMapTargetHttpsProxyRequest, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.ISetCertificateMapTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Sets the QUIC override policy for TargetHttpsProxy.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {string} request.requestId
     *   An optional request ID to identify requests. Specify a unique request ID so
     *   that if you must retry your request, the server will know to ignore the
     *   request if it has already been completed.
     *
     *   For example, consider a situation where you make an initial request and
     *   the request times out. If you make the request again with the same
     *   request ID, the server can check if original operation with the same
     *   request ID was received, and if so, will ignore the second request. This
     *   prevents clients from accidentally creating duplicate commitments.
     *
     *   The request ID must be
     *   a valid UUID with the exception that zero UUID is not supported
     *   (00000000-0000-0000-0000-000000000000).
     * @param {google.cloud.compute.v1beta.TargetHttpsProxiesSetQuicOverrideRequest} request.targetHttpsProxiesSetQuicOverrideRequestResource
     *   The body resource for this request
     * @param {string} request.targetHttpsProxy
     *   Name of the TargetHttpsProxy resource to set the QUIC override policy for.
     *   The name should conform to RFC1035.
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Promise} - The promise which resolves to an array.
     *   The first element of the array is an object representing
     *   a long running operation.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation }
     *   for more details and examples.
     *   This method is considered to be in beta. This means while
     *   stable it is still a work-in-progress and under active development,
     *   and might get backwards-incompatible changes at any time.
     *   `.promise()` is not supported yet.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.set_quic_override.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_SetQuicOverride_async
     */
    setQuicOverride(request?: protos.google.cloud.compute.v1beta.ISetQuicOverrideTargetHttpsProxyRequest, options?: CallOptions): Promise<[
        LROperation<protos.google.cloud.compute.v1beta.IOperation, null>,
        protos.google.cloud.compute.v1beta.IOperation | undefined,
        {} | undefined
    ]>;
    setQuicOverride(request: protos.google.cloud.compute.v1beta.ISetQuicOverrideTargetHttpsProxyRequest, options: CallOptions, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.ISetQuicOverrideTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    setQuicOverride(request: protos.google.cloud.compute.v1beta.ISetQuicOverrideTargetHttpsProxyRequest, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.ISetQuicOverrideTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Replaces SslCertificates for TargetHttpsProxy.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {string} request.requestId
     *   An optional request ID to identify requests. Specify a unique request ID so
     *   that if you must retry your request, the server will know to ignore the
     *   request if it has already been completed.
     *
     *   For example, consider a situation where you make an initial request and
     *   the request times out. If you make the request again with the same
     *   request ID, the server can check if original operation with the same
     *   request ID was received, and if so, will ignore the second request. This
     *   prevents clients from accidentally creating duplicate commitments.
     *
     *   The request ID must be
     *   a valid UUID with the exception that zero UUID is not supported
     *   (00000000-0000-0000-0000-000000000000).
     * @param {google.cloud.compute.v1beta.TargetHttpsProxiesSetSslCertificatesRequest} request.targetHttpsProxiesSetSslCertificatesRequestResource
     *   The body resource for this request
     * @param {string} request.targetHttpsProxy
     *   Name of the TargetHttpsProxy resource to set an
     *   SslCertificates resource for.
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Promise} - The promise which resolves to an array.
     *   The first element of the array is an object representing
     *   a long running operation.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation }
     *   for more details and examples.
     *   This method is considered to be in beta. This means while
     *   stable it is still a work-in-progress and under active development,
     *   and might get backwards-incompatible changes at any time.
     *   `.promise()` is not supported yet.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.set_ssl_certificates.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_SetSslCertificates_async
     */
    setSslCertificates(request?: protos.google.cloud.compute.v1beta.ISetSslCertificatesTargetHttpsProxyRequest, options?: CallOptions): Promise<[
        LROperation<protos.google.cloud.compute.v1beta.IOperation, null>,
        protos.google.cloud.compute.v1beta.IOperation | undefined,
        {} | undefined
    ]>;
    setSslCertificates(request: protos.google.cloud.compute.v1beta.ISetSslCertificatesTargetHttpsProxyRequest, options: CallOptions, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.ISetSslCertificatesTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    setSslCertificates(request: protos.google.cloud.compute.v1beta.ISetSslCertificatesTargetHttpsProxyRequest, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.ISetSslCertificatesTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Sets the SSL policy for TargetHttpsProxy. The SSL policy specifies the
     * server-side support for SSL features. This affects connections between
     * clients and the HTTPS proxy load balancer. They do not affect the
     * connection between the load balancer and the backends.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {string} request.requestId
     *   An optional request ID to identify requests. Specify a unique request ID so
     *   that if you must retry your request, the server will know to ignore the
     *   request if it has already been completed.
     *
     *   For example, consider a situation where you make an initial request and
     *   the request times out. If you make the request again with the same
     *   request ID, the server can check if original operation with the same
     *   request ID was received, and if so, will ignore the second request. This
     *   prevents clients from accidentally creating duplicate commitments.
     *
     *   The request ID must be
     *   a valid UUID with the exception that zero UUID is not supported
     *   (00000000-0000-0000-0000-000000000000).
     * @param {google.cloud.compute.v1beta.SslPolicyReference} request.sslPolicyReferenceResource
     *   The body resource for this request
     * @param {string} request.targetHttpsProxy
     *   Name of the TargetHttpsProxy resource whose SSL policy is
     *   to be set. The name must be 1-63 characters long, and comply with RFC1035.
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Promise} - The promise which resolves to an array.
     *   The first element of the array is an object representing
     *   a long running operation.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation }
     *   for more details and examples.
     *   This method is considered to be in beta. This means while
     *   stable it is still a work-in-progress and under active development,
     *   and might get backwards-incompatible changes at any time.
     *   `.promise()` is not supported yet.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.set_ssl_policy.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_SetSslPolicy_async
     */
    setSslPolicy(request?: protos.google.cloud.compute.v1beta.ISetSslPolicyTargetHttpsProxyRequest, options?: CallOptions): Promise<[
        LROperation<protos.google.cloud.compute.v1beta.IOperation, null>,
        protos.google.cloud.compute.v1beta.IOperation | undefined,
        {} | undefined
    ]>;
    setSslPolicy(request: protos.google.cloud.compute.v1beta.ISetSslPolicyTargetHttpsProxyRequest, options: CallOptions, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.ISetSslPolicyTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    setSslPolicy(request: protos.google.cloud.compute.v1beta.ISetSslPolicyTargetHttpsProxyRequest, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.ISetSslPolicyTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Changes the URL map for TargetHttpsProxy.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {string} request.requestId
     *   An optional request ID to identify requests. Specify a unique request ID so
     *   that if you must retry your request, the server will know to ignore the
     *   request if it has already been completed.
     *
     *   For example, consider a situation where you make an initial request and
     *   the request times out. If you make the request again with the same
     *   request ID, the server can check if original operation with the same
     *   request ID was received, and if so, will ignore the second request. This
     *   prevents clients from accidentally creating duplicate commitments.
     *
     *   The request ID must be
     *   a valid UUID with the exception that zero UUID is not supported
     *   (00000000-0000-0000-0000-000000000000).
     * @param {string} request.targetHttpsProxy
     *   Name of the TargetHttpsProxy resource whose URL map is
     *   to be set.
     * @param {google.cloud.compute.v1beta.UrlMapReference} request.urlMapReferenceResource
     *   The body resource for this request
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Promise} - The promise which resolves to an array.
     *   The first element of the array is an object representing
     *   a long running operation.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation }
     *   for more details and examples.
     *   This method is considered to be in beta. This means while
     *   stable it is still a work-in-progress and under active development,
     *   and might get backwards-incompatible changes at any time.
     *   `.promise()` is not supported yet.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.set_url_map.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_SetUrlMap_async
     */
    setUrlMap(request?: protos.google.cloud.compute.v1beta.ISetUrlMapTargetHttpsProxyRequest, options?: CallOptions): Promise<[
        LROperation<protos.google.cloud.compute.v1beta.IOperation, null>,
        protos.google.cloud.compute.v1beta.IOperation | undefined,
        {} | undefined
    ]>;
    setUrlMap(request: protos.google.cloud.compute.v1beta.ISetUrlMapTargetHttpsProxyRequest, options: CallOptions, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.ISetUrlMapTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    setUrlMap(request: protos.google.cloud.compute.v1beta.ISetUrlMapTargetHttpsProxyRequest, callback: Callback<protos.google.cloud.compute.v1beta.IOperation, protos.google.cloud.compute.v1beta.ISetUrlMapTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Returns permissions that a caller has on the specified resource.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {string} request.resource
     *   Name or id of the resource for this request.
     * @param {google.cloud.compute.v1beta.TestPermissionsRequest} request.testPermissionsRequestResource
     *   The body resource for this request
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Promise} - The promise which resolves to an array.
     *   The first element of the array is an object representing {@link protos.google.cloud.compute.v1beta.TestPermissionsResponse|TestPermissionsResponse}.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation }
     *   for more details and examples.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.test_iam_permissions.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_TestIamPermissions_async
     */
    testIamPermissions(request?: protos.google.cloud.compute.v1beta.ITestIamPermissionsTargetHttpsProxyRequest, options?: CallOptions): Promise<[
        protos.google.cloud.compute.v1beta.ITestPermissionsResponse,
        protos.google.cloud.compute.v1beta.ITestIamPermissionsTargetHttpsProxyRequest | undefined,
        {} | undefined
    ]>;
    testIamPermissions(request: protos.google.cloud.compute.v1beta.ITestIamPermissionsTargetHttpsProxyRequest, options: CallOptions, callback: Callback<protos.google.cloud.compute.v1beta.ITestPermissionsResponse, protos.google.cloud.compute.v1beta.ITestIamPermissionsTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    testIamPermissions(request: protos.google.cloud.compute.v1beta.ITestIamPermissionsTargetHttpsProxyRequest, callback: Callback<protos.google.cloud.compute.v1beta.ITestPermissionsResponse, protos.google.cloud.compute.v1beta.ITestIamPermissionsTargetHttpsProxyRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Retrieves the list of all TargetHttpsProxy resources, regional and global,
     * available to the specified project.
     *
     * To prevent failure, Google recommends that you set the
     * `returnPartialSuccess` parameter to `true`.
     *
     * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand.
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.filter
     *   A filter expression that filters resources listed in the response. Most
     *   Compute resources support two types of filter expressions:
     *   expressions that support regular expressions and expressions that follow
     *   API improvement proposal AIP-160.
     *   These two types of filter expressions cannot be mixed in one request.
     *
     *   If you want to use AIP-160, your expression must specify the field name, an
     *   operator, and the value that you want to use for filtering. The value
     *   must be a string, a number, or a boolean. The operator
     *   must be either `=`, `!=`, `>`, `<`, `<=`, `>=` or `:`.
     *
     *   For example, if you are filtering Compute Engine instances, you can
     *   exclude instances named `example-instance` by specifying
     *   `name != example-instance`.
     *
     *   The `:*` comparison can be used to test whether a key has been defined.
     *   For example, to find all objects with `owner` label use:
     *   ```
     *   labels.owner:*
     *   ```
     *
     *   You can also filter nested fields. For example, you could specify
     *   `scheduling.automaticRestart = false` to include instances only
     *   if they are not scheduled for automatic restarts. You can use filtering
     *   on nested fields to filter based onresource labels.
     *
     *   To filter on multiple expressions, provide each separate expression within
     *   parentheses. For example:
     *   ```
     *   (scheduling.automaticRestart = true)
     *   (cpuPlatform = "Intel Skylake")
     *   ```
     *   By default, each expression is an `AND` expression. However, you
     *   can include `AND` and `OR` expressions explicitly.
     *   For example:
     *   ```
     *   (cpuPlatform = "Intel Skylake") OR
     *   (cpuPlatform = "Intel Broadwell") AND
     *   (scheduling.automaticRestart = true)
     *   ```
     *
     *   If you want to use a regular expression, use the `eq` (equal) or `ne`
     *   (not equal) operator against a single un-parenthesized expression with or
     *   without quotes or against multiple parenthesized expressions. Examples:
     *
     *   `fieldname eq unquoted literal`
     *   `fieldname eq 'single quoted literal'`
     *   `fieldname eq "double quoted literal"`
     *   `(fieldname1 eq literal) (fieldname2 ne "literal")`
     *
     *   The literal value is interpreted as a regular expression using GoogleRE2 library syntax.
     *   The literal value must match the entire field.
     *
     *   For example, to filter for instances that do not end with name "instance",
     *   you would use `name ne .*instance`.
     *
     *   You cannot combine constraints on multiple fields using regular
     *   expressions.
     * @param {boolean} request.includeAllScopes
     *   Indicates whether every visible scope for each scope type (zone, region,
     *   global) should be included in the response. For new resource types added
     *   after this field, the flag has no effect as new resource types will always
     *   include every visible scope for each scope type in response. For resource
     *   types which predate this field, if this flag is omitted or false, only
     *   scopes of the scope types where the resource type is expected to be found
     *   will be included.
     * @param {number} request.maxResults
     *   The maximum number of results per page that should be returned.
     *   If the number of available results is larger than `maxResults`,
     *   Compute Engine returns a `nextPageToken` that can be used to get
     *   the next page of results in subsequent list requests. Acceptable values are
     *   `0` to `500`, inclusive. (Default: `500`)
     * @param {string} request.orderBy
     *   Sorts list results by a certain order. By default, results
     *   are returned in alphanumerical order based on the resource name.
     *
     *   You can also sort results in descending order based on the creation
     *   timestamp using `orderBy="creationTimestamp desc"`. This sorts
     *   results based on the `creationTimestamp` field in
     *   reverse chronological order (newest result first). Use this to sort
     *   resources like operations so that the newest operation is returned first.
     *
     *   Currently, only sorting by `name` or
     *   `creationTimestamp desc` is supported.
     * @param {string} request.pageToken
     *   Specifies a page token to use. Set `pageToken` to the
     *   `nextPageToken` returned by a previous list request to get
     *   the next page of results.
     * @param {string} request.project
     *   Name of the project scoping this request.
     * @param {boolean} request.returnPartialSuccess
     *   Opt-in for partial success behavior which provides partial results in case
     *   of failure. The default value is false.
     *
     *   For example, when partial success behavior is enabled, aggregatedList for a
     *   single zone scope either returns all resources in the zone or no resources,
     *   with an error code.
     * @param {number} request.serviceProjectNumber
     *   The Shared VPC service project id or service project number for which
     *   aggregated list request is invoked for subnetworks list-usable api.
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Object}
     *   An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }.
     *   When you iterate the returned iterable, each element will be an object representing
     *   as tuple [string, {@link protos.google.cloud.compute.v1beta.TargetHttpsProxiesScopedList|TargetHttpsProxiesScopedList}]. The API will be called under the hood as needed, once per the page,
     *   so you can stop the iteration when you don't need more results.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation }
     *   for more details and examples.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.aggregated_list.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_AggregatedList_async
     */
    aggregatedListAsync(request?: protos.google.cloud.compute.v1beta.IAggregatedListTargetHttpsProxiesRequest, options?: CallOptions): AsyncIterable<[string, protos.google.cloud.compute.v1beta.ITargetHttpsProxiesScopedList]>;
    /**
    * Retrieves the list of TargetHttpsProxy resources
    * available to the specified project.
    *
    * @param {Object} request
    *   The request object that will be sent.
    * @param {string} request.filter
    *   A filter expression that filters resources listed in the response. Most
    *   Compute resources support two types of filter expressions:
    *   expressions that support regular expressions and expressions that follow
    *   API improvement proposal AIP-160.
    *   These two types of filter expressions cannot be mixed in one request.
    *
    *   If you want to use AIP-160, your expression must specify the field name, an
    *   operator, and the value that you want to use for filtering. The value
    *   must be a string, a number, or a boolean. The operator
    *   must be either `=`, `!=`, `>`, `<`, `<=`, `>=` or `:`.
    *
    *   For example, if you are filtering Compute Engine instances, you can
    *   exclude instances named `example-instance` by specifying
    *   `name != example-instance`.
    *
    *   The `:*` comparison can be used to test whether a key has been defined.
    *   For example, to find all objects with `owner` label use:
    *   ```
    *   labels.owner:*
    *   ```
    *
    *   You can also filter nested fields. For example, you could specify
    *   `scheduling.automaticRestart = false` to include instances only
    *   if they are not scheduled for automatic restarts. You can use filtering
    *   on nested fields to filter based onresource labels.
    *
    *   To filter on multiple expressions, provide each separate expression within
    *   parentheses. For example:
    *   ```
    *   (scheduling.automaticRestart = true)
    *   (cpuPlatform = "Intel Skylake")
    *   ```
    *   By default, each expression is an `AND` expression. However, you
    *   can include `AND` and `OR` expressions explicitly.
    *   For example:
    *   ```
    *   (cpuPlatform = "Intel Skylake") OR
    *   (cpuPlatform = "Intel Broadwell") AND
    *   (scheduling.automaticRestart = true)
    *   ```
    *
    *   If you want to use a regular expression, use the `eq` (equal) or `ne`
    *   (not equal) operator against a single un-parenthesized expression with or
    *   without quotes or against multiple parenthesized expressions. Examples:
    *
    *   `fieldname eq unquoted literal`
    *   `fieldname eq 'single quoted literal'`
    *   `fieldname eq "double quoted literal"`
    *   `(fieldname1 eq literal) (fieldname2 ne "literal")`
    *
    *   The literal value is interpreted as a regular expression using GoogleRE2 library syntax.
    *   The literal value must match the entire field.
    *
    *   For example, to filter for instances that do not end with name "instance",
    *   you would use `name ne .*instance`.
    *
    *   You cannot combine constraints on multiple fields using regular
    *   expressions.
    * @param {number} request.maxResults
    *   The maximum number of results per page that should be returned.
    *   If the number of available results is larger than `maxResults`,
    *   Compute Engine returns a `nextPageToken` that can be used to get
    *   the next page of results in subsequent list requests. Acceptable values are
    *   `0` to `500`, inclusive. (Default: `500`)
    * @param {string} request.orderBy
    *   Sorts list results by a certain order. By default, results
    *   are returned in alphanumerical order based on the resource name.
    *
    *   You can also sort results in descending order based on the creation
    *   timestamp using `orderBy="creationTimestamp desc"`. This sorts
    *   results based on the `creationTimestamp` field in
    *   reverse chronological order (newest result first). Use this to sort
    *   resources like operations so that the newest operation is returned first.
    *
    *   Currently, only sorting by `name` or
    *   `creationTimestamp desc` is supported.
    * @param {string} request.pageToken
    *   Specifies a page token to use. Set `pageToken` to the
    *   `nextPageToken` returned by a previous list request to get
    *   the next page of results.
    * @param {string} request.project
    *   Project ID for this request.
    * @param {boolean} request.returnPartialSuccess
    *   Opt-in for partial success behavior which provides partial results in case
    *   of failure. The default value is false.
    *
    *   For example, when partial success behavior is enabled, aggregatedList for a
    *   single zone scope either returns all resources in the zone or no resources,
    *   with an error code.
    * @param {object} [options]
    *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
    * @returns {Promise} - The promise which resolves to an array.
    *   The first element of the array is Array of {@link protos.google.cloud.compute.v1beta.TargetHttpsProxy|TargetHttpsProxy}.
    *   The client library will perform auto-pagination by default: it will call the API as many
    *   times as needed and will merge results from all the pages into this array.
    *   Note that it can affect your quota.
    *   We recommend using `listAsync()`
    *   method described below for async iteration which you can stop as needed.
    *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation }
    *   for more details and examples.
    */
    list(request?: protos.google.cloud.compute.v1beta.IListTargetHttpsProxiesRequest, options?: CallOptions): Promise<[
        protos.google.cloud.compute.v1beta.ITargetHttpsProxy[],
        protos.google.cloud.compute.v1beta.IListTargetHttpsProxiesRequest | null,
        protos.google.cloud.compute.v1beta.ITargetHttpsProxyList
    ]>;
    list(request: protos.google.cloud.compute.v1beta.IListTargetHttpsProxiesRequest, options: CallOptions, callback: PaginationCallback<protos.google.cloud.compute.v1beta.IListTargetHttpsProxiesRequest, protos.google.cloud.compute.v1beta.ITargetHttpsProxyList | null | undefined, protos.google.cloud.compute.v1beta.ITargetHttpsProxy>): void;
    list(request: protos.google.cloud.compute.v1beta.IListTargetHttpsProxiesRequest, callback: PaginationCallback<protos.google.cloud.compute.v1beta.IListTargetHttpsProxiesRequest, protos.google.cloud.compute.v1beta.ITargetHttpsProxyList | null | undefined, protos.google.cloud.compute.v1beta.ITargetHttpsProxy>): void;
    /**
     * Equivalent to `list`, but returns a NodeJS Stream object.
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.filter
     *   A filter expression that filters resources listed in the response. Most
     *   Compute resources support two types of filter expressions:
     *   expressions that support regular expressions and expressions that follow
     *   API improvement proposal AIP-160.
     *   These two types of filter expressions cannot be mixed in one request.
     *
     *   If you want to use AIP-160, your expression must specify the field name, an
     *   operator, and the value that you want to use for filtering. The value
     *   must be a string, a number, or a boolean. The operator
     *   must be either `=`, `!=`, `>`, `<`, `<=`, `>=` or `:`.
     *
     *   For example, if you are filtering Compute Engine instances, you can
     *   exclude instances named `example-instance` by specifying
     *   `name != example-instance`.
     *
     *   The `:*` comparison can be used to test whether a key has been defined.
     *   For example, to find all objects with `owner` label use:
     *   ```
     *   labels.owner:*
     *   ```
     *
     *   You can also filter nested fields. For example, you could specify
     *   `scheduling.automaticRestart = false` to include instances only
     *   if they are not scheduled for automatic restarts. You can use filtering
     *   on nested fields to filter based onresource labels.
     *
     *   To filter on multiple expressions, provide each separate expression within
     *   parentheses. For example:
     *   ```
     *   (scheduling.automaticRestart = true)
     *   (cpuPlatform = "Intel Skylake")
     *   ```
     *   By default, each expression is an `AND` expression. However, you
     *   can include `AND` and `OR` expressions explicitly.
     *   For example:
     *   ```
     *   (cpuPlatform = "Intel Skylake") OR
     *   (cpuPlatform = "Intel Broadwell") AND
     *   (scheduling.automaticRestart = true)
     *   ```
     *
     *   If you want to use a regular expression, use the `eq` (equal) or `ne`
     *   (not equal) operator against a single un-parenthesized expression with or
     *   without quotes or against multiple parenthesized expressions. Examples:
     *
     *   `fieldname eq unquoted literal`
     *   `fieldname eq 'single quoted literal'`
     *   `fieldname eq "double quoted literal"`
     *   `(fieldname1 eq literal) (fieldname2 ne "literal")`
     *
     *   The literal value is interpreted as a regular expression using GoogleRE2 library syntax.
     *   The literal value must match the entire field.
     *
     *   For example, to filter for instances that do not end with name "instance",
     *   you would use `name ne .*instance`.
     *
     *   You cannot combine constraints on multiple fields using regular
     *   expressions.
     * @param {number} request.maxResults
     *   The maximum number of results per page that should be returned.
     *   If the number of available results is larger than `maxResults`,
     *   Compute Engine returns a `nextPageToken` that can be used to get
     *   the next page of results in subsequent list requests. Acceptable values are
     *   `0` to `500`, inclusive. (Default: `500`)
     * @param {string} request.orderBy
     *   Sorts list results by a certain order. By default, results
     *   are returned in alphanumerical order based on the resource name.
     *
     *   You can also sort results in descending order based on the creation
     *   timestamp using `orderBy="creationTimestamp desc"`. This sorts
     *   results based on the `creationTimestamp` field in
     *   reverse chronological order (newest result first). Use this to sort
     *   resources like operations so that the newest operation is returned first.
     *
     *   Currently, only sorting by `name` or
     *   `creationTimestamp desc` is supported.
     * @param {string} request.pageToken
     *   Specifies a page token to use. Set `pageToken` to the
     *   `nextPageToken` returned by a previous list request to get
     *   the next page of results.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {boolean} request.returnPartialSuccess
     *   Opt-in for partial success behavior which provides partial results in case
     *   of failure. The default value is false.
     *
     *   For example, when partial success behavior is enabled, aggregatedList for a
     *   single zone scope either returns all resources in the zone or no resources,
     *   with an error code.
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Stream}
     *   An object stream which emits an object representing {@link protos.google.cloud.compute.v1beta.TargetHttpsProxy|TargetHttpsProxy} on 'data' event.
     *   The client library will perform auto-pagination by default: it will call the API as many
     *   times as needed. Note that it can affect your quota.
     *   We recommend using `listAsync()`
     *   method described below for async iteration which you can stop as needed.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation }
     *   for more details and examples.
     */
    listStream(request?: protos.google.cloud.compute.v1beta.IListTargetHttpsProxiesRequest, options?: CallOptions): Transform;
    /**
     * Equivalent to `list`, but returns an iterable object.
     *
     * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand.
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.filter
     *   A filter expression that filters resources listed in the response. Most
     *   Compute resources support two types of filter expressions:
     *   expressions that support regular expressions and expressions that follow
     *   API improvement proposal AIP-160.
     *   These two types of filter expressions cannot be mixed in one request.
     *
     *   If you want to use AIP-160, your expression must specify the field name, an
     *   operator, and the value that you want to use for filtering. The value
     *   must be a string, a number, or a boolean. The operator
     *   must be either `=`, `!=`, `>`, `<`, `<=`, `>=` or `:`.
     *
     *   For example, if you are filtering Compute Engine instances, you can
     *   exclude instances named `example-instance` by specifying
     *   `name != example-instance`.
     *
     *   The `:*` comparison can be used to test whether a key has been defined.
     *   For example, to find all objects with `owner` label use:
     *   ```
     *   labels.owner:*
     *   ```
     *
     *   You can also filter nested fields. For example, you could specify
     *   `scheduling.automaticRestart = false` to include instances only
     *   if they are not scheduled for automatic restarts. You can use filtering
     *   on nested fields to filter based onresource labels.
     *
     *   To filter on multiple expressions, provide each separate expression within
     *   parentheses. For example:
     *   ```
     *   (scheduling.automaticRestart = true)
     *   (cpuPlatform = "Intel Skylake")
     *   ```
     *   By default, each expression is an `AND` expression. However, you
     *   can include `AND` and `OR` expressions explicitly.
     *   For example:
     *   ```
     *   (cpuPlatform = "Intel Skylake") OR
     *   (cpuPlatform = "Intel Broadwell") AND
     *   (scheduling.automaticRestart = true)
     *   ```
     *
     *   If you want to use a regular expression, use the `eq` (equal) or `ne`
     *   (not equal) operator against a single un-parenthesized expression with or
     *   without quotes or against multiple parenthesized expressions. Examples:
     *
     *   `fieldname eq unquoted literal`
     *   `fieldname eq 'single quoted literal'`
     *   `fieldname eq "double quoted literal"`
     *   `(fieldname1 eq literal) (fieldname2 ne "literal")`
     *
     *   The literal value is interpreted as a regular expression using GoogleRE2 library syntax.
     *   The literal value must match the entire field.
     *
     *   For example, to filter for instances that do not end with name "instance",
     *   you would use `name ne .*instance`.
     *
     *   You cannot combine constraints on multiple fields using regular
     *   expressions.
     * @param {number} request.maxResults
     *   The maximum number of results per page that should be returned.
     *   If the number of available results is larger than `maxResults`,
     *   Compute Engine returns a `nextPageToken` that can be used to get
     *   the next page of results in subsequent list requests. Acceptable values are
     *   `0` to `500`, inclusive. (Default: `500`)
     * @param {string} request.orderBy
     *   Sorts list results by a certain order. By default, results
     *   are returned in alphanumerical order based on the resource name.
     *
     *   You can also sort results in descending order based on the creation
     *   timestamp using `orderBy="creationTimestamp desc"`. This sorts
     *   results based on the `creationTimestamp` field in
     *   reverse chronological order (newest result first). Use this to sort
     *   resources like operations so that the newest operation is returned first.
     *
     *   Currently, only sorting by `name` or
     *   `creationTimestamp desc` is supported.
     * @param {string} request.pageToken
     *   Specifies a page token to use. Set `pageToken` to the
     *   `nextPageToken` returned by a previous list request to get
     *   the next page of results.
     * @param {string} request.project
     *   Project ID for this request.
     * @param {boolean} request.returnPartialSuccess
     *   Opt-in for partial success behavior which provides partial results in case
     *   of failure. The default value is false.
     *
     *   For example, when partial success behavior is enabled, aggregatedList for a
     *   single zone scope either returns all resources in the zone or no resources,
     *   with an error code.
     * @param {object} [options]
     *   Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details.
     * @returns {Object}
     *   An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }.
     *   When you iterate the returned iterable, each element will be an object representing
     *   {@link protos.google.cloud.compute.v1beta.TargetHttpsProxy|TargetHttpsProxy}. The API will be called under the hood as needed, once per the page,
     *   so you can stop the iteration when you don't need more results.
     *   Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation }
     *   for more details and examples.
     * @example <caption>include:samples/generated/v1beta/target_https_proxies.list.js</caption>
     * region_tag:compute_v1beta_generated_TargetHttpsProxies_List_async
     */
    listAsync(request?: protos.google.cloud.compute.v1beta.IListTargetHttpsProxiesRequest, options?: CallOptions): AsyncIterable<protos.google.cloud.compute.v1beta.ITargetHttpsProxy>;
    /**
     * Terminate the gRPC channel and close the client.
     *
     * The client will no longer be usable and all future behavior is undefined.
     * @returns {Promise} A promise that resolves when the client is closed.
     */
    close(): Promise<void>;
}
