@entropic-bond/firebase 1.11.1 → 1.12.1
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.
- package/lib/auth/firebase-auth.d.ts +1 -0
- package/lib/auth/firebase-auth.js +8 -7
- package/lib/auth/firebase-auth.js.map +1 -1
- package/lib/cloud-functions/firebase-cloud-functions.js +1 -2
- package/lib/cloud-functions/firebase-cloud-functions.js.map +1 -1
- package/lib/cloud-storage/firebase-cloud-storage.js +13 -17
- package/lib/cloud-storage/firebase-cloud-storage.js.map +1 -1
- package/lib/mocks/test-user.js +6 -3
- package/lib/mocks/test-user.js.map +1 -1
- package/lib/store/firebase-datasource.js +3 -5
- package/lib/store/firebase-datasource.js.map +1 -1
- package/package.json +10 -11
- package/lib/auth/firebase-auth.spec.d.ts +0 -1
- package/lib/auth/firebase-auth.spec.js +0 -73
- package/lib/auth/firebase-auth.spec.js.map +0 -1
- package/lib/cloud-functions/firebase-cloud-functions.spec.d.ts +0 -6
- package/lib/cloud-functions/firebase-cloud-functions.spec.js +0 -52
- package/lib/cloud-functions/firebase-cloud-functions.spec.js.map +0 -1
- package/lib/cloud-storage/firebase-cloud-storage.spec.d.ts +0 -1
- package/lib/cloud-storage/firebase-cloud-storage.spec.js +0 -112
- package/lib/cloud-storage/firebase-cloud-storage.spec.js.map +0 -1
- package/lib/mocks/mock-data.json +0 -148
- package/lib/store/firebase-datasource.spec.d.ts +0 -1
- package/lib/store/firebase-datasource.spec.js +0 -425
- package/lib/store/firebase-datasource.spec.js.map +0 -1
|
@@ -8,6 +8,7 @@ export declare class FirebaseAuth extends AuthService {
|
|
|
8
8
|
logout(): Promise<void>;
|
|
9
9
|
resetEmailPassword(email: string): Promise<void>;
|
|
10
10
|
resendVerificationEmail(email: string, password: string, verificationLink: string): Promise<void>;
|
|
11
|
+
refreshToken(): Promise<void>;
|
|
11
12
|
onAuthStateChange<T extends {}>(onChange: (userCredentials: UserCredentials<T> | undefined) => void): void;
|
|
12
13
|
linkAdditionalProvider(provider: AuthProvider): Promise<unknown>;
|
|
13
14
|
unlinkProvider(provider: AuthProvider): Promise<unknown>;
|
|
@@ -11,12 +11,11 @@ const providerFactory = {
|
|
|
11
11
|
};
|
|
12
12
|
class FirebaseAuth extends entropic_bond_1.AuthService {
|
|
13
13
|
constructor(emulator) {
|
|
14
|
-
var _a;
|
|
15
14
|
super();
|
|
16
15
|
this.credentialProviders = {};
|
|
17
16
|
if (emulator)
|
|
18
17
|
firebase_helper_1.FirebaseHelper.useEmulator(emulator);
|
|
19
|
-
if (
|
|
18
|
+
if (firebase_helper_1.FirebaseHelper.emulator?.emulate) {
|
|
20
19
|
const { host, authPort } = firebase_helper_1.FirebaseHelper.emulator;
|
|
21
20
|
if (!host || !authPort)
|
|
22
21
|
throw new Error(`You should define a host and an auth emulator port to use the emulator`);
|
|
@@ -116,6 +115,9 @@ class FirebaseAuth extends entropic_bond_1.AuthService {
|
|
|
116
115
|
}
|
|
117
116
|
});
|
|
118
117
|
}
|
|
118
|
+
refreshToken() {
|
|
119
|
+
return firebase_helper_1.FirebaseHelper.instance.auth().currentUser?.getIdToken(true);
|
|
120
|
+
}
|
|
119
121
|
onAuthStateChange(onChange) {
|
|
120
122
|
firebase_helper_1.FirebaseHelper.instance.auth().onAuthStateChanged(async (credentials) => {
|
|
121
123
|
onChange(credentials ? await this.toUserCredentials(credentials) : undefined);
|
|
@@ -142,13 +144,12 @@ class FirebaseAuth extends entropic_bond_1.AuthService {
|
|
|
142
144
|
return FirebaseAuth.convertCredentials(nativeUserCredential, claims);
|
|
143
145
|
}
|
|
144
146
|
static convertCredentials(nativeUserCredential, claims) {
|
|
145
|
-
var _a, _b, _c, _d;
|
|
146
147
|
return ({
|
|
147
148
|
id: nativeUserCredential.uid,
|
|
148
|
-
email:
|
|
149
|
-
name:
|
|
150
|
-
pictureUrl:
|
|
151
|
-
phoneNumber:
|
|
149
|
+
email: nativeUserCredential.email ?? '',
|
|
150
|
+
name: nativeUserCredential.displayName ?? undefined,
|
|
151
|
+
pictureUrl: nativeUserCredential.photoURL ?? undefined,
|
|
152
|
+
phoneNumber: nativeUserCredential.phoneNumber ?? undefined,
|
|
152
153
|
emailVerified: nativeUserCredential.emailVerified,
|
|
153
154
|
customData: { ...claims },
|
|
154
155
|
lastLogin: Date.now(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"firebase-auth.js","sourceRoot":"","sources":["../../src/auth/firebase-auth.ts"],"names":[],"mappings":";;;AAAA,iDAAiJ;AACjJ,wCAA6T;AAC7T,wDAAmE;AAMnE,MAAM,eAAe,GAAG;IACvB,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI,0BAAmB,EAAE;IAC1C,UAAU,EAAE,GAAG,EAAE,CAAC,IAAI,2BAAoB,EAAE;IAC5C,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,yBAAkB,EAAE;CACxC,CAAA;AAED,MAAa,YAAa,SAAQ,2BAAW;IAC5C,YAAa,QAAyB
|
|
1
|
+
{"version":3,"file":"firebase-auth.js","sourceRoot":"","sources":["../../src/auth/firebase-auth.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,12 +5,11 @@ const functions_1 = require("firebase/functions");
|
|
|
5
5
|
const firebase_helper_1 = require("../firebase-helper");
|
|
6
6
|
class FirebaseCloudFunctions {
|
|
7
7
|
constructor(region, emulator) {
|
|
8
|
-
var _a;
|
|
9
8
|
if (region)
|
|
10
9
|
firebase_helper_1.FirebaseHelper.setRegion(region);
|
|
11
10
|
if (emulator)
|
|
12
11
|
firebase_helper_1.FirebaseHelper.useEmulator(emulator);
|
|
13
|
-
if (
|
|
12
|
+
if (firebase_helper_1.FirebaseHelper.emulator?.emulate) {
|
|
14
13
|
const { host, functionsPort } = firebase_helper_1.FirebaseHelper.emulator;
|
|
15
14
|
(0, functions_1.connectFunctionsEmulator)(firebase_helper_1.FirebaseHelper.instance.functions(), host, functionsPort);
|
|
16
15
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"firebase-cloud-functions.js","sourceRoot":"","sources":["../../src/cloud-functions/firebase-cloud-functions.ts"],"names":[],"mappings":";;;AACA,kDAA4E;AAC5E,wDAAmE;AAEnE,MAAa,sBAAsB;IAClC,YAAa,MAAe,EAAE,QAAkC
|
|
1
|
+
{"version":3,"file":"firebase-cloud-functions.js","sourceRoot":"","sources":["../../src/cloud-functions/firebase-cloud-functions.ts"],"names":[],"mappings":";;;AACA,kDAA4E;AAC5E,wDAAmE;AAEnE,MAAa,sBAAsB;IAClC,YAAa,MAAe,EAAE,QAAkC;QAC/D,IAAK,MAAM;YAAG,gCAAc,CAAC,SAAS,CAAE,MAAM,CAAE,CAAA;QAChD,IAAK,QAAQ;YAAG,gCAAc,CAAC,WAAW,CAAE,QAAQ,CAAE,CAAA;QAEtD,IAAK,gCAAc,CAAC,QAAQ,EAAE,OAAO,EAAG,CAAC;YACxC,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,GAAG,gCAAc,CAAC,QAAQ,CAAA;YACvD,IAAA,oCAAwB,EAAE,gCAAc,CAAC,QAAQ,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,aAAa,CAAE,CAAA;QACrF,CAAC;IAEF,CAAC;IAED,gBAAgB,CAAQ,aAAqB;QAC5C,OAAO,IAAA,yBAAa,EAAO,gCAAc,CAAC,QAAQ,CAAC,SAAS,EAAE,EAAE,aAAa,CAAoC,CAAA;IAClH,CAAC;IAED,KAAK,CAAC,YAAY,CAAQ,IAAyB,EAAE,MAAS;QAC7D,MAAM,GAAG,GAAG,MAAM,IAAI,CAAE,MAAM,CAAS,CAAA;QACvC,OAAO,GAAG,CAAC,IAAI,CAAA;IAChB,CAAC;CACD;AApBD,wDAoBC"}
|
|
@@ -5,19 +5,17 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
5
5
|
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
6
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
7
|
};
|
|
8
|
-
var FirebaseCloudStorage_1;
|
|
9
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
9
|
exports.FirebaseCloudStorage = void 0;
|
|
11
10
|
const entropic_bond_1 = require("entropic-bond");
|
|
12
11
|
const storage_1 = require("firebase/storage");
|
|
13
12
|
const firebase_helper_1 = require("../firebase-helper");
|
|
14
|
-
let FirebaseCloudStorage =
|
|
13
|
+
let FirebaseCloudStorage = class FirebaseCloudStorage extends entropic_bond_1.CloudStorage {
|
|
15
14
|
constructor(emulator) {
|
|
16
|
-
var _a;
|
|
17
15
|
super();
|
|
18
16
|
if (emulator)
|
|
19
17
|
firebase_helper_1.FirebaseHelper.useEmulator(emulator);
|
|
20
|
-
if (
|
|
18
|
+
if (firebase_helper_1.FirebaseHelper.emulator?.emulate) {
|
|
21
19
|
const { host, storagePort } = firebase_helper_1.FirebaseHelper.emulator;
|
|
22
20
|
(0, storage_1.connectStorageEmulator)(firebase_helper_1.FirebaseHelper.instance.storage(), host, storagePort);
|
|
23
21
|
}
|
|
@@ -46,17 +44,14 @@ let FirebaseCloudStorage = exports.FirebaseCloudStorage = FirebaseCloudStorage_1
|
|
|
46
44
|
if (!this._uploadTask)
|
|
47
45
|
throw new Error(`You should call save() before uploadControl()`);
|
|
48
46
|
return {
|
|
49
|
-
cancel: () =>
|
|
50
|
-
pause: () =>
|
|
51
|
-
resume: () =>
|
|
52
|
-
onProgress: (callback) => {
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
}
|
|
58
|
-
});
|
|
59
|
-
}
|
|
47
|
+
cancel: () => this._uploadTask?.cancel(),
|
|
48
|
+
pause: () => this._uploadTask?.pause(),
|
|
49
|
+
resume: () => this._uploadTask?.resume(),
|
|
50
|
+
onProgress: (callback) => this._uploadTask?.on('state_changed', snapShot => {
|
|
51
|
+
if (callback) {
|
|
52
|
+
callback(snapShot.bytesTransferred, snapShot.totalBytes);
|
|
53
|
+
}
|
|
54
|
+
})
|
|
60
55
|
};
|
|
61
56
|
}
|
|
62
57
|
delete(reference) {
|
|
@@ -64,7 +59,8 @@ let FirebaseCloudStorage = exports.FirebaseCloudStorage = FirebaseCloudStorage_1
|
|
|
64
59
|
return (0, storage_1.deleteObject)((0, storage_1.ref)(storage, reference));
|
|
65
60
|
}
|
|
66
61
|
};
|
|
67
|
-
exports.FirebaseCloudStorage = FirebaseCloudStorage
|
|
68
|
-
|
|
62
|
+
exports.FirebaseCloudStorage = FirebaseCloudStorage;
|
|
63
|
+
exports.FirebaseCloudStorage = FirebaseCloudStorage = __decorate([
|
|
64
|
+
(0, entropic_bond_1.registerCloudStorage)('FirebaseCloudStorage', () => new FirebaseCloudStorage())
|
|
69
65
|
], FirebaseCloudStorage);
|
|
70
66
|
//# sourceMappingURL=firebase-cloud-storage.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"firebase-cloud-storage.js","sourceRoot":"","sources":["../../src/cloud-storage/firebase-cloud-storage.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"firebase-cloud-storage.js","sourceRoot":"","sources":["../../src/cloud-storage/firebase-cloud-storage.ts"],"names":[],"mappings":"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"}
|
package/lib/mocks/test-user.js
CHANGED
|
@@ -8,7 +8,7 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
9
|
exports.DerivedUser = exports.TestUser = exports.SubClass = void 0;
|
|
10
10
|
const entropic_bond_1 = require("entropic-bond");
|
|
11
|
-
let SubClass =
|
|
11
|
+
let SubClass = class SubClass extends entropic_bond_1.Persistent {
|
|
12
12
|
set year(value) {
|
|
13
13
|
this._year = value;
|
|
14
14
|
}
|
|
@@ -16,13 +16,14 @@ let SubClass = exports.SubClass = class SubClass extends entropic_bond_1.Persist
|
|
|
16
16
|
return this._year;
|
|
17
17
|
}
|
|
18
18
|
};
|
|
19
|
+
exports.SubClass = SubClass;
|
|
19
20
|
__decorate([
|
|
20
21
|
entropic_bond_1.persistent
|
|
21
22
|
], SubClass.prototype, "_year", void 0);
|
|
22
23
|
exports.SubClass = SubClass = __decorate([
|
|
23
24
|
(0, entropic_bond_1.registerPersistentClass)('SubClass')
|
|
24
25
|
], SubClass);
|
|
25
|
-
let TestUser =
|
|
26
|
+
let TestUser = class TestUser extends entropic_bond_1.Persistent {
|
|
26
27
|
constructor() {
|
|
27
28
|
super(...arguments);
|
|
28
29
|
this._colleagues = [];
|
|
@@ -83,6 +84,7 @@ let TestUser = exports.TestUser = class TestUser extends entropic_bond_1.Persist
|
|
|
83
84
|
return this._colleagues;
|
|
84
85
|
}
|
|
85
86
|
};
|
|
87
|
+
exports.TestUser = TestUser;
|
|
86
88
|
__decorate([
|
|
87
89
|
entropic_bond_1.persistent,
|
|
88
90
|
entropic_bond_1.searchableArray
|
|
@@ -114,7 +116,7 @@ __decorate([
|
|
|
114
116
|
exports.TestUser = TestUser = __decorate([
|
|
115
117
|
(0, entropic_bond_1.registerPersistentClass)('TestUser')
|
|
116
118
|
], TestUser);
|
|
117
|
-
let DerivedUser =
|
|
119
|
+
let DerivedUser = class DerivedUser extends TestUser {
|
|
118
120
|
set salary(value) {
|
|
119
121
|
this._salary = value;
|
|
120
122
|
}
|
|
@@ -122,6 +124,7 @@ let DerivedUser = exports.DerivedUser = class DerivedUser extends TestUser {
|
|
|
122
124
|
return this._salary;
|
|
123
125
|
}
|
|
124
126
|
};
|
|
127
|
+
exports.DerivedUser = DerivedUser;
|
|
125
128
|
__decorate([
|
|
126
129
|
entropic_bond_1.persistent
|
|
127
130
|
], DerivedUser.prototype, "_salary", void 0);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"test-user.js","sourceRoot":"","sources":["../../src/mocks/test-user.ts"],"names":[],"mappings":";;;;;;;;;AAAA,iDAA4I;AAYrI,IAAM,QAAQ,
|
|
1
|
+
{"version":3,"file":"test-user.js","sourceRoot":"","sources":["../../src/mocks/test-user.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,12 +6,11 @@ const entropic_bond_1 = require("entropic-bond");
|
|
|
6
6
|
const firebase_helper_1 = require("../firebase-helper");
|
|
7
7
|
class FirebaseDatasource extends entropic_bond_1.DataSource {
|
|
8
8
|
constructor(emulator) {
|
|
9
|
-
var _a;
|
|
10
9
|
super();
|
|
11
10
|
this._lastLimit = 0;
|
|
12
11
|
if (emulator)
|
|
13
12
|
firebase_helper_1.FirebaseHelper.useEmulator(emulator);
|
|
14
|
-
if (
|
|
13
|
+
if (firebase_helper_1.FirebaseHelper.emulator?.emulate) {
|
|
15
14
|
const { host, firestorePort } = firebase_helper_1.FirebaseHelper.emulator;
|
|
16
15
|
(0, firestore_1.connectFirestoreEmulator)(firebase_helper_1.FirebaseHelper.instance.firestore(), host, firestorePort);
|
|
17
16
|
}
|
|
@@ -33,7 +32,7 @@ class FirebaseDatasource extends entropic_bond_1.DataSource {
|
|
|
33
32
|
const db = firebase_helper_1.FirebaseHelper.instance.firestore();
|
|
34
33
|
const batch = (0, firestore_1.writeBatch)(db);
|
|
35
34
|
Object.entries(collections).forEach(([collectionName, collection]) => {
|
|
36
|
-
collection
|
|
35
|
+
collection?.forEach(document => {
|
|
37
36
|
const ref = (0, firestore_1.doc)(db, collectionName, document.id);
|
|
38
37
|
batch.set(ref, document);
|
|
39
38
|
});
|
|
@@ -65,7 +64,6 @@ class FirebaseDatasource extends entropic_bond_1.DataSource {
|
|
|
65
64
|
// prev( limit?: number ): Promise< DocumentObject[] > {
|
|
66
65
|
// }
|
|
67
66
|
queryObjectToQueryConstraints(queryObject, collectionName) {
|
|
68
|
-
var _a;
|
|
69
67
|
const db = firebase_helper_1.FirebaseHelper.instance.firestore();
|
|
70
68
|
const andConstraints = [];
|
|
71
69
|
const orConstraints = [];
|
|
@@ -77,7 +75,7 @@ class FirebaseDatasource extends entropic_bond_1.DataSource {
|
|
|
77
75
|
else
|
|
78
76
|
andConstraints.push((0, firestore_1.where)(operation.property, operator, operation.value));
|
|
79
77
|
});
|
|
80
|
-
if (
|
|
78
|
+
if (queryObject.sort?.propertyName) {
|
|
81
79
|
nonFilterConstraints.push((0, firestore_1.orderBy)(queryObject.sort.propertyName, queryObject.sort.order));
|
|
82
80
|
}
|
|
83
81
|
this._lastConstraints = {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"firebase-datasource.js","sourceRoot":"","sources":["../../src/store/firebase-datasource.ts"],"names":[],"mappings":";;;AAAA,kDAA8S;AAC9S,iDAAmG;AACnG,wDAAkF;AAQlF,MAAa,kBAAmB,SAAQ,0BAAU;IACjD,YAAa,QAAyB
|
|
1
|
+
{"version":3,"file":"firebase-datasource.js","sourceRoot":"","sources":["../../src/store/firebase-datasource.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@entropic-bond/firebase",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.12.1",
|
|
4
|
+
"type": "module",
|
|
4
5
|
"publishConfig": {
|
|
5
6
|
"access": "public",
|
|
6
7
|
"branches": [
|
|
@@ -23,7 +24,7 @@
|
|
|
23
24
|
"lib"
|
|
24
25
|
],
|
|
25
26
|
"scripts": {
|
|
26
|
-
"test": "npm run install-functions-dependencies && firebase emulators:exec --project demo-test
|
|
27
|
+
"test": "npm run install-functions-dependencies && firebase emulators:exec --project demo-test vitest",
|
|
27
28
|
"build": "npm run build-cjs",
|
|
28
29
|
"prepare": "npm run build",
|
|
29
30
|
"build-ts": "cp -r ./src/ ./lib",
|
|
@@ -48,18 +49,16 @@
|
|
|
48
49
|
"devDependencies": {
|
|
49
50
|
"@semantic-release/changelog": "^6.0.3",
|
|
50
51
|
"@semantic-release/git": "^10.0.1",
|
|
51
|
-
"@types/
|
|
52
|
-
"@types/node": "^20.3.1",
|
|
52
|
+
"@types/node": "^20.11.16",
|
|
53
53
|
"git-branch-is": "^4.0.0",
|
|
54
|
-
"husky": "^
|
|
55
|
-
"
|
|
56
|
-
"
|
|
57
|
-
"
|
|
58
|
-
"typescript": "^5.1.3",
|
|
54
|
+
"husky": "^9.0.10",
|
|
55
|
+
"semantic-release": "^23.0.0",
|
|
56
|
+
"typescript": "^5.3.3",
|
|
57
|
+
"vitest": "^1.2.2",
|
|
59
58
|
"xhr2": "^0.2.1"
|
|
60
59
|
},
|
|
61
60
|
"dependencies": {
|
|
62
|
-
"entropic-bond": "^1.
|
|
63
|
-
"firebase": "^
|
|
61
|
+
"entropic-bond": "^1.49.0",
|
|
62
|
+
"firebase": "^10.8.0"
|
|
64
63
|
}
|
|
65
64
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
// NOTE: Firebase auth emulator requires a modification of the code to test which
|
|
4
|
-
// violates testing best practices. Therefore, this test is disabled.
|
|
5
|
-
describe('Firebase Auth', () => {
|
|
6
|
-
it('should pass', () => {
|
|
7
|
-
expect(true).toBe(true);
|
|
8
|
-
});
|
|
9
|
-
// let authChangeSpy = jest.fn()
|
|
10
|
-
// FirebaseHelper.setFirebaseConfig({
|
|
11
|
-
// projectId: "demo-test",
|
|
12
|
-
// })
|
|
13
|
-
// FirebaseHelper.useEmulator({ authPort: 9099 })
|
|
14
|
-
// beforeEach(()=>{
|
|
15
|
-
// Auth.registerAuthService( new FirebaseAuth() )
|
|
16
|
-
// Auth.instance.onAuthStateChange( authChangeSpy )
|
|
17
|
-
// })
|
|
18
|
-
// it( 'should emulate sign-up', async ()=>{
|
|
19
|
-
// const userCredential = await Auth.instance.signUp({
|
|
20
|
-
// authProvider: 'google',
|
|
21
|
-
// email: 'test@test.com',
|
|
22
|
-
// password: 'password'
|
|
23
|
-
// })
|
|
24
|
-
// expect( userCredential.email ).toEqual( 'test@test.com' )
|
|
25
|
-
// expect( authChangeSpy ).toHaveBeenCalledWith( userCredential )
|
|
26
|
-
// })
|
|
27
|
-
// it( 'should emulate failed sign-up', async ()=>{
|
|
28
|
-
// try {
|
|
29
|
-
// var userCredential = await Auth.instance.signUp({
|
|
30
|
-
// authProvider: 'fail',
|
|
31
|
-
// email: 'test@test.com',
|
|
32
|
-
// password: 'password'
|
|
33
|
-
// })
|
|
34
|
-
// }
|
|
35
|
-
// catch {}
|
|
36
|
-
// expect( userCredential ).toBeUndefined()
|
|
37
|
-
// expect( authChangeSpy ).toHaveBeenCalledWith( undefined )
|
|
38
|
-
// })
|
|
39
|
-
// it( 'should login with fake registered user', async ()=>{
|
|
40
|
-
// const userCredentials = await Auth.instance.login({
|
|
41
|
-
// email: 'fakeUser@test.com',
|
|
42
|
-
// password: 'password',
|
|
43
|
-
// authProvider: 'google'
|
|
44
|
-
// })
|
|
45
|
-
// expect( userCredentials ).toEqual( 'fakeUseCredentials' )
|
|
46
|
-
// expect( authChangeSpy ).toHaveBeenCalledWith( 'fakeUseCredentials' )
|
|
47
|
-
// })
|
|
48
|
-
// it( 'should fail login with email auth provider if does not match fake user credentials', async ()=>{
|
|
49
|
-
// try {
|
|
50
|
-
// var userCredentials = await Auth.instance.login({
|
|
51
|
-
// email: 'test@test.com',
|
|
52
|
-
// password: 'password',
|
|
53
|
-
// authProvider: 'email'
|
|
54
|
-
// })
|
|
55
|
-
// } catch {}
|
|
56
|
-
// expect( userCredentials ).toEqual( undefined )
|
|
57
|
-
// expect( authChangeSpy ).toHaveBeenCalledWith( undefined )
|
|
58
|
-
// })
|
|
59
|
-
// it( 'should NOT fail login with non email auth provider even if does not match fake user credentials', async ()=>{
|
|
60
|
-
// const userCredentials = await Auth.instance.login({
|
|
61
|
-
// email: 'test@test.com',
|
|
62
|
-
// password: 'password',
|
|
63
|
-
// authProvider: 'google'
|
|
64
|
-
// })
|
|
65
|
-
// expect( userCredentials.email ).toEqual( 'test@test.com' )
|
|
66
|
-
// expect( authChangeSpy ).toHaveBeenCalledWith( undefined )
|
|
67
|
-
// })
|
|
68
|
-
// it( 'should logout', async ()=>{
|
|
69
|
-
// await Auth.instance.logout()
|
|
70
|
-
// expect( authChangeSpy ).toHaveBeenCalledWith( undefined )
|
|
71
|
-
// })
|
|
72
|
-
});
|
|
73
|
-
//# sourceMappingURL=firebase-auth.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"firebase-auth.spec.js","sourceRoot":"","sources":["../../src/auth/firebase-auth.spec.ts"],"names":[],"mappings":";;AAIA,iFAAiF;AACjF,2EAA2E;AAE3E,QAAQ,CAAE,eAAe,EAAE,GAAE,EAAE;IAC9B,EAAE,CAAE,aAAa,EAAE,GAAE,EAAE;QACtB,MAAM,CAAE,IAAI,CAAE,CAAC,IAAI,CAAE,IAAI,CAAE,CAAA;IAC5B,CAAC,CAAC,CAAA;IAEH,iCAAiC;IACjC,sCAAsC;IACtC,4BAA4B;IAC5B,MAAM;IACN,kDAAkD;IAElD,oBAAoB;IACpB,mDAAmD;IACnD,sDAAsD;IACtD,MAAM;IAEN,6CAA6C;IAC7C,wDAAwD;IACxD,6BAA6B;IAC7B,6BAA6B;IAC7B,0BAA0B;IAC1B,OAAO;IAEP,8DAA8D;IAC9D,mEAAmE;IACnE,MAAM;IAEN,oDAAoD;IACpD,UAAU;IACV,uDAAuD;IACvD,4BAA4B;IAC5B,8BAA8B;IAC9B,2BAA2B;IAC3B,QAAQ;IACR,MAAM;IACN,aAAa;IAEb,6CAA6C;IAC7C,8DAA8D;IAC9D,MAAM;IAEN,6DAA6D;IAC7D,wDAAwD;IACxD,iCAAiC;IACjC,2BAA2B;IAC3B,4BAA4B;IAC5B,OAAO;IAEP,8DAA8D;IAC9D,yEAAyE;IACzE,MAAM;IAEN,yGAAyG;IACzG,UAAU;IACV,uDAAuD;IACvD,8BAA8B;IAC9B,4BAA4B;IAC5B,4BAA4B;IAC5B,QAAQ;IACR,eAAe;IAEf,mDAAmD;IACnD,8DAA8D;IAC9D,MAAM;IAEN,sHAAsH;IACtH,wDAAwD;IACxD,6BAA6B;IAC7B,2BAA2B;IAC3B,4BAA4B;IAC5B,OAAO;IAEP,+DAA+D;IAC/D,8DAA8D;IAC9D,MAAM;IAEN,oCAAoC;IACpC,iCAAiC;IAEjC,8DAA8D;IAC9D,MAAM;AAEN,CAAC,CAAC,CAAA"}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
-
exports.ParamWrapper = void 0;
|
|
10
|
-
const entropic_bond_1 = require("entropic-bond");
|
|
11
|
-
const firebase_helper_1 = require("../firebase-helper");
|
|
12
|
-
const firebase_cloud_functions_1 = require("./firebase-cloud-functions");
|
|
13
|
-
let ParamWrapper = exports.ParamWrapper = class ParamWrapper extends entropic_bond_1.Persistent {
|
|
14
|
-
constructor(a, b) {
|
|
15
|
-
super();
|
|
16
|
-
this._a = a;
|
|
17
|
-
this._b = b;
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
__decorate([
|
|
21
|
-
entropic_bond_1.persistent
|
|
22
|
-
], ParamWrapper.prototype, "_a", void 0);
|
|
23
|
-
__decorate([
|
|
24
|
-
entropic_bond_1.persistent
|
|
25
|
-
], ParamWrapper.prototype, "_b", void 0);
|
|
26
|
-
exports.ParamWrapper = ParamWrapper = __decorate([
|
|
27
|
-
(0, entropic_bond_1.registerPersistentClass)('ParamWrapper')
|
|
28
|
-
], ParamWrapper);
|
|
29
|
-
describe('Cloud functions', () => {
|
|
30
|
-
beforeEach(() => {
|
|
31
|
-
firebase_helper_1.FirebaseHelper.setFirebaseConfig({
|
|
32
|
-
projectId: 'demo-test',
|
|
33
|
-
storageBucket: 'default-bucket'
|
|
34
|
-
});
|
|
35
|
-
firebase_helper_1.FirebaseHelper.useEmulator();
|
|
36
|
-
entropic_bond_1.CloudFunctions.useCloudFunctionsService(new firebase_cloud_functions_1.FirebaseCloudFunctions('europe-west1', { emulate: true }));
|
|
37
|
-
});
|
|
38
|
-
it('should call cloud functions with plain types', async () => {
|
|
39
|
-
const testCallablePlain = entropic_bond_1.CloudFunctions.instance.getFunction('testCallablePlain');
|
|
40
|
-
const result = await testCallablePlain('Hello');
|
|
41
|
-
expect(result).toBe(5);
|
|
42
|
-
});
|
|
43
|
-
it('should call cloud function for Persistent', async () => {
|
|
44
|
-
const testCallablePersistent = entropic_bond_1.CloudFunctions.instance.getFunction('testCallablePersistent');
|
|
45
|
-
const paramWrapper = new ParamWrapper('test', 30);
|
|
46
|
-
const a = paramWrapper.toObject();
|
|
47
|
-
const result = await testCallablePersistent(paramWrapper);
|
|
48
|
-
expect(result._a).toEqual('test');
|
|
49
|
-
expect(result._b).toEqual(30);
|
|
50
|
-
});
|
|
51
|
-
});
|
|
52
|
-
//# sourceMappingURL=firebase-cloud-functions.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"firebase-cloud-functions.spec.js","sourceRoot":"","sources":["../../src/cloud-functions/firebase-cloud-functions.spec.ts"],"names":[],"mappings":";;;;;;;;;AAAA,iDAA+F;AAC/F,wDAAmD;AACnD,yEAAmE;AAG5D,IAAM,YAAY,0BAAlB,MAAM,YAAa,SAAQ,0BAAU;IAC3C,YAAa,CAAU,EAAE,CAAU;QAClC,KAAK,EAAE,CAAA;QACP,IAAI,CAAC,EAAE,GAAG,CAAC,CAAA;QACX,IAAI,CAAC,EAAE,GAAG,CAAC,CAAA;IACZ,CAAC;CAGD,CAAA;AAFY;IAAX,0BAAU;wCAAuB;AACtB;IAAX,0BAAU;wCAAuB;uBAPtB,YAAY;IADxB,IAAA,uCAAuB,EAAE,cAAc,CAAE;GAC7B,YAAY,CAQxB;AAED,QAAQ,CAAE,iBAAiB,EAAE,GAAE,EAAE;IAEhC,UAAU,CAAC,GAAE,EAAE;QACd,gCAAc,CAAC,iBAAiB,CAAC;YAChC,SAAS,EAAE,WAAW;YACtB,aAAa,EAAE,gBAAgB;SAC/B,CAAC,CAAA;QAEF,gCAAc,CAAC,WAAW,EAAE,CAAA;QAC5B,8BAAc,CAAC,wBAAwB,CACtC,IAAI,iDAAsB,CAAE,cAAc,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAC9D,CAAA;IACF,CAAC,CAAC,CAAA;IAEF,EAAE,CAAE,8CAA8C,EAAE,KAAK,IAAG,EAAE;QAC7D,MAAM,iBAAiB,GAAG,8BAAc,CAAC,QAAQ,CAAC,WAAW,CAAkB,mBAAmB,CAAE,CAAA;QACpG,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAE,OAAO,CAAE,CAAA;QAEjD,MAAM,CAAE,MAAM,CAAE,CAAC,IAAI,CAAE,CAAC,CAAE,CAAA;IAC3B,CAAC,CAAC,CAAA;IAEF,EAAE,CAAE,2CAA2C,EAAE,KAAK,IAAG,EAAE;QAC1D,MAAM,sBAAsB,GAAG,8BAAc,CAAC,QAAQ,CAAC,WAAW,CAA8B,wBAAwB,CAAE,CAAA;QAC1H,MAAM,YAAY,GAAG,IAAI,YAAY,CAAE,MAAM,EAAE,EAAE,CAAE,CAAA;QAEnD,MAAM,CAAC,GAAG,YAAY,CAAC,QAAQ,EAAE,CAAA;QAEjC,MAAM,MAAM,GAAG,MAAM,sBAAsB,CAAE,YAAY,CAAE,CAAA;QAC3D,MAAM,CAAE,MAAM,CAAC,EAAE,CAAE,CAAC,OAAO,CAAE,MAAM,CAAE,CAAA;QACrC,MAAM,CAAE,MAAM,CAAC,EAAE,CAAE,CAAC,OAAO,CAAE,EAAE,CAAE,CAAA;IAClC,CAAC,CAAC,CAAA;AACH,CAAC,CAAC,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,112 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
-
/**
|
|
10
|
-
* @jest-environment node
|
|
11
|
-
*/
|
|
12
|
-
global.XMLHttpRequest = require('xhr2');
|
|
13
|
-
const firebase_cloud_storage_1 = require("./firebase-cloud-storage");
|
|
14
|
-
const firebase_helper_1 = require("../firebase-helper");
|
|
15
|
-
const firebase_datasource_1 = require("../store/firebase-datasource");
|
|
16
|
-
const entropic_bond_1 = require("entropic-bond");
|
|
17
|
-
// Note about tests leaking. I've been checking and looks like firebase.storage
|
|
18
|
-
// methods are the responsible for the test leaking (as firebase v. 8.6.3).
|
|
19
|
-
class File {
|
|
20
|
-
}
|
|
21
|
-
global['File'] = File;
|
|
22
|
-
let Test = class Test extends entropic_bond_1.Persistent {
|
|
23
|
-
constructor() {
|
|
24
|
-
super(...arguments);
|
|
25
|
-
this._file = new entropic_bond_1.StoredFile();
|
|
26
|
-
}
|
|
27
|
-
get file() {
|
|
28
|
-
return this._file;
|
|
29
|
-
}
|
|
30
|
-
};
|
|
31
|
-
__decorate([
|
|
32
|
-
entropic_bond_1.persistent
|
|
33
|
-
], Test.prototype, "_file", void 0);
|
|
34
|
-
Test = __decorate([
|
|
35
|
-
(0, entropic_bond_1.registerPersistentClass)('Test')
|
|
36
|
-
], Test);
|
|
37
|
-
describe('Firebase Cloud Storage', () => {
|
|
38
|
-
const blobData1 = new Uint8Array([0x48, 0x65, 0x6c, 0x6c, 0x6f, 0x2c, 0x20, 0x77, 0x6f, 0x72, 0x6c, 0x64, 0x21]);
|
|
39
|
-
const blobData2 = new Uint8Array([0x6c, 0x6c, 0x6f, 0x2c, 0x48, 0x65, 0x20, 0x77, 0x6f, 0x72, 0x6c, 0x64, 0x21]);
|
|
40
|
-
let file;
|
|
41
|
-
firebase_helper_1.FirebaseHelper.setFirebaseConfig({
|
|
42
|
-
projectId: 'demo-test',
|
|
43
|
-
storageBucket: 'default-bucket'
|
|
44
|
-
});
|
|
45
|
-
firebase_helper_1.FirebaseHelper.useEmulator({ firestorePort: 9080 });
|
|
46
|
-
entropic_bond_1.Store.useDataSource(new firebase_datasource_1.FirebaseDatasource());
|
|
47
|
-
beforeEach(() => {
|
|
48
|
-
entropic_bond_1.CloudStorage.useCloudStorage(new firebase_cloud_storage_1.FirebaseCloudStorage());
|
|
49
|
-
file = new entropic_bond_1.StoredFile();
|
|
50
|
-
});
|
|
51
|
-
it('should save and get a url', async () => {
|
|
52
|
-
await file.save({ data: blobData1 });
|
|
53
|
-
expect(file.url).toContain(file.id);
|
|
54
|
-
});
|
|
55
|
-
it('should report metadata', async () => {
|
|
56
|
-
await file.save({ data: blobData1, fileName: 'test.dat' });
|
|
57
|
-
expect(file.originalFileName).toEqual('test.dat');
|
|
58
|
-
expect(file.provider.className).toEqual('FirebaseCloudStorage');
|
|
59
|
-
});
|
|
60
|
-
it('should delete file', async () => {
|
|
61
|
-
await file.save({ data: blobData1 });
|
|
62
|
-
await file.delete();
|
|
63
|
-
expect(file.url).not.toBeDefined();
|
|
64
|
-
});
|
|
65
|
-
it('should overwrite file on subsequent writes', async () => {
|
|
66
|
-
var _a;
|
|
67
|
-
await file.save({ data: blobData1 });
|
|
68
|
-
const firstUrl = file.url;
|
|
69
|
-
let resp = await fetch(file.url);
|
|
70
|
-
expect(await resp.text()).toEqual('Hello, world!');
|
|
71
|
-
await file.save({ data: blobData2 });
|
|
72
|
-
resp = await fetch(file.url);
|
|
73
|
-
expect((_a = file.url) === null || _a === void 0 ? void 0 : _a.slice(0, file.url.indexOf('token'))).toEqual(firstUrl === null || firstUrl === void 0 ? void 0 : firstUrl.slice(0, firstUrl.indexOf('token')));
|
|
74
|
-
expect(await resp.text()).toEqual('llo,He world!');
|
|
75
|
-
});
|
|
76
|
-
it('should trigger events', done => {
|
|
77
|
-
const cb = jest.fn();
|
|
78
|
-
file.save({ data: blobData1 }).then(() => {
|
|
79
|
-
expect(cb).toHaveBeenCalledTimes(2);
|
|
80
|
-
done();
|
|
81
|
-
});
|
|
82
|
-
file.uploadControl().onProgress(cb);
|
|
83
|
-
});
|
|
84
|
-
describe('Streaming', () => {
|
|
85
|
-
let model;
|
|
86
|
-
let testObj;
|
|
87
|
-
beforeEach(() => {
|
|
88
|
-
testObj = new Test();
|
|
89
|
-
model = entropic_bond_1.Store.getModel(testObj);
|
|
90
|
-
});
|
|
91
|
-
it('should load object with StoredFile', async () => {
|
|
92
|
-
await testObj.file.save({ data: blobData1, fileName: 'test.dat' });
|
|
93
|
-
await model.save(testObj);
|
|
94
|
-
const newTestObj = await model.findById(testObj.id);
|
|
95
|
-
expect(newTestObj === null || newTestObj === void 0 ? void 0 : newTestObj.file).toBeInstanceOf(entropic_bond_1.StoredFile);
|
|
96
|
-
expect(newTestObj === null || newTestObj === void 0 ? void 0 : newTestObj.file.url).toContain(testObj.file.id);
|
|
97
|
-
});
|
|
98
|
-
it('should replace file on save after load', async () => {
|
|
99
|
-
const deleteSpy = jest.spyOn(testObj.file, 'delete');
|
|
100
|
-
await testObj.file.save({ data: blobData1, fileName: 'test.dat' });
|
|
101
|
-
await model.save(testObj);
|
|
102
|
-
const newTestObj = await model.findById(testObj.id);
|
|
103
|
-
expect(newTestObj === null || newTestObj === void 0 ? void 0 : newTestObj.file).toBeInstanceOf(entropic_bond_1.StoredFile);
|
|
104
|
-
expect(newTestObj === null || newTestObj === void 0 ? void 0 : newTestObj.file.url).toContain(testObj.file.id);
|
|
105
|
-
expect(deleteSpy).not.toHaveBeenCalled();
|
|
106
|
-
testObj.file.setDataToStore(blobData2);
|
|
107
|
-
await testObj.file.save();
|
|
108
|
-
expect(deleteSpy).toHaveBeenCalled();
|
|
109
|
-
});
|
|
110
|
-
});
|
|
111
|
-
});
|
|
112
|
-
//# sourceMappingURL=firebase-cloud-storage.spec.js.map
|