firebase-functions 3.20.1 → 3.21.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. package/lib/apps.js +1 -1
  2. package/lib/bin/firebase-functions.js +1 -1
  3. package/lib/cloud-functions.d.ts +8 -0
  4. package/lib/cloud-functions.js +12 -12
  5. package/lib/common/providers/https.js +8 -6
  6. package/lib/common/providers/identity.d.ts +7 -1
  7. package/lib/common/providers/identity.js +55 -207
  8. package/lib/function-builder.d.ts +1 -1
  9. package/lib/function-builder.js +1 -1
  10. package/lib/handler-builder.js +3 -3
  11. package/lib/index.js +6 -2
  12. package/lib/logger/compat.js +1 -1
  13. package/lib/providers/analytics.js +1 -1
  14. package/lib/providers/auth.d.ts +19 -6
  15. package/lib/providers/auth.js +62 -10
  16. package/lib/providers/database.js +11 -11
  17. package/lib/providers/firestore.js +7 -7
  18. package/lib/providers/https.js +7 -7
  19. package/lib/providers/pubsub.js +2 -2
  20. package/lib/providers/remoteConfig.js +1 -1
  21. package/lib/providers/storage.js +2 -2
  22. package/lib/providers/tasks.d.ts +1 -1
  23. package/lib/providers/tasks.js +9 -9
  24. package/lib/providers/testLab.js +1 -1
  25. package/lib/runtime/loader.js +9 -7
  26. package/lib/runtime/manifest.d.ts +5 -0
  27. package/lib/setup.js +3 -3
  28. package/lib/v2/core.d.ts +3 -21
  29. package/lib/v2/index.d.ts +3 -2
  30. package/lib/v2/index.js +5 -3
  31. package/lib/v2/options.d.ts +13 -2
  32. package/lib/v2/options.js +31 -39
  33. package/lib/v2/providers/alerts/alerts.d.ts +15 -7
  34. package/lib/v2/providers/alerts/appDistribution.d.ts +11 -11
  35. package/lib/v2/providers/alerts/appDistribution.js +1 -1
  36. package/lib/v2/providers/alerts/billing.d.ts +17 -11
  37. package/lib/v2/providers/alerts/billing.js +1 -1
  38. package/lib/v2/providers/alerts/crashlytics.d.ts +62 -29
  39. package/lib/v2/providers/alerts/crashlytics.js +1 -1
  40. package/lib/v2/providers/alerts/index.js +5 -1
  41. package/lib/v2/providers/eventarc.d.ts +1 -1
  42. package/lib/v2/providers/eventarc.js +3 -3
  43. package/lib/v2/providers/https.d.ts +6 -3
  44. package/lib/v2/providers/https.js +5 -11
  45. package/lib/v2/providers/identity.d.ts +22 -0
  46. package/lib/v2/providers/identity.js +73 -0
  47. package/lib/v2/providers/pubsub.d.ts +3 -3
  48. package/lib/v2/providers/pubsub.js +2 -5
  49. package/lib/v2/providers/storage.d.ts +17 -13
  50. package/lib/v2/providers/storage.js +5 -4
  51. package/lib/v2/providers/tasks.d.ts +1 -1
  52. package/lib/v2/providers/tasks.js +7 -8
  53. package/package.json +16 -3
@@ -0,0 +1,73 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getOpts = exports.beforeOperation = exports.beforeUserSignedIn = exports.beforeUserCreated = exports.HttpsError = void 0;
4
+ const identity_1 = require("../../common/providers/identity");
5
+ Object.defineProperty(exports, "HttpsError", { enumerable: true, get: function () { return identity_1.HttpsError; } });
6
+ const options = require("../options");
7
+ function beforeUserCreated(optsOrHandler, handler) {
8
+ return beforeOperation('beforeCreate', optsOrHandler, handler);
9
+ }
10
+ exports.beforeUserCreated = beforeUserCreated;
11
+ function beforeUserSignedIn(optsOrHandler, handler) {
12
+ return beforeOperation('beforeSignIn', optsOrHandler, handler);
13
+ }
14
+ exports.beforeUserSignedIn = beforeUserSignedIn;
15
+ /** @internal */
16
+ function beforeOperation(eventType, optsOrHandler, handler) {
17
+ if (!handler || typeof optsOrHandler === 'function') {
18
+ handler = optsOrHandler;
19
+ optsOrHandler = {};
20
+ }
21
+ const { opts, accessToken, idToken, refreshToken } = getOpts(optsOrHandler);
22
+ // Create our own function that just calls the provided function so we know for sure that
23
+ // handler takes one argument. This is something common/providers/identity depends on.
24
+ const wrappedHandler = (event) => handler(event);
25
+ const func = (0, identity_1.wrapHandler)(eventType, wrappedHandler);
26
+ const legacyEventType = `providers/cloud.auth/eventTypes/user.${eventType}`;
27
+ /** Endpoint */
28
+ const baseOptsEndpoint = options.optionsToEndpoint(options.getGlobalOptions());
29
+ const specificOptsEndpoint = options.optionsToEndpoint(opts);
30
+ func.__endpoint = {
31
+ platform: 'gcfv2',
32
+ ...baseOptsEndpoint,
33
+ ...specificOptsEndpoint,
34
+ labels: {
35
+ ...baseOptsEndpoint === null || baseOptsEndpoint === void 0 ? void 0 : baseOptsEndpoint.labels,
36
+ ...specificOptsEndpoint === null || specificOptsEndpoint === void 0 ? void 0 : specificOptsEndpoint.labels,
37
+ },
38
+ blockingTrigger: {
39
+ eventType: legacyEventType,
40
+ options: {
41
+ accessToken,
42
+ idToken,
43
+ refreshToken,
44
+ },
45
+ },
46
+ };
47
+ func.__requiredAPIs = [
48
+ {
49
+ api: 'identitytoolkit.googleapis.com',
50
+ reason: 'Needed for auth blocking functions',
51
+ },
52
+ ];
53
+ func.run = handler;
54
+ return func;
55
+ }
56
+ exports.beforeOperation = beforeOperation;
57
+ /** @internal */
58
+ function getOpts(blockingOptions) {
59
+ const accessToken = blockingOptions.accessToken || false;
60
+ const idToken = blockingOptions.idToken || false;
61
+ const refreshToken = blockingOptions.refreshToken || false;
62
+ const opts = { ...blockingOptions };
63
+ delete opts.accessToken;
64
+ delete opts.idToken;
65
+ delete opts.refreshToken;
66
+ return {
67
+ opts,
68
+ accessToken,
69
+ idToken,
70
+ refreshToken,
71
+ };
72
+ }
73
+ exports.getOpts = getOpts;
@@ -1,5 +1,5 @@
1
- import * as options from '../options';
2
1
  import { CloudEvent, CloudFunction } from '../core';
2
+ import * as options from '../options';
3
3
  /**
4
4
  * Interface representing a Google Cloud Pub/Sub message.
5
5
  *
@@ -52,6 +52,6 @@ export interface PubSubOptions extends options.EventHandlerOptions {
52
52
  topic: string;
53
53
  }
54
54
  /** Handle a message being published to a Pub/Sub topic. */
55
- export declare function onMessagePublished<T = any>(topic: string, handler: (event: CloudEvent<MessagePublishedData<T>>) => any | Promise<any>): CloudFunction<MessagePublishedData<T>>;
55
+ export declare function onMessagePublished<T = any>(topic: string, handler: (event: CloudEvent<MessagePublishedData<T>>) => any | Promise<any>): CloudFunction<CloudEvent<MessagePublishedData<T>>>;
56
56
  /** Handle a message being published to a Pub/Sub topic. */
57
- export declare function onMessagePublished<T = any>(options: PubSubOptions, handler: (event: CloudEvent<MessagePublishedData<T>>) => any | Promise<any>): CloudFunction<MessagePublishedData<T>>;
57
+ export declare function onMessagePublished<T = any>(options: PubSubOptions, handler: (event: CloudEvent<MessagePublishedData<T>>) => any | Promise<any>): CloudFunction<CloudEvent<MessagePublishedData<T>>>;
@@ -1,8 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.onMessagePublished = exports.Message = void 0;
4
- const options = require("../options");
5
4
  const encoding_1 = require("../../common/encoding");
5
+ const options = require("../options");
6
6
  /**
7
7
  * Interface representing a Google Cloud Pub/Sub message.
8
8
  *
@@ -75,9 +75,6 @@ function onMessagePublished(topicOrOptions, handler) {
75
75
  const baseOpts = options.optionsToTriggerAnnotations(options.getGlobalOptions());
76
76
  const specificOpts = options.optionsToTriggerAnnotations(opts);
77
77
  return {
78
- // TODO(inlined): Remove "apiVersion" once the CLI has migrated to
79
- // "platform"
80
- apiVersion: 2,
81
78
  platform: 'gcfv2',
82
79
  ...baseOpts,
83
80
  ...specificOpts,
@@ -108,7 +105,7 @@ function onMessagePublished(topicOrOptions, handler) {
108
105
  retry: false,
109
106
  },
110
107
  };
111
- encoding_1.copyIfPresent(endpoint.eventTrigger, opts, 'retry', 'retry');
108
+ (0, encoding_1.copyIfPresent)(endpoint.eventTrigger, opts, 'retry', 'retry');
112
109
  func.__endpoint = endpoint;
113
110
  return func;
114
111
  }
@@ -1,5 +1,5 @@
1
- import * as options from '../options';
2
1
  import { CloudEvent, CloudFunction } from '../core';
2
+ import * as options from '../options';
3
3
  /**
4
4
  * An object within Google Cloud Storage.
5
5
  * Ref: https://github.com/googleapis/google-cloudevents-nodejs/blob/main/cloud/storage/v1/StorageObjectData.ts
@@ -148,23 +148,27 @@ export interface CustomerEncryption {
148
148
  */
149
149
  keySha256?: string;
150
150
  }
151
+ export interface StorageEvent extends CloudEvent<StorageObjectData> {
152
+ /** The name of the bucket containing this object. */
153
+ bucket: string;
154
+ }
151
155
  /** StorageOptions extend EventHandlerOptions with a bucket name */
152
156
  export interface StorageOptions extends options.EventHandlerOptions {
153
157
  bucket?: string;
154
158
  }
155
159
  /** Handle a storage object archived */
156
- export declare function onObjectArchived(handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
157
- export declare function onObjectArchived(bucket: string, handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
158
- export declare function onObjectArchived(opts: StorageOptions, handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
160
+ export declare function onObjectArchived(handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
161
+ export declare function onObjectArchived(bucket: string, handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
162
+ export declare function onObjectArchived(opts: StorageOptions, handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
159
163
  /** Handle a storage object finalized */
160
- export declare function onObjectFinalized(handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
161
- export declare function onObjectFinalized(bucket: string, handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
162
- export declare function onObjectFinalized(opts: StorageOptions, handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
164
+ export declare function onObjectFinalized(handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
165
+ export declare function onObjectFinalized(bucket: string, handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
166
+ export declare function onObjectFinalized(opts: StorageOptions, handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
163
167
  /** Handle a storage object deleted */
164
- export declare function onObjectDeleted(handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
165
- export declare function onObjectDeleted(bucket: string, handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
166
- export declare function onObjectDeleted(opts: StorageOptions, handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
168
+ export declare function onObjectDeleted(handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
169
+ export declare function onObjectDeleted(bucket: string, handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
170
+ export declare function onObjectDeleted(opts: StorageOptions, handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
167
171
  /** Handle a storage object metadata updated */
168
- export declare function onObjectMetadataUpdated(handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
169
- export declare function onObjectMetadataUpdated(bucket: string, handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
170
- export declare function onObjectMetadataUpdated(opts: StorageOptions, handler: (event: CloudEvent<StorageObjectData>) => any | Promise<any>): CloudFunction<StorageObjectData>;
172
+ export declare function onObjectMetadataUpdated(handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
173
+ export declare function onObjectMetadataUpdated(bucket: string, handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
174
+ export declare function onObjectMetadataUpdated(opts: StorageOptions, handler: (event: StorageEvent) => any | Promise<any>): CloudFunction<StorageEvent>;
@@ -22,9 +22,9 @@
22
22
  // SOFTWARE.
23
23
  Object.defineProperty(exports, "__esModule", { value: true });
24
24
  exports.getOptsAndBucket = exports.onOperation = exports.onObjectMetadataUpdated = exports.onObjectDeleted = exports.onObjectFinalized = exports.onObjectArchived = exports.metadataUpdatedEvent = exports.deletedEvent = exports.finalizedEvent = exports.archivedEvent = void 0;
25
- const options = require("../options");
26
- const config_1 = require("../../config");
27
25
  const encoding_1 = require("../../common/encoding");
26
+ const config_1 = require("../../config");
27
+ const options = require("../options");
28
28
  /** @internal */
29
29
  exports.archivedEvent = 'google.cloud.storage.object.v1.archived';
30
30
  /** @internal */
@@ -103,7 +103,7 @@ function onOperation(eventType, bucketOrOptsOrHandler, handler) {
103
103
  retry: false,
104
104
  },
105
105
  };
106
- encoding_1.copyIfPresent(endpoint.eventTrigger, opts, 'retry', 'retry');
106
+ (0, encoding_1.copyIfPresent)(endpoint.eventTrigger, opts, 'retry', 'retry');
107
107
  return endpoint;
108
108
  },
109
109
  });
@@ -112,6 +112,7 @@ function onOperation(eventType, bucketOrOptsOrHandler, handler) {
112
112
  exports.onOperation = onOperation;
113
113
  /** @internal */
114
114
  function getOptsAndBucket(bucketOrOpts) {
115
+ var _a;
115
116
  let bucket;
116
117
  let opts;
117
118
  if (typeof bucketOrOpts === 'string') {
@@ -119,7 +120,7 @@ function getOptsAndBucket(bucketOrOpts) {
119
120
  opts = {};
120
121
  }
121
122
  else {
122
- bucket = bucketOrOpts.bucket || config_1.firebaseConfig().storageBucket;
123
+ bucket = bucketOrOpts.bucket || ((_a = (0, config_1.firebaseConfig)()) === null || _a === void 0 ? void 0 : _a.storageBucket);
123
124
  opts = { ...bucketOrOpts };
124
125
  delete opts.bucket;
125
126
  }
@@ -1,6 +1,6 @@
1
+ import { AuthData, RateLimits, Request, RetryConfig } from '../../common/providers/tasks';
1
2
  import * as options from '../options';
2
3
  import { HttpsFunction } from './https';
3
- import { AuthData, RateLimits, Request, RetryConfig } from '../../common/providers/tasks';
4
4
  export { AuthData, RateLimits, Request, RetryConfig as RetryPolicy };
5
5
  export interface TaskQueueOptions extends options.GlobalOptions {
6
6
  retryConfig?: RetryConfig;
@@ -22,9 +22,9 @@
22
22
  // SOFTWARE.
23
23
  Object.defineProperty(exports, "__esModule", { value: true });
24
24
  exports.onTaskDispatched = void 0;
25
- const options = require("../options");
26
25
  const encoding_1 = require("../../common/encoding");
27
26
  const tasks_1 = require("../../common/providers/tasks");
27
+ const options = require("../options");
28
28
  function onTaskDispatched(optsOrHandler, handler) {
29
29
  let opts;
30
30
  if (arguments.length == 1) {
@@ -37,7 +37,7 @@ function onTaskDispatched(optsOrHandler, handler) {
37
37
  // onDispatchHandler sniffs the function length to determine which API to present.
38
38
  // fix the length to prevent api versions from being mismatched.
39
39
  const fixedLen = (req) => handler(req);
40
- const func = tasks_1.onDispatchHandler(fixedLen);
40
+ const func = (0, tasks_1.onDispatchHandler)(fixedLen);
41
41
  Object.defineProperty(func, '__trigger', {
42
42
  get: () => {
43
43
  const baseOpts = options.optionsToTriggerAnnotations(options.getGlobalOptions());
@@ -45,10 +45,9 @@ function onTaskDispatched(optsOrHandler, handler) {
45
45
  // but optionsToTriggerAnnotations handles both cases.
46
46
  const specificOpts = options.optionsToTriggerAnnotations(opts);
47
47
  const taskQueueTrigger = {};
48
- encoding_1.copyIfPresent(taskQueueTrigger, opts, 'retryConfig', 'rateLimits');
49
- encoding_1.convertIfPresent(taskQueueTrigger, opts, 'invoker', 'invoker', encoding_1.convertInvoker);
48
+ (0, encoding_1.copyIfPresent)(taskQueueTrigger, opts, 'retryConfig', 'rateLimits');
49
+ (0, encoding_1.convertIfPresent)(taskQueueTrigger, opts, 'invoker', 'invoker', encoding_1.convertInvoker);
50
50
  return {
51
- apiVersion: 2,
52
51
  platform: 'gcfv2',
53
52
  ...baseOpts,
54
53
  ...specificOpts,
@@ -74,9 +73,9 @@ function onTaskDispatched(optsOrHandler, handler) {
74
73
  },
75
74
  taskQueueTrigger: {},
76
75
  };
77
- encoding_1.copyIfPresent(func.__endpoint.taskQueueTrigger, opts, 'retryConfig');
78
- encoding_1.copyIfPresent(func.__endpoint.taskQueueTrigger, opts, 'rateLimits');
79
- encoding_1.convertIfPresent(func.__endpoint.taskQueueTrigger, opts, 'invoker', 'invoker', encoding_1.convertInvoker);
76
+ (0, encoding_1.copyIfPresent)(func.__endpoint.taskQueueTrigger, opts, 'retryConfig');
77
+ (0, encoding_1.copyIfPresent)(func.__endpoint.taskQueueTrigger, opts, 'rateLimits');
78
+ (0, encoding_1.convertIfPresent)(func.__endpoint.taskQueueTrigger, opts, 'invoker', 'invoker', encoding_1.convertInvoker);
80
79
  func.__requiredAPIs = [
81
80
  {
82
81
  api: 'cloudtasks.googleapis.com',
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "firebase-functions",
3
- "version": "3.20.1",
3
+ "version": "3.21.0",
4
4
  "description": "Firebase SDK for Cloud Functions",
5
5
  "keywords": [
6
6
  "firebase",
@@ -64,7 +64,8 @@
64
64
  "./v2/alerts/appDistribution": "./lib/v2/providers/alerts/appDistribution.js",
65
65
  "./v2/alerts/billing": "./lib/v2/providers/alerts/billing.js",
66
66
  "./v2/alerts/crashlytics": "./lib/v2/providers/alerts/crashlytics.js",
67
- "./v2/eventarc": "./lib/v2/providers/eventarc.js"
67
+ "./v2/eventarc": "./lib/v2/providers/eventarc.js",
68
+ "./v2/identity": "./lib/v2/providers/identity.js"
68
69
  },
69
70
  "typesVersions": {
70
71
  "*": {
@@ -128,6 +129,9 @@
128
129
  "v2/eventarc": [
129
130
  "lib/v2/providers/eventarc"
130
131
  ],
132
+ "v2/identity": [
133
+ "lib/v2/providers/identity"
134
+ ],
131
135
  "v2/options": [
132
136
  "lib/v2/options"
133
137
  ],
@@ -153,6 +157,12 @@
153
157
  },
154
158
  "scripts": {
155
159
  "apidocs": "node docgen/generate-docs.js",
160
+ "docgen:v1:extract": "api-extractor run -c docgen/api-extractor.v1.json --local",
161
+ "docgen:v1:gen": "api-documenter-fire markdown -i docgen/v1 -o docgen/v1/markdown && api-documenter-fire toc -i docgen/v1 -o docgen/v1/markdown/toc -p /docs/reference/functions",
162
+ "docgen:v1": "npm run docgen:v1:extract && npm run docgen:v1:gen",
163
+ "docgen:v2:extract": "api-extractor run -c docgen/api-extractor.v2.json --local",
164
+ "docgen:v2:gen": "api-documenter-fire markdown -i docgen/v2 -o docgen/v2/markdown && api-documenter-fire toc -i docgen/v2 -o docgen/v2/markdown/toc -p /docs/reference/functions/v2",
165
+ "docgen:v2": "npm run docgen:v2:extract && npm run docgen:v2:gen",
156
166
  "build:pack": "rm -rf lib && npm install && tsc -p tsconfig.release.json && npm pack",
157
167
  "build:release": "npm ci --production && npm install --no-save typescript firebase-admin && tsc -p tsconfig.release.json",
158
168
  "build": "tsc -p tsconfig.release.json",
@@ -173,6 +183,9 @@
173
183
  "node-fetch": "^2.6.7"
174
184
  },
175
185
  "devDependencies": {
186
+ "@firebase/api-documenter": "^0.1.2",
187
+ "@microsoft/api-documenter": "^7.13.45",
188
+ "@microsoft/api-extractor": "^7.18.7",
176
189
  "@types/chai": "^4.1.7",
177
190
  "@types/chai-as-promised": "^7.1.0",
178
191
  "@types/jsonwebtoken": "^8.3.2",
@@ -186,7 +199,7 @@
186
199
  "chai": "^4.2.0",
187
200
  "chai-as-promised": "^7.1.1",
188
201
  "child-process-promise": "^2.2.1",
189
- "firebase-admin": "10.0.0",
202
+ "firebase-admin": "^10.1.0",
190
203
  "js-yaml": "^3.13.1",
191
204
  "jsdom": "^16.2.1",
192
205
  "jsonwebtoken": "^8.5.1",