import * as express from "express"; import { ResetValue } from "../../common/options"; import { CallableRequest, CallableResponse, FunctionsErrorCode, HttpsError, Request, AuthData } from "../../common/providers/https"; import { ManifestEndpoint } from "../../runtime/manifest"; import { GlobalOptions, SupportedRegion } from "../options"; import { Expression } from "../../params"; import { SecretParam } from "../../params/types"; import * as options from "../options"; export { Request, CallableRequest, FunctionsErrorCode, HttpsError }; /** * Options that can be set on an onRequest HTTPS function. */ export interface HttpsOptions extends Omit { /** * If true, do not deploy or emulate this function. */ omit?: boolean | Expression; /** HTTP functions can override global options and can specify multiple regions to deploy to. */ region?: SupportedRegion | string | Array | Expression | ResetValue; /** If true, allows CORS on requests to this function. * If this is a `string` or `RegExp`, allows requests from domains that match the provided value. * If this is an `Array`, allows requests from domains matching at least one entry of the array. * Defaults to true for {@link https.CallableFunction} and false otherwise. */ cors?: string | boolean | RegExp | Array; /** * Amount of memory to allocate to a function. */ memory?: options.MemoryOption | Expression | ResetValue; /** * Timeout for the function in seconds, possible values are 0 to 540. * HTTPS functions can specify a higher timeout. * * @remarks * The minimum timeout for a gen 2 function is 1s. The maximum timeout for a * function depends on the type of function: Event handling functions have a * maximum timeout of 540s (9 minutes). HTTPS and callable functions have a * maximum timeout of 36,00s (1 hour). Task queue functions have a maximum * timeout of 1,800s (30 minutes) */ timeoutSeconds?: number | Expression | ResetValue; /** * Min number of actual instances to be running at a given time. * * @remarks * Instances will be billed for memory allocation and 10% of CPU allocation * while idle. */ minInstances?: number | Expression | ResetValue; /** * Max number of instances to be running in parallel. */ maxInstances?: number | Expression | ResetValue; /** * Number of requests a function can serve at once. * * @remarks * Can only be applied to functions running on Cloud Functions v2. * A value of null restores the default concurrency (80 when CPU >= 1, 1 otherwise). * Concurrency cannot be set to any value other than 1 if `cpu` is less than 1. * The maximum value for concurrency is 1,000. */ concurrency?: number | Expression | ResetValue; /** * Fractional number of CPUs to allocate to a function. * * @remarks * Defaults to 1 for functions with <= 2GB RAM and increases for larger memory sizes. * This is different from the defaults when using the gcloud utility and is different from * the fixed amount assigned in Google Cloud Functions generation 1. * To revert to the CPU amounts used in gcloud or in Cloud Functions generation 1, set this * to the value "gcf_gen1" */ cpu?: number | "gcf_gen1"; /** * Connect cloud function to specified VPC connector. */ vpcConnector?: string | Expression | ResetValue; /** * Egress settings for VPC connector. */ vpcConnectorEgressSettings?: options.VpcEgressSetting | ResetValue; /** * Specific service account for the function to run as. */ serviceAccount?: string | Expression | ResetValue; /** * Ingress settings which control where this function can be called from. */ ingressSettings?: options.IngressSetting | ResetValue; /** * User labels to set on the function. */ labels?: Record; secrets?: (string | SecretParam)[]; /** * Invoker to set access control on https functions. */ invoker?: "public" | "private" | string | string[]; } /** * Options that can be set on a callable HTTPS function. */ export interface CallableOptions extends HttpsOptions { /** * Determines whether Firebase AppCheck is enforced. * When true, requests with invalid tokens autorespond with a 401 * (Unauthorized) error. * When false, requests with invalid tokens set event.app to undefiend. */ enforceAppCheck?: boolean; /** * Determines whether Firebase App Check token is consumed on request. Defaults to false. * * @remarks * Set this to true to enable the App Check replay protection feature by consuming the App Check token on callable * request. Tokens that are found to be already consumed will have request.app.alreadyConsumed property set true. * * * Tokens are only considered to be consumed if it is sent to the App Check service by setting this option to true. * Other uses of the token do not consume it. * * This replay protection feature requires an additional network call to the App Check backend and forces the clients * to obtain a fresh attestation from the chosen attestation providers. This can therefore negatively impact * performance and can potentially deplete your attestation providers' quotas faster. Use this feature only for * protecting low volume, security critical, or expensive operations. * * This option does not affect the enforceAppCheck option. Setting the latter to true will cause the callable function * to automatically respond with a 401 Unauthorized status code when request includes an invalid App Check token. * When request includes valid but consumed App Check tokens, requests will not be automatically rejected. Instead, * the request.app.alreadyConsumed property will be set to true and pass the execution to the handler code for making * further decisions, such as requiring additional security checks or rejecting the request. */ consumeAppCheckToken?: boolean; /** * Time in seconds between sending heartbeat messages to keep the connection * alive. Set to `null` to disable heartbeats. * * Defaults to 30 seconds. */ heartbeatSeconds?: number | null; /** * Callback for whether a request is authorized. * * Designed to allow reusable auth policies to be passed as an options object. Two built-in reusable policies exist: * isSignedIn and hasClaim. */ authPolicy?: (auth: AuthData | null, data: T) => boolean | Promise; } /** * An auth policy that requires a user to be signed in. */ export declare const isSignedIn: () => (auth: AuthData | null) => boolean; /** * An auth policy that requires a user to be both signed in and have a specific claim (optionally with a specific value) */ export declare const hasClaim: (claim: string, value?: string) => (auth: AuthData | null) => boolean; /** * Handles HTTPS requests. */ export type HttpsFunction = (( /** An Express request object representing the HTTPS call to the function. */ req: Request, /** An Express response object, for this function to respond to callers. */ res: express.Response) => void | Promise) & { /** @alpha */ __trigger?: unknown; /** @alpha */ __endpoint: ManifestEndpoint; }; /** * Creates a callable method for clients to call using a Firebase SDK. */ export interface CallableFunction extends HttpsFunction { /** Executes the handler function with the provided data as input. Used for unit testing. * @param data - An input for the handler function. * @returns The output of the handler function. */ run(request: CallableRequest): Return; stream(request: CallableRequest, response: CallableResponse): { stream: AsyncIterator; output: Return; }; } /** * Handles HTTPS requests. * @param opts - Options to set on this function * @param handler - A function that takes a {@link https.Request} and response object, same signature as an Express app. * @returns A function that you can export and deploy. */ export declare function onRequest(opts: HttpsOptions, handler: (request: Request, response: express.Response) => void | Promise): HttpsFunction; /** * Handles HTTPS requests. * @param handler - A function that takes a {@link https.Request} and response object, same signature as an Express app. * @returns A function that you can export and deploy. */ export declare function onRequest(handler: (request: Request, response: express.Response) => void | Promise): HttpsFunction; /** * Declares a callable method for clients to call using a Firebase SDK. * @param opts - Options to set on this function. * @param handler - A function that takes a {@link https.CallableRequest}. * @returns A function that you can export and deploy. */ export declare function onCall, Stream = unknown>(opts: CallableOptions, handler: (request: CallableRequest, response?: CallableResponse) => Return): CallableFunction ? Return : Promise, Stream>; /** * Declares a callable method for clients to call using a Firebase SDK. * @param handler - A function that takes a {@link https.CallableRequest}. * @returns A function that you can export and deploy. */ export declare function onCall, Stream = unknown>(handler: (request: CallableRequest, response?: CallableResponse) => Return): CallableFunction ? Return : Promise>;