From 2142155159440e979b885d63136cda26a5918484 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 27 May 2020 00:05:35 +0300 Subject: [PATCH 01/34] feat(firebase-auth): setup firebase package --- package-lock.json | 614 ++++++++++++++++-- package.json | 2 + .../firebase-auth/firebase-auth.module.ts | 17 + src/framework/firebase-auth/package.json | 34 + src/framework/firebase-auth/public_api.ts | 9 + .../firebase-password-strategy.options.ts | 52 ++ .../strategies/firebase-password.strategy.ts | 91 +++ 7 files changed, 776 insertions(+), 43 deletions(-) create mode 100644 src/framework/firebase-auth/firebase-auth.module.ts create mode 100644 src/framework/firebase-auth/package.json create mode 100644 src/framework/firebase-auth/public_api.ts create mode 100644 src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts create mode 100644 src/framework/firebase-auth/strategies/firebase-password.strategy.ts diff --git a/package-lock.json b/package-lock.json index 3f1c075cd8..3273823321 100644 --- a/package-lock.json +++ b/package-lock.json @@ -937,6 +937,11 @@ "resolved": "https://registry.npmjs.org/@angular/core/-/core-9.0.4.tgz", "integrity": "sha512-6RqQb1GO2uglSlgiGbxhvy8plztZtABCWLRn0X+T1PnrxoqgxqA5WkKJjGxao+1M/ECW1V0fw4Xy7DE6KvAJwQ==" }, + "@angular/fire": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/@angular/fire/-/fire-6.0.0.tgz", + "integrity": "sha512-zWhaJaZPtfJKiNSb1I3WqqvopW0fN3S61w4PjPdsm5WME+9M9alP0zpRVclpbCU26LpBSLhrRrSLyn3ROlAOIw==" + }, "@angular/forms": { "version": "9.0.4", "resolved": "https://registry.npmjs.org/@angular/forms/-/forms-9.0.4.tgz", @@ -2187,6 +2192,348 @@ } } }, + "@firebase/analytics": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@firebase/analytics/-/analytics-0.3.5.tgz", + "integrity": "sha512-p+h1s9A8EjGWfjAObu8ei46JoN2Ogbtl1RzqW7HjcPuclOIOmPTXKEXXCEXgO79OLxnzzezVeBtHPSx6r6gxJA==", + "requires": { + "@firebase/analytics-types": "0.3.1", + "@firebase/component": "0.1.12", + "@firebase/installations": "0.4.10", + "@firebase/logger": "0.2.4", + "@firebase/util": "0.2.47", + "tslib": "1.11.1" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/analytics-types": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/@firebase/analytics-types/-/analytics-types-0.3.1.tgz", + "integrity": "sha512-63vVJ5NIBh/JF8l9LuPrQYSzFimk7zYHySQB4Dk9rVdJ8kV/vGQoVTvRu1UW05sEc2Ug5PqtEChtTHU+9hvPcA==" + }, + "@firebase/app": { + "version": "0.6.4", + "resolved": "https://registry.npmjs.org/@firebase/app/-/app-0.6.4.tgz", + "integrity": "sha512-E1Zw6yeZYdYYFurMnklKPvE+q/xleHXs7bmcVgyhgAEg3Gv6/qXI4+4GdWh+iF7wmQ3Liesh51xqfdpvHBwAMQ==", + "requires": { + "@firebase/app-types": "0.6.1", + "@firebase/component": "0.1.12", + "@firebase/logger": "0.2.4", + "@firebase/util": "0.2.47", + "dom-storage": "2.1.0", + "tslib": "1.11.1", + "xmlhttprequest": "1.8.0" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/app-types": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/@firebase/app-types/-/app-types-0.6.1.tgz", + "integrity": "sha512-L/ZnJRAq7F++utfuoTKX4CLBG5YR7tFO3PLzG1/oXXKEezJ0kRL3CMRoueBEmTCzVb/6SIs2Qlaw++uDgi5Xyg==" + }, + "@firebase/auth": { + "version": "0.14.6", + "resolved": "https://registry.npmjs.org/@firebase/auth/-/auth-0.14.6.tgz", + "integrity": "sha512-7gaEUWhUubWBGfOXAZvpTpJqBJT9KyG83RXC6VnjSQIfNUaarHZ485WkzERil43A6KvIl+f4kHxfZShE6ZCK3A==", + "requires": { + "@firebase/auth-types": "0.10.1" + } + }, + "@firebase/auth-interop-types": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/@firebase/auth-interop-types/-/auth-interop-types-0.1.5.tgz", + "integrity": "sha512-88h74TMQ6wXChPA6h9Q3E1Jg6TkTHep2+k63OWg3s0ozyGVMeY+TTOti7PFPzq5RhszQPQOoCi59es4MaRvgCw==" + }, + "@firebase/auth-types": { + "version": "0.10.1", + "resolved": "https://registry.npmjs.org/@firebase/auth-types/-/auth-types-0.10.1.tgz", + "integrity": "sha512-/+gBHb1O9x/YlG7inXfxff/6X3BPZt4zgBv4kql6HEmdzNQCodIRlEYnI+/da+lN+dha7PjaFH7C7ewMmfV7rw==" + }, + "@firebase/component": { + "version": "0.1.12", + "resolved": "https://registry.npmjs.org/@firebase/component/-/component-0.1.12.tgz", + "integrity": "sha512-03w800MxR/EW1m7N0Q46WNcngwdDIHDWpFPHTdbZEI6U/HuLks5RJQlBxWqb1P73nYPkN8YP3U8gTdqrDpqY3Q==", + "requires": { + "@firebase/util": "0.2.47", + "tslib": "1.11.1" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/database": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/@firebase/database/-/database-0.6.3.tgz", + "integrity": "sha512-gHoCISHQVLoq+rGu+PorYxMkhsjhXov3ocBxz/0uVdznNhrbKkAZaEKF+dIAsUPDlwSYeZuwWuik7xcV3DtRaw==", + "requires": { + "@firebase/auth-interop-types": "0.1.5", + "@firebase/component": "0.1.12", + "@firebase/database-types": "0.5.1", + "@firebase/logger": "0.2.4", + "@firebase/util": "0.2.47", + "faye-websocket": "0.11.3", + "tslib": "1.11.1" + }, + "dependencies": { + "faye-websocket": { + "version": "0.11.3", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.3.tgz", + "integrity": "sha512-D2y4bovYpzziGgbHYtGCMjlJM36vAl/y+xUyn1C+FVx8szd1E+86KwVw6XvYSzOP8iMpm1X0I4xJD+QtUb36OA==", + "requires": { + "websocket-driver": ">=0.5.1" + } + }, + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/database-types": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/@firebase/database-types/-/database-types-0.5.1.tgz", + "integrity": "sha512-onQxom1ZBYBJ648w/VNRzUewovEDAH7lvnrrpCd69ukkyrMk6rGEO/PQ9BcNEbhlNtukpsqRS0oNOFlHs0FaSA==", + "requires": { + "@firebase/app-types": "0.6.1" + } + }, + "@firebase/firestore": { + "version": "1.14.5", + "resolved": "https://registry.npmjs.org/@firebase/firestore/-/firestore-1.14.5.tgz", + "integrity": "sha512-BZD3RqlAEnq15i8Y53VUFsuWkbujslGaQIcuEnt6bOENzlKiLBwESmt/uGKRIsdQjc1krG2qdoPmaSMqULR0dA==", + "requires": { + "@firebase/component": "0.1.12", + "@firebase/firestore-types": "1.10.2", + "@firebase/logger": "0.2.4", + "@firebase/util": "0.2.47", + "@firebase/webchannel-wrapper": "0.2.41", + "@grpc/grpc-js": "0.8.1", + "@grpc/proto-loader": "^0.5.0", + "tslib": "1.11.1" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/firestore-types": { + "version": "1.10.2", + "resolved": "https://registry.npmjs.org/@firebase/firestore-types/-/firestore-types-1.10.2.tgz", + "integrity": "sha512-T1GttZezQ+gUpdDgLeLOvgS3KMeeIuodQ+JBBEd6M11zdilfTHsEHhmli15c6V3g/PfuFzyKDKExe05lPuYe4w==" + }, + "@firebase/functions": { + "version": "0.4.44", + "resolved": "https://registry.npmjs.org/@firebase/functions/-/functions-0.4.44.tgz", + "integrity": "sha512-Nbw+V/jYqfgq7wscsSDidqIzx8TrnmA2wRD1auCFNmf+gSJg8o+gNyCDdNHZI407jvrZcxp3nG1eMbqwmmnp7Q==", + "requires": { + "@firebase/component": "0.1.12", + "@firebase/functions-types": "0.3.17", + "@firebase/messaging-types": "0.4.5", + "isomorphic-fetch": "2.2.1", + "tslib": "1.11.1" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/functions-types": { + "version": "0.3.17", + "resolved": "https://registry.npmjs.org/@firebase/functions-types/-/functions-types-0.3.17.tgz", + "integrity": "sha512-DGR4i3VI55KnYk4IxrIw7+VG7Q3gA65azHnZxo98Il8IvYLr2UTBlSh72dTLlDf25NW51HqvJgYJDKvSaAeyHQ==" + }, + "@firebase/installations": { + "version": "0.4.10", + "resolved": "https://registry.npmjs.org/@firebase/installations/-/installations-0.4.10.tgz", + "integrity": "sha512-Nf7VK9++0eQzjdvBkBNNaOdxPjFiKD0EllLCIQycHozF97BmuFUqb2Ik5L2JaWspWg7vxLNacLHvW48nPGx4Zw==", + "requires": { + "@firebase/component": "0.1.12", + "@firebase/installations-types": "0.3.4", + "@firebase/util": "0.2.47", + "idb": "3.0.2", + "tslib": "1.11.1" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/installations-types": { + "version": "0.3.4", + "resolved": "https://registry.npmjs.org/@firebase/installations-types/-/installations-types-0.3.4.tgz", + "integrity": "sha512-RfePJFovmdIXb6rYwtngyxuEcWnOrzdZd9m7xAW0gRxDIjBT20n3BOhjpmgRWXo/DAxRmS7bRjWAyTHY9cqN7Q==" + }, + "@firebase/logger": { + "version": "0.2.4", + "resolved": "https://registry.npmjs.org/@firebase/logger/-/logger-0.2.4.tgz", + "integrity": "sha512-akHkOU7izYB1okp/B5sxClGjjw6KvZdSHyjNM5pKd67Zg5W6PsbkI/GFNv21+y6LkUkJwDRbdeDgJoYXWT3mMA==" + }, + "@firebase/messaging": { + "version": "0.6.16", + "resolved": "https://registry.npmjs.org/@firebase/messaging/-/messaging-0.6.16.tgz", + "integrity": "sha512-TAPISK5y3xbxUw81HxLDP6YPsRryU6Nl8Z7AjNnem13BoN9LJ2/wCi9RDMfPnQhAn0h0N+mpxy/GB+0IlEARlg==", + "requires": { + "@firebase/component": "0.1.12", + "@firebase/installations": "0.4.10", + "@firebase/messaging-types": "0.4.5", + "@firebase/util": "0.2.47", + "idb": "3.0.2", + "tslib": "1.11.1" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/messaging-types": { + "version": "0.4.5", + "resolved": "https://registry.npmjs.org/@firebase/messaging-types/-/messaging-types-0.4.5.tgz", + "integrity": "sha512-sux4fgqr/0KyIxqzHlatI04Ajs5rc3WM+WmtCpxrKP1E5Bke8xu/0M+2oy4lK/sQ7nov9z15n3iltAHCgTRU3Q==" + }, + "@firebase/performance": { + "version": "0.3.4", + "resolved": "https://registry.npmjs.org/@firebase/performance/-/performance-0.3.4.tgz", + "integrity": "sha512-VDoqJSB+2RuXlyyP7oSvBPEmoznG84HmEtb8DQWsAHeVkf+qlec1OTZR8IjktlIv+8Pg8MMuYoB0crx5g7xU5A==", + "requires": { + "@firebase/component": "0.1.12", + "@firebase/installations": "0.4.10", + "@firebase/logger": "0.2.4", + "@firebase/performance-types": "0.0.13", + "@firebase/util": "0.2.47", + "tslib": "1.11.1" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/performance-types": { + "version": "0.0.13", + "resolved": "https://registry.npmjs.org/@firebase/performance-types/-/performance-types-0.0.13.tgz", + "integrity": "sha512-6fZfIGjQpwo9S5OzMpPyqgYAUZcFzZxHFqOyNtorDIgNXq33nlldTL/vtaUZA8iT9TT5cJlCrF/jthKU7X21EA==" + }, + "@firebase/polyfill": { + "version": "0.3.36", + "resolved": "https://registry.npmjs.org/@firebase/polyfill/-/polyfill-0.3.36.tgz", + "integrity": "sha512-zMM9oSJgY6cT2jx3Ce9LYqb0eIpDE52meIzd/oe/y70F+v9u1LDqk5kUF5mf16zovGBWMNFmgzlsh6Wj0OsFtg==", + "requires": { + "core-js": "3.6.5", + "promise-polyfill": "8.1.3", + "whatwg-fetch": "2.0.4" + }, + "dependencies": { + "core-js": { + "version": "3.6.5", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.6.5.tgz", + "integrity": "sha512-vZVEEwZoIsI+vPEuoF9Iqf5H7/M3eeQqWlQnYa8FSKKePuYTf5MWnxb5SDAzCa60b3JBRS5g9b+Dq7b1y/RCrA==" + }, + "whatwg-fetch": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/whatwg-fetch/-/whatwg-fetch-2.0.4.tgz", + "integrity": "sha512-dcQ1GWpOD/eEQ97k66aiEVpNnapVj90/+R+SXTPYGHpYBBypfKJEQjLrvMZ7YXbKm21gXd4NcuxUTjiv1YtLng==" + } + } + }, + "@firebase/remote-config": { + "version": "0.1.21", + "resolved": "https://registry.npmjs.org/@firebase/remote-config/-/remote-config-0.1.21.tgz", + "integrity": "sha512-EwDNU1mT+8Jn66IUwwNP5SM8AbaI7wmCXjp7djZtTXNrpPoh3xqzSRM1vTgp4Uu/mHffEDfbydsoJAIftADIfQ==", + "requires": { + "@firebase/component": "0.1.12", + "@firebase/installations": "0.4.10", + "@firebase/logger": "0.2.4", + "@firebase/remote-config-types": "0.1.9", + "@firebase/util": "0.2.47", + "tslib": "1.11.1" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/remote-config-types": { + "version": "0.1.9", + "resolved": "https://registry.npmjs.org/@firebase/remote-config-types/-/remote-config-types-0.1.9.tgz", + "integrity": "sha512-G96qnF3RYGbZsTRut7NBX0sxyczxt1uyCgXQuH/eAfUCngxjEGcZQnBdy6mvSdqdJh5mC31rWPO4v9/s7HwtzA==" + }, + "@firebase/storage": { + "version": "0.3.34", + "resolved": "https://registry.npmjs.org/@firebase/storage/-/storage-0.3.34.tgz", + "integrity": "sha512-vuR1PpGdaCk25D2dT2trfmZZjpdfOn0rPTksvoqg7TAPLeoVsVoDyT2LgF3Arna/jqx52sAIRx1HLrlvzE1pgA==", + "requires": { + "@firebase/component": "0.1.12", + "@firebase/storage-types": "0.3.12", + "@firebase/util": "0.2.47", + "tslib": "1.11.1" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/storage-types": { + "version": "0.3.12", + "resolved": "https://registry.npmjs.org/@firebase/storage-types/-/storage-types-0.3.12.tgz", + "integrity": "sha512-DDV6Fs6aYoGw3w/zZZTkqiipxihnsvHf6znbeZYjIIHit3tr1uLJdGPDPiCTfZcTGPpg2ux6ZmvNDvVgJdHALw==" + }, + "@firebase/util": { + "version": "0.2.47", + "resolved": "https://registry.npmjs.org/@firebase/util/-/util-0.2.47.tgz", + "integrity": "sha512-RjcIvcfswyxYhf0OMXod+qeI/933wl9FGLIszf0/O1yMZ/s8moXcse7xnOpMjmQPRLB9vHzCMoxW5X90kKg/bQ==", + "requires": { + "tslib": "1.11.1" + }, + "dependencies": { + "tslib": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", + "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" + } + } + }, + "@firebase/webchannel-wrapper": { + "version": "0.2.41", + "resolved": "https://registry.npmjs.org/@firebase/webchannel-wrapper/-/webchannel-wrapper-0.2.41.tgz", + "integrity": "sha512-XcdMT5PSZHiuf7LJIhzKIe+RyYa25S3LHRRvLnZc6iFjwXkrSDJ8J/HWO6VT8d2ZTbawp3VcLEjRF/VN8glCrA==" + }, "@google-cloud/common": { "version": "0.17.0", "resolved": "http://registry.npmjs.org/@google-cloud/common/-/common-0.17.0.tgz", @@ -2620,6 +2967,30 @@ } } }, + "@grpc/grpc-js": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/@grpc/grpc-js/-/grpc-js-0.8.1.tgz", + "integrity": "sha512-e8gSjRZnOUefsR3obOgxG9RtYW2Mw83hh7ogE2ByCdgRhoX0mdnJwBcZOami3E0l643KCTZvORFwfSEi48KFIQ==", + "requires": { + "semver": "^6.2.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + } + } + }, + "@grpc/proto-loader": { + "version": "0.5.4", + "resolved": "https://registry.npmjs.org/@grpc/proto-loader/-/proto-loader-0.5.4.tgz", + "integrity": "sha512-HTM4QpI9B2XFkPz7pjwMyMgZchJ93TVkL3kWPW8GDMDKYxsMnmf4w2TNMJK7+KNiYHS5cJrCEAFlF+AwtXWVPA==", + "requires": { + "lodash.camelcase": "^4.3.0", + "protobufjs": "^6.8.6" + } + }, "@gulp-sourcemaps/identity-map": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/@gulp-sourcemaps/identity-map/-/identity-map-1.0.2.tgz", @@ -2740,6 +3111,60 @@ "esquery": "^1.0.1" } }, + "@protobufjs/aspromise": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", + "integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=" + }, + "@protobufjs/base64": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", + "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==" + }, + "@protobufjs/codegen": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", + "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==" + }, + "@protobufjs/eventemitter": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", + "integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=" + }, + "@protobufjs/fetch": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", + "integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", + "requires": { + "@protobufjs/aspromise": "^1.1.1", + "@protobufjs/inquire": "^1.1.0" + } + }, + "@protobufjs/float": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", + "integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=" + }, + "@protobufjs/inquire": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", + "integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=" + }, + "@protobufjs/path": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", + "integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=" + }, + "@protobufjs/pool": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", + "integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=" + }, + "@protobufjs/utf8": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", + "integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=" + }, "@schematics/angular": { "version": "9.0.1", "resolved": "https://registry.npmjs.org/@schematics/angular/-/angular-9.0.1.tgz", @@ -3045,6 +3470,11 @@ "integrity": "sha512-ogI4g9W5qIQQUhXAclq6zhqgqNUr7UlFaqDHbch7WLSLeeM/7d3CRaw7GLajxvyFvhJqw4Rpcz5bhoaYtIx6Tg==", "dev": true }, + "@types/long": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.1.tgz", + "integrity": "sha512-5tXH6Bx/kNGd3MgffdmP4dy2Z+G4eaXw0SE81Tq3BNadtnMR5/ySMzX4SLEzHJzSmPNn4HIdpQsBvXMUykr58w==" + }, "@types/marked": { "version": "0.4.2", "resolved": "https://registry.npmjs.org/@types/marked/-/marked-0.4.2.tgz", @@ -8230,6 +8660,11 @@ } } }, + "dom-storage": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/dom-storage/-/dom-storage-2.1.0.tgz", + "integrity": "sha512-g6RpyWXzl0RR6OTElHKBl7nwnK87GUyZMYC7JWsB/IA73vpqK2K6LT39x4VepLxlSsWBFrPVLnsSR5Jyty0+2Q==" + }, "dom-walk": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/dom-walk/-/dom-walk-0.1.1.tgz", @@ -8408,7 +8843,6 @@ "version": "0.1.12", "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.12.tgz", "integrity": "sha1-U4tm8+5izRq1HsMjgp0flIDHS+s=", - "dev": true, "requires": { "iconv-lite": "~0.4.13" } @@ -9418,42 +9852,24 @@ } }, "firebase": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/firebase/-/firebase-2.4.2.tgz", - "integrity": "sha1-ThEZ7AOWylYdinrL/xYw/qxsCjE=", - "dev": true, - "requires": { - "faye-websocket": ">=0.6.0" - }, - "dependencies": { - "faye-websocket": { - "version": "0.9.3", - "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.9.3.tgz", - "integrity": "sha1-SCpQWw3wrmJrlphm0710DNuWLoM=", - "dev": true, - "requires": { - "websocket-driver": ">=0.5.1" - }, - "dependencies": { - "websocket-driver": { - "version": "0.5.2", - "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.5.2.tgz", - "integrity": "sha1-jHyF2gcTtAYFVrTXHAF3XuEmnrk=", - "dev": true, - "requires": { - "websocket-extensions": ">=0.1.1" - }, - "dependencies": { - "websocket-extensions": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.1.tgz", - "integrity": "sha1-domUmcGEtu91Q3fC27DNbLVdKec=", - "dev": true - } - } - } - } - } + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/firebase/-/firebase-7.14.5.tgz", + "integrity": "sha512-1vrC1UZIVhaT7owaElQoEseP81xqRt6tHQmxRJRojn0yI3JNXrdWCFsD+26xA1eQQCwodJuMsYJLzQSScgjHuQ==", + "requires": { + "@firebase/analytics": "0.3.5", + "@firebase/app": "0.6.4", + "@firebase/app-types": "0.6.1", + "@firebase/auth": "0.14.6", + "@firebase/database": "0.6.3", + "@firebase/firestore": "1.14.5", + "@firebase/functions": "0.4.44", + "@firebase/installations": "0.4.10", + "@firebase/messaging": "0.6.16", + "@firebase/performance": "0.3.4", + "@firebase/polyfill": "0.3.36", + "@firebase/remote-config": "0.1.21", + "@firebase/storage": "0.3.34", + "@firebase/util": "0.2.47" } }, "firebase-tools": { @@ -9538,6 +9954,45 @@ "object-assign": "^4.1.0" } }, + "firebase": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/firebase/-/firebase-2.4.2.tgz", + "integrity": "sha1-ThEZ7AOWylYdinrL/xYw/qxsCjE=", + "dev": true, + "requires": { + "faye-websocket": ">=0.6.0" + }, + "dependencies": { + "faye-websocket": { + "version": "0.9.3", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.9.3.tgz", + "integrity": "sha1-SCpQWw3wrmJrlphm0710DNuWLoM=", + "dev": true, + "requires": { + "websocket-driver": ">=0.5.1" + }, + "dependencies": { + "websocket-driver": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.5.2.tgz", + "integrity": "sha1-jHyF2gcTtAYFVrTXHAF3XuEmnrk=", + "dev": true, + "requires": { + "websocket-extensions": ">=0.1.1" + }, + "dependencies": { + "websocket-extensions": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.1.tgz", + "integrity": "sha1-domUmcGEtu91Q3fC27DNbLVdKec=", + "dev": true + } + } + } + } + } + } + }, "fs-extra": { "version": "0.23.1", "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-0.23.1.tgz", @@ -12476,8 +12931,7 @@ "http-parser-js": { "version": "0.4.10", "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.4.10.tgz", - "integrity": "sha1-ksnBN0w1CF912zWexWzCV8u5P6Q=", - "dev": true + "integrity": "sha1-ksnBN0w1CF912zWexWzCV8u5P6Q=" }, "http-proxy": { "version": "1.17.0", @@ -12614,11 +13068,15 @@ "version": "0.4.23", "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", - "dev": true, "requires": { "safer-buffer": ">= 2.1.2 < 3" } }, + "idb": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/idb/-/idb-3.0.2.tgz", + "integrity": "sha512-+FLa/0sTXqyux0o6C+i2lOR0VoS60LU/jzUo5xjfY6+7sEEgy4Gz1O7yFBXvjd7N0NyIGWIRg8DcQSLEG+VSPw==" + }, "ieee754": { "version": "1.1.13", "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", @@ -13474,6 +13932,26 @@ "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", "dev": true }, + "isomorphic-fetch": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/isomorphic-fetch/-/isomorphic-fetch-2.2.1.tgz", + "integrity": "sha1-YRrhrPFPXoH3KVB0coGf6XM1WKk=", + "requires": { + "node-fetch": "^1.0.1", + "whatwg-fetch": ">=0.10.0" + }, + "dependencies": { + "node-fetch": { + "version": "1.7.3", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-1.7.3.tgz", + "integrity": "sha512-NhZ4CsKx7cYm2vSrBAr2PvFOe6sWDf0UYLRqA6svUYg7+/TSfVAu49jYC4BvQ4Sms9SZgdqGBgroqfDhJdTyKQ==", + "requires": { + "encoding": "^0.1.11", + "is-stream": "^1.0.1" + } + } + } + }, "isstream": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", @@ -14735,6 +15213,11 @@ "lodash._objecttypes": "~2.4.1" } }, + "lodash.camelcase": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", + "integrity": "sha1-soqmKIorn8ZRA1x3EfZathkDMaY=" + }, "lodash.clonedeep": { "version": "4.5.0", "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", @@ -14953,6 +15436,11 @@ "integrity": "sha1-fD2mL/yzDw9agKJWbKJORdigHzE=", "dev": true }, + "long": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", + "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" + }, "loose-envify": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", @@ -18385,6 +18873,11 @@ "integrity": "sha1-mEcocL8igTL8vdhoEputEsPAKeM=", "dev": true }, + "promise-polyfill": { + "version": "8.1.3", + "resolved": "https://registry.npmjs.org/promise-polyfill/-/promise-polyfill-8.1.3.tgz", + "integrity": "sha512-MG5r82wBzh7pSKDRa9y+vllNHz3e3d4CNj1PQE4BQYxLme0gKYYBm9YENq+UkEikyZ0XbiGWxYlVw3Rl9O/U8g==" + }, "promise-retry": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/promise-retry/-/promise-retry-1.1.1.tgz", @@ -18459,6 +18952,33 @@ } } }, + "protobufjs": { + "version": "6.9.0", + "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.9.0.tgz", + "integrity": "sha512-LlGVfEWDXoI/STstRDdZZKb/qusoAWUnmLg9R8OLSO473mBLWHowx8clbX5/+mKDEI+v7GzjoK9tRPZMMcoTrg==", + "requires": { + "@protobufjs/aspromise": "^1.1.2", + "@protobufjs/base64": "^1.1.2", + "@protobufjs/codegen": "^2.0.4", + "@protobufjs/eventemitter": "^1.1.0", + "@protobufjs/fetch": "^1.1.0", + "@protobufjs/float": "^1.0.2", + "@protobufjs/inquire": "^1.1.0", + "@protobufjs/path": "^1.1.2", + "@protobufjs/pool": "^1.1.0", + "@protobufjs/utf8": "^1.1.0", + "@types/long": "^4.0.1", + "@types/node": "^13.7.0", + "long": "^4.0.0" + }, + "dependencies": { + "@types/node": { + "version": "13.13.9", + "resolved": "https://registry.npmjs.org/@types/node/-/node-13.13.9.tgz", + "integrity": "sha512-EPZBIGed5gNnfWCiwEIwTE2Jdg4813odnG8iNPMQGrqVxrI+wL68SPtPeCX+ZxGBaA6pKAVc6jaKgP/Q0QzfdQ==" + } + } + }, "protochain": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/protochain/-/protochain-1.0.5.tgz", @@ -24576,7 +25096,6 @@ "version": "0.7.3", "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.3.tgz", "integrity": "sha512-bpxWlvbbB459Mlipc5GBzzZwhoZgGEZLuqPaR0INBGnPAY1vdBX6hPnoFXiw+3yWxDuHyQjO2oXTMyS8A5haFg==", - "dev": true, "requires": { "http-parser-js": ">=0.4.0 <0.4.11", "safe-buffer": ">=5.1.0", @@ -24586,8 +25105,12 @@ "websocket-extensions": { "version": "0.1.3", "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.3.tgz", - "integrity": "sha512-nqHUnMXmBzT0w570r2JpJxfiSD1IzoI+HGVdd3aZ0yNi3ngvQ4jv1dtHt5VGxfI2yj5yqImPhOK4vmIh2xMbGg==", - "dev": true + "integrity": "sha512-nqHUnMXmBzT0w570r2JpJxfiSD1IzoI+HGVdd3aZ0yNi3ngvQ4jv1dtHt5VGxfI2yj5yqImPhOK4vmIh2xMbGg==" + }, + "whatwg-fetch": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/whatwg-fetch/-/whatwg-fetch-3.0.0.tgz", + "integrity": "sha512-9GSJUgz1D4MfyKU7KRqwOjXCXTqWdFNvEr7eUBYchQiVc744mqK/MzXPNR2WsPkmkOa4ywfg8C2n8h+13Bey1Q==" }, "when": { "version": "3.6.4", @@ -24815,6 +25338,11 @@ "integrity": "sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA==", "dev": true }, + "xmlhttprequest": { + "version": "1.8.0", + "resolved": "https://registry.npmjs.org/xmlhttprequest/-/xmlhttprequest-1.8.0.tgz", + "integrity": "sha1-Z/4HXFwk/vOfnWX197f+dRcZaPw=" + }, "xmlhttprequest-ssl": { "version": "1.5.3", "resolved": "https://registry.npmjs.org/xmlhttprequest-ssl/-/xmlhttprequest-ssl-1.5.3.tgz", diff --git a/package.json b/package.json index 33e6198de2..079a637d90 100644 --- a/package.json +++ b/package.json @@ -90,6 +90,7 @@ "@angular/common": "^9.0.4", "@angular/compiler": "^9.0.4", "@angular/core": "^9.0.4", + "@angular/fire": "^6.0.0", "@angular/forms": "^9.0.4", "@angular/localize": "^9.0.4", "@angular/platform-browser": "^9.0.4", @@ -101,6 +102,7 @@ "date-fns": "2", "docsearch.js": "^2.5.2", "eva-icons": "^1.1.2", + "firebase": "^7.14.5", "gulp-bump": "2.7.0", "highlight.js": "9.12.0", "intersection-observer": "0.7.0", diff --git a/src/framework/firebase-auth/firebase-auth.module.ts b/src/framework/firebase-auth/firebase-auth.module.ts new file mode 100644 index 0000000000..c6c1169146 --- /dev/null +++ b/src/framework/firebase-auth/firebase-auth.module.ts @@ -0,0 +1,17 @@ +/* + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ + + +import { NgModule } from '@angular/core'; +import { NbFirebasePasswordStrategy } from './strategies/firebase-password.strategy'; + + +@NgModule({ + providers: [ + NbFirebasePasswordStrategy, + ], +}) +export class FirebaseAuthModule { } diff --git a/src/framework/firebase-auth/package.json b/src/framework/firebase-auth/package.json new file mode 100644 index 0000000000..a1a9bc69b6 --- /dev/null +++ b/src/framework/firebase-auth/package.json @@ -0,0 +1,34 @@ +{ + "name": "@nebular/eva-icons", + "version": "5.0.0", + "description": "@nebular/firebase-auth", + "author": "akveo", + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/akveo/nebular.git" + }, + "bugs": { + "url": "https://github.com/akveo/nebular/issues" + }, + "homepage": "https://github.com/akveo/nebular#readme", + "keywords": [ + "angular", + "typescript", + "ng2-admin", + "ngx-admin", + "theme", + "auth", + "login", + "register", + "nebular", + "firebase" + ], + "peerDependencies": { + "@angular/core": "^9.0.0", + "@nebular/auth": "^5.0.0", + "rxjs": "^6.5.1", + "firebase": "^7.14.5" + }, + "sideEffects": false +} diff --git a/src/framework/firebase-auth/public_api.ts b/src/framework/firebase-auth/public_api.ts new file mode 100644 index 0000000000..aeeaa4410a --- /dev/null +++ b/src/framework/firebase-auth/public_api.ts @@ -0,0 +1,9 @@ +/* + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ + + +export * from './strategies/firebase-password.strategy'; +export * from './firebase-auth.module'; diff --git a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts b/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts new file mode 100644 index 0000000000..f238b5e8b6 --- /dev/null +++ b/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts @@ -0,0 +1,52 @@ +/** + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ +import { NbAuthStrategyOptions } from '../../auth/strategies/auth-strategy-options'; +import { getDeepFromObject } from '../../auth/helpers'; +import { NbPasswordStrategyMessage } from '../../auth/strategies/password/password-strategy-options'; + +export interface NbFirebasePasswordStrategyModule { + redirect?: { + success?: string | null; + failure?: string | null; + }; + defaultErrors?: string[], + defaultMessages?: string[], +} + +export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { + register?: boolean | NbFirebasePasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['You have been successfully registered.'], + }; + login? = { + redirect: { + success: '/', + failure: null, + } + }; + errors?: NbPasswordStrategyMessage = { + key: 'message', + getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( + res, + options.errors.key, + options[module].defaultErrors, + ), + }; + messages?: NbPasswordStrategyMessage = { + key: 'messages', + getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( + res.body, + options.messages.key, + options[module].defaultMessages, + ), + }; +} + +export const firebasePasswordStrategyOptions: NbFirebasePasswordStrategyOptions = new NbFirebasePasswordStrategyOptions(); diff --git a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/firebase-password.strategy.ts new file mode 100644 index 0000000000..a1eee43460 --- /dev/null +++ b/src/framework/firebase-auth/strategies/firebase-password.strategy.ts @@ -0,0 +1,91 @@ +/* + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ + +import { Injectable } from '@angular/core'; +import { NbAuthStrategy } from '../../auth/strategies/auth-strategy'; +import { NbAuthResult } from '../../auth/services/auth-result'; +import { Observable, of as observableOf } from 'rxjs'; +import { NbAuthStrategyClass } from '../../auth/auth.options'; +import { HttpClient } from '@angular/common/http'; +import { + firebasePasswordStrategyOptions, + NbFirebasePasswordStrategyOptions +} from './firebase-password-strategy.options'; +import { NbAuthStrategyOptions } from '../../auth/strategies/auth-strategy-options'; +import { AngularFireAuth } from '@angular/fire/auth'; +import { fromPromise } from 'rxjs/internal-compatibility'; +import { catchError, map, switchMap, tap } from 'rxjs/operators'; +import UserCredential = firebase.auth.UserCredential; + + +@Injectable() +export class NbFirebasePasswordStrategy extends NbAuthStrategy { + + protected defaultOptions: NbFirebasePasswordStrategyOptions = firebasePasswordStrategyOptions; + + static setup(options: NbFirebasePasswordStrategyOptions): [NbAuthStrategyClass, NbAuthStrategyOptions] { + return [NbFirebasePasswordStrategy, options]; + } + + constructor( + protected http: HttpClient, + protected afAuth: AngularFireAuth + ) { + super(); + } + + authenticate(data?: any): Observable { + return undefined; + } + + logout(): Observable { + return undefined; + } + + refreshToken(data?: any): Observable { + return undefined; + } + + register({ email, password }: any): Observable { + const module = 'register'; + return fromPromise(this.afAuth.createUserWithEmailAndPassword(email, password)) + .pipe( + switchMap((res) => this.processSuccess(res, module)), + catchError((error) => this.proccessFailure(error, module)), + ); + } + + requestPassword(data?: any): Observable { + return undefined; + } + + resetPassword(data?: any): Observable { + return undefined; + } + + private proccessFailure(error: any, module: string): Observable { + return observableOf(new NbAuthResult( + false, + error, + this.getOption(`register.redirect.fail`), + this.getOption('errors.getter')(module, error, this.options), + )); + } + + private processSuccess(res: UserCredential, module: string): Observable { + return this.afAuth.idToken + .pipe(map(token => { + return new NbAuthResult( + true, + res, + this.getOption(`register.redirect.success`), + [], + this.getOption('messages.getter')(module, res, this.options), + this.createToken(token), + ); + })); + } +} From 3f06587c6b909fec562d16bbd636b4cbe1fe63db Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 27 May 2020 00:07:15 +0300 Subject: [PATCH 02/34] feat(firebase-auth): add firebase auth playground --- src/app/playground-components.ts | 41 +++++++++ .../firebase/firebase-playground.component.ts | 16 ++++ .../firebase/firebase-routing.module.ts | 85 +++++++++++++++++++ .../firebase/firebase.module.ts | 77 +++++++++++++++++ .../firebase/result/result.component.html | 1 + .../firebase/result/result.component.scss | 0 .../firebase/result/result.component.ts | 24 ++++++ .../without-layout-routing.module.ts | 4 + 8 files changed, 248 insertions(+) create mode 100644 src/playground/without-layout/firebase/firebase-playground.component.ts create mode 100644 src/playground/without-layout/firebase/firebase-routing.module.ts create mode 100644 src/playground/without-layout/firebase/firebase.module.ts create mode 100644 src/playground/without-layout/firebase/result/result.component.html create mode 100644 src/playground/without-layout/firebase/result/result.component.scss create mode 100644 src/playground/without-layout/firebase/result/result.component.ts diff --git a/src/app/playground-components.ts b/src/app/playground-components.ts index 039204222f..52bab9771b 100644 --- a/src/app/playground-components.ts +++ b/src/app/playground-components.ts @@ -1797,6 +1797,47 @@ export const PLAYGROUND_COMPONENTS: ComponentLink[] = [ }, ], }, + { + path: 'firebase', + children: [ + { + path: 'login', + link: '/firebase/login', + component: 'NbLoginComponent', + name: 'Nb Login', + }, + { + path: 'register', + link: '/firebase/register', + component: 'NbRegisterComponent', + name: 'Nb Register', + }, + { + path: 'logout', + link: '/firebase/logout', + component: 'NbLogoutComponent', + name: 'Nb Logout', + }, + { + path: 'request-password', + link: '/firebase/request-password', + component: 'NbRequestPasswordComponent', + name: 'Nb Request Password', + }, + { + path: 'reset-password', + link: '/firebase/reset-password', + component: 'NbResetPasswordComponent', + name: 'Nb Reset Password', + }, + { + path: 'result', + link: '/firebase/result', + component: 'FirebaseAuthResultComponent', + name: 'Firebase Auth Result', + }, + ], + }, { path: 'smart-home', children: [ diff --git a/src/playground/without-layout/firebase/firebase-playground.component.ts b/src/playground/without-layout/firebase/firebase-playground.component.ts new file mode 100644 index 0000000000..cfd2315915 --- /dev/null +++ b/src/playground/without-layout/firebase/firebase-playground.component.ts @@ -0,0 +1,16 @@ +/** + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ + +import { Component } from '@angular/core'; + +@Component({ + selector: 'nb-firebase-playground', + template: ` + + `, +}) +export class FirebasePlaygroundComponent { +} diff --git a/src/playground/without-layout/firebase/firebase-routing.module.ts b/src/playground/without-layout/firebase/firebase-routing.module.ts new file mode 100644 index 0000000000..c6bc100e91 --- /dev/null +++ b/src/playground/without-layout/firebase/firebase-routing.module.ts @@ -0,0 +1,85 @@ +/** + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ + +import { NgModule } from '@angular/core'; +import { RouterModule, Routes } from '@angular/router'; + +import { + NbAuthComponent, + NbLoginComponent, + NbLogoutComponent, + NbRegisterComponent, + NbRequestPasswordComponent, + NbResetPasswordComponent, +} from '@nebular/auth'; +import { FirebasePlaygroundComponent } from './firebase-playground.component'; +import { FirebaseAuthResultComponent } from './result/result.component'; + + +export const routes: Routes = [ + { + path: '', + component: FirebasePlaygroundComponent, + children: [ + { + path: '', + component: NbAuthComponent, + children: [ + { + path: '', + redirectTo: 'login', + pathMatch: 'full', + }, + { + path: 'login', + component: NbLoginComponent, + }, + { + path: 'register', + component: NbRegisterComponent, + }, + { + path: 'logout', + component: NbLogoutComponent, + }, + { + path: 'request-password', + component: NbRequestPasswordComponent, + }, + { + path: 'reset-password', + component: NbResetPasswordComponent, + }, + ], + }, + ], + }, + { + path: 'result', + component: FirebaseAuthResultComponent, + } + // { + // path: 'acl/acl-test.component', + // component: AclTestComponent, + // }, + // { + // path: 'auth-guard.service', + // canActivate: [AuthGuard], + // component: AuthPlaygroundComponent, + // }, + // { + // path: 'api-calls.component', + // canActivate: [AuthGuard], + // component: PlaygroundApiCallsComponent, + // }, +]; + +@NgModule({ + imports: [RouterModule.forChild(routes)], + exports: [RouterModule], +}) +export class FirebasePlaygroundRoutingModule { +} diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts new file mode 100644 index 0000000000..7f17076d5f --- /dev/null +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -0,0 +1,77 @@ +import { NgModule } from '@angular/core'; +import { NbAuthModule } from '../../../framework/auth/auth.module'; +import { NbFirebasePasswordStrategy } from '../../../framework/firebase-auth/strategies/firebase-password.strategy'; +import { FirebasePlaygroundRoutingModule } from './firebase-routing.module'; +import { FirebasePlaygroundComponent } from './firebase-playground.component'; +import { FirebaseAuthModule } from '@nebular/firebase-auth'; +import { CommonModule } from '@angular/common'; +import { NbAuthJWTToken } from '../../../framework/auth/services/token/token'; +import { AngularFireAuthModule } from '@angular/fire/auth'; +import { AngularFireModule } from '@angular/fire'; +import { FirebaseAuthResultComponent } from './result/result.component'; + +@NgModule({ + imports: [ + CommonModule, + // developers test firebase app + // TODO: change for some better alternative + AngularFireModule.initializeApp({ + apiKey: 'AIzaSyBEvySH74-sISCTkCC6lXUd3zzYj26GjRk', + authDomain: 'auth-sample-f48f1.firebaseapp.com', + databaseURL: 'https://auth-sample-f48f1.firebaseio.com', + projectId: 'auth-sample-f48f1', + storageBucket: 'auth-sample-f48f1.appspot.com', + messagingSenderId: '246754092661', + appId: '1:246754092661:web:c2606b9ecdbed579673a3c' + }), + AngularFireAuthModule, + FirebasePlaygroundRoutingModule, + FirebaseAuthModule, + NbAuthModule.forRoot({ + forms: { + login: { + strategy: 'password', + }, + register: { + strategy: 'password', + terms: false, + }, + validation: { + password: { + required: true, + minLength: 6, + maxLength: 50, + }, + email: { + required: true, + }, + fullName: { + required: false, + minLength: 4, + maxLength: 50, + }, + }, + }, + strategies: [ + NbFirebasePasswordStrategy.setup({ + name: 'password', + token: { + class: NbAuthJWTToken, // TODO: should be custom token? + }, + register: { + redirect: { + success: '/firebase/result' + } + } + }), + ] + }), + ], + declarations: [ + FirebasePlaygroundComponent, + FirebaseAuthResultComponent, + ], + providers: [], +}) +export class FirebasePlaygroundModule { +} diff --git a/src/playground/without-layout/firebase/result/result.component.html b/src/playground/without-layout/firebase/result/result.component.html new file mode 100644 index 0000000000..d3d712163b --- /dev/null +++ b/src/playground/without-layout/firebase/result/result.component.html @@ -0,0 +1 @@ +
 {{ userToken$ | async | json }} 
diff --git a/src/playground/without-layout/firebase/result/result.component.scss b/src/playground/without-layout/firebase/result/result.component.scss new file mode 100644 index 0000000000..e69de29bb2 diff --git a/src/playground/without-layout/firebase/result/result.component.ts b/src/playground/without-layout/firebase/result/result.component.ts new file mode 100644 index 0000000000..cee565f1b9 --- /dev/null +++ b/src/playground/without-layout/firebase/result/result.component.ts @@ -0,0 +1,24 @@ +import { Component, OnInit } from '@angular/core'; +import { NbAuthService } from '../../../../framework/auth/services/auth.service'; +import { NbAuthToken } from '../../../../framework/auth/services/token/token'; +import { Observable } from 'rxjs'; + +@Component({ + selector: 'nb-firebase-auth-result', + templateUrl: './result.component.html', + styleUrls: ['./result.component.scss'] +}) +export class FirebaseAuthResultComponent implements OnInit { + + userToken$: Observable; + + constructor( + private authService: NbAuthService, + ) { + this.userToken$ = this.authService.onTokenChange(); + } + + ngOnInit(): void { + } + +} diff --git a/src/playground/without-layout/without-layout-routing.module.ts b/src/playground/without-layout/without-layout-routing.module.ts index a45d2a9ac3..43d35da7c3 100644 --- a/src/playground/without-layout/without-layout-routing.module.ts +++ b/src/playground/without-layout/without-layout-routing.module.ts @@ -49,6 +49,10 @@ const routes: Route[] = [ path: 'auth', loadChildren: () => import('./auth/auth.module').then(m => m.AuthPlaygroundModule), }, + { + path: 'firebase', + loadChildren: () => import('./firebase/firebase.module').then(m => m.FirebasePlaygroundModule), + }, { path: 'smart-home', loadChildren: () => import('./smart-home/app.module').then(m => m.AppModule), From bb4a27df097275098b51338a16cd7ecdda416e9e Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 27 May 2020 01:02:31 +0300 Subject: [PATCH 03/34] feat(firebase-auth): add login/logout --- .../firebase-password-strategy.options.ts | 14 +++++++-- .../strategies/firebase-password.strategy.ts | 29 +++++++++++++++---- .../firebase/firebase.module.ts | 8 +++++ .../firebase/result/result.component.html | 4 +++ .../firebase/result/result.component.ts | 18 +++++++++++- 5 files changed, 64 insertions(+), 9 deletions(-) diff --git a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts b/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts index f238b5e8b6..aa76b386b1 100644 --- a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts @@ -25,11 +25,21 @@ export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { defaultErrors: ['Something went wrong, please try again.'], defaultMessages: ['You have been successfully registered.'], }; - login? = { + login?: boolean | NbFirebasePasswordStrategyModule = { redirect: { success: '/', failure: null, - } + }, + defaultErrors: ['Login/Email combination is not correct, please try again.'], + defaultMessages: ['You have been successfully logged in.'], + }; + logout? = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['You have been successfully logged out.'], }; errors?: NbPasswordStrategyMessage = { key: 'message', diff --git a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/firebase-password.strategy.ts index a1eee43460..1c9ef1b00f 100644 --- a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/firebase-password.strategy.ts @@ -17,7 +17,7 @@ import { import { NbAuthStrategyOptions } from '../../auth/strategies/auth-strategy-options'; import { AngularFireAuth } from '@angular/fire/auth'; import { fromPromise } from 'rxjs/internal-compatibility'; -import { catchError, map, switchMap, tap } from 'rxjs/operators'; +import { catchError, map, switchMap} from 'rxjs/operators'; import UserCredential = firebase.auth.UserCredential; @@ -37,12 +37,29 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { super(); } - authenticate(data?: any): Observable { - return undefined; + authenticate({ email, password }: any): Observable { + return fromPromise(this.afAuth.signInWithEmailAndPassword(email, password)) + .pipe( + switchMap((res) => this.processSuccess(res, 'login')), + catchError((error) => this.proccessFailure(error, 'login')), + ); } logout(): Observable { - return undefined; + const module = 'logout'; + return fromPromise(this.afAuth.signOut()) + .pipe( + map(() => { + return new NbAuthResult( + true, + null, + this.getOption(`${module}.redirect.success`), + [], + this.getOption('logout.defaultMessages'), + ) + }), + catchError((error) => this.proccessFailure(error, module)), + ); } refreshToken(data?: any): Observable { @@ -70,7 +87,7 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { return observableOf(new NbAuthResult( false, error, - this.getOption(`register.redirect.fail`), + this.getOption(`${module}.redirect.fail`), this.getOption('errors.getter')(module, error, this.options), )); } @@ -81,7 +98,7 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { return new NbAuthResult( true, res, - this.getOption(`register.redirect.success`), + this.getOption(`${module}.redirect.success`), [], this.getOption('messages.getter')(module, res, this.options), this.createToken(token), diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 7f17076d5f..969826a33e 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -36,6 +36,9 @@ import { FirebaseAuthResultComponent } from './result/result.component'; strategy: 'password', terms: false, }, + logout: { + strategy: 'password', + }, validation: { password: { required: true, @@ -58,6 +61,11 @@ import { FirebaseAuthResultComponent } from './result/result.component'; token: { class: NbAuthJWTToken, // TODO: should be custom token? }, + login: { + redirect: { + success: '/firebase/result', + } + }, register: { redirect: { success: '/firebase/result' diff --git a/src/playground/without-layout/firebase/result/result.component.html b/src/playground/without-layout/firebase/result/result.component.html index d3d712163b..d0f07f6d51 100644 --- a/src/playground/without-layout/firebase/result/result.component.html +++ b/src/playground/without-layout/firebase/result/result.component.html @@ -1 +1,5 @@
 {{ userToken$ | async | json }} 
+ + + + diff --git a/src/playground/without-layout/firebase/result/result.component.ts b/src/playground/without-layout/firebase/result/result.component.ts index cee565f1b9..3b4f52322d 100644 --- a/src/playground/without-layout/firebase/result/result.component.ts +++ b/src/playground/without-layout/firebase/result/result.component.ts @@ -1,7 +1,8 @@ import { Component, OnInit } from '@angular/core'; import { NbAuthService } from '../../../../framework/auth/services/auth.service'; import { NbAuthToken } from '../../../../framework/auth/services/token/token'; -import { Observable } from 'rxjs'; +import { Observable, Subject } from 'rxjs'; +import { Router } from '@angular/router'; @Component({ selector: 'nb-firebase-auth-result', @@ -12,8 +13,11 @@ export class FirebaseAuthResultComponent implements OnInit { userToken$: Observable; + private destroyed$ = new Subject(); + constructor( private authService: NbAuthService, + private router: Router, ) { this.userToken$ = this.authService.onTokenChange(); } @@ -21,4 +25,16 @@ export class FirebaseAuthResultComponent implements OnInit { ngOnInit(): void { } + ngOnDestroy() { + this.destroyed$.next(); + this.destroyed$.complete(); + } + + logout() { + this.router.navigateByUrl('/firebase/logout'); + } + + login() { + this.router.navigateByUrl('/firebase/login'); + } } From 8e0d6c92dcff5732a6e5dc478e84a9621af759a3 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 27 May 2020 12:22:57 +0300 Subject: [PATCH 04/34] feat(firebase-auth): add refresh token method --- .../firebase-password-strategy.options.ts | 15 ++++- .../strategies/firebase-password.strategy.ts | 64 ++++++++++++++++--- .../firebase/firebase.module.ts | 7 +- .../firebase/result/result.component.html | 6 ++ .../firebase/result/result.component.ts | 11 ++++ 5 files changed, 91 insertions(+), 12 deletions(-) diff --git a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts b/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts index aa76b386b1..e3abb3184a 100644 --- a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts @@ -5,7 +5,10 @@ */ import { NbAuthStrategyOptions } from '../../auth/strategies/auth-strategy-options'; import { getDeepFromObject } from '../../auth/helpers'; -import { NbPasswordStrategyMessage } from '../../auth/strategies/password/password-strategy-options'; +import { + NbPasswordStrategyMessage, + NbPasswordStrategyModule +} from '../../auth/strategies/password/password-strategy-options'; export interface NbFirebasePasswordStrategyModule { redirect?: { @@ -33,7 +36,7 @@ export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { defaultErrors: ['Login/Email combination is not correct, please try again.'], defaultMessages: ['You have been successfully logged in.'], }; - logout? = { + logout?: boolean | NbFirebasePasswordStrategyModule = { redirect: { success: '/', failure: null, @@ -41,6 +44,14 @@ export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { defaultErrors: ['Something went wrong, please try again.'], defaultMessages: ['You have been successfully logged out.'], }; + refreshToken?: boolean | NbPasswordStrategyModule = { + redirect: { + success: null, + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['Your token has been successfully refreshed.'], + }; errors?: NbPasswordStrategyMessage = { key: 'message', getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( diff --git a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/firebase-password.strategy.ts index 1c9ef1b00f..bf2fba2ea5 100644 --- a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/firebase-password.strategy.ts @@ -7,7 +7,7 @@ import { Injectable } from '@angular/core'; import { NbAuthStrategy } from '../../auth/strategies/auth-strategy'; import { NbAuthResult } from '../../auth/services/auth-result'; -import { Observable, of as observableOf } from 'rxjs'; +import { Observable, of as observableOf, throwError } from 'rxjs'; import { NbAuthStrategyClass } from '../../auth/auth.options'; import { HttpClient } from '@angular/common/http'; import { @@ -17,8 +17,9 @@ import { import { NbAuthStrategyOptions } from '../../auth/strategies/auth-strategy-options'; import { AngularFireAuth } from '@angular/fire/auth'; import { fromPromise } from 'rxjs/internal-compatibility'; -import { catchError, map, switchMap} from 'rxjs/operators'; +import { catchError, map, switchMap, take } from 'rxjs/operators'; import UserCredential = firebase.auth.UserCredential; +import { User } from 'firebase'; @Injectable() @@ -38,10 +39,11 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { } authenticate({ email, password }: any): Observable { + const module = 'login'; return fromPromise(this.afAuth.signInWithEmailAndPassword(email, password)) .pipe( - switchMap((res) => this.processSuccess(res, 'login')), - catchError((error) => this.proccessFailure(error, 'login')), + switchMap((res) => this.processSuccess(res, module)), + catchError((error) => this.proccessFailure(error, module)), ); } @@ -63,7 +65,22 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { } refreshToken(data?: any): Observable { - return undefined; + const module = 'refreshToken'; + return this.afAuth.authState + .pipe( + take(1), // need this to prevent loop + switchMap(user => { + if (user == null) { + return observableOf(new NbAuthResult( + false, + null, + this.getOption(`${module}.redirect.failure`), + ['There is no logged in user so refresh of id token isn\'t possible'], + )); + } + return this.refreshIdToken(user, module); + }), + ); } register({ email, password }: any): Observable { @@ -75,24 +92,53 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { ); } - requestPassword(data?: any): Observable { - return undefined; + requestPassword({ email }: any): Observable { + return fromPromise(this.afAuth.sendPasswordResetEmail(email)) + .pipe( + map(() => { + return new NbAuthResult( + true + ); + }), + catchError(() => { + return observableOf(new NbAuthResult( + false, + )) + }) + ); } resetPassword(data?: any): Observable { return undefined; } + private refreshIdToken(user: User, module): Observable { + return fromPromise(user.getIdToken(true)) + .pipe( + map(token => { + return new NbAuthResult( + true, + null, + this.getOption(`${module}.redirect.success`), + [], + this.getOption('refreshToken.defaultMessages'), + this.createToken(token), + ); + }), + catchError(error => this.proccessFailure(error, module)), + ); + } + private proccessFailure(error: any, module: string): Observable { return observableOf(new NbAuthResult( false, error, - this.getOption(`${module}.redirect.fail`), + this.getOption(`${module}.redirect.failure`), this.getOption('errors.getter')(module, error, this.options), )); } - private processSuccess(res: UserCredential, module: string): Observable { + private processSuccess(res: UserCredential | null, module: string): Observable { return this.afAuth.idToken .pipe(map(token => { return new NbAuthResult( diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 969826a33e..126d86359c 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -70,7 +70,12 @@ import { FirebaseAuthResultComponent } from './result/result.component'; redirect: { success: '/firebase/result' } - } + }, + logout: { + redirect: { + success: '/firebase/login', + } + }, }), ] }), diff --git a/src/playground/without-layout/firebase/result/result.component.html b/src/playground/without-layout/firebase/result/result.component.html index d0f07f6d51..1495cfec30 100644 --- a/src/playground/without-layout/firebase/result/result.component.html +++ b/src/playground/without-layout/firebase/result/result.component.html @@ -1,5 +1,11 @@ +

Nebular token:

 {{ userToken$ | async | json }} 
+

Firebase User:

+
 {{ afUser$ | async | json }}
+ + + diff --git a/src/playground/without-layout/firebase/result/result.component.ts b/src/playground/without-layout/firebase/result/result.component.ts index 3b4f52322d..4488ad0b8c 100644 --- a/src/playground/without-layout/firebase/result/result.component.ts +++ b/src/playground/without-layout/firebase/result/result.component.ts @@ -3,6 +3,8 @@ import { NbAuthService } from '../../../../framework/auth/services/auth.service' import { NbAuthToken } from '../../../../framework/auth/services/token/token'; import { Observable, Subject } from 'rxjs'; import { Router } from '@angular/router'; +import { AngularFireAuth } from '@angular/fire/auth'; +import { User } from 'firebase'; @Component({ selector: 'nb-firebase-auth-result', @@ -12,14 +14,18 @@ import { Router } from '@angular/router'; export class FirebaseAuthResultComponent implements OnInit { userToken$: Observable; + afUser$: Observable; private destroyed$ = new Subject(); constructor( private authService: NbAuthService, private router: Router, + private afAuth: AngularFireAuth, ) { this.userToken$ = this.authService.onTokenChange(); + this.afUser$ = this.afAuth.authState; + } ngOnInit(): void { @@ -37,4 +43,9 @@ export class FirebaseAuthResultComponent implements OnInit { login() { this.router.navigateByUrl('/firebase/login'); } + + refreshToken() { + this.authService.refreshToken('password') + .subscribe((res) => console.log('result of token refresh', res)); + } } From 67cff06f490ee328de36c2596ea1fcfadbdb3e5b Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 27 May 2020 13:02:37 +0300 Subject: [PATCH 05/34] feat(firebase-auth): add request password --- .../firebase-password-strategy.options.ts | 8 ++++++++ .../strategies/firebase-password.strategy.ts | 20 ++++++++++--------- .../firebase/firebase.module.ts | 12 +++++++++++ .../firebase/result/result.component.html | 1 + .../firebase/result/result.component.ts | 4 ++++ 5 files changed, 36 insertions(+), 9 deletions(-) diff --git a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts b/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts index e3abb3184a..af96c949bf 100644 --- a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts @@ -52,6 +52,14 @@ export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { defaultErrors: ['Something went wrong, please try again.'], defaultMessages: ['Your token has been successfully refreshed.'], }; + requestPassword?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['Reset password instructions have been sent to your email.'], + }; errors?: NbPasswordStrategyMessage = { key: 'message', getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( diff --git a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/firebase-password.strategy.ts index bf2fba2ea5..11356660a9 100644 --- a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/firebase-password.strategy.ts @@ -57,7 +57,7 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { null, this.getOption(`${module}.redirect.success`), [], - this.getOption('logout.defaultMessages'), + this.getOption(`${module}.defaultMessages`), ) }), catchError((error) => this.proccessFailure(error, module)), @@ -93,22 +93,24 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { } requestPassword({ email }: any): Observable { + const module = 'requestPassword'; return fromPromise(this.afAuth.sendPasswordResetEmail(email)) .pipe( map(() => { return new NbAuthResult( - true + true, + null, + this.getOption(`${module}.redirect.success`), + [], + this.getOption(`${module}.defaultMessages`), ); }), - catchError(() => { - return observableOf(new NbAuthResult( - false, - )) - }) + catchError((error) => this.proccessFailure(error, module)), ); } - resetPassword(data?: any): Observable { + resetPassword({ email }): Observable { + return undefined; } @@ -121,7 +123,7 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { null, this.getOption(`${module}.redirect.success`), [], - this.getOption('refreshToken.defaultMessages'), + this.getOption(`${module}.defaultMessages`), this.createToken(token), ); }), diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 126d86359c..9346a9686a 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -31,14 +31,21 @@ import { FirebaseAuthResultComponent } from './result/result.component'; forms: { login: { strategy: 'password', + rememberMe: false, + socialLinks: [], }, register: { strategy: 'password', terms: false, + socialLinks: [], }, logout: { strategy: 'password', }, + requestPassword: { + strategy: 'password', + socialLinks: [], + }, validation: { password: { required: true, @@ -76,6 +83,11 @@ import { FirebaseAuthResultComponent } from './result/result.component'; success: '/firebase/login', } }, + requestPassword: { + redirect: { + success: '/firebase/login', + } + }, }), ] }), diff --git a/src/playground/without-layout/firebase/result/result.component.html b/src/playground/without-layout/firebase/result/result.component.html index 1495cfec30..091d3c8814 100644 --- a/src/playground/without-layout/firebase/result/result.component.html +++ b/src/playground/without-layout/firebase/result/result.component.html @@ -8,4 +8,5 @@

Firebase User:

+ diff --git a/src/playground/without-layout/firebase/result/result.component.ts b/src/playground/without-layout/firebase/result/result.component.ts index 4488ad0b8c..7035247b58 100644 --- a/src/playground/without-layout/firebase/result/result.component.ts +++ b/src/playground/without-layout/firebase/result/result.component.ts @@ -48,4 +48,8 @@ export class FirebaseAuthResultComponent implements OnInit { this.authService.refreshToken('password') .subscribe((res) => console.log('result of token refresh', res)); } + + requestPassword() { + this.router.navigateByUrl('/firebase/request-password'); + } } From a76882ee759dced65a2a92aaad15243e9ece9a4f Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 27 May 2020 13:33:06 +0300 Subject: [PATCH 06/34] feat(firebase-auth): add reset password --- .../firebase-password-strategy.options.ts | 8 +++++ .../strategies/firebase-password.strategy.ts | 36 +++++++++++++++++-- .../firebase/firebase.module.ts | 9 +++++ .../firebase/result/result.component.html | 2 ++ .../firebase/result/result.component.ts | 4 +++ 5 files changed, 56 insertions(+), 3 deletions(-) diff --git a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts b/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts index af96c949bf..6f7c255a6f 100644 --- a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts @@ -60,6 +60,14 @@ export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { defaultErrors: ['Something went wrong, please try again.'], defaultMessages: ['Reset password instructions have been sent to your email.'], }; + resetPassword?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['Your password has been successfully changed.'], + }; errors?: NbPasswordStrategyMessage = { key: 'message', getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( diff --git a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/firebase-password.strategy.ts index 11356660a9..653a439b36 100644 --- a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/firebase-password.strategy.ts @@ -7,7 +7,7 @@ import { Injectable } from '@angular/core'; import { NbAuthStrategy } from '../../auth/strategies/auth-strategy'; import { NbAuthResult } from '../../auth/services/auth-result'; -import { Observable, of as observableOf, throwError } from 'rxjs'; +import { Observable, of as observableOf } from 'rxjs'; import { NbAuthStrategyClass } from '../../auth/auth.options'; import { HttpClient } from '@angular/common/http'; import { @@ -109,9 +109,39 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { ); } - resetPassword({ email }): Observable { + resetPassword({ password }): Observable { + const module = 'resetPassword'; + return this.afAuth.authState + .pipe( + switchMap(user => { + if (user == null) { + return observableOf(new NbAuthResult( + false, + null, + this.getOption(`${module}.redirect.failure`), + ['There is no logged in user so the reset of the password isn\'t possible'], + )); + } + return this.updatePassword(user, password, module); + }), + ); + } - return undefined; + private updatePassword(user, password, module) { + return fromPromise(user.updatePassword(password)) + .pipe( + map(token => { + return new NbAuthResult( + true, + null, + this.getOption(`${module}.redirect.success`), + [], + this.getOption(`${module}.defaultMessages`), + this.createToken(token), + ); + }), + catchError(error => this.proccessFailure(error, module)), + ); } private refreshIdToken(user: User, module): Observable { diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 9346a9686a..92f98b86d2 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -46,6 +46,10 @@ import { FirebaseAuthResultComponent } from './result/result.component'; strategy: 'password', socialLinks: [], }, + resetPassword: { + strategy: 'password', + socialLinks: [], + }, validation: { password: { required: true, @@ -88,6 +92,11 @@ import { FirebaseAuthResultComponent } from './result/result.component'; success: '/firebase/login', } }, + resetPassword: { + redirect: { + success: '/firebase/login', + } + }, }), ] }), diff --git a/src/playground/without-layout/firebase/result/result.component.html b/src/playground/without-layout/firebase/result/result.component.html index 091d3c8814..e28f718210 100644 --- a/src/playground/without-layout/firebase/result/result.component.html +++ b/src/playground/without-layout/firebase/result/result.component.html @@ -10,3 +10,5 @@

Firebase User:

+ + diff --git a/src/playground/without-layout/firebase/result/result.component.ts b/src/playground/without-layout/firebase/result/result.component.ts index 7035247b58..28ff1e1686 100644 --- a/src/playground/without-layout/firebase/result/result.component.ts +++ b/src/playground/without-layout/firebase/result/result.component.ts @@ -52,4 +52,8 @@ export class FirebaseAuthResultComponent implements OnInit { requestPassword() { this.router.navigateByUrl('/firebase/request-password'); } + + resetPassword() { + this.router.navigateByUrl('firebase/reset-password'); + } } From 0a2c953f4b529e2ccd47451d14190f929d8b0fff Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 27 May 2020 19:34:30 +0300 Subject: [PATCH 07/34] feat(firebase-auth): add google strategy --- src/app/playground-components.ts | 4 +- .../firebase-auth/firebase-auth.module.ts | 4 +- src/framework/firebase-auth/public_api.ts | 5 +- .../firebase-google-strategy.options.ts | 42 ++++++++++++++ .../google/firebase-google.strategy.ts | 57 +++++++++++++++++++ .../firebase-password-strategy.options.ts | 10 ++-- .../firebase-password.strategy.ts | 23 ++++---- .../firebase/firebase-api.service.ts | 15 +++++ .../firebase/firebase-routing.module.ts | 6 +- .../firebase/firebase.module.ts | 40 ++++++++----- .../firebase/result/result.component.html | 14 ----- .../showcase/firebase-showcase.component.html | 22 +++++++ .../firebase-showcase.component.scss} | 0 .../firebase-showcase.component.ts} | 28 ++++++--- 14 files changed, 211 insertions(+), 59 deletions(-) create mode 100644 src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts create mode 100644 src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts rename src/framework/firebase-auth/strategies/{ => password}/firebase-password-strategy.options.ts (90%) rename src/framework/firebase-auth/strategies/{ => password}/firebase-password.strategy.ts (87%) create mode 100644 src/playground/without-layout/firebase/firebase-api.service.ts delete mode 100644 src/playground/without-layout/firebase/result/result.component.html create mode 100644 src/playground/without-layout/firebase/showcase/firebase-showcase.component.html rename src/playground/without-layout/firebase/{result/result.component.scss => showcase/firebase-showcase.component.scss} (100%) rename src/playground/without-layout/firebase/{result/result.component.ts => showcase/firebase-showcase.component.ts} (63%) diff --git a/src/app/playground-components.ts b/src/app/playground-components.ts index 52bab9771b..cef7ec76d8 100644 --- a/src/app/playground-components.ts +++ b/src/app/playground-components.ts @@ -1833,8 +1833,8 @@ export const PLAYGROUND_COMPONENTS: ComponentLink[] = [ { path: 'result', link: '/firebase/result', - component: 'FirebaseAuthResultComponent', - name: 'Firebase Auth Result', + component: 'FirebaseAuthShowcaseComponent', + name: 'Firebase Auth Showcase', }, ], }, diff --git a/src/framework/firebase-auth/firebase-auth.module.ts b/src/framework/firebase-auth/firebase-auth.module.ts index c6c1169146..b34193715f 100644 --- a/src/framework/firebase-auth/firebase-auth.module.ts +++ b/src/framework/firebase-auth/firebase-auth.module.ts @@ -6,12 +6,14 @@ import { NgModule } from '@angular/core'; -import { NbFirebasePasswordStrategy } from './strategies/firebase-password.strategy'; +import { NbFirebasePasswordStrategy } from './strategies/password/firebase-password.strategy'; +import { NbFirebaseGoogleStrategy } from './strategies/google/firebase-google.strategy'; @NgModule({ providers: [ NbFirebasePasswordStrategy, + NbFirebaseGoogleStrategy, ], }) export class FirebaseAuthModule { } diff --git a/src/framework/firebase-auth/public_api.ts b/src/framework/firebase-auth/public_api.ts index aeeaa4410a..52269ed267 100644 --- a/src/framework/firebase-auth/public_api.ts +++ b/src/framework/firebase-auth/public_api.ts @@ -5,5 +5,8 @@ */ -export * from './strategies/firebase-password.strategy'; +export * from './strategies/password/firebase-password.strategy'; +export * from './strategies/password/firebase-password-strategy.options'; +export * from './strategies/google/firebase-google.strategy'; +export * from './strategies/google/firebase-google-strategy.options'; export * from './firebase-auth.module'; diff --git a/src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts b/src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts new file mode 100644 index 0000000000..b801509c26 --- /dev/null +++ b/src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts @@ -0,0 +1,42 @@ +/** + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ +import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; +import { NbPasswordStrategyMessage } from '../../../auth/strategies/password/password-strategy-options'; +import { getDeepFromObject } from '../../../auth/helpers'; +import { + NbFirebasePasswordStrategyModule, + NbFirebasePasswordStrategyOptions, +} from '../password/firebase-password-strategy.options'; + + +export class NbFirebaseGoogleStrategyOptions extends NbAuthStrategyOptions { + login?: boolean | NbFirebasePasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Login/Email combination is not correct, please try again.'], + defaultMessages: ['You have been successfully logged in.'], + }; + errors?: NbPasswordStrategyMessage = { + key: 'message', + getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( + res, + options.errors.key, + options[module].defaultErrors, + ), + }; + messages?: NbPasswordStrategyMessage = { + key: 'messages', + getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( + res.body, + options.messages.key, + options[module].defaultMessages, + ), + }; +} + +export const firebaseGoolgeStrategyOptions: NbFirebaseGoogleStrategyOptions = new NbFirebaseGoogleStrategyOptions(); diff --git a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts new file mode 100644 index 0000000000..4f0243f986 --- /dev/null +++ b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts @@ -0,0 +1,57 @@ +/** + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ +import { Injectable } from '@angular/core'; +import { AngularFireAuth } from '@angular/fire/auth'; +import { firebaseGoolgeStrategyOptions, NbFirebaseGoogleStrategyOptions } from './firebase-google-strategy.options'; +import { Observable } from 'rxjs'; +import { fromPromise } from 'rxjs/internal-compatibility'; +import { catchError, switchMap } from 'rxjs/operators'; +import { NbAuthStrategyClass } from '../../../auth/auth.options'; +import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; +import { NbAuthResult } from '../../../auth/services/auth-result'; + +import { NbFirebasePasswordStrategy } from '../password/firebase-password.strategy'; +import * as firebase from 'firebase/app'; +import 'firebase/auth'; + +@Injectable() +export class NbFirebaseGoogleStrategy extends NbFirebasePasswordStrategy { + + protected defaultOptions: NbFirebaseGoogleStrategyOptions = firebaseGoolgeStrategyOptions; + + static setup(options: NbFirebaseGoogleStrategyOptions): [NbAuthStrategyClass, NbAuthStrategyOptions] { + return [NbFirebaseGoogleStrategy, options]; + } + + constructor( + protected afAuth: AngularFireAuth, + ) { + super(afAuth); + } + + authenticate(data?: any): Observable { + const module = 'login'; + const provider = new firebase.auth.GoogleAuthProvider(); + + return fromPromise(this.afAuth.signInWithPopup(provider)) + .pipe( + switchMap((res) => this.processSuccess(res, module)), + catchError(error => this.proccessFailure(error, module)), + ); + } + + register(data?: any): Observable { + throw new Error('`register` is not supported by `NbFirebaseGoogleStrategy`, use `authenticate`.'); + } + + requestPassword(data?: any): Observable { + throw new Error('`requestPassword` is not supported by `NbFirebaseGoogleStrategy`, use `authenticate`.'); + } + + resetPassword(data: any = {}): Observable { + throw new Error('`resetPassword` is not supported by `NbFirebaseGoogleStrategy`, use `authenticate`.'); + } +} diff --git a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts b/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts similarity index 90% rename from src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts rename to src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts index 6f7c255a6f..71afb704aa 100644 --- a/src/framework/firebase-auth/strategies/firebase-password-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts @@ -3,12 +3,13 @@ * Copyright Akveo. All Rights Reserved. * Licensed under the MIT License. See License.txt in the project root for license information. */ -import { NbAuthStrategyOptions } from '../../auth/strategies/auth-strategy-options'; -import { getDeepFromObject } from '../../auth/helpers'; +import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; import { NbPasswordStrategyMessage, - NbPasswordStrategyModule -} from '../../auth/strategies/password/password-strategy-options'; + NbPasswordStrategyModule, +} from '../../../auth/strategies/password/password-strategy-options'; +import { getDeepFromObject } from '../../../auth/helpers'; + export interface NbFirebasePasswordStrategyModule { redirect?: { @@ -86,4 +87,5 @@ export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { }; } +// tslint:disable-next-line:max-line-length export const firebasePasswordStrategyOptions: NbFirebasePasswordStrategyOptions = new NbFirebasePasswordStrategyOptions(); diff --git a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts similarity index 87% rename from src/framework/firebase-auth/strategies/firebase-password.strategy.ts rename to src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts index 653a439b36..2435ac2154 100644 --- a/src/framework/firebase-auth/strategies/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts @@ -5,21 +5,21 @@ */ import { Injectable } from '@angular/core'; -import { NbAuthStrategy } from '../../auth/strategies/auth-strategy'; -import { NbAuthResult } from '../../auth/services/auth-result'; + import { Observable, of as observableOf } from 'rxjs'; -import { NbAuthStrategyClass } from '../../auth/auth.options'; -import { HttpClient } from '@angular/common/http'; import { firebasePasswordStrategyOptions, - NbFirebasePasswordStrategyOptions + NbFirebasePasswordStrategyOptions, } from './firebase-password-strategy.options'; -import { NbAuthStrategyOptions } from '../../auth/strategies/auth-strategy-options'; import { AngularFireAuth } from '@angular/fire/auth'; import { fromPromise } from 'rxjs/internal-compatibility'; import { catchError, map, switchMap, take } from 'rxjs/operators'; import UserCredential = firebase.auth.UserCredential; import { User } from 'firebase'; +import { NbAuthStrategy } from '../../../auth/strategies/auth-strategy'; +import { NbAuthStrategyClass } from '../../../auth/auth.options'; +import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; +import { NbAuthResult } from '../../../auth/services/auth-result'; @Injectable() @@ -32,8 +32,7 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { } constructor( - protected http: HttpClient, - protected afAuth: AngularFireAuth + protected afAuth: AngularFireAuth, ) { super(); } @@ -127,7 +126,7 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { ); } - private updatePassword(user, password, module) { + protected updatePassword(user, password, module) { return fromPromise(user.updatePassword(password)) .pipe( map(token => { @@ -144,7 +143,7 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { ); } - private refreshIdToken(user: User, module): Observable { + protected refreshIdToken(user: User, module): Observable { return fromPromise(user.getIdToken(true)) .pipe( map(token => { @@ -161,7 +160,7 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { ); } - private proccessFailure(error: any, module: string): Observable { + protected proccessFailure(error: any, module: string): Observable { return observableOf(new NbAuthResult( false, error, @@ -170,7 +169,7 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { )); } - private processSuccess(res: UserCredential | null, module: string): Observable { + protected processSuccess(res: UserCredential | null, module: string): Observable { return this.afAuth.idToken .pipe(map(token => { return new NbAuthResult( diff --git a/src/playground/without-layout/firebase/firebase-api.service.ts b/src/playground/without-layout/firebase/firebase-api.service.ts new file mode 100644 index 0000000000..7d1690bab9 --- /dev/null +++ b/src/playground/without-layout/firebase/firebase-api.service.ts @@ -0,0 +1,15 @@ +import { Injectable } from '@angular/core'; +import { AngularFireDatabase } from '@angular/fire/database'; + +@Injectable() +export class FirebaseAPIService { + + constructor( + private db: AngularFireDatabase, + ) { + } + + getAdmins() { + return this.db.object('/admins/').valueChanges(); + } +} diff --git a/src/playground/without-layout/firebase/firebase-routing.module.ts b/src/playground/without-layout/firebase/firebase-routing.module.ts index c6bc100e91..0ba17d3bcd 100644 --- a/src/playground/without-layout/firebase/firebase-routing.module.ts +++ b/src/playground/without-layout/firebase/firebase-routing.module.ts @@ -16,7 +16,7 @@ import { NbResetPasswordComponent, } from '@nebular/auth'; import { FirebasePlaygroundComponent } from './firebase-playground.component'; -import { FirebaseAuthResultComponent } from './result/result.component'; +import { FirebaseAuthShowcaseComponent } from './showcase/firebase-showcase.component'; export const routes: Routes = [ @@ -59,8 +59,8 @@ export const routes: Routes = [ }, { path: 'result', - component: FirebaseAuthResultComponent, - } + component: FirebaseAuthShowcaseComponent, + }, // { // path: 'acl/acl-test.component', // component: AclTestComponent, diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 92f98b86d2..47cb9a2dfc 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -1,14 +1,15 @@ import { NgModule } from '@angular/core'; -import { NbAuthModule } from '../../../framework/auth/auth.module'; -import { NbFirebasePasswordStrategy } from '../../../framework/firebase-auth/strategies/firebase-password.strategy'; +import { NbFirebasePasswordStrategy, FirebaseAuthModule } from '@nebular/firebase-auth'; import { FirebasePlaygroundRoutingModule } from './firebase-routing.module'; import { FirebasePlaygroundComponent } from './firebase-playground.component'; -import { FirebaseAuthModule } from '@nebular/firebase-auth'; import { CommonModule } from '@angular/common'; -import { NbAuthJWTToken } from '../../../framework/auth/services/token/token'; +import { NbAuthJWTToken, NbAuthModule } from '@nebular/auth'; import { AngularFireAuthModule } from '@angular/fire/auth'; import { AngularFireModule } from '@angular/fire'; -import { FirebaseAuthResultComponent } from './result/result.component'; +import { FirebaseAuthShowcaseComponent } from './showcase/firebase-showcase.component'; +import { FirebaseAPIService } from './firebase-api.service'; +import { AngularFireDatabaseModule } from '@angular/fire/database'; +import { NbFirebaseGoogleStrategy } from '../../../framework/firebase-auth/strategies/google/firebase-google.strategy'; @NgModule({ imports: [ @@ -22,9 +23,10 @@ import { FirebaseAuthResultComponent } from './result/result.component'; projectId: 'auth-sample-f48f1', storageBucket: 'auth-sample-f48f1.appspot.com', messagingSenderId: '246754092661', - appId: '1:246754092661:web:c2606b9ecdbed579673a3c' + appId: '1:246754092661:web:c2606b9ecdbed579673a3c', }), AngularFireAuthModule, + AngularFireDatabaseModule, FirebasePlaygroundRoutingModule, FirebaseAuthModule, NbAuthModule.forRoot({ @@ -75,37 +77,45 @@ import { FirebaseAuthResultComponent } from './result/result.component'; login: { redirect: { success: '/firebase/result', - } + }, }, register: { redirect: { - success: '/firebase/result' - } + success: '/firebase/result', + }, }, logout: { redirect: { success: '/firebase/login', - } + }, }, requestPassword: { redirect: { success: '/firebase/login', - } + }, }, resetPassword: { redirect: { success: '/firebase/login', - } + }, + }, + }), + NbFirebaseGoogleStrategy.setup({ + name: 'google', + token: { + class: NbAuthJWTToken, // TODO: should be custom token? }, }), - ] + ], }), ], declarations: [ FirebasePlaygroundComponent, - FirebaseAuthResultComponent, + FirebaseAuthShowcaseComponent, + ], + providers: [ + FirebaseAPIService, ], - providers: [], }) export class FirebasePlaygroundModule { } diff --git a/src/playground/without-layout/firebase/result/result.component.html b/src/playground/without-layout/firebase/result/result.component.html deleted file mode 100644 index e28f718210..0000000000 --- a/src/playground/without-layout/firebase/result/result.component.html +++ /dev/null @@ -1,14 +0,0 @@ -

Nebular token:

-
 {{ userToken$ | async | json }} 
- -

Firebase User:

-
 {{ afUser$ | async | json }}
- - - - - - - - - diff --git a/src/playground/without-layout/firebase/showcase/firebase-showcase.component.html b/src/playground/without-layout/firebase/showcase/firebase-showcase.component.html new file mode 100644 index 0000000000..ddbc825620 --- /dev/null +++ b/src/playground/without-layout/firebase/showcase/firebase-showcase.component.html @@ -0,0 +1,22 @@ +

Nebular token:

+
 {{ userToken$ | async | json }} 
+ + + + +

Data from backend

+
{{ data$ | async | json }}
+ + + + + + + + + + + + + + diff --git a/src/playground/without-layout/firebase/result/result.component.scss b/src/playground/without-layout/firebase/showcase/firebase-showcase.component.scss similarity index 100% rename from src/playground/without-layout/firebase/result/result.component.scss rename to src/playground/without-layout/firebase/showcase/firebase-showcase.component.scss diff --git a/src/playground/without-layout/firebase/result/result.component.ts b/src/playground/without-layout/firebase/showcase/firebase-showcase.component.ts similarity index 63% rename from src/playground/without-layout/firebase/result/result.component.ts rename to src/playground/without-layout/firebase/showcase/firebase-showcase.component.ts index 28ff1e1686..7b65154ca0 100644 --- a/src/playground/without-layout/firebase/result/result.component.ts +++ b/src/playground/without-layout/firebase/showcase/firebase-showcase.component.ts @@ -1,20 +1,23 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { NbAuthService } from '../../../../framework/auth/services/auth.service'; import { NbAuthToken } from '../../../../framework/auth/services/token/token'; import { Observable, Subject } from 'rxjs'; import { Router } from '@angular/router'; import { AngularFireAuth } from '@angular/fire/auth'; import { User } from 'firebase'; +import { FirebaseAPIService } from '../firebase-api.service'; +import { take } from 'rxjs/operators'; @Component({ - selector: 'nb-firebase-auth-result', - templateUrl: './result.component.html', - styleUrls: ['./result.component.scss'] + selector: 'nb-firebase-auth-showcase', + templateUrl: './firebase-showcase.component.html', + styleUrls: ['./firebase-showcase.component.scss'], }) -export class FirebaseAuthResultComponent implements OnInit { +export class FirebaseAuthShowcaseComponent implements OnInit, OnDestroy { userToken$: Observable; afUser$: Observable; + data$: Observable; private destroyed$ = new Subject(); @@ -22,10 +25,10 @@ export class FirebaseAuthResultComponent implements OnInit { private authService: NbAuthService, private router: Router, private afAuth: AngularFireAuth, + private firebaseApi: FirebaseAPIService, ) { this.userToken$ = this.authService.onTokenChange(); this.afUser$ = this.afAuth.authState; - } ngOnInit(): void { @@ -46,7 +49,8 @@ export class FirebaseAuthResultComponent implements OnInit { refreshToken() { this.authService.refreshToken('password') - .subscribe((res) => console.log('result of token refresh', res)); + .pipe(take(1)) + .subscribe(() => {}); } requestPassword() { @@ -56,4 +60,14 @@ export class FirebaseAuthResultComponent implements OnInit { resetPassword() { this.router.navigateByUrl('firebase/reset-password'); } + + loginWithGoogle() { + this.authService.authenticate('google') + .pipe(take(1)) + .subscribe(() => {}); + } + + getData() { + this.data$ = this.firebaseApi.getAdmins(); + } } From b514d1e3fcc7146f4b8e4ebb0566acd591b3372b Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Thu, 28 May 2020 15:50:43 +0300 Subject: [PATCH 08/34] feat(firebase-auth): add additional params for google strategy --- .../firebase-google-strategy.options.ts | 26 +++++++------------ .../google/firebase-google.strategy.ts | 24 ++++++++++++++--- .../password/firebase-password.strategy.ts | 1 + 3 files changed, 31 insertions(+), 20 deletions(-) diff --git a/src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts b/src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts index b801509c26..b04d1d218e 100644 --- a/src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts @@ -13,30 +13,22 @@ import { export class NbFirebaseGoogleStrategyOptions extends NbAuthStrategyOptions { - login?: boolean | NbFirebasePasswordStrategyModule = { - redirect: { - success: '/', - failure: null, - }, - defaultErrors: ['Login/Email combination is not correct, please try again.'], - defaultMessages: ['You have been successfully logged in.'], + redirect?: { success?: string; failure?: string } = { + success: '/', + failure: null, }; errors?: NbPasswordStrategyMessage = { key: 'message', - getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( + getter: (module: string, res, options: NbFirebaseGoogleStrategyOptions) => getDeepFromObject( res, options.errors.key, - options[module].defaultErrors, - ), - }; - messages?: NbPasswordStrategyMessage = { - key: 'messages', - getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( - res.body, - options.messages.key, - options[module].defaultMessages, + options.defaultErrors, ), }; + scopes?: string[] = []; + customParameters?: { [key: string]: string } = {}; + defaultErrors?: any[] = ['Something went wrong, please try again.']; + defaultMessages?: any[] = ['You have been successfully authenticated.']; } export const firebaseGoolgeStrategyOptions: NbFirebaseGoogleStrategyOptions = new NbFirebaseGoogleStrategyOptions(); diff --git a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts index 4f0243f986..957ecb7862 100644 --- a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts +++ b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts @@ -8,7 +8,7 @@ import { AngularFireAuth } from '@angular/fire/auth'; import { firebaseGoolgeStrategyOptions, NbFirebaseGoogleStrategyOptions } from './firebase-google-strategy.options'; import { Observable } from 'rxjs'; import { fromPromise } from 'rxjs/internal-compatibility'; -import { catchError, switchMap } from 'rxjs/operators'; +import { catchError, map, switchMap } from 'rxjs/operators'; import { NbAuthStrategyClass } from '../../../auth/auth.options'; import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; import { NbAuthResult } from '../../../auth/services/auth-result'; @@ -16,6 +16,7 @@ import { NbAuthResult } from '../../../auth/services/auth-result'; import { NbFirebasePasswordStrategy } from '../password/firebase-password.strategy'; import * as firebase from 'firebase/app'; import 'firebase/auth'; +import UserCredential = firebase.auth.UserCredential; @Injectable() export class NbFirebaseGoogleStrategy extends NbFirebasePasswordStrategy { @@ -33,12 +34,15 @@ export class NbFirebaseGoogleStrategy extends NbFirebasePasswordStrategy { } authenticate(data?: any): Observable { - const module = 'login'; + const module = 'authenticate'; const provider = new firebase.auth.GoogleAuthProvider(); + const scopes = this.getOption('scopes'); + scopes.forEach((scope) => provider.addScope(scope)); + provider.setCustomParameters(this.getOption('customParameters')); return fromPromise(this.afAuth.signInWithPopup(provider)) .pipe( - switchMap((res) => this.processSuccess(res, module)), + switchMap((res) => this.processSuccess(res)), catchError(error => this.proccessFailure(error, module)), ); } @@ -54,4 +58,18 @@ export class NbFirebaseGoogleStrategy extends NbFirebasePasswordStrategy { resetPassword(data: any = {}): Observable { throw new Error('`resetPassword` is not supported by `NbFirebaseGoogleStrategy`, use `authenticate`.'); } + + protected processSuccess(res: UserCredential | null): Observable { + return this.afAuth.idToken + .pipe(map(token => { + return new NbAuthResult( + true, + res, + this.getOption('redirect.success'), + [], + this.getOption('defaultMessages'), + this.createToken(token), + ); + })); + } } diff --git a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts index 2435ac2154..63750e4ed5 100644 --- a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts @@ -166,6 +166,7 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { error, this.getOption(`${module}.redirect.failure`), this.getOption('errors.getter')(module, error, this.options), + [], )); } From e4601dbc44605e3bcf68050fb0519c42e7b10393 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Thu, 28 May 2020 15:55:07 +0300 Subject: [PATCH 09/34] feat(firebase-auth): handle NbAuthIllegalTokenError --- .../strategies/password/firebase-password.strategy.ts | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts index 63750e4ed5..3fa2765be1 100644 --- a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts @@ -20,6 +20,7 @@ import { NbAuthStrategy } from '../../../auth/strategies/auth-strategy'; import { NbAuthStrategyClass } from '../../../auth/auth.options'; import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; import { NbAuthResult } from '../../../auth/services/auth-result'; +import { NbAuthIllegalTokenError } from '../../../auth/services/token/token'; @Injectable() @@ -161,11 +162,19 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { } protected proccessFailure(error: any, module: string): Observable { + let errorMessages = []; + + if (error instanceof NbAuthIllegalTokenError) { + errorMessages.push(error.message) + } else { + errorMessages.push(this.getOption('errors.getter')(module, error, this.options)); + } + return observableOf(new NbAuthResult( false, error, this.getOption(`${module}.redirect.failure`), - this.getOption('errors.getter')(module, error, this.options), + errorMessages, [], )); } From 85ee7f6ada643e60b65ea999c2ee1b61a7b63e54 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Thu, 28 May 2020 17:35:29 +0300 Subject: [PATCH 10/34] feat(firebase-auth): add showcase for firebase-google strategy --- src/framework/auth/services/auth.service.ts | 2 +- .../google/firebase-google.strategy.ts | 2 +- .../firebase/firebase-api.service.ts | 4 +- .../firebase/firebase-routing.module.ts | 11 ++- .../firebase/firebase.module.ts | 6 +- .../google-auth-showcase.component.html | 25 +++++++ .../google-auth-showcase.component.scss} | 0 .../google-auth-showcase.component.ts | 49 +++++++++++++ .../password-auth-showcase.component.html | 27 +++++++ .../password-auth-showcase.component.scss | 0 .../password-auth-showcase.component.ts | 53 ++++++++++++++ .../showcase/firebase-showcase.component.html | 22 ------ .../showcase/firebase-showcase.component.ts | 73 ------------------- 13 files changed, 170 insertions(+), 104 deletions(-) create mode 100644 src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html rename src/playground/without-layout/firebase/{showcase/firebase-showcase.component.scss => google-auth-showcase/google-auth-showcase.component.scss} (100%) create mode 100644 src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts create mode 100644 src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.html create mode 100644 src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.scss create mode 100644 src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts delete mode 100644 src/playground/without-layout/firebase/showcase/firebase-showcase.component.html delete mode 100644 src/playground/without-layout/firebase/showcase/firebase-showcase.component.ts diff --git a/src/framework/auth/services/auth.service.ts b/src/framework/auth/services/auth.service.ts index 575e58f48e..a89ca540d3 100644 --- a/src/framework/auth/services/auth.service.ts +++ b/src/framework/auth/services/auth.service.ts @@ -6,7 +6,7 @@ import { Inject, Injectable } from '@angular/core'; import { Observable, of as observableOf } from 'rxjs'; -import { switchMap, map } from 'rxjs/operators'; +import { switchMap, map, tap } from 'rxjs/operators'; import { NbAuthStrategy } from '../strategies/auth-strategy'; import { NB_AUTH_STRATEGIES } from '../auth.options'; diff --git a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts index 957ecb7862..766426dbd2 100644 --- a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts +++ b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts @@ -6,7 +6,7 @@ import { Injectable } from '@angular/core'; import { AngularFireAuth } from '@angular/fire/auth'; import { firebaseGoolgeStrategyOptions, NbFirebaseGoogleStrategyOptions } from './firebase-google-strategy.options'; -import { Observable } from 'rxjs'; +import { Observable, of } from 'rxjs'; import { fromPromise } from 'rxjs/internal-compatibility'; import { catchError, map, switchMap } from 'rxjs/operators'; import { NbAuthStrategyClass } from '../../../auth/auth.options'; diff --git a/src/playground/without-layout/firebase/firebase-api.service.ts b/src/playground/without-layout/firebase/firebase-api.service.ts index 7d1690bab9..76c81eff26 100644 --- a/src/playground/without-layout/firebase/firebase-api.service.ts +++ b/src/playground/without-layout/firebase/firebase-api.service.ts @@ -9,7 +9,7 @@ export class FirebaseAPIService { ) { } - getAdmins() { - return this.db.object('/admins/').valueChanges(); + getGreeting() { + return this.db.object('/greeting/').valueChanges(); } } diff --git a/src/playground/without-layout/firebase/firebase-routing.module.ts b/src/playground/without-layout/firebase/firebase-routing.module.ts index 0ba17d3bcd..cdc56453b7 100644 --- a/src/playground/without-layout/firebase/firebase-routing.module.ts +++ b/src/playground/without-layout/firebase/firebase-routing.module.ts @@ -16,7 +16,8 @@ import { NbResetPasswordComponent, } from '@nebular/auth'; import { FirebasePlaygroundComponent } from './firebase-playground.component'; -import { FirebaseAuthShowcaseComponent } from './showcase/firebase-showcase.component'; +import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password-auth-showcase.component'; +import { GoogleAuthShowcaseComponent } from './google-auth-showcase/google-auth-showcase.component'; export const routes: Routes = [ @@ -58,8 +59,12 @@ export const routes: Routes = [ ], }, { - path: 'result', - component: FirebaseAuthShowcaseComponent, + path: 'password-showcase', + component: PasswordAuthShowcaseComponent, + }, + { + path: 'google-showcase', + component: GoogleAuthShowcaseComponent, }, // { // path: 'acl/acl-test.component', diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 47cb9a2dfc..87f49dc3f3 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -6,10 +6,11 @@ import { CommonModule } from '@angular/common'; import { NbAuthJWTToken, NbAuthModule } from '@nebular/auth'; import { AngularFireAuthModule } from '@angular/fire/auth'; import { AngularFireModule } from '@angular/fire'; -import { FirebaseAuthShowcaseComponent } from './showcase/firebase-showcase.component'; +import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password-auth-showcase.component'; import { FirebaseAPIService } from './firebase-api.service'; import { AngularFireDatabaseModule } from '@angular/fire/database'; import { NbFirebaseGoogleStrategy } from '../../../framework/firebase-auth/strategies/google/firebase-google.strategy'; +import { GoogleAuthShowcaseComponent } from './google-auth-showcase/google-auth-showcase.component'; @NgModule({ imports: [ @@ -111,7 +112,8 @@ import { NbFirebaseGoogleStrategy } from '../../../framework/firebase-auth/strat ], declarations: [ FirebasePlaygroundComponent, - FirebaseAuthShowcaseComponent, + PasswordAuthShowcaseComponent, + GoogleAuthShowcaseComponent, ], providers: [ FirebaseAPIService, diff --git a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html b/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html new file mode 100644 index 0000000000..98e7802f33 --- /dev/null +++ b/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html @@ -0,0 +1,25 @@ +
Authenticated: {{ isAuthenticated$ | async }}
+ +
+ Current User Token: +
 {{ userToken$ | async | json }} 
+
+ +
+ Data from backend +
{{ data$ | async | json }}
+
+ + + + + + diff --git a/src/playground/without-layout/firebase/showcase/firebase-showcase.component.scss b/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.scss similarity index 100% rename from src/playground/without-layout/firebase/showcase/firebase-showcase.component.scss rename to src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.scss diff --git a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts b/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts new file mode 100644 index 0000000000..4091489454 --- /dev/null +++ b/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts @@ -0,0 +1,49 @@ +import { Component, OnInit } from '@angular/core'; +import { Observable, of } from 'rxjs'; +import { FirebaseAPIService } from '../firebase-api.service'; +import { NbAuthService } from '../../../../framework/auth/services/auth.service'; +import { NbAuthToken } from '../../../../framework/auth/services/token/token'; +import { catchError, share, take } from 'rxjs/operators'; +import { NbAuthResult } from '../../../../framework/auth/services/auth-result'; + +@Component({ + selector: 'app-google-auth-showcase', + templateUrl: './google-auth-showcase.component.html', + styleUrls: ['./google-auth-showcase.component.scss'] +}) +export class GoogleAuthShowcaseComponent { + + userToken$: Observable; + isAuthenticated$: Observable; + // afUser$: Observable; + data$: Observable; + + constructor( + private firebaseApi: FirebaseAPIService, + private authService: NbAuthService, + ) { + this.userToken$ = this.authService.onTokenChange(); + this.isAuthenticated$ = this.authService.onAuthenticationChange(); + } + + logout() { + this.authService.logout('google') + .pipe(take(1)) + .subscribe((authResult: NbAuthResult) => {}); + } + + login() { + this.authService.authenticate('google') + .pipe(take(1)) + .subscribe((authResult: NbAuthResult) => {}); + } + + getData() { + this.data$ = this.firebaseApi.getGreeting() + .pipe( + take(1), + catchError((error) => of(error)), + share(), + ); + } +} diff --git a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.html b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.html new file mode 100644 index 0000000000..726740315b --- /dev/null +++ b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.html @@ -0,0 +1,27 @@ +
Authenticated: {{ isAuthenticated$ | async }}
+ +
+ Current User Token: +
 {{ userToken$ | async | json }} 
+
+ +
+ Data from backend +
{{ data$ | async | json }}
+
+ + + + + + + + diff --git a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.scss b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.scss new file mode 100644 index 0000000000..e69de29bb2 diff --git a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts new file mode 100644 index 0000000000..98fc719a71 --- /dev/null +++ b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts @@ -0,0 +1,53 @@ +import { Component, OnDestroy, OnInit } from '@angular/core'; +import { NbAuthService } from '../../../../framework/auth/services/auth.service'; +import { NbAuthToken } from '../../../../framework/auth/services/token/token'; +import { Observable, of } from 'rxjs'; +import { Router } from '@angular/router'; +import { AngularFireAuth } from '@angular/fire/auth'; +import { FirebaseAPIService } from '../firebase-api.service'; +import { catchError, share, take } from 'rxjs/operators'; + +@Component({ + selector: 'nb-password-auth-showcase', + templateUrl: './password-auth-showcase.component.html', + styleUrls: ['./password-auth-showcase.component.scss'], +}) +export class PasswordAuthShowcaseComponent { + + userToken$: Observable; + isAuthenticated$: Observable; + // afUser$: Observable; + data$: Observable; + + constructor( + private authService: NbAuthService, + private router: Router, + private afAuth: AngularFireAuth, + private firebaseApi: FirebaseAPIService, + ) { + this.userToken$ = this.authService.onTokenChange(); + this.isAuthenticated$ = this.authService.onAuthenticationChange(); + // this.afUser$ = this.afAuth.authState; + } + + logout() { + this.router.navigateByUrl('/firebase/logout'); + } + + login() { + this.router.navigateByUrl('/firebase/login'); + } + + resetPassword() { + this.router.navigateByUrl('firebase/reset-password'); + } + + getData() { + this.data$ = this.firebaseApi.getGreeting() + .pipe( + take(1), + catchError((error) => of(error)), + share(), + ); + } +} diff --git a/src/playground/without-layout/firebase/showcase/firebase-showcase.component.html b/src/playground/without-layout/firebase/showcase/firebase-showcase.component.html deleted file mode 100644 index ddbc825620..0000000000 --- a/src/playground/without-layout/firebase/showcase/firebase-showcase.component.html +++ /dev/null @@ -1,22 +0,0 @@ -

Nebular token:

-
 {{ userToken$ | async | json }} 
- - - - -

Data from backend

-
{{ data$ | async | json }}
- - - - - - - - - - - - - - diff --git a/src/playground/without-layout/firebase/showcase/firebase-showcase.component.ts b/src/playground/without-layout/firebase/showcase/firebase-showcase.component.ts deleted file mode 100644 index 7b65154ca0..0000000000 --- a/src/playground/without-layout/firebase/showcase/firebase-showcase.component.ts +++ /dev/null @@ -1,73 +0,0 @@ -import { Component, OnDestroy, OnInit } from '@angular/core'; -import { NbAuthService } from '../../../../framework/auth/services/auth.service'; -import { NbAuthToken } from '../../../../framework/auth/services/token/token'; -import { Observable, Subject } from 'rxjs'; -import { Router } from '@angular/router'; -import { AngularFireAuth } from '@angular/fire/auth'; -import { User } from 'firebase'; -import { FirebaseAPIService } from '../firebase-api.service'; -import { take } from 'rxjs/operators'; - -@Component({ - selector: 'nb-firebase-auth-showcase', - templateUrl: './firebase-showcase.component.html', - styleUrls: ['./firebase-showcase.component.scss'], -}) -export class FirebaseAuthShowcaseComponent implements OnInit, OnDestroy { - - userToken$: Observable; - afUser$: Observable; - data$: Observable; - - private destroyed$ = new Subject(); - - constructor( - private authService: NbAuthService, - private router: Router, - private afAuth: AngularFireAuth, - private firebaseApi: FirebaseAPIService, - ) { - this.userToken$ = this.authService.onTokenChange(); - this.afUser$ = this.afAuth.authState; - } - - ngOnInit(): void { - } - - ngOnDestroy() { - this.destroyed$.next(); - this.destroyed$.complete(); - } - - logout() { - this.router.navigateByUrl('/firebase/logout'); - } - - login() { - this.router.navigateByUrl('/firebase/login'); - } - - refreshToken() { - this.authService.refreshToken('password') - .pipe(take(1)) - .subscribe(() => {}); - } - - requestPassword() { - this.router.navigateByUrl('/firebase/request-password'); - } - - resetPassword() { - this.router.navigateByUrl('firebase/reset-password'); - } - - loginWithGoogle() { - this.authService.authenticate('google') - .pipe(take(1)) - .subscribe(() => {}); - } - - getData() { - this.data$ = this.firebaseApi.getAdmins(); - } -} From 720882c7c6d962fe486a65f54557d05b673dfdf8 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Fri, 29 May 2020 03:05:42 +0300 Subject: [PATCH 11/34] feat(firebase-auth): add base firebase strategy --- .../firebase-auth/firebase-auth.module.ts | 2 + src/framework/firebase-auth/public_api.ts | 3 +- .../strategies/base/firebase-base.strategy.ts | 92 +++++++++++++++++++ ...base-identity-provider-strategy.options.ts | 39 ++++++++ .../firebase-google-strategy.options.ts | 34 ------- .../google/firebase-google.strategy.ts | 45 ++------- .../firebase-password-strategy.options.ts | 16 +--- .../password/firebase-password.strategy.ts | 64 +------------ 8 files changed, 151 insertions(+), 144 deletions(-) create mode 100644 src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts create mode 100644 src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts delete mode 100644 src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts diff --git a/src/framework/firebase-auth/firebase-auth.module.ts b/src/framework/firebase-auth/firebase-auth.module.ts index b34193715f..8aebba4d34 100644 --- a/src/framework/firebase-auth/firebase-auth.module.ts +++ b/src/framework/firebase-auth/firebase-auth.module.ts @@ -8,12 +8,14 @@ import { NgModule } from '@angular/core'; import { NbFirebasePasswordStrategy } from './strategies/password/firebase-password.strategy'; import { NbFirebaseGoogleStrategy } from './strategies/google/firebase-google.strategy'; +import { NbFirebaseFacebookStrategy } from './strategies/facebook/firebase-facebook.strategy'; @NgModule({ providers: [ NbFirebasePasswordStrategy, NbFirebaseGoogleStrategy, + NbFirebaseFacebookStrategy, ], }) export class FirebaseAuthModule { } diff --git a/src/framework/firebase-auth/public_api.ts b/src/framework/firebase-auth/public_api.ts index 52269ed267..e5a7da158d 100644 --- a/src/framework/firebase-auth/public_api.ts +++ b/src/framework/firebase-auth/public_api.ts @@ -5,8 +5,9 @@ */ +export * from './strategies/base/firebase-base.strategy'; export * from './strategies/password/firebase-password.strategy'; export * from './strategies/password/firebase-password-strategy.options'; +export * from './strategies/base/firebase-identity-provider-strategy.options'; export * from './strategies/google/firebase-google.strategy'; -export * from './strategies/google/firebase-google-strategy.options'; export * from './firebase-auth.module'; diff --git a/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts b/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts new file mode 100644 index 0000000000..c56c7fb0dd --- /dev/null +++ b/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts @@ -0,0 +1,92 @@ +/* + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ + +import { Injectable } from '@angular/core'; + +import { Observable, of as observableOf } from 'rxjs'; +import { AngularFireAuth } from '@angular/fire/auth'; +import { fromPromise } from 'rxjs/internal-compatibility'; +import { catchError, map } from 'rxjs/operators'; +import UserCredential = firebase.auth.UserCredential; +import { NbAuthStrategy } from '../../../auth/strategies/auth-strategy'; +import { NbAuthResult } from '../../../auth/services/auth-result'; +import { NbAuthIllegalTokenError } from '../../../auth/services/token/token'; + + +@Injectable() +export abstract class NbFirebaseBaseStrategy extends NbAuthStrategy { + + constructor( + protected afAuth: AngularFireAuth, + ) { + super(); + } + + logout(): Observable { + const module = 'logout'; + return fromPromise(this.afAuth.signOut()) + .pipe( + map(() => { + return new NbAuthResult( + true, + null, + this.getOption(`${module}.redirect.success`), + [], + this.getOption(`${module}.defaultMessages`), + ) + }), + catchError((error) => this.proccessFailure(error, module)), + ); + } + + register(data?: any): Observable { + throw new Error(`\`register\` is not supported by \`${this.constructor.name}\`, use \`authenticate\`.`); + } + + requestPassword(data?: any): Observable { + throw new Error(`\`requestPassword\` is not supported by \`${this.constructor.name}\`, use \`authenticate\`.`); + } + + resetPassword(data: any = {}): Observable { + throw new Error(`\`resetPassword\` is not supported by \`${this.constructor.name}\`, use \`authenticate\`.`); + } + + refreshToken(data: any = {}): Observable { + throw new Error(`\`refreshToken\` is not supported by \`${this.constructor.name}\`, use \`authenticate\`.`); + } + + protected proccessFailure(error: any, module: string): Observable { + let errorMessages = []; + + if (error instanceof NbAuthIllegalTokenError) { + errorMessages.push(error.message) + } else { + errorMessages.push(this.getOption('errors.getter')(module, error, this.options)); + } + + return observableOf(new NbAuthResult( + false, + error, + this.getOption(`${module}.redirect.failure`), + errorMessages, + [], + )); + } + + protected processSuccess(res: UserCredential | null, module: string): Observable { + return this.afAuth.idToken + .pipe(map(token => { + return new NbAuthResult( + true, + res, + this.getOption(`${module}.redirect.success`), + [], + this.getOption('messages.getter')(module, res, this.options), + this.createToken(token), + ); + })); + } +} diff --git a/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts b/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts new file mode 100644 index 0000000000..5bc8320e1d --- /dev/null +++ b/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts @@ -0,0 +1,39 @@ +/** + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ +import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; +import { + NbPasswordStrategyMessage, + NbPasswordStrategyModule +} from '../../../auth/strategies/password/password-strategy-options'; + +export class NbFirebaseIdentityProviderStrategyOptions extends NbAuthStrategyOptions { + logout?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['You have been successfully logged out.'], + }; + authenticate?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['You have been successfully authenticated.'], + }; + errors?: NbPasswordStrategyMessage = { + key: 'message', + getter: (module: string, res, options: NbFirebaseIdentityProviderStrategyOptions) => options[module].defaultErrors, + }; + messages?: NbPasswordStrategyMessage = { + key: 'message', + getter: (module: string, res, options: NbFirebaseIdentityProviderStrategyOptions) => options[module].defaultMessages, + }; + scopes?: string[] = []; + customParameters?: { [key: string]: string } = {}; +}; diff --git a/src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts b/src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts deleted file mode 100644 index b04d1d218e..0000000000 --- a/src/framework/firebase-auth/strategies/google/firebase-google-strategy.options.ts +++ /dev/null @@ -1,34 +0,0 @@ -/** - * @license - * Copyright Akveo. All Rights Reserved. - * Licensed under the MIT License. See License.txt in the project root for license information. - */ -import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; -import { NbPasswordStrategyMessage } from '../../../auth/strategies/password/password-strategy-options'; -import { getDeepFromObject } from '../../../auth/helpers'; -import { - NbFirebasePasswordStrategyModule, - NbFirebasePasswordStrategyOptions, -} from '../password/firebase-password-strategy.options'; - - -export class NbFirebaseGoogleStrategyOptions extends NbAuthStrategyOptions { - redirect?: { success?: string; failure?: string } = { - success: '/', - failure: null, - }; - errors?: NbPasswordStrategyMessage = { - key: 'message', - getter: (module: string, res, options: NbFirebaseGoogleStrategyOptions) => getDeepFromObject( - res, - options.errors.key, - options.defaultErrors, - ), - }; - scopes?: string[] = []; - customParameters?: { [key: string]: string } = {}; - defaultErrors?: any[] = ['Something went wrong, please try again.']; - defaultMessages?: any[] = ['You have been successfully authenticated.']; -} - -export const firebaseGoolgeStrategyOptions: NbFirebaseGoogleStrategyOptions = new NbFirebaseGoogleStrategyOptions(); diff --git a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts index 766426dbd2..7a663ad653 100644 --- a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts +++ b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts @@ -5,25 +5,26 @@ */ import { Injectable } from '@angular/core'; import { AngularFireAuth } from '@angular/fire/auth'; -import { firebaseGoolgeStrategyOptions, NbFirebaseGoogleStrategyOptions } from './firebase-google-strategy.options'; -import { Observable, of } from 'rxjs'; +import { Observable } from 'rxjs'; import { fromPromise } from 'rxjs/internal-compatibility'; -import { catchError, map, switchMap } from 'rxjs/operators'; +import { catchError, switchMap } from 'rxjs/operators'; import { NbAuthStrategyClass } from '../../../auth/auth.options'; import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; import { NbAuthResult } from '../../../auth/services/auth-result'; -import { NbFirebasePasswordStrategy } from '../password/firebase-password.strategy'; import * as firebase from 'firebase/app'; import 'firebase/auth'; -import UserCredential = firebase.auth.UserCredential; +import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; +import { + NbFirebaseIdentityProviderStrategyOptions +} from '../base/firebase-identity-provider-strategy.options'; @Injectable() -export class NbFirebaseGoogleStrategy extends NbFirebasePasswordStrategy { +export class NbFirebaseGoogleStrategy extends NbFirebaseBaseStrategy { - protected defaultOptions: NbFirebaseGoogleStrategyOptions = firebaseGoolgeStrategyOptions; + protected defaultOptions: NbFirebaseIdentityProviderStrategyOptions = new NbFirebaseIdentityProviderStrategyOptions(); - static setup(options: NbFirebaseGoogleStrategyOptions): [NbAuthStrategyClass, NbAuthStrategyOptions] { + static setup(options: NbFirebaseIdentityProviderStrategyOptions): [NbAuthStrategyClass, NbAuthStrategyOptions] { return [NbFirebaseGoogleStrategy, options]; } @@ -42,34 +43,8 @@ export class NbFirebaseGoogleStrategy extends NbFirebasePasswordStrategy { return fromPromise(this.afAuth.signInWithPopup(provider)) .pipe( - switchMap((res) => this.processSuccess(res)), + switchMap((res) => this.processSuccess(res, module)), catchError(error => this.proccessFailure(error, module)), ); } - - register(data?: any): Observable { - throw new Error('`register` is not supported by `NbFirebaseGoogleStrategy`, use `authenticate`.'); - } - - requestPassword(data?: any): Observable { - throw new Error('`requestPassword` is not supported by `NbFirebaseGoogleStrategy`, use `authenticate`.'); - } - - resetPassword(data: any = {}): Observable { - throw new Error('`resetPassword` is not supported by `NbFirebaseGoogleStrategy`, use `authenticate`.'); - } - - protected processSuccess(res: UserCredential | null): Observable { - return this.afAuth.idToken - .pipe(map(token => { - return new NbAuthResult( - true, - res, - this.getOption('redirect.success'), - [], - this.getOption('defaultMessages'), - this.createToken(token), - ); - })); - } } diff --git a/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts b/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts index 71afb704aa..8c1d256200 100644 --- a/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts @@ -10,18 +10,8 @@ import { } from '../../../auth/strategies/password/password-strategy-options'; import { getDeepFromObject } from '../../../auth/helpers'; - -export interface NbFirebasePasswordStrategyModule { - redirect?: { - success?: string | null; - failure?: string | null; - }; - defaultErrors?: string[], - defaultMessages?: string[], -} - export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { - register?: boolean | NbFirebasePasswordStrategyModule = { + register?: boolean | NbPasswordStrategyModule = { redirect: { success: '/', failure: null, @@ -29,7 +19,7 @@ export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { defaultErrors: ['Something went wrong, please try again.'], defaultMessages: ['You have been successfully registered.'], }; - login?: boolean | NbFirebasePasswordStrategyModule = { + login?: boolean | NbPasswordStrategyModule = { redirect: { success: '/', failure: null, @@ -37,7 +27,7 @@ export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { defaultErrors: ['Login/Email combination is not correct, please try again.'], defaultMessages: ['You have been successfully logged in.'], }; - logout?: boolean | NbFirebasePasswordStrategyModule = { + logout?: boolean | NbPasswordStrategyModule = { redirect: { success: '/', failure: null, diff --git a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts index 3fa2765be1..9f4d1e476c 100644 --- a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts @@ -11,20 +11,17 @@ import { firebasePasswordStrategyOptions, NbFirebasePasswordStrategyOptions, } from './firebase-password-strategy.options'; -import { AngularFireAuth } from '@angular/fire/auth'; import { fromPromise } from 'rxjs/internal-compatibility'; import { catchError, map, switchMap, take } from 'rxjs/operators'; -import UserCredential = firebase.auth.UserCredential; import { User } from 'firebase'; -import { NbAuthStrategy } from '../../../auth/strategies/auth-strategy'; import { NbAuthStrategyClass } from '../../../auth/auth.options'; import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; import { NbAuthResult } from '../../../auth/services/auth-result'; -import { NbAuthIllegalTokenError } from '../../../auth/services/token/token'; +import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; @Injectable() -export class NbFirebasePasswordStrategy extends NbAuthStrategy { +export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { protected defaultOptions: NbFirebasePasswordStrategyOptions = firebasePasswordStrategyOptions; @@ -32,12 +29,6 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { return [NbFirebasePasswordStrategy, options]; } - constructor( - protected afAuth: AngularFireAuth, - ) { - super(); - } - authenticate({ email, password }: any): Observable { const module = 'login'; return fromPromise(this.afAuth.signInWithEmailAndPassword(email, password)) @@ -47,28 +38,11 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { ); } - logout(): Observable { - const module = 'logout'; - return fromPromise(this.afAuth.signOut()) - .pipe( - map(() => { - return new NbAuthResult( - true, - null, - this.getOption(`${module}.redirect.success`), - [], - this.getOption(`${module}.defaultMessages`), - ) - }), - catchError((error) => this.proccessFailure(error, module)), - ); - } - refreshToken(data?: any): Observable { const module = 'refreshToken'; return this.afAuth.authState .pipe( - take(1), // need this to prevent loop + take(1), switchMap(user => { if (user == null) { return observableOf(new NbAuthResult( @@ -160,36 +134,4 @@ export class NbFirebasePasswordStrategy extends NbAuthStrategy { catchError(error => this.proccessFailure(error, module)), ); } - - protected proccessFailure(error: any, module: string): Observable { - let errorMessages = []; - - if (error instanceof NbAuthIllegalTokenError) { - errorMessages.push(error.message) - } else { - errorMessages.push(this.getOption('errors.getter')(module, error, this.options)); - } - - return observableOf(new NbAuthResult( - false, - error, - this.getOption(`${module}.redirect.failure`), - errorMessages, - [], - )); - } - - protected processSuccess(res: UserCredential | null, module: string): Observable { - return this.afAuth.idToken - .pipe(map(token => { - return new NbAuthResult( - true, - res, - this.getOption(`${module}.redirect.success`), - [], - this.getOption('messages.getter')(module, res, this.options), - this.createToken(token), - ); - })); - } } From a10884b8ba2eda41aac737a05a9c46faf21ee373 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Fri, 29 May 2020 03:07:44 +0300 Subject: [PATCH 12/34] feat(firebase-auth): add facebook strategy --- src/app/playground-components.ts | 14 +++++-- .../facebook/firebase-facebook.strategy.ts | 42 +++++++++++++++++++ .../firebase/firebase.module.ts | 15 ++++--- .../google-auth-showcase.component.html | 8 +++- .../google-auth-showcase.component.ts | 14 ++++++- .../password-auth-showcase.component.ts | 8 ++-- 6 files changed, 84 insertions(+), 17 deletions(-) create mode 100644 src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts diff --git a/src/app/playground-components.ts b/src/app/playground-components.ts index cef7ec76d8..2abc76c99e 100644 --- a/src/app/playground-components.ts +++ b/src/app/playground-components.ts @@ -1831,10 +1831,16 @@ export const PLAYGROUND_COMPONENTS: ComponentLink[] = [ name: 'Nb Reset Password', }, { - path: 'result', - link: '/firebase/result', - component: 'FirebaseAuthShowcaseComponent', - name: 'Firebase Auth Showcase', + path: 'password-showcase', + link: '/firebase/password-showcase', + component: 'PasswordAuthShowcaseComponent', + name: 'Password Auth Showcase', + }, + { + path: 'google-showcase', + link: '/firebase/google-showcase', + component: 'GoogleAuthShowcaseComponent', + name: 'Google Auth Showcase', }, ], }, diff --git a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts new file mode 100644 index 0000000000..b16b938a80 --- /dev/null +++ b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts @@ -0,0 +1,42 @@ +/** + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ +import { Injectable } from '@angular/core'; +import { Observable } from 'rxjs'; +import { fromPromise } from 'rxjs/internal-compatibility'; +import { catchError, switchMap } from 'rxjs/operators'; +import { NbAuthStrategyClass } from '../../../auth/auth.options'; +import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; +import { NbAuthResult } from '../../../auth/services/auth-result'; +import * as firebase from 'firebase/app'; +import 'firebase/auth'; +import { + NbFirebaseIdentityProviderStrategyOptions +} from '../base/firebase-identity-provider-strategy.options'; +import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; + +@Injectable() +export class NbFirebaseFacebookStrategy extends NbFirebaseBaseStrategy { + + protected defaultOptions: NbFirebaseIdentityProviderStrategyOptions = new NbFirebaseIdentityProviderStrategyOptions(); + + static setup(options: NbFirebaseIdentityProviderStrategyOptions): [NbAuthStrategyClass, NbAuthStrategyOptions] { + return [NbFirebaseFacebookStrategy, options]; + } + + authenticate(data?: any): Observable { + const module = 'authenticate'; + const provider = new firebase.auth.FacebookAuthProvider(); + const scopes = this.getOption('scopes'); + scopes.forEach((scope) => provider.addScope(scope)); + provider.setCustomParameters(this.getOption('customParameters')); + + return fromPromise(this.afAuth.signInWithPopup(provider)) + .pipe( + switchMap((res) => this.processSuccess(res, module)), + catchError(error => this.proccessFailure(error, module)), + ); + } +} diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 87f49dc3f3..69f18f29a3 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -11,12 +11,11 @@ import { FirebaseAPIService } from './firebase-api.service'; import { AngularFireDatabaseModule } from '@angular/fire/database'; import { NbFirebaseGoogleStrategy } from '../../../framework/firebase-auth/strategies/google/firebase-google.strategy'; import { GoogleAuthShowcaseComponent } from './google-auth-showcase/google-auth-showcase.component'; +import { NbFirebaseFacebookStrategy } from '../../../framework/firebase-auth/strategies/facebook/firebase-facebook.strategy'; @NgModule({ imports: [ CommonModule, - // developers test firebase app - // TODO: change for some better alternative AngularFireModule.initializeApp({ apiKey: 'AIzaSyBEvySH74-sISCTkCC6lXUd3zzYj26GjRk', authDomain: 'auth-sample-f48f1.firebaseapp.com', @@ -73,16 +72,16 @@ import { GoogleAuthShowcaseComponent } from './google-auth-showcase/google-auth- NbFirebasePasswordStrategy.setup({ name: 'password', token: { - class: NbAuthJWTToken, // TODO: should be custom token? + class: NbAuthJWTToken, }, login: { redirect: { - success: '/firebase/result', + success: '/firebase/password-showcase', }, }, register: { redirect: { - success: '/firebase/result', + success: '/firebase/password-showcase', }, }, logout: { @@ -107,6 +106,12 @@ import { GoogleAuthShowcaseComponent } from './google-auth-showcase/google-auth- class: NbAuthJWTToken, // TODO: should be custom token? }, }), + NbFirebaseFacebookStrategy.setup({ + name: 'facebook', + token: { + class: NbAuthJWTToken, // TODO: should be custom token? + }, + }), ], }), ], diff --git a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html b/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html index 98e7802f33..19b5ad4af4 100644 --- a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html +++ b/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html @@ -18,8 +18,14 @@ + + diff --git a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts b/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts index 4091489454..277b8aa0c4 100644 --- a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts +++ b/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts @@ -32,10 +32,20 @@ export class GoogleAuthShowcaseComponent { .subscribe((authResult: NbAuthResult) => {}); } - login() { + loginWithGoogle() { this.authService.authenticate('google') .pipe(take(1)) - .subscribe((authResult: NbAuthResult) => {}); + .subscribe((authResult: NbAuthResult) => { + console.log(authResult); + }); + } + + loginWithFacebook() { + this.authService.authenticate('facebook') + .pipe(take(1)) + .subscribe((authResult: NbAuthResult) => { + console.log(authResult); + }); } getData() { diff --git a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts index 98fc719a71..c30f66b927 100644 --- a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts +++ b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts @@ -5,7 +5,7 @@ import { Observable, of } from 'rxjs'; import { Router } from '@angular/router'; import { AngularFireAuth } from '@angular/fire/auth'; import { FirebaseAPIService } from '../firebase-api.service'; -import { catchError, share, take } from 'rxjs/operators'; +import { catchError, share, take, tap } from 'rxjs/operators'; @Component({ selector: 'nb-password-auth-showcase', @@ -16,7 +16,6 @@ export class PasswordAuthShowcaseComponent { userToken$: Observable; isAuthenticated$: Observable; - // afUser$: Observable; data$: Observable; constructor( @@ -25,9 +24,8 @@ export class PasswordAuthShowcaseComponent { private afAuth: AngularFireAuth, private firebaseApi: FirebaseAPIService, ) { - this.userToken$ = this.authService.onTokenChange(); - this.isAuthenticated$ = this.authService.onAuthenticationChange(); - // this.afUser$ = this.afAuth.authState; + this.userToken$ = this.authService.onTokenChange().pipe(tap((isAuth) => console.log(isAuth))); + this.isAuthenticated$ = this.authService.isAuthenticated().pipe(tap((isAuth) => console.log(isAuth))); } logout() { From 9b6a206a5007431e06bd0d8aec4e7220f21cff6e Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Mon, 1 Jun 2020 14:51:24 +0300 Subject: [PATCH 13/34] feat(firebase-auth): remove facebook and twitter auth from showcase --- .../firebase/firebase-routing.module.ts | 6 ++--- .../firebase/firebase.module.ts | 23 +++++++------------ ...ty-providers-auth-showcase.component.html} | 6 ----- ...ty-providers-auth-showcase.component.scss} | 0 ...tity-providers-auth-showcase.component.ts} | 18 ++++----------- .../password-auth-showcase.component.ts | 9 ++++---- 6 files changed, 20 insertions(+), 42 deletions(-) rename src/playground/without-layout/firebase/{google-auth-showcase/google-auth-showcase.component.html => identity-proders-auth-showcase/identity-providers-auth-showcase.component.html} (82%) rename src/playground/without-layout/firebase/{google-auth-showcase/google-auth-showcase.component.scss => identity-proders-auth-showcase/identity-providers-auth-showcase.component.scss} (100%) rename src/playground/without-layout/firebase/{google-auth-showcase/google-auth-showcase.component.ts => identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts} (74%) diff --git a/src/playground/without-layout/firebase/firebase-routing.module.ts b/src/playground/without-layout/firebase/firebase-routing.module.ts index cdc56453b7..d75040ab8a 100644 --- a/src/playground/without-layout/firebase/firebase-routing.module.ts +++ b/src/playground/without-layout/firebase/firebase-routing.module.ts @@ -17,7 +17,7 @@ import { } from '@nebular/auth'; import { FirebasePlaygroundComponent } from './firebase-playground.component'; import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password-auth-showcase.component'; -import { GoogleAuthShowcaseComponent } from './google-auth-showcase/google-auth-showcase.component'; +import { IdentityProvidersAuthShowcaseComponent } from './identity-proders-auth-showcase/identity-providers-auth-showcase.component'; export const routes: Routes = [ @@ -63,8 +63,8 @@ export const routes: Routes = [ component: PasswordAuthShowcaseComponent, }, { - path: 'google-showcase', - component: GoogleAuthShowcaseComponent, + path: 'social-auth-showcase', + component: IdentityProvidersAuthShowcaseComponent, }, // { // path: 'acl/acl-test.component', diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 69f18f29a3..fc34a9c929 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -10,8 +10,7 @@ import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password import { FirebaseAPIService } from './firebase-api.service'; import { AngularFireDatabaseModule } from '@angular/fire/database'; import { NbFirebaseGoogleStrategy } from '../../../framework/firebase-auth/strategies/google/firebase-google.strategy'; -import { GoogleAuthShowcaseComponent } from './google-auth-showcase/google-auth-showcase.component'; -import { NbFirebaseFacebookStrategy } from '../../../framework/firebase-auth/strategies/facebook/firebase-facebook.strategy'; +import { IdentityProvidersAuthShowcaseComponent } from './identity-proders-auth-showcase/identity-providers-auth-showcase.component'; @NgModule({ imports: [ @@ -76,40 +75,34 @@ import { NbFirebaseFacebookStrategy } from '../../../framework/firebase-auth/str }, login: { redirect: { - success: '/firebase/password-showcase', + success: 'example/firebase/password-showcase', }, }, register: { redirect: { - success: '/firebase/password-showcase', + success: 'example/firebase/password-showcase', }, }, logout: { redirect: { - success: '/firebase/login', + success: 'example/firebase/login', }, }, requestPassword: { redirect: { - success: '/firebase/login', + success: 'example/firebase/login', }, }, resetPassword: { redirect: { - success: '/firebase/login', + success: 'example/firebase/login', }, }, }), NbFirebaseGoogleStrategy.setup({ name: 'google', token: { - class: NbAuthJWTToken, // TODO: should be custom token? - }, - }), - NbFirebaseFacebookStrategy.setup({ - name: 'facebook', - token: { - class: NbAuthJWTToken, // TODO: should be custom token? + class: NbAuthJWTToken, }, }), ], @@ -118,7 +111,7 @@ import { NbFirebaseFacebookStrategy } from '../../../framework/firebase-auth/str declarations: [ FirebasePlaygroundComponent, PasswordAuthShowcaseComponent, - GoogleAuthShowcaseComponent, + IdentityProvidersAuthShowcaseComponent, ], providers: [ FirebaseAPIService, diff --git a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html b/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.html similarity index 82% rename from src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html rename to src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.html index 19b5ad4af4..bbb3fb6e2a 100644 --- a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.html +++ b/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.html @@ -22,10 +22,4 @@ Login with google - - diff --git a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.scss b/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.scss similarity index 100% rename from src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.scss rename to src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.scss diff --git a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts b/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts similarity index 74% rename from src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts rename to src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts index 277b8aa0c4..856d228fd6 100644 --- a/src/playground/without-layout/firebase/google-auth-showcase/google-auth-showcase.component.ts +++ b/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts @@ -8,10 +8,10 @@ import { NbAuthResult } from '../../../../framework/auth/services/auth-result'; @Component({ selector: 'app-google-auth-showcase', - templateUrl: './google-auth-showcase.component.html', - styleUrls: ['./google-auth-showcase.component.scss'] + templateUrl: './identity-providers-auth-showcase.component.html', + styleUrls: ['./identity-providers-auth-showcase.component.scss'] }) -export class GoogleAuthShowcaseComponent { +export class IdentityProvidersAuthShowcaseComponent { userToken$: Observable; isAuthenticated$: Observable; @@ -35,17 +35,7 @@ export class GoogleAuthShowcaseComponent { loginWithGoogle() { this.authService.authenticate('google') .pipe(take(1)) - .subscribe((authResult: NbAuthResult) => { - console.log(authResult); - }); - } - - loginWithFacebook() { - this.authService.authenticate('facebook') - .pipe(take(1)) - .subscribe((authResult: NbAuthResult) => { - console.log(authResult); - }); + .subscribe((authResult: NbAuthResult) => {}); } getData() { diff --git a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts index c30f66b927..a1bc7ef20f 100644 --- a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts +++ b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts @@ -2,7 +2,7 @@ import { Component, OnDestroy, OnInit } from '@angular/core'; import { NbAuthService } from '../../../../framework/auth/services/auth.service'; import { NbAuthToken } from '../../../../framework/auth/services/token/token'; import { Observable, of } from 'rxjs'; -import { Router } from '@angular/router'; +import { ActivatedRoute, Router } from '@angular/router'; import { AngularFireAuth } from '@angular/fire/auth'; import { FirebaseAPIService } from '../firebase-api.service'; import { catchError, share, take, tap } from 'rxjs/operators'; @@ -23,21 +23,22 @@ export class PasswordAuthShowcaseComponent { private router: Router, private afAuth: AngularFireAuth, private firebaseApi: FirebaseAPIService, + private route: ActivatedRoute, ) { this.userToken$ = this.authService.onTokenChange().pipe(tap((isAuth) => console.log(isAuth))); this.isAuthenticated$ = this.authService.isAuthenticated().pipe(tap((isAuth) => console.log(isAuth))); } logout() { - this.router.navigateByUrl('/firebase/logout'); + this.router.navigate(['../logout'], { relativeTo: this.route }); } login() { - this.router.navigateByUrl('/firebase/login'); + this.router.navigate(['../login'], { relativeTo: this.route }); } resetPassword() { - this.router.navigateByUrl('firebase/reset-password'); + this.router.navigate(['../reset-password'], { relativeTo: this.route }); } getData() { From 970acc66b35530430178a31b853ecc7f7b036b2d Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Mon, 1 Jun 2020 15:00:30 +0300 Subject: [PATCH 14/34] feat(firebase-auth): add default token --- .../base/firebase-identity-provider-strategy.options.ts | 4 ++++ .../password/firebase-password-strategy.options.ts | 4 ++++ src/playground/without-layout/firebase/firebase.module.ts | 6 ------ 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts b/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts index 5bc8320e1d..b0dd9351c1 100644 --- a/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts @@ -8,8 +8,12 @@ import { NbPasswordStrategyMessage, NbPasswordStrategyModule } from '../../../auth/strategies/password/password-strategy-options'; +import { NbAuthJWTToken } from '../../../auth/services/token/token'; export class NbFirebaseIdentityProviderStrategyOptions extends NbAuthStrategyOptions { + token? = { + class: NbAuthJWTToken, + }; logout?: boolean | NbPasswordStrategyModule = { redirect: { success: '/', diff --git a/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts b/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts index 8c1d256200..f2cf42fa55 100644 --- a/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts @@ -9,8 +9,12 @@ import { NbPasswordStrategyModule, } from '../../../auth/strategies/password/password-strategy-options'; import { getDeepFromObject } from '../../../auth/helpers'; +import { NbAuthJWTToken } from '../../../auth/services/token/token'; export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { + token? = { + class: NbAuthJWTToken, + }; register?: boolean | NbPasswordStrategyModule = { redirect: { success: '/', diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index fc34a9c929..60ee345467 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -70,9 +70,6 @@ import { IdentityProvidersAuthShowcaseComponent } from './identity-proders-auth- strategies: [ NbFirebasePasswordStrategy.setup({ name: 'password', - token: { - class: NbAuthJWTToken, - }, login: { redirect: { success: 'example/firebase/password-showcase', @@ -101,9 +98,6 @@ import { IdentityProvidersAuthShowcaseComponent } from './identity-proders-auth- }), NbFirebaseGoogleStrategy.setup({ name: 'google', - token: { - class: NbAuthJWTToken, - }, }), ], }), From b05309dc7c445e98f628ace8f22a3ed111513ca1 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Mon, 1 Jun 2020 15:04:01 +0300 Subject: [PATCH 15/34] feat(firebase-auth): add twitter strategy --- .../firebase-auth/firebase-auth.module.ts | 2 + .../twitter/firebase-twitter.strategy.ts | 40 +++++++++++++++++++ 2 files changed, 42 insertions(+) create mode 100644 src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts diff --git a/src/framework/firebase-auth/firebase-auth.module.ts b/src/framework/firebase-auth/firebase-auth.module.ts index 8aebba4d34..ae48c288dd 100644 --- a/src/framework/firebase-auth/firebase-auth.module.ts +++ b/src/framework/firebase-auth/firebase-auth.module.ts @@ -9,6 +9,7 @@ import { NgModule } from '@angular/core'; import { NbFirebasePasswordStrategy } from './strategies/password/firebase-password.strategy'; import { NbFirebaseGoogleStrategy } from './strategies/google/firebase-google.strategy'; import { NbFirebaseFacebookStrategy } from './strategies/facebook/firebase-facebook.strategy'; +import { NbFirebaseTwitteStrategy } from './strategies/twitter/firebase-twitter.strategy'; @NgModule({ @@ -16,6 +17,7 @@ import { NbFirebaseFacebookStrategy } from './strategies/facebook/firebase-faceb NbFirebasePasswordStrategy, NbFirebaseGoogleStrategy, NbFirebaseFacebookStrategy, + NbFirebaseTwitteStrategy, ], }) export class FirebaseAuthModule { } diff --git a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts new file mode 100644 index 0000000000..abfb653d1e --- /dev/null +++ b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts @@ -0,0 +1,40 @@ +/** + * @license + * Copyright Akveo. All Rights Reserved. + * Licensed under the MIT License. See License.txt in the project root for license information. + */ +import { Injectable } from '@angular/core'; +import { Observable } from 'rxjs'; +import { fromPromise } from 'rxjs/internal-compatibility'; +import { catchError, switchMap } from 'rxjs/operators'; +import { NbAuthStrategyClass } from '../../../auth/auth.options'; +import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; +import { NbAuthResult } from '../../../auth/services/auth-result'; +import * as firebase from 'firebase/app'; +import 'firebase/auth'; +import { + NbFirebaseIdentityProviderStrategyOptions +} from '../base/firebase-identity-provider-strategy.options'; +import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; + +@Injectable() +export class NbFirebaseTwitteStrategy extends NbFirebaseBaseStrategy { + + protected defaultOptions: NbFirebaseIdentityProviderStrategyOptions = new NbFirebaseIdentityProviderStrategyOptions(); + + static setup(options: NbFirebaseIdentityProviderStrategyOptions): [NbAuthStrategyClass, NbAuthStrategyOptions] { + return [NbFirebaseTwitteStrategy, options]; + } + + authenticate(data?: any): Observable { + const module = 'authenticate'; + const provider = new firebase.auth.TwitterAuthProvider(); + provider.setCustomParameters(this.getOption('customParameters')); + + return fromPromise(this.afAuth.signInWithPopup(provider)) + .pipe( + switchMap((res) => this.processSuccess(res, module)), + catchError(error => this.proccessFailure(error, module)), + ); + } +} From 88acb3560dea3b405d71bcb96e303372a882ecd0 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Mon, 1 Jun 2020 15:09:13 +0300 Subject: [PATCH 16/34] feat(firebase-auth): add documentation --- docs/articles/auth/firebase-authentication.md | 195 ++++++++++++++++++ .../getting-started/what-is-nebular.md | 2 + docs/structure.ts | 16 ++ docs/tsconfig.app.json | 3 +- 4 files changed, 215 insertions(+), 1 deletion(-) create mode 100644 docs/articles/auth/firebase-authentication.md diff --git a/docs/articles/auth/firebase-authentication.md b/docs/articles/auth/firebase-authentication.md new file mode 100644 index 0000000000..7ad3cb6861 --- /dev/null +++ b/docs/articles/auth/firebase-authentication.md @@ -0,0 +1,195 @@ +## Firebase authentication with Nebular Auth +@nebualar/firebase-auth allows authentication in firebase applications with nebular/auth. +The package provides the following strategies: + - NbFirebasePasswordStrategy - authentication with email/password + - NbFirebaseGoogleStrategy - authentication with google accounts + - NbFirebaseFacebookStrategy - authentication with facebook accounts + - NbFirebaseTwitteStrategy - authentication with twitter accounts + +## Installation + +
+
Note
+
+ The package connects firebase auth with nebular/auth so you need `firebase` and `@angular/fire` installed + and configured for your application. For more instructions please see [@angular/fire docs](https://github.com/akveo/nebular/tree/master/src/playground/without-layout/azure). + Also make sure you import AngularFireAuthModule. +
+
+ + +Install Nebular Auth and Nebular Firebase Auth. + + ```sh + npm i @nebular/eva-icons firebase @angular\fire + ``` + +Import the NbAuthModule with some firebase strategies, in that example we use NbFirebasePasswordStrategy. + +```ts +import { NbAuthModule } from '@nebular/auth'; +import { NbFirebasePasswordStrategy } from '@nebular/firebase-auth'; + + +@NgModule({ + imports: [ + // ... + + NbAuthModule.forRoot({ + strategies: [ + NbFirebasePasswordStrategy.setup({ + name: 'password', + }), + ], + forms: {}, + }), + ], +}); +``` +
+ +## Authentication with email and password + +Nebular Firebase Auth provides NbFirebasePassword strategy for authentication with email and password. + +Strategy settings: +
+
Note
+
+ There is no need to copy over the whole object to change the settings you need. + Also, this.getOption call won't work outside of the default options declaration (which is inside of the NbPasswordAuthStrategy class), + so you have to replace it with a custom helper function if you need it. +
+
+ +```ts +export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { + name: string; + token = { + class: NbAuthJWTToken, + }; + register?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['You have been successfully registered.'], + }; + login?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Login/Email combination is not correct, please try again.'], + defaultMessages: ['You have been successfully logged in.'], + }; + logout?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['You have been successfully logged out.'], + }; + refreshToken?: boolean | NbPasswordStrategyModule = { + redirect: { + success: null, + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['Your token has been successfully refreshed.'], + }; + requestPassword?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['Reset password instructions have been sent to your email.'], + }; + resetPassword?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['Your password has been successfully changed.'], + }; + errors?: NbPasswordStrategyMessage = { + key: 'message', + getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( + res, + options.errors.key, + options[module].defaultErrors, + ), + }; + messages?: NbPasswordStrategyMessage = { + key: 'messages', + getter: (module: string, res, options: NbFirebasePasswordStrategyOptions) => getDeepFromObject( + res.body, + options.messages.key, + options[module].defaultMessages, + ), + }; +} +``` +
+ +## Social Authentication providers + +Nebular Firebase Auth for now provides strategies for authentication with Google, Facebook and Twitter. +These strategies share the same settings structure and default settings value. + +Strategies settings: + +
+
Note
+
+ There is no need to copy over the whole object to change the settings you need. + Also, this.getOption call won't work outside of the default options declaration (which is inside of the NbPasswordAuthStrategy class), + so you have to replace it with a custom helper function if you need it. +
+
+ +```ts +export class NbFirebaseIdentityProviderStrategyOptions extends NbAuthStrategyOptions { + name: string; + logout?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['You have been successfully logged out.'], + }; + authenticate?: boolean | NbPasswordStrategyModule = { + redirect: { + success: '/', + failure: null, + }, + defaultErrors: ['Something went wrong, please try again.'], + defaultMessages: ['You have been successfully authenticated.'], + }; + errors?: NbPasswordStrategyMessage = { + key: 'message', + getter: (module: string, res, options: NbFirebaseIdentityProviderStrategyOptions) => options[module].defaultErrors, + }; + messages?: NbPasswordStrategyMessage = { + key: 'message', + getter: (module: string, res, options: NbFirebaseIdentityProviderStrategyOptions) => options[module].defaultMessages, + }; + scopes?: string[] = []; + customParameters?: { [key: string]: string } = {}; + } +}; +``` +
+ +## Complete example + +A complete code example could be found on [GitHub](https://github.com/akveo/nebular/tree/master/src/playground/with-layout/firebase). + +And here the playground examples available to play around with + - [Firebase Nebular Password Example](/example/firebase/password-showcase) + - [Firebase Nebular Social Authentication Providers Example](/example/firebase/social-auth-showcase) diff --git a/docs/articles/getting-started/what-is-nebular.md b/docs/articles/getting-started/what-is-nebular.md index d7eb019b98..f96171016a 100644 --- a/docs/articles/getting-started/what-is-nebular.md +++ b/docs/articles/getting-started/what-is-nebular.md @@ -16,6 +16,8 @@ Nebular modules are distributed as separated `npm` packages: - Authentication components (login/register/reset password/restore password). - Multiple configurable authentication Strategies (backend connectors). - Helpers for token management (storing, passing with HTTP requests, etc). +- Nebular Auth for Firebase `@nebular/firebase-auth + - module for authentication in firebase applications with nebular/auth - Nebular Security `@nebular/security` - roles and permissions management. - Nebular Moment `@nebular/moment` diff --git a/docs/structure.ts b/docs/structure.ts index 03832e576a..ecafe9e887 100644 --- a/docs/structure.ts +++ b/docs/structure.ts @@ -915,6 +915,22 @@ export const structure = [ }, ], }, + { + type: 'page', + name: 'Firebase Authentication', + children: [ + { + type: 'block', + block: 'markdown', + source: 'auth/firebase-authentication.md', + }, + { + type: 'block', + block: 'component', + source: 'NbPasswordAuthStrategy', + }, + ], + }, { type: 'page', name: 'NbAuthService', diff --git a/docs/tsconfig.app.json b/docs/tsconfig.app.json index 15ffc4f06c..86841ae302 100644 --- a/docs/tsconfig.app.json +++ b/docs/tsconfig.app.json @@ -18,7 +18,8 @@ "@nebular/theme": ["../src/framework/theme/public_api.ts"], "@nebular/auth": ["../src/framework/auth/public_api.ts"], "@nebular/security": ["../src/framework/security/public_api.ts"], - "@nebular/eva-icons": ["../src/framework/eva-icons/public_api.ts"] + "@nebular/eva-icons": ["../src/framework/eva-icons/public_api.ts"], + "@nebular/firebase-auth": ["../src/framework/firebase-auth/public_api.ts"] } }, "files": [ From d61abb5a5bdca30a6b73f0ad9ef707bfa892ba61 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Mon, 1 Jun 2020 15:12:24 +0300 Subject: [PATCH 17/34] style(firebase-auth): add empty line after license --- .../base/firebase-identity-provider-strategy.options.ts | 1 + .../strategies/facebook/firebase-facebook.strategy.ts | 2 ++ .../firebase-auth/strategies/google/firebase-google.strategy.ts | 1 + .../strategies/password/firebase-password-strategy.options.ts | 1 + .../strategies/twitter/firebase-twitter.strategy.ts | 1 + 5 files changed, 6 insertions(+) diff --git a/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts b/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts index b0dd9351c1..ee9a898168 100644 --- a/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts @@ -3,6 +3,7 @@ * Copyright Akveo. All Rights Reserved. * Licensed under the MIT License. See License.txt in the project root for license information. */ + import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; import { NbPasswordStrategyMessage, diff --git a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts index b16b938a80..d3d6ffbf89 100644 --- a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts +++ b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts @@ -3,6 +3,8 @@ * Copyright Akveo. All Rights Reserved. * Licensed under the MIT License. See License.txt in the project root for license information. */ + + import { Injectable } from '@angular/core'; import { Observable } from 'rxjs'; import { fromPromise } from 'rxjs/internal-compatibility'; diff --git a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts index 7a663ad653..6e1a802055 100644 --- a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts +++ b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts @@ -3,6 +3,7 @@ * Copyright Akveo. All Rights Reserved. * Licensed under the MIT License. See License.txt in the project root for license information. */ + import { Injectable } from '@angular/core'; import { AngularFireAuth } from '@angular/fire/auth'; import { Observable } from 'rxjs'; diff --git a/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts b/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts index f2cf42fa55..1b3f82bb31 100644 --- a/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts @@ -3,6 +3,7 @@ * Copyright Akveo. All Rights Reserved. * Licensed under the MIT License. See License.txt in the project root for license information. */ + import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; import { NbPasswordStrategyMessage, diff --git a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts index abfb653d1e..81bf108cda 100644 --- a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts +++ b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts @@ -3,6 +3,7 @@ * Copyright Akveo. All Rights Reserved. * Licensed under the MIT License. See License.txt in the project root for license information. */ + import { Injectable } from '@angular/core'; import { Observable } from 'rxjs'; import { fromPromise } from 'rxjs/internal-compatibility'; From c9f3dee2b78bceb578d022f2c5fd9dc58af69f7d Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Mon, 1 Jun 2020 15:19:28 +0300 Subject: [PATCH 18/34] chore(firebase-auth): add firebase-auth to the list of firebase packages --- .../gulp/tasks/build/bundle/rollup-config.ts | 1 + scripts/gulp/tasks/change-prefix.ts | 13 +++++++++-- scripts/gulp/tasks/config.ts | 1 + src/app/playground-components.ts | 8 +++---- src/framework/firebase-auth/LICENSE.txt | 22 +++++++++++++++++++ src/framework/firebase-auth/README.md | 1 + src/framework/firebase-auth/package.json | 5 +++-- 7 files changed, 43 insertions(+), 8 deletions(-) create mode 100644 src/framework/firebase-auth/LICENSE.txt create mode 100644 src/framework/firebase-auth/README.md diff --git a/scripts/gulp/tasks/build/bundle/rollup-config.ts b/scripts/gulp/tasks/build/bundle/rollup-config.ts index 155ee45c11..965f00efd2 100644 --- a/scripts/gulp/tasks/build/bundle/rollup-config.ts +++ b/scripts/gulp/tasks/build/bundle/rollup-config.ts @@ -47,6 +47,7 @@ const ROLLUP_GLOBALS = { '@nebular/moment': 'nb.moment', '@nebular/date-fns': 'nb.date-fns', '@nebular/eva-icons': 'nb.eva-icons', + '@nebular/firebase-auth': 'nb.eva-icons', 'eva-icons': 'eva-icons', }; diff --git a/scripts/gulp/tasks/change-prefix.ts b/scripts/gulp/tasks/change-prefix.ts index d0277119bf..77b9993e53 100644 --- a/scripts/gulp/tasks/change-prefix.ts +++ b/scripts/gulp/tasks/change-prefix.ts @@ -8,7 +8,7 @@ import { capitalize, dasherize } from '@angular-devkit/core/src/utils/strings'; import { BUILD_DIR } from './config'; -type NebularPackage = 'auth' | 'bootstrap' | 'dateFns' | 'evaIcons' | 'moment' | 'theme' | 'security'; +type NebularPackage = 'auth' | 'bootstrap' | 'dateFns' | 'evaIcons' | 'moment' | 'theme' | 'security' | 'firebase-auth'; interface PackagePrefix { prefix: string; @@ -26,7 +26,16 @@ interface StringReplacement { const ROLLUP_CONFIG_DIR = './scripts/gulp/tasks/bundle'; const ROLLUP_CONFIG_PATH = `${ROLLUP_CONFIG_DIR}/rollup-config.ts`; -const NEBULAR_PACKAGES: NebularPackage[] = ['auth', 'bootstrap', 'dateFns', 'evaIcons', 'moment', 'theme', 'security']; +const NEBULAR_PACKAGES: NebularPackage[] = [ + 'auth', + 'bootstrap', + 'dateFns', + 'evaIcons', + 'moment', + 'theme', + 'security', + 'firebase-auth', +]; /** * Reads package prefix and all package names passed as command line arguments. diff --git a/scripts/gulp/tasks/config.ts b/scripts/gulp/tasks/config.ts index 70e670d756..a27914c898 100644 --- a/scripts/gulp/tasks/config.ts +++ b/scripts/gulp/tasks/config.ts @@ -12,4 +12,5 @@ export const JS_PACKAGES = [ 'moment', 'security', 'theme', + 'firebase-auth', ]; diff --git a/src/app/playground-components.ts b/src/app/playground-components.ts index 2abc76c99e..a857d146e7 100644 --- a/src/app/playground-components.ts +++ b/src/app/playground-components.ts @@ -1837,10 +1837,10 @@ export const PLAYGROUND_COMPONENTS: ComponentLink[] = [ name: 'Password Auth Showcase', }, { - path: 'google-showcase', - link: '/firebase/google-showcase', - component: 'GoogleAuthShowcaseComponent', - name: 'Google Auth Showcase', + path: 'social-auth-showcase', + link: '/firebase/social-auth-showcase', + component: 'IdentityProvidersAuthShowcaseComponent', + name: 'Identity Providers Auth Showcase', }, ], }, diff --git a/src/framework/firebase-auth/LICENSE.txt b/src/framework/firebase-auth/LICENSE.txt new file mode 100644 index 0000000000..031c83cb11 --- /dev/null +++ b/src/framework/firebase-auth/LICENSE.txt @@ -0,0 +1,22 @@ +The MIT License (MIT) + +Copyright (c) 2017 Akveo. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + diff --git a/src/framework/firebase-auth/README.md b/src/framework/firebase-auth/README.md new file mode 100644 index 0000000000..6cb1e27bed --- /dev/null +++ b/src/framework/firebase-auth/README.md @@ -0,0 +1 @@ +### @nebular/firebase-auth module, more details https://akveo.github.io/nebular/ diff --git a/src/framework/firebase-auth/package.json b/src/framework/firebase-auth/package.json index a1a9bc69b6..9f332b6723 100644 --- a/src/framework/firebase-auth/package.json +++ b/src/framework/firebase-auth/package.json @@ -1,5 +1,5 @@ { - "name": "@nebular/eva-icons", + "name": "@nebular/firebase-auth", "version": "5.0.0", "description": "@nebular/firebase-auth", "author": "akveo", @@ -28,7 +28,8 @@ "@angular/core": "^9.0.0", "@nebular/auth": "^5.0.0", "rxjs": "^6.5.1", - "firebase": "^7.14.5" + "firebase": "^7.14.5", + "@angular/fire": "^6.0.0" }, "sideEffects": false } From 0d4074b48c4590049436b3e7927d0286c22fd82f Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Mon, 1 Jun 2020 15:37:21 +0300 Subject: [PATCH 19/34] chore(firebase-auth): fix lint errors --- src/framework/auth/services/auth.service.ts | 2 +- .../strategies/base/firebase-base.strategy.ts | 2 +- .../firebase-identity-provider-strategy.options.ts | 6 ++++-- .../strategies/facebook/firebase-facebook.strategy.ts | 2 +- .../strategies/google/firebase-google.strategy.ts | 2 +- .../strategies/twitter/firebase-twitter.strategy.ts | 2 +- .../without-layout/firebase/firebase-routing.module.ts | 4 +++- .../without-layout/firebase/firebase.module.ts | 6 ++++-- .../identity-providers-auth-showcase.component.ts | 4 ++-- .../password-auth-showcase.component.ts | 10 ++++------ 10 files changed, 22 insertions(+), 18 deletions(-) diff --git a/src/framework/auth/services/auth.service.ts b/src/framework/auth/services/auth.service.ts index a89ca540d3..575e58f48e 100644 --- a/src/framework/auth/services/auth.service.ts +++ b/src/framework/auth/services/auth.service.ts @@ -6,7 +6,7 @@ import { Inject, Injectable } from '@angular/core'; import { Observable, of as observableOf } from 'rxjs'; -import { switchMap, map, tap } from 'rxjs/operators'; +import { switchMap, map } from 'rxjs/operators'; import { NbAuthStrategy } from '../strategies/auth-strategy'; import { NB_AUTH_STRATEGIES } from '../auth.options'; diff --git a/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts b/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts index c56c7fb0dd..cd9defc925 100644 --- a/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts +++ b/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts @@ -59,7 +59,7 @@ export abstract class NbFirebaseBaseStrategy extends NbAuthStrategy { } protected proccessFailure(error: any, module: string): Observable { - let errorMessages = []; + const errorMessages = []; if (error instanceof NbAuthIllegalTokenError) { errorMessages.push(error.message) diff --git a/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts b/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts index ee9a898168..2be4167664 100644 --- a/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts @@ -7,7 +7,7 @@ import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; import { NbPasswordStrategyMessage, - NbPasswordStrategyModule + NbPasswordStrategyModule, } from '../../../auth/strategies/password/password-strategy-options'; import { NbAuthJWTToken } from '../../../auth/services/token/token'; @@ -37,7 +37,9 @@ export class NbFirebaseIdentityProviderStrategyOptions extends NbAuthStrategyOpt }; messages?: NbPasswordStrategyMessage = { key: 'message', - getter: (module: string, res, options: NbFirebaseIdentityProviderStrategyOptions) => options[module].defaultMessages, + getter: (module: string, res, options: NbFirebaseIdentityProviderStrategyOptions) => { + return options[module].defaultMessages; + }, }; scopes?: string[] = []; customParameters?: { [key: string]: string } = {}; diff --git a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts index d3d6ffbf89..7aaebd6890 100644 --- a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts +++ b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts @@ -15,7 +15,7 @@ import { NbAuthResult } from '../../../auth/services/auth-result'; import * as firebase from 'firebase/app'; import 'firebase/auth'; import { - NbFirebaseIdentityProviderStrategyOptions + NbFirebaseIdentityProviderStrategyOptions, } from '../base/firebase-identity-provider-strategy.options'; import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; diff --git a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts index 6e1a802055..c260091f36 100644 --- a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts +++ b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts @@ -17,7 +17,7 @@ import * as firebase from 'firebase/app'; import 'firebase/auth'; import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; import { - NbFirebaseIdentityProviderStrategyOptions + NbFirebaseIdentityProviderStrategyOptions, } from '../base/firebase-identity-provider-strategy.options'; @Injectable() diff --git a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts index 81bf108cda..4ec3db2db9 100644 --- a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts +++ b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts @@ -14,7 +14,7 @@ import { NbAuthResult } from '../../../auth/services/auth-result'; import * as firebase from 'firebase/app'; import 'firebase/auth'; import { - NbFirebaseIdentityProviderStrategyOptions + NbFirebaseIdentityProviderStrategyOptions, } from '../base/firebase-identity-provider-strategy.options'; import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; diff --git a/src/playground/without-layout/firebase/firebase-routing.module.ts b/src/playground/without-layout/firebase/firebase-routing.module.ts index d75040ab8a..e86f5d1e06 100644 --- a/src/playground/without-layout/firebase/firebase-routing.module.ts +++ b/src/playground/without-layout/firebase/firebase-routing.module.ts @@ -17,7 +17,9 @@ import { } from '@nebular/auth'; import { FirebasePlaygroundComponent } from './firebase-playground.component'; import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password-auth-showcase.component'; -import { IdentityProvidersAuthShowcaseComponent } from './identity-proders-auth-showcase/identity-providers-auth-showcase.component'; +import { + IdentityProvidersAuthShowcaseComponent, +} from './identity-proders-auth-showcase/identity-providers-auth-showcase.component'; export const routes: Routes = [ diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 60ee345467..33fe35991d 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -3,14 +3,16 @@ import { NbFirebasePasswordStrategy, FirebaseAuthModule } from '@nebular/firebas import { FirebasePlaygroundRoutingModule } from './firebase-routing.module'; import { FirebasePlaygroundComponent } from './firebase-playground.component'; import { CommonModule } from '@angular/common'; -import { NbAuthJWTToken, NbAuthModule } from '@nebular/auth'; +import { NbAuthModule } from '@nebular/auth'; import { AngularFireAuthModule } from '@angular/fire/auth'; import { AngularFireModule } from '@angular/fire'; import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password-auth-showcase.component'; import { FirebaseAPIService } from './firebase-api.service'; import { AngularFireDatabaseModule } from '@angular/fire/database'; import { NbFirebaseGoogleStrategy } from '../../../framework/firebase-auth/strategies/google/firebase-google.strategy'; -import { IdentityProvidersAuthShowcaseComponent } from './identity-proders-auth-showcase/identity-providers-auth-showcase.component'; +import { + IdentityProvidersAuthShowcaseComponent, +} from './identity-proders-auth-showcase/identity-providers-auth-showcase.component'; @NgModule({ imports: [ diff --git a/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts b/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts index 856d228fd6..26728cb38f 100644 --- a/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts +++ b/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts @@ -1,4 +1,4 @@ -import { Component, OnInit } from '@angular/core'; +import { Component } from '@angular/core'; import { Observable, of } from 'rxjs'; import { FirebaseAPIService } from '../firebase-api.service'; import { NbAuthService } from '../../../../framework/auth/services/auth.service'; @@ -9,7 +9,7 @@ import { NbAuthResult } from '../../../../framework/auth/services/auth-result'; @Component({ selector: 'app-google-auth-showcase', templateUrl: './identity-providers-auth-showcase.component.html', - styleUrls: ['./identity-providers-auth-showcase.component.scss'] + styleUrls: ['./identity-providers-auth-showcase.component.scss'], }) export class IdentityProvidersAuthShowcaseComponent { diff --git a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts index a1bc7ef20f..af625f1303 100644 --- a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts +++ b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts @@ -1,11 +1,10 @@ -import { Component, OnDestroy, OnInit } from '@angular/core'; +import { Component } from '@angular/core'; import { NbAuthService } from '../../../../framework/auth/services/auth.service'; import { NbAuthToken } from '../../../../framework/auth/services/token/token'; import { Observable, of } from 'rxjs'; import { ActivatedRoute, Router } from '@angular/router'; -import { AngularFireAuth } from '@angular/fire/auth'; import { FirebaseAPIService } from '../firebase-api.service'; -import { catchError, share, take, tap } from 'rxjs/operators'; +import { catchError, share, take } from 'rxjs/operators'; @Component({ selector: 'nb-password-auth-showcase', @@ -21,12 +20,11 @@ export class PasswordAuthShowcaseComponent { constructor( private authService: NbAuthService, private router: Router, - private afAuth: AngularFireAuth, private firebaseApi: FirebaseAPIService, private route: ActivatedRoute, ) { - this.userToken$ = this.authService.onTokenChange().pipe(tap((isAuth) => console.log(isAuth))); - this.isAuthenticated$ = this.authService.isAuthenticated().pipe(tap((isAuth) => console.log(isAuth))); + this.userToken$ = this.authService.onTokenChange(); + this.isAuthenticated$ = this.authService.isAuthenticated(); } logout() { From 431bb6d67a6aa52146e6599f1c3cef4cf79d4c60 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Mon, 1 Jun 2020 15:55:01 +0300 Subject: [PATCH 20/34] chore(firebase-auth): feature sponsors on the docs page --- docs/articles/auth/firebase-authentication.md | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/docs/articles/auth/firebase-authentication.md b/docs/articles/auth/firebase-authentication.md index 7ad3cb6861..bd9e5f2fa1 100644 --- a/docs/articles/auth/firebase-authentication.md +++ b/docs/articles/auth/firebase-authentication.md @@ -1,10 +1,13 @@ ## Firebase authentication with Nebular Auth -@nebualar/firebase-auth allows authentication in firebase applications with nebular/auth. + +`@nebualar/firebase-auth` allows authentication in firebase applications with `@nebular/auth`. The package provides the following strategies: - - NbFirebasePasswordStrategy - authentication with email/password - - NbFirebaseGoogleStrategy - authentication with google accounts - - NbFirebaseFacebookStrategy - authentication with facebook accounts - - NbFirebaseTwitteStrategy - authentication with twitter accounts + - `NbFirebasePasswordStrategy` - authentication with email/password + - `NbFirebaseGoogleStrategy` - authentication with google accounts + - `NbFirebaseFacebookStrategy` - authentication with facebook accounts + - `NbFirebaseTwitteStrategy` - authentication with twitter accounts + +`@nebular/auth` package is sponsored by [GO-ER](www.go-er.com) and What Now Travel. ## Installation @@ -193,3 +196,4 @@ A complete code example could be found on [GitHub](https://github.com/akveo/nebu And here the playground examples available to play around with - [Firebase Nebular Password Example](/example/firebase/password-showcase) - [Firebase Nebular Social Authentication Providers Example](/example/firebase/social-auth-showcase) + From 9549e9c8a2d9f789fbe944b1dc3b97eeb38dfbaa Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Tue, 2 Jun 2020 15:49:32 +0300 Subject: [PATCH 21/34] fix(firebase-auth): use correct name for rollup global dependency --- scripts/gulp/tasks/build/bundle/rollup-config.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/scripts/gulp/tasks/build/bundle/rollup-config.ts b/scripts/gulp/tasks/build/bundle/rollup-config.ts index 965f00efd2..3101894e15 100644 --- a/scripts/gulp/tasks/build/bundle/rollup-config.ts +++ b/scripts/gulp/tasks/build/bundle/rollup-config.ts @@ -47,7 +47,7 @@ const ROLLUP_GLOBALS = { '@nebular/moment': 'nb.moment', '@nebular/date-fns': 'nb.date-fns', '@nebular/eva-icons': 'nb.eva-icons', - '@nebular/firebase-auth': 'nb.eva-icons', + '@nebular/firebase-auth': 'nb.firebase-auth', 'eva-icons': 'eva-icons', }; From 2df438de5878a9cca61efd8d18f28d3d6f902283 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Tue, 2 Jun 2020 16:11:05 +0300 Subject: [PATCH 22/34] fix(firebase-auth): reexport all entities in public_api --- src/framework/firebase-auth/public_api.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/framework/firebase-auth/public_api.ts b/src/framework/firebase-auth/public_api.ts index e5a7da158d..205dea594d 100644 --- a/src/framework/firebase-auth/public_api.ts +++ b/src/framework/firebase-auth/public_api.ts @@ -10,4 +10,6 @@ export * from './strategies/password/firebase-password.strategy'; export * from './strategies/password/firebase-password-strategy.options'; export * from './strategies/base/firebase-identity-provider-strategy.options'; export * from './strategies/google/firebase-google.strategy'; +export * from './strategies/facebook/firebase-facebook.strategy'; +export * from './strategies/twitter/firebase-twitter.strategy'; export * from './firebase-auth.module'; From 0a0b85ddef5b579e0fcd93ad5f66a399c7c68f8a Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Tue, 2 Jun 2020 16:18:50 +0300 Subject: [PATCH 23/34] fix(firebase-auth): fix imports order --- .../firebase-auth/firebase-auth.module.ts | 1 + .../strategies/base/firebase-base.strategy.ts | 15 ++++-------- ...base-identity-provider-strategy.options.ts | 6 ++--- .../facebook/firebase-facebook.strategy.ts | 18 +++++++-------- .../google/firebase-google.strategy.ts | 16 +++++-------- .../firebase-password-strategy.options.ts | 8 +++---- .../password/firebase-password.strategy.ts | 23 ++++++++----------- .../twitter/firebase-twitter.strategy.ts | 17 ++++++-------- .../firebase/firebase-api.service.ts | 5 +--- .../firebase/firebase-routing.module.ts | 1 + .../firebase/firebase.module.ts | 22 ++++++++---------- ...ntity-providers-auth-showcase.component.ts | 8 +++---- .../password-auth-showcase.component.ts | 8 +++---- 13 files changed, 63 insertions(+), 85 deletions(-) diff --git a/src/framework/firebase-auth/firebase-auth.module.ts b/src/framework/firebase-auth/firebase-auth.module.ts index ae48c288dd..250d13f77b 100644 --- a/src/framework/firebase-auth/firebase-auth.module.ts +++ b/src/framework/firebase-auth/firebase-auth.module.ts @@ -6,6 +6,7 @@ import { NgModule } from '@angular/core'; + import { NbFirebasePasswordStrategy } from './strategies/password/firebase-password.strategy'; import { NbFirebaseGoogleStrategy } from './strategies/google/firebase-google.strategy'; import { NbFirebaseFacebookStrategy } from './strategies/facebook/firebase-facebook.strategy'; diff --git a/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts b/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts index cd9defc925..374960a812 100644 --- a/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts +++ b/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts @@ -5,29 +5,24 @@ */ import { Injectable } from '@angular/core'; - -import { Observable, of as observableOf } from 'rxjs'; import { AngularFireAuth } from '@angular/fire/auth'; -import { fromPromise } from 'rxjs/internal-compatibility'; +import { Observable, of as observableOf, from } from 'rxjs'; import { catchError, map } from 'rxjs/operators'; +import { NbAuthResult, NbAuthIllegalTokenError, NbAuthStrategy } from '@nebular/auth'; + import UserCredential = firebase.auth.UserCredential; -import { NbAuthStrategy } from '../../../auth/strategies/auth-strategy'; -import { NbAuthResult } from '../../../auth/services/auth-result'; -import { NbAuthIllegalTokenError } from '../../../auth/services/token/token'; @Injectable() export abstract class NbFirebaseBaseStrategy extends NbAuthStrategy { - constructor( - protected afAuth: AngularFireAuth, - ) { + constructor(protected afAuth: AngularFireAuth) { super(); } logout(): Observable { const module = 'logout'; - return fromPromise(this.afAuth.signOut()) + return from(this.afAuth.signOut()) .pipe( map(() => { return new NbAuthResult( diff --git a/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts b/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts index 2be4167664..d72235981e 100644 --- a/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/base/firebase-identity-provider-strategy.options.ts @@ -4,12 +4,12 @@ * Licensed under the MIT License. See License.txt in the project root for license information. */ -import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; import { NbPasswordStrategyMessage, NbPasswordStrategyModule, -} from '../../../auth/strategies/password/password-strategy-options'; -import { NbAuthJWTToken } from '../../../auth/services/token/token'; + NbAuthJWTToken, + NbAuthStrategyOptions, +} from '@nebular/auth'; export class NbFirebaseIdentityProviderStrategyOptions extends NbAuthStrategyOptions { token? = { diff --git a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts index 7aaebd6890..9b17857cf2 100644 --- a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts +++ b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts @@ -6,18 +6,16 @@ import { Injectable } from '@angular/core'; -import { Observable } from 'rxjs'; -import { fromPromise } from 'rxjs/internal-compatibility'; +import { NbAuthResult, NbAuthStrategyClass, NbAuthStrategyOptions } from '@nebular/auth'; +import { from, Observable } from 'rxjs'; import { catchError, switchMap } from 'rxjs/operators'; -import { NbAuthStrategyClass } from '../../../auth/auth.options'; -import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; -import { NbAuthResult } from '../../../auth/services/auth-result'; + +import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; +import { NbFirebaseIdentityProviderStrategyOptions, } from '../base/firebase-identity-provider-strategy.options'; + import * as firebase from 'firebase/app'; import 'firebase/auth'; -import { - NbFirebaseIdentityProviderStrategyOptions, -} from '../base/firebase-identity-provider-strategy.options'; -import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; + @Injectable() export class NbFirebaseFacebookStrategy extends NbFirebaseBaseStrategy { @@ -35,7 +33,7 @@ export class NbFirebaseFacebookStrategy extends NbFirebaseBaseStrategy { scopes.forEach((scope) => provider.addScope(scope)); provider.setCustomParameters(this.getOption('customParameters')); - return fromPromise(this.afAuth.signInWithPopup(provider)) + return from(this.afAuth.signInWithPopup(provider)) .pipe( switchMap((res) => this.processSuccess(res, module)), catchError(error => this.proccessFailure(error, module)), diff --git a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts index c260091f36..debe633ff9 100644 --- a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts +++ b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts @@ -6,19 +6,15 @@ import { Injectable } from '@angular/core'; import { AngularFireAuth } from '@angular/fire/auth'; -import { Observable } from 'rxjs'; -import { fromPromise } from 'rxjs/internal-compatibility'; +import { from, Observable } from 'rxjs'; import { catchError, switchMap } from 'rxjs/operators'; -import { NbAuthStrategyClass } from '../../../auth/auth.options'; -import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; -import { NbAuthResult } from '../../../auth/services/auth-result'; +import { NbAuthStrategyClass, NbAuthResult, NbAuthStrategyOptions } from '@nebular/auth'; + +import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; +import { NbFirebaseIdentityProviderStrategyOptions, } from '../base/firebase-identity-provider-strategy.options'; import * as firebase from 'firebase/app'; import 'firebase/auth'; -import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; -import { - NbFirebaseIdentityProviderStrategyOptions, -} from '../base/firebase-identity-provider-strategy.options'; @Injectable() export class NbFirebaseGoogleStrategy extends NbFirebaseBaseStrategy { @@ -42,7 +38,7 @@ export class NbFirebaseGoogleStrategy extends NbFirebaseBaseStrategy { scopes.forEach((scope) => provider.addScope(scope)); provider.setCustomParameters(this.getOption('customParameters')); - return fromPromise(this.afAuth.signInWithPopup(provider)) + return from(this.afAuth.signInWithPopup(provider)) .pipe( switchMap((res) => this.processSuccess(res, module)), catchError(error => this.proccessFailure(error, module)), diff --git a/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts b/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts index 1b3f82bb31..553ca1446c 100644 --- a/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password-strategy.options.ts @@ -4,13 +4,13 @@ * Licensed under the MIT License. See License.txt in the project root for license information. */ -import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; import { + getDeepFromObject, + NbAuthJWTToken, + NbAuthStrategyOptions, NbPasswordStrategyMessage, NbPasswordStrategyModule, -} from '../../../auth/strategies/password/password-strategy-options'; -import { getDeepFromObject } from '../../../auth/helpers'; -import { NbAuthJWTToken } from '../../../auth/services/token/token'; +} from '@nebular/auth'; export class NbFirebasePasswordStrategyOptions extends NbAuthStrategyOptions { token? = { diff --git a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts index 9f4d1e476c..10b67f152d 100644 --- a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts @@ -5,19 +5,16 @@ */ import { Injectable } from '@angular/core'; +import { User } from 'firebase'; +import { Observable, of as observableOf, from } from 'rxjs'; +import { catchError, map, switchMap, take } from 'rxjs/operators'; +import { NbAuthStrategyOptions, NbAuthStrategyClass, NbAuthResult } from '@nebular/auth'; -import { Observable, of as observableOf } from 'rxjs'; +import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; import { firebasePasswordStrategyOptions, NbFirebasePasswordStrategyOptions, } from './firebase-password-strategy.options'; -import { fromPromise } from 'rxjs/internal-compatibility'; -import { catchError, map, switchMap, take } from 'rxjs/operators'; -import { User } from 'firebase'; -import { NbAuthStrategyClass } from '../../../auth/auth.options'; -import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; -import { NbAuthResult } from '../../../auth/services/auth-result'; -import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; @Injectable() @@ -31,7 +28,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { authenticate({ email, password }: any): Observable { const module = 'login'; - return fromPromise(this.afAuth.signInWithEmailAndPassword(email, password)) + return from(this.afAuth.signInWithEmailAndPassword(email, password)) .pipe( switchMap((res) => this.processSuccess(res, module)), catchError((error) => this.proccessFailure(error, module)), @@ -59,7 +56,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { register({ email, password }: any): Observable { const module = 'register'; - return fromPromise(this.afAuth.createUserWithEmailAndPassword(email, password)) + return from(this.afAuth.createUserWithEmailAndPassword(email, password)) .pipe( switchMap((res) => this.processSuccess(res, module)), catchError((error) => this.proccessFailure(error, module)), @@ -68,7 +65,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { requestPassword({ email }: any): Observable { const module = 'requestPassword'; - return fromPromise(this.afAuth.sendPasswordResetEmail(email)) + return from(this.afAuth.sendPasswordResetEmail(email)) .pipe( map(() => { return new NbAuthResult( @@ -102,7 +99,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { } protected updatePassword(user, password, module) { - return fromPromise(user.updatePassword(password)) + return from(user.updatePassword(password)) .pipe( map(token => { return new NbAuthResult( @@ -119,7 +116,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { } protected refreshIdToken(user: User, module): Observable { - return fromPromise(user.getIdToken(true)) + return from(user.getIdToken(true)) .pipe( map(token => { return new NbAuthResult( diff --git a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts index 4ec3db2db9..d6ff120503 100644 --- a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts +++ b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts @@ -5,18 +5,15 @@ */ import { Injectable } from '@angular/core'; -import { Observable } from 'rxjs'; -import { fromPromise } from 'rxjs/internal-compatibility'; +import { Observable, from } from 'rxjs'; import { catchError, switchMap } from 'rxjs/operators'; -import { NbAuthStrategyClass } from '../../../auth/auth.options'; -import { NbAuthStrategyOptions } from '../../../auth/strategies/auth-strategy-options'; -import { NbAuthResult } from '../../../auth/services/auth-result'; +import { NbAuthStrategyClass, NbAuthResult, NbAuthStrategyOptions } from '@nebular/auth'; + +import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; +import { NbFirebaseIdentityProviderStrategyOptions, } from '../base/firebase-identity-provider-strategy.options'; + import * as firebase from 'firebase/app'; import 'firebase/auth'; -import { - NbFirebaseIdentityProviderStrategyOptions, -} from '../base/firebase-identity-provider-strategy.options'; -import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; @Injectable() export class NbFirebaseTwitteStrategy extends NbFirebaseBaseStrategy { @@ -32,7 +29,7 @@ export class NbFirebaseTwitteStrategy extends NbFirebaseBaseStrategy { const provider = new firebase.auth.TwitterAuthProvider(); provider.setCustomParameters(this.getOption('customParameters')); - return fromPromise(this.afAuth.signInWithPopup(provider)) + return from(this.afAuth.signInWithPopup(provider)) .pipe( switchMap((res) => this.processSuccess(res, module)), catchError(error => this.proccessFailure(error, module)), diff --git a/src/playground/without-layout/firebase/firebase-api.service.ts b/src/playground/without-layout/firebase/firebase-api.service.ts index 76c81eff26..02a8adfa5c 100644 --- a/src/playground/without-layout/firebase/firebase-api.service.ts +++ b/src/playground/without-layout/firebase/firebase-api.service.ts @@ -4,10 +4,7 @@ import { AngularFireDatabase } from '@angular/fire/database'; @Injectable() export class FirebaseAPIService { - constructor( - private db: AngularFireDatabase, - ) { - } + constructor(private db: AngularFireDatabase) { } getGreeting() { return this.db.object('/greeting/').valueChanges(); diff --git a/src/playground/without-layout/firebase/firebase-routing.module.ts b/src/playground/without-layout/firebase/firebase-routing.module.ts index e86f5d1e06..e78574e68a 100644 --- a/src/playground/without-layout/firebase/firebase-routing.module.ts +++ b/src/playground/without-layout/firebase/firebase-routing.module.ts @@ -15,6 +15,7 @@ import { NbRequestPasswordComponent, NbResetPasswordComponent, } from '@nebular/auth'; + import { FirebasePlaygroundComponent } from './firebase-playground.component'; import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password-auth-showcase.component'; import { diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 33fe35991d..f87af0b959 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -1,18 +1,16 @@ -import { NgModule } from '@angular/core'; -import { NbFirebasePasswordStrategy, FirebaseAuthModule } from '@nebular/firebase-auth'; -import { FirebasePlaygroundRoutingModule } from './firebase-routing.module'; -import { FirebasePlaygroundComponent } from './firebase-playground.component'; import { CommonModule } from '@angular/common'; -import { NbAuthModule } from '@nebular/auth'; -import { AngularFireAuthModule } from '@angular/fire/auth'; +import { NgModule } from '@angular/core'; import { AngularFireModule } from '@angular/fire'; -import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password-auth-showcase.component'; -import { FirebaseAPIService } from './firebase-api.service'; +import { AngularFireAuthModule } from '@angular/fire/auth'; import { AngularFireDatabaseModule } from '@angular/fire/database'; -import { NbFirebaseGoogleStrategy } from '../../../framework/firebase-auth/strategies/google/firebase-google.strategy'; -import { - IdentityProvidersAuthShowcaseComponent, -} from './identity-proders-auth-showcase/identity-providers-auth-showcase.component'; +import { NbAuthModule } from '@nebular/auth'; +import { FirebaseAuthModule, NbFirebasePasswordStrategy, NbFirebaseGoogleStrategy } from '@nebular/firebase-auth'; + +import { FirebaseAPIService } from './firebase-api.service'; +import { FirebasePlaygroundComponent } from './firebase-playground.component'; +import { FirebasePlaygroundRoutingModule } from './firebase-routing.module'; +import { IdentityProvidersAuthShowcaseComponent, } from './identity-proders-auth-showcase/identity-providers-auth-showcase.component'; +import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password-auth-showcase.component'; @NgModule({ imports: [ diff --git a/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts b/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts index 26728cb38f..78681a8db9 100644 --- a/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts +++ b/src/playground/without-layout/firebase/identity-proders-auth-showcase/identity-providers-auth-showcase.component.ts @@ -1,10 +1,9 @@ import { Component } from '@angular/core'; import { Observable, of } from 'rxjs'; -import { FirebaseAPIService } from '../firebase-api.service'; -import { NbAuthService } from '../../../../framework/auth/services/auth.service'; -import { NbAuthToken } from '../../../../framework/auth/services/token/token'; import { catchError, share, take } from 'rxjs/operators'; -import { NbAuthResult } from '../../../../framework/auth/services/auth-result'; +import { NbAuthResult, NbAuthService, NbAuthToken } from '@nebular/auth'; + +import { FirebaseAPIService } from '../firebase-api.service'; @Component({ selector: 'app-google-auth-showcase', @@ -15,7 +14,6 @@ export class IdentityProvidersAuthShowcaseComponent { userToken$: Observable; isAuthenticated$: Observable; - // afUser$: Observable; data$: Observable; constructor( diff --git a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts index af625f1303..50d680e257 100644 --- a/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts +++ b/src/playground/without-layout/firebase/password-auth-showcase/password-auth-showcase.component.ts @@ -1,10 +1,10 @@ import { Component } from '@angular/core'; -import { NbAuthService } from '../../../../framework/auth/services/auth.service'; -import { NbAuthToken } from '../../../../framework/auth/services/token/token'; -import { Observable, of } from 'rxjs'; import { ActivatedRoute, Router } from '@angular/router'; -import { FirebaseAPIService } from '../firebase-api.service'; +import { Observable, of } from 'rxjs'; import { catchError, share, take } from 'rxjs/operators'; +import { NbAuthService, NbAuthToken } from '@nebular/auth'; + +import { FirebaseAPIService } from '../firebase-api.service'; @Component({ selector: 'nb-password-auth-showcase', From a4f9095d50e5882f38720847cf1a66724389b880 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Tue, 2 Jun 2020 16:23:19 +0300 Subject: [PATCH 24/34] fix(firebase-auth): delete unneded comments --- .../firebase/firebase-routing.module.ts | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/src/playground/without-layout/firebase/firebase-routing.module.ts b/src/playground/without-layout/firebase/firebase-routing.module.ts index e78574e68a..6db5319b04 100644 --- a/src/playground/without-layout/firebase/firebase-routing.module.ts +++ b/src/playground/without-layout/firebase/firebase-routing.module.ts @@ -69,20 +69,6 @@ export const routes: Routes = [ path: 'social-auth-showcase', component: IdentityProvidersAuthShowcaseComponent, }, - // { - // path: 'acl/acl-test.component', - // component: AclTestComponent, - // }, - // { - // path: 'auth-guard.service', - // canActivate: [AuthGuard], - // component: AuthPlaygroundComponent, - // }, - // { - // path: 'api-calls.component', - // canActivate: [AuthGuard], - // component: PlaygroundApiCallsComponent, - // }, ]; @NgModule({ From 617cd4014741cc7f75da8eab2aa1a0bf6e6a21c2 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Tue, 2 Jun 2020 17:00:56 +0300 Subject: [PATCH 25/34] fix(firebase-auth): fix lint errors --- .../strategies/facebook/firebase-facebook.strategy.ts | 2 +- .../strategies/google/firebase-google.strategy.ts | 2 +- .../strategies/twitter/firebase-twitter.strategy.ts | 2 +- src/playground/without-layout/firebase/firebase.module.ts | 4 +++- 4 files changed, 6 insertions(+), 4 deletions(-) diff --git a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts index 9b17857cf2..678ced5495 100644 --- a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts +++ b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts @@ -11,7 +11,7 @@ import { from, Observable } from 'rxjs'; import { catchError, switchMap } from 'rxjs/operators'; import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; -import { NbFirebaseIdentityProviderStrategyOptions, } from '../base/firebase-identity-provider-strategy.options'; +import { NbFirebaseIdentityProviderStrategyOptions } from '../base/firebase-identity-provider-strategy.options'; import * as firebase from 'firebase/app'; import 'firebase/auth'; diff --git a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts index debe633ff9..ae687bcac7 100644 --- a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts +++ b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts @@ -11,7 +11,7 @@ import { catchError, switchMap } from 'rxjs/operators'; import { NbAuthStrategyClass, NbAuthResult, NbAuthStrategyOptions } from '@nebular/auth'; import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; -import { NbFirebaseIdentityProviderStrategyOptions, } from '../base/firebase-identity-provider-strategy.options'; +import { NbFirebaseIdentityProviderStrategyOptions } from '../base/firebase-identity-provider-strategy.options'; import * as firebase from 'firebase/app'; import 'firebase/auth'; diff --git a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts index d6ff120503..c9125d8e65 100644 --- a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts +++ b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts @@ -10,7 +10,7 @@ import { catchError, switchMap } from 'rxjs/operators'; import { NbAuthStrategyClass, NbAuthResult, NbAuthStrategyOptions } from '@nebular/auth'; import { NbFirebaseBaseStrategy } from '../base/firebase-base.strategy'; -import { NbFirebaseIdentityProviderStrategyOptions, } from '../base/firebase-identity-provider-strategy.options'; +import { NbFirebaseIdentityProviderStrategyOptions } from '../base/firebase-identity-provider-strategy.options'; import * as firebase from 'firebase/app'; import 'firebase/auth'; diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index f87af0b959..14ee1f2f95 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -9,7 +9,9 @@ import { FirebaseAuthModule, NbFirebasePasswordStrategy, NbFirebaseGoogleStrateg import { FirebaseAPIService } from './firebase-api.service'; import { FirebasePlaygroundComponent } from './firebase-playground.component'; import { FirebasePlaygroundRoutingModule } from './firebase-routing.module'; -import { IdentityProvidersAuthShowcaseComponent, } from './identity-proders-auth-showcase/identity-providers-auth-showcase.component'; +import { + IdentityProvidersAuthShowcaseComponent, +} from './identity-proders-auth-showcase/identity-providers-auth-showcase.component'; import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password-auth-showcase.component'; @NgModule({ From 53cdad19ddca2479429581751ea2f2cf35b467bb Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Tue, 2 Jun 2020 18:30:17 +0300 Subject: [PATCH 26/34] fix(firebase-auth): make reset password method work with confirmPasswordReset form firebase auth --- .../password/firebase-password.strategy.ts | 23 +++++++++---------- 1 file changed, 11 insertions(+), 12 deletions(-) diff --git a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts index 10b67f152d..16f9b1cd48 100644 --- a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts @@ -80,21 +80,20 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { ); } - resetPassword({ password }): Observable { + resetPassword({ code, password }): Observable { const module = 'resetPassword'; - return this.afAuth.authState + return from(this.afAuth.confirmPasswordReset(code, password)) .pipe( - switchMap(user => { - if (user == null) { - return observableOf(new NbAuthResult( - false, - null, - this.getOption(`${module}.redirect.failure`), - ['There is no logged in user so the reset of the password isn\'t possible'], - )); - } - return this.updatePassword(user, password, module); + map(() => { + return new NbAuthResult( + true, + null, + this.getOption(`${module}.redirect.success`), + [], + this.getOption(`${module}.defaultMessages`), + ); }), + catchError((error) => this.proccessFailure(error, module)), ); } From fb2635357e9668289807afb65dd1af97ad894fba Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 3 Jun 2020 12:53:24 +0300 Subject: [PATCH 27/34] fix(firebase-auth): fix packages build --- scripts/gulp/tasks/build/bundle/rollup-config.ts | 5 +++++ tsconfig.publish.json | 3 ++- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/scripts/gulp/tasks/build/bundle/rollup-config.ts b/scripts/gulp/tasks/build/bundle/rollup-config.ts index 3101894e15..24914654e2 100644 --- a/scripts/gulp/tasks/build/bundle/rollup-config.ts +++ b/scripts/gulp/tasks/build/bundle/rollup-config.ts @@ -25,6 +25,8 @@ const ROLLUP_GLOBALS = { '@angular/cdk/table': 'ng.cdk.table', '@angular/cdk/bidi': 'ng.cdk.bidi', '@angular/cdk/keycodes': 'ng.cdk.keycodes', + '@angular/fire': 'ng.fire', + '@angular/fire/auth': 'ng.fire.auth', // RxJS dependencies @@ -33,6 +35,9 @@ const ROLLUP_GLOBALS = { // 3rd party dependencies 'intersection-observer': 'intersection-observer', + 'firebase': 'firebase', + 'firebase/app': 'firebase.app', + 'firebase/auth': 'firebase.auth', // date libs for date service 'moment': 'moment', diff --git a/tsconfig.publish.json b/tsconfig.publish.json index a7c49fbbbb..50cb76ee20 100644 --- a/tsconfig.publish.json +++ b/tsconfig.publish.json @@ -18,7 +18,8 @@ "importHelpers": true, "baseUrl": ".", "paths": { - "@nebular/theme": ["./src/.lib/theme"] + "@nebular/theme": ["./src/.lib/theme"], + "@nebular/auth": ["./src/.lib/auth"] }, "skipLibCheck": true, "typeRoots": [ From 4ecd8500ff66a6c90928c6598e5685966286271a Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 3 Jun 2020 15:32:02 +0300 Subject: [PATCH 28/34] fix(firebase-auth): add terms and conditions checkbox --- src/playground/without-layout/firebase/firebase.module.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 14ee1f2f95..031fec363b 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -34,12 +34,12 @@ import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password forms: { login: { strategy: 'password', - rememberMe: false, + rememberMe: true, socialLinks: [], }, register: { strategy: 'password', - terms: false, + terms: true, socialLinks: [], }, logout: { From 7c6c6cd366425c9a87214c53489a932249b1b27d Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 3 Jun 2020 15:32:50 +0300 Subject: [PATCH 29/34] fix(firebase-auth): fix typos in docs --- docs/articles/auth/firebase-authentication.md | 11 +---------- 1 file changed, 1 insertion(+), 10 deletions(-) diff --git a/docs/articles/auth/firebase-authentication.md b/docs/articles/auth/firebase-authentication.md index bd9e5f2fa1..e24a2a878d 100644 --- a/docs/articles/auth/firebase-authentication.md +++ b/docs/articles/auth/firebase-authentication.md @@ -24,7 +24,7 @@ The package provides the following strategies: Install Nebular Auth and Nebular Firebase Auth. ```sh - npm i @nebular/eva-icons firebase @angular\fire + npm i @nebular/auth @angular\firebase-auth ``` Import the NbAuthModule with some firebase strategies, in that example we use NbFirebasePasswordStrategy. @@ -146,15 +146,6 @@ These strategies share the same settings structure and default settings value. Strategies settings: -
-
Note
-
- There is no need to copy over the whole object to change the settings you need. - Also, this.getOption call won't work outside of the default options declaration (which is inside of the NbPasswordAuthStrategy class), - so you have to replace it with a custom helper function if you need it. -
-
- ```ts export class NbFirebaseIdentityProviderStrategyOptions extends NbAuthStrategyOptions { name: string; From 9dad48b222308649c4494ccb87e4e27bdec03192 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 3 Jun 2020 15:34:04 +0300 Subject: [PATCH 30/34] fix(firebase-auth): remove redundant block from docs page --- docs/structure.ts | 5 ----- 1 file changed, 5 deletions(-) diff --git a/docs/structure.ts b/docs/structure.ts index ecafe9e887..3373c6c787 100644 --- a/docs/structure.ts +++ b/docs/structure.ts @@ -924,11 +924,6 @@ export const structure = [ block: 'markdown', source: 'auth/firebase-authentication.md', }, - { - type: 'block', - block: 'component', - source: 'NbPasswordAuthStrategy', - }, ], }, { From b3ae5c8c6210a7b9db67276cb9b924536bfa03a8 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 3 Jun 2020 15:36:19 +0300 Subject: [PATCH 31/34] fix(firebase-auth): fix typos --- .../strategies/base/firebase-base.strategy.ts | 12 ++++++------ .../facebook/firebase-facebook.strategy.ts | 2 +- .../strategies/google/firebase-google.strategy.ts | 2 +- .../password/firebase-password.strategy.ts | 12 ++++++------ .../strategies/twitter/firebase-twitter.strategy.ts | 2 +- 5 files changed, 15 insertions(+), 15 deletions(-) diff --git a/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts b/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts index 374960a812..b9340824f4 100644 --- a/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts +++ b/src/framework/firebase-auth/strategies/base/firebase-base.strategy.ts @@ -33,27 +33,27 @@ export abstract class NbFirebaseBaseStrategy extends NbAuthStrategy { this.getOption(`${module}.defaultMessages`), ) }), - catchError((error) => this.proccessFailure(error, module)), + catchError((error) => this.processFailure(error, module)), ); } register(data?: any): Observable { - throw new Error(`\`register\` is not supported by \`${this.constructor.name}\`, use \`authenticate\`.`); + throw new Error(`'register' is not supported by '${this.constructor.name}', use 'authenticate'.`); } requestPassword(data?: any): Observable { - throw new Error(`\`requestPassword\` is not supported by \`${this.constructor.name}\`, use \`authenticate\`.`); + throw new Error(`'requestPassword' is not supported by '${this.constructor.name}', use 'authenticate'.`); } resetPassword(data: any = {}): Observable { - throw new Error(`\`resetPassword\` is not supported by \`${this.constructor.name}\`, use \`authenticate\`.`); + throw new Error(`'resetPassword' is not supported by '${this.constructor.name}', use 'authenticate'.`); } refreshToken(data: any = {}): Observable { - throw new Error(`\`refreshToken\` is not supported by \`${this.constructor.name}\`, use \`authenticate\`.`); + throw new Error(`'refreshToken' is not supported by '${this.constructor.name}', use 'authenticate'.`); } - protected proccessFailure(error: any, module: string): Observable { + protected processFailure(error: any, module: string): Observable { const errorMessages = []; if (error instanceof NbAuthIllegalTokenError) { diff --git a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts index 678ced5495..886c34a734 100644 --- a/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts +++ b/src/framework/firebase-auth/strategies/facebook/firebase-facebook.strategy.ts @@ -36,7 +36,7 @@ export class NbFirebaseFacebookStrategy extends NbFirebaseBaseStrategy { return from(this.afAuth.signInWithPopup(provider)) .pipe( switchMap((res) => this.processSuccess(res, module)), - catchError(error => this.proccessFailure(error, module)), + catchError(error => this.processFailure(error, module)), ); } } diff --git a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts index ae687bcac7..d545a74732 100644 --- a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts +++ b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts @@ -41,7 +41,7 @@ export class NbFirebaseGoogleStrategy extends NbFirebaseBaseStrategy { return from(this.afAuth.signInWithPopup(provider)) .pipe( switchMap((res) => this.processSuccess(res, module)), - catchError(error => this.proccessFailure(error, module)), + catchError(error => this.processFailure(error, module)), ); } } diff --git a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts index 16f9b1cd48..48c6570465 100644 --- a/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts +++ b/src/framework/firebase-auth/strategies/password/firebase-password.strategy.ts @@ -31,7 +31,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { return from(this.afAuth.signInWithEmailAndPassword(email, password)) .pipe( switchMap((res) => this.processSuccess(res, module)), - catchError((error) => this.proccessFailure(error, module)), + catchError((error) => this.processFailure(error, module)), ); } @@ -59,7 +59,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { return from(this.afAuth.createUserWithEmailAndPassword(email, password)) .pipe( switchMap((res) => this.processSuccess(res, module)), - catchError((error) => this.proccessFailure(error, module)), + catchError((error) => this.processFailure(error, module)), ); } @@ -76,7 +76,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { this.getOption(`${module}.defaultMessages`), ); }), - catchError((error) => this.proccessFailure(error, module)), + catchError((error) => this.processFailure(error, module)), ); } @@ -93,7 +93,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { this.getOption(`${module}.defaultMessages`), ); }), - catchError((error) => this.proccessFailure(error, module)), + catchError((error) => this.processFailure(error, module)), ); } @@ -110,7 +110,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { this.createToken(token), ); }), - catchError(error => this.proccessFailure(error, module)), + catchError(error => this.processFailure(error, module)), ); } @@ -127,7 +127,7 @@ export class NbFirebasePasswordStrategy extends NbFirebaseBaseStrategy { this.createToken(token), ); }), - catchError(error => this.proccessFailure(error, module)), + catchError(error => this.processFailure(error, module)), ); } } diff --git a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts index c9125d8e65..365c9c501b 100644 --- a/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts +++ b/src/framework/firebase-auth/strategies/twitter/firebase-twitter.strategy.ts @@ -32,7 +32,7 @@ export class NbFirebaseTwitteStrategy extends NbFirebaseBaseStrategy { return from(this.afAuth.signInWithPopup(provider)) .pipe( switchMap((res) => this.processSuccess(res, module)), - catchError(error => this.proccessFailure(error, module)), + catchError(error => this.processFailure(error, module)), ); } } From da37cfaddf5453ba664bf0b577291de3e7a351fe Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 3 Jun 2020 15:37:23 +0300 Subject: [PATCH 32/34] fix(firebase-auth): remove unneeded constructor --- .../strategies/google/firebase-google.strategy.ts | 7 ------- 1 file changed, 7 deletions(-) diff --git a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts index d545a74732..d7c5b72f1a 100644 --- a/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts +++ b/src/framework/firebase-auth/strategies/google/firebase-google.strategy.ts @@ -5,7 +5,6 @@ */ import { Injectable } from '@angular/core'; -import { AngularFireAuth } from '@angular/fire/auth'; import { from, Observable } from 'rxjs'; import { catchError, switchMap } from 'rxjs/operators'; import { NbAuthStrategyClass, NbAuthResult, NbAuthStrategyOptions } from '@nebular/auth'; @@ -25,12 +24,6 @@ export class NbFirebaseGoogleStrategy extends NbFirebaseBaseStrategy { return [NbFirebaseGoogleStrategy, options]; } - constructor( - protected afAuth: AngularFireAuth, - ) { - super(afAuth); - } - authenticate(data?: any): Observable { const module = 'authenticate'; const provider = new firebase.auth.GoogleAuthProvider(); From aef7b17beef65dd32d417cc93362c62f6ca17d11 Mon Sep 17 00:00:00 2001 From: mkolesnikov Date: Wed, 3 Jun 2020 17:52:57 +0300 Subject: [PATCH 33/34] fix(firebase-auth): change module prefix --- src/framework/firebase-auth/firebase-auth.module.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/framework/firebase-auth/firebase-auth.module.ts b/src/framework/firebase-auth/firebase-auth.module.ts index 250d13f77b..910d78c318 100644 --- a/src/framework/firebase-auth/firebase-auth.module.ts +++ b/src/framework/firebase-auth/firebase-auth.module.ts @@ -21,4 +21,4 @@ import { NbFirebaseTwitteStrategy } from './strategies/twitter/firebase-twitter. NbFirebaseTwitteStrategy, ], }) -export class FirebaseAuthModule { } +export class NbFirebaseAuthModule { } From 6dd7a19e937f696450cb97a5e6c41c31f73ca431 Mon Sep 17 00:00:00 2001 From: Sergey Andrievskiy Date: Wed, 3 Jun 2020 18:47:46 +0300 Subject: [PATCH 34/34] fix(playground): correct module name --- src/playground/without-layout/firebase/firebase.module.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/playground/without-layout/firebase/firebase.module.ts b/src/playground/without-layout/firebase/firebase.module.ts index 031fec363b..9e24ffae9e 100644 --- a/src/playground/without-layout/firebase/firebase.module.ts +++ b/src/playground/without-layout/firebase/firebase.module.ts @@ -4,7 +4,7 @@ import { AngularFireModule } from '@angular/fire'; import { AngularFireAuthModule } from '@angular/fire/auth'; import { AngularFireDatabaseModule } from '@angular/fire/database'; import { NbAuthModule } from '@nebular/auth'; -import { FirebaseAuthModule, NbFirebasePasswordStrategy, NbFirebaseGoogleStrategy } from '@nebular/firebase-auth'; +import { NbFirebaseAuthModule, NbFirebasePasswordStrategy, NbFirebaseGoogleStrategy } from '@nebular/firebase-auth'; import { FirebaseAPIService } from './firebase-api.service'; import { FirebasePlaygroundComponent } from './firebase-playground.component'; @@ -29,7 +29,7 @@ import { PasswordAuthShowcaseComponent } from './password-auth-showcase/password AngularFireAuthModule, AngularFireDatabaseModule, FirebasePlaygroundRoutingModule, - FirebaseAuthModule, + NbFirebaseAuthModule, NbAuthModule.forRoot({ forms: { login: {