import type * as gax from 'google-gax';
import type { Callback, CallOptions, Descriptors, ClientOptions } from 'google-gax';
import * as protos from '../../protos/protos';
/**
 *  Provides methods for handling User objects.
 * @class
 * @memberof v1
 */
export declare class UserServiceClient {
    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;
    };
    pathTemplates: {
        [name: string]: gax.PathTemplate;
    };
    userServiceStub?: Promise<{
        [name: string]: Function;
    }>;
    /**
     * Construct an instance of UserServiceClient.
     *
     * @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 UserServiceClient({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(): never[];
    getProjectId(): Promise<string>;
    getProjectId(callback: Callback<string, undefined, undefined>): void;
    /**
     * API to retrieve a User object.
     *
     * To get the current user, the resource name
     * `networks/{networkCode}/users/me` can be used.
     *
     * @param {Object} request
     *   The request object that will be sent.
     * @param {string} request.name
     *   Required. The resource name of the User.
     *   Format: `networks/{network_code}/users/{user_id}`
     * @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.ads.admanager.v1.User|User}.
     *   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/v1/user_service.get_user.js</caption>
     * region_tag:admanager_v1_generated_UserService_GetUser_async
     */
    getUser(request?: protos.google.ads.admanager.v1.IGetUserRequest, options?: CallOptions): Promise<[
        protos.google.ads.admanager.v1.IUser,
        protos.google.ads.admanager.v1.IGetUserRequest | undefined,
        {} | undefined
    ]>;
    getUser(request: protos.google.ads.admanager.v1.IGetUserRequest, options: CallOptions, callback: Callback<protos.google.ads.admanager.v1.IUser, protos.google.ads.admanager.v1.IGetUserRequest | null | undefined, {} | null | undefined>): void;
    getUser(request: protos.google.ads.admanager.v1.IGetUserRequest, callback: Callback<protos.google.ads.admanager.v1.IUser, protos.google.ads.admanager.v1.IGetUserRequest | null | undefined, {} | null | undefined>): void;
    /**
     * Return a fully-qualified adUnit resource name string.
     *
     * @param {string} network_code
     * @param {string} ad_unit
     * @returns {string} Resource name string.
     */
    adUnitPath(networkCode: string, adUnit: string): string;
    /**
     * Parse the network_code from AdUnit resource.
     *
     * @param {string} adUnitName
     *   A fully-qualified path representing AdUnit resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromAdUnitName(adUnitName: string): string | number;
    /**
     * Parse the ad_unit from AdUnit resource.
     *
     * @param {string} adUnitName
     *   A fully-qualified path representing AdUnit resource.
     * @returns {string} A string representing the ad_unit.
     */
    matchAdUnitFromAdUnitName(adUnitName: string): string | number;
    /**
     * Return a fully-qualified company resource name string.
     *
     * @param {string} network_code
     * @param {string} company
     * @returns {string} Resource name string.
     */
    companyPath(networkCode: string, company: string): string;
    /**
     * Parse the network_code from Company resource.
     *
     * @param {string} companyName
     *   A fully-qualified path representing Company resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromCompanyName(companyName: string): string | number;
    /**
     * Parse the company from Company resource.
     *
     * @param {string} companyName
     *   A fully-qualified path representing Company resource.
     * @returns {string} A string representing the company.
     */
    matchCompanyFromCompanyName(companyName: string): string | number;
    /**
     * Return a fully-qualified contact resource name string.
     *
     * @param {string} network_code
     * @param {string} contact
     * @returns {string} Resource name string.
     */
    contactPath(networkCode: string, contact: string): string;
    /**
     * Parse the network_code from Contact resource.
     *
     * @param {string} contactName
     *   A fully-qualified path representing Contact resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromContactName(contactName: string): string | number;
    /**
     * Parse the contact from Contact resource.
     *
     * @param {string} contactName
     *   A fully-qualified path representing Contact resource.
     * @returns {string} A string representing the contact.
     */
    matchContactFromContactName(contactName: string): string | number;
    /**
     * Return a fully-qualified customField resource name string.
     *
     * @param {string} network_code
     * @param {string} custom_field
     * @returns {string} Resource name string.
     */
    customFieldPath(networkCode: string, customField: string): string;
    /**
     * Parse the network_code from CustomField resource.
     *
     * @param {string} customFieldName
     *   A fully-qualified path representing CustomField resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromCustomFieldName(customFieldName: string): string | number;
    /**
     * Parse the custom_field from CustomField resource.
     *
     * @param {string} customFieldName
     *   A fully-qualified path representing CustomField resource.
     * @returns {string} A string representing the custom_field.
     */
    matchCustomFieldFromCustomFieldName(customFieldName: string): string | number;
    /**
     * Return a fully-qualified customTargetingKey resource name string.
     *
     * @param {string} network_code
     * @param {string} custom_targeting_key
     * @returns {string} Resource name string.
     */
    customTargetingKeyPath(networkCode: string, customTargetingKey: string): string;
    /**
     * Parse the network_code from CustomTargetingKey resource.
     *
     * @param {string} customTargetingKeyName
     *   A fully-qualified path representing CustomTargetingKey resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromCustomTargetingKeyName(customTargetingKeyName: string): string | number;
    /**
     * Parse the custom_targeting_key from CustomTargetingKey resource.
     *
     * @param {string} customTargetingKeyName
     *   A fully-qualified path representing CustomTargetingKey resource.
     * @returns {string} A string representing the custom_targeting_key.
     */
    matchCustomTargetingKeyFromCustomTargetingKeyName(customTargetingKeyName: string): string | number;
    /**
     * Return a fully-qualified customTargetingValue resource name string.
     *
     * @param {string} network_code
     * @param {string} custom_targeting_key
     * @param {string} custom_targeting_value
     * @returns {string} Resource name string.
     */
    customTargetingValuePath(networkCode: string, customTargetingKey: string, customTargetingValue: string): string;
    /**
     * Parse the network_code from CustomTargetingValue resource.
     *
     * @param {string} customTargetingValueName
     *   A fully-qualified path representing CustomTargetingValue resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromCustomTargetingValueName(customTargetingValueName: string): string | number;
    /**
     * Parse the custom_targeting_key from CustomTargetingValue resource.
     *
     * @param {string} customTargetingValueName
     *   A fully-qualified path representing CustomTargetingValue resource.
     * @returns {string} A string representing the custom_targeting_key.
     */
    matchCustomTargetingKeyFromCustomTargetingValueName(customTargetingValueName: string): string | number;
    /**
     * Parse the custom_targeting_value from CustomTargetingValue resource.
     *
     * @param {string} customTargetingValueName
     *   A fully-qualified path representing CustomTargetingValue resource.
     * @returns {string} A string representing the custom_targeting_value.
     */
    matchCustomTargetingValueFromCustomTargetingValueName(customTargetingValueName: string): string | number;
    /**
     * Return a fully-qualified entitySignalsMapping resource name string.
     *
     * @param {string} network_code
     * @param {string} entity_signals_mapping
     * @returns {string} Resource name string.
     */
    entitySignalsMappingPath(networkCode: string, entitySignalsMapping: string): string;
    /**
     * Parse the network_code from EntitySignalsMapping resource.
     *
     * @param {string} entitySignalsMappingName
     *   A fully-qualified path representing EntitySignalsMapping resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromEntitySignalsMappingName(entitySignalsMappingName: string): string | number;
    /**
     * Parse the entity_signals_mapping from EntitySignalsMapping resource.
     *
     * @param {string} entitySignalsMappingName
     *   A fully-qualified path representing EntitySignalsMapping resource.
     * @returns {string} A string representing the entity_signals_mapping.
     */
    matchEntitySignalsMappingFromEntitySignalsMappingName(entitySignalsMappingName: string): string | number;
    /**
     * Return a fully-qualified label resource name string.
     *
     * @param {string} network_code
     * @param {string} label
     * @returns {string} Resource name string.
     */
    labelPath(networkCode: string, label: string): string;
    /**
     * Parse the network_code from Label resource.
     *
     * @param {string} labelName
     *   A fully-qualified path representing Label resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromLabelName(labelName: string): string | number;
    /**
     * Parse the label from Label resource.
     *
     * @param {string} labelName
     *   A fully-qualified path representing Label resource.
     * @returns {string} A string representing the label.
     */
    matchLabelFromLabelName(labelName: string): string | number;
    /**
     * Return a fully-qualified network resource name string.
     *
     * @param {string} network_code
     * @returns {string} Resource name string.
     */
    networkPath(networkCode: string): string;
    /**
     * Parse the network_code from Network resource.
     *
     * @param {string} networkName
     *   A fully-qualified path representing Network resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromNetworkName(networkName: string): string | number;
    /**
     * Return a fully-qualified order resource name string.
     *
     * @param {string} network_code
     * @param {string} order
     * @returns {string} Resource name string.
     */
    orderPath(networkCode: string, order: string): string;
    /**
     * Parse the network_code from Order resource.
     *
     * @param {string} orderName
     *   A fully-qualified path representing Order resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromOrderName(orderName: string): string | number;
    /**
     * Parse the order from Order resource.
     *
     * @param {string} orderName
     *   A fully-qualified path representing Order resource.
     * @returns {string} A string representing the order.
     */
    matchOrderFromOrderName(orderName: string): string | number;
    /**
     * Return a fully-qualified placement resource name string.
     *
     * @param {string} network_code
     * @param {string} placement
     * @returns {string} Resource name string.
     */
    placementPath(networkCode: string, placement: string): string;
    /**
     * Parse the network_code from Placement resource.
     *
     * @param {string} placementName
     *   A fully-qualified path representing Placement resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromPlacementName(placementName: string): string | number;
    /**
     * Parse the placement from Placement resource.
     *
     * @param {string} placementName
     *   A fully-qualified path representing Placement resource.
     * @returns {string} A string representing the placement.
     */
    matchPlacementFromPlacementName(placementName: string): string | number;
    /**
     * Return a fully-qualified report resource name string.
     *
     * @param {string} network_code
     * @param {string} report
     * @returns {string} Resource name string.
     */
    reportPath(networkCode: string, report: string): string;
    /**
     * Parse the network_code from Report resource.
     *
     * @param {string} reportName
     *   A fully-qualified path representing Report resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromReportName(reportName: string): string | number;
    /**
     * Parse the report from Report resource.
     *
     * @param {string} reportName
     *   A fully-qualified path representing Report resource.
     * @returns {string} A string representing the report.
     */
    matchReportFromReportName(reportName: string): string | number;
    /**
     * Return a fully-qualified role resource name string.
     *
     * @param {string} network_code
     * @param {string} role
     * @returns {string} Resource name string.
     */
    rolePath(networkCode: string, role: string): string;
    /**
     * Parse the network_code from Role resource.
     *
     * @param {string} roleName
     *   A fully-qualified path representing Role resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromRoleName(roleName: string): string | number;
    /**
     * Parse the role from Role resource.
     *
     * @param {string} roleName
     *   A fully-qualified path representing Role resource.
     * @returns {string} A string representing the role.
     */
    matchRoleFromRoleName(roleName: string): string | number;
    /**
     * Return a fully-qualified taxonomyCategory resource name string.
     *
     * @param {string} network_code
     * @param {string} taxonomy_category
     * @returns {string} Resource name string.
     */
    taxonomyCategoryPath(networkCode: string, taxonomyCategory: string): string;
    /**
     * Parse the network_code from TaxonomyCategory resource.
     *
     * @param {string} taxonomyCategoryName
     *   A fully-qualified path representing TaxonomyCategory resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromTaxonomyCategoryName(taxonomyCategoryName: string): string | number;
    /**
     * Parse the taxonomy_category from TaxonomyCategory resource.
     *
     * @param {string} taxonomyCategoryName
     *   A fully-qualified path representing TaxonomyCategory resource.
     * @returns {string} A string representing the taxonomy_category.
     */
    matchTaxonomyCategoryFromTaxonomyCategoryName(taxonomyCategoryName: string): string | number;
    /**
     * Return a fully-qualified team resource name string.
     *
     * @param {string} network_code
     * @param {string} team
     * @returns {string} Resource name string.
     */
    teamPath(networkCode: string, team: string): string;
    /**
     * Parse the network_code from Team resource.
     *
     * @param {string} teamName
     *   A fully-qualified path representing Team resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromTeamName(teamName: string): string | number;
    /**
     * Parse the team from Team resource.
     *
     * @param {string} teamName
     *   A fully-qualified path representing Team resource.
     * @returns {string} A string representing the team.
     */
    matchTeamFromTeamName(teamName: string): string | number;
    /**
     * Return a fully-qualified user resource name string.
     *
     * @param {string} network_code
     * @param {string} user
     * @returns {string} Resource name string.
     */
    userPath(networkCode: string, user: string): string;
    /**
     * Parse the network_code from User resource.
     *
     * @param {string} userName
     *   A fully-qualified path representing User resource.
     * @returns {string} A string representing the network_code.
     */
    matchNetworkCodeFromUserName(userName: string): string | number;
    /**
     * Parse the user from User resource.
     *
     * @param {string} userName
     *   A fully-qualified path representing User resource.
     * @returns {string} A string representing the user.
     */
    matchUserFromUserName(userName: string): string | number;
    /**
     * 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>;
}
