ngx-firebase-cms
Version:
Angular Content Management System using Google Firebase (Authentication, Storage & Firestore)
326 lines • 21.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Injectable, Inject } from '@angular/core';
import { AngularFireAuth } from '@angular/fire/auth';
import { AngularFirestore } from '@angular/fire/firestore';
import { of } from 'rxjs';
import { switchMap, tap } from 'rxjs/operators';
import { Router } from '@angular/router';
import * as firebase from 'firebase/app';
import { NzMessageService } from 'ng-zorro-antd';
import * as i0 from "@angular/core";
import * as i1 from "@angular/fire/auth";
import * as i2 from "ng-zorro-antd";
import * as i3 from "@angular/router";
import * as i4 from "@angular/fire/firestore";
var AuthService = /** @class */ (function () {
function AuthService(config, afAuth, message, router, afs) {
var _this = this;
this.config = config;
this.afAuth = afAuth;
this.message = message;
this.router = router;
this.afs = afs;
this.user$ = this.afAuth.authState.pipe(tap((/**
* @param {?} res
* @return {?}
*/
function (res) {
if (res) {
_this.uid = res["uid"];
_this.email = res["email"];
_this.emailVerified = res["emailVerified"];
_this.lastLogin = new Date(res["metadata"]["lastSignInTime"]);
}
})), switchMap((/**
* @param {?} user
* @return {?}
*/
function (user) {
if (user) {
return _this.afs.doc("users/" + user.uid).valueChanges();
}
else {
return of(null);
}
})), tap((/**
* @param {?} user
* @return {?}
*/
function (user) {
if (user) {
_this.displayName = user["displayName"];
_this.profileURL = user["profileURL"];
_this.role = user["roles"];
}
})));
}
/**
* @param {?} username
* @param {?} password
* @return {?}
*/
AuthService.prototype.login = /**
* @param {?} username
* @param {?} password
* @return {?}
*/
function (username, password) {
var _this = this;
/** @type {?} */
var adminURL = this.config.adminURL || 'admin';
this.afAuth.auth.signInWithEmailAndPassword(username, password)
.then((/**
* @param {?} res
* @return {?}
*/
function (res) {
_this.router.navigate([adminURL + "/dashboard"]);
})).catch((/**
* @param {?} err
* @return {?}
*/
function (err) {
_this.message.error(err);
}));
};
/**
* @param {?} username
* @param {?} password
* @return {?}
*/
AuthService.prototype.signup = /**
* @param {?} username
* @param {?} password
* @return {?}
*/
function (username, password) {
var _this = this;
/** @type {?} */
var adminURL = this.config.adminURL || 'admin';
this.afAuth.auth.createUserWithEmailAndPassword(username, password).then((/**
* @param {?} res
* @return {?}
*/
function (res) {
/** @type {?} */
var data = {
uid: res['user']['uid'],
email: res['user']['email'],
displayName: res['user']['email'],
emailVerified: false,
createdTime: firebase.firestore.FieldValue.serverTimestamp(),
updatedTime: firebase.firestore.FieldValue.serverTimestamp(),
lastLoginTime: firebase.firestore.FieldValue.serverTimestamp(),
roles: ["Contributor"]
};
if (res['user']['uid']) {
_this.afs.collection("users").doc(res['user']['uid']).set(data)
.then((/**
* @param {?} res
* @return {?}
*/
function (res) {
_this.router.navigate([adminURL + "/dashboard"]);
}))
.catch((/**
* @param {?} err
* @return {?}
*/
function (err) {
_this.message.error(err);
}));
}
}));
};
/**
* @return {?}
*/
AuthService.prototype.signOut = /**
* @return {?}
*/
function () {
return this.afAuth.auth.signOut();
};
/**
* @private
* @param {?} user
* @return {?}
*/
AuthService.prototype.updateUserData = /**
* @private
* @param {?} user
* @return {?}
*/
function (user) {
/** @type {?} */
var userRef = this.afs.doc("users/" + user.uid);
/** @type {?} */
var data = {
uid: user.uid,
email: user.email,
roles: ["Contributor"]
};
return userRef.set(data, { merge: true });
};
///// Role-based Authorization //////
///// Role-based Authorization //////
/**
* @param {?} user
* @return {?}
*/
AuthService.prototype.canRead =
///// Role-based Authorization //////
/**
* @param {?} user
* @return {?}
*/
function (user) {
/** @type {?} */
var allowed = ['Administrator', 'Editor', 'Author', 'Contributor'];
return this.checkAuthorization(user, allowed);
};
/**
* @param {?} user
* @return {?}
*/
AuthService.prototype.canEdit = /**
* @param {?} user
* @return {?}
*/
function (user) {
/** @type {?} */
var allowed = ['Administrator', 'Editor'];
return this.checkAuthorization(user, allowed);
};
/**
* @param {?} user
* @return {?}
*/
AuthService.prototype.canDelete = /**
* @param {?} user
* @return {?}
*/
function (user) {
/** @type {?} */
var allowed = ['Administrator'];
return this.checkAuthorization(user, allowed);
};
// determines if user has matching role
// determines if user has matching role
/**
* @private
* @param {?} user
* @param {?} allowedRoles
* @return {?}
*/
AuthService.prototype.checkAuthorization =
// determines if user has matching role
/**
* @private
* @param {?} user
* @param {?} allowedRoles
* @return {?}
*/
function (user, allowedRoles) {
var e_1, _a;
if (!user)
return false;
try {
for (var allowedRoles_1 = tslib_1.__values(allowedRoles), allowedRoles_1_1 = allowedRoles_1.next(); !allowedRoles_1_1.done; allowedRoles_1_1 = allowedRoles_1.next()) {
var role = allowedRoles_1_1.value;
if (user.roles[role]) {
return true;
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (allowedRoles_1_1 && !allowedRoles_1_1.done && (_a = allowedRoles_1.return)) _a.call(allowedRoles_1);
}
finally { if (e_1) throw e_1.error; }
}
return false;
};
/**
* @param {?} description
* @return {?}
*/
AuthService.prototype.log = /**
* @param {?} description
* @return {?}
*/
function (description) {
if (this.uid) {
this.afs.collection('log').add({
"description": description,
"uid": this.uid,
"createdTime": firebase.firestore.FieldValue.serverTimestamp()
});
}
};
AuthService.decorators = [
{ type: Injectable, args: [{
providedIn: 'root'
},] }
];
/** @nocollapse */
AuthService.ctorParameters = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: ['env',] }] },
{ type: AngularFireAuth },
{ type: NzMessageService },
{ type: Router },
{ type: AngularFirestore }
]; };
/** @nocollapse */ AuthService.ngInjectableDef = i0.defineInjectable({ factory: function AuthService_Factory() { return new AuthService(i0.inject("env"), i0.inject(i1.AngularFireAuth), i0.inject(i2.NzMessageService), i0.inject(i3.Router), i0.inject(i4.AngularFirestore)); }, token: AuthService, providedIn: "root" });
return AuthService;
}());
export { AuthService };
if (false) {
/** @type {?} */
AuthService.prototype.user$;
/** @type {?} */
AuthService.prototype.uid;
/** @type {?} */
AuthService.prototype.displayName;
/** @type {?} */
AuthService.prototype.email;
/** @type {?} */
AuthService.prototype.profileURL;
/** @type {?} */
AuthService.prototype.emailVerified;
/** @type {?} */
AuthService.prototype.lastLogin;
/** @type {?} */
AuthService.prototype.role;
/**
* @type {?}
* @private
*/
AuthService.prototype.config;
/**
* @type {?}
* @private
*/
AuthService.prototype.afAuth;
/**
* @type {?}
* @private
*/
AuthService.prototype.message;
/**
* @type {?}
* @private
*/
AuthService.prototype.router;
/**
* @type {?}
* @private
*/
AuthService.prototype.afs;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"ng://ngx-firebase-cms/","sources":["lib/service/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from '@angular/core';\nimport { AngularFireAuth } from '@angular/fire/auth';\nimport { AngularFirestore, AngularFirestoreDocument } from '@angular/fire/firestore';\nimport { Observable, of } from 'rxjs';\nimport { switchMap, tap } from 'rxjs/operators';\nimport { Router } from '@angular/router';\nimport { User } from '../interface/user';\nimport * as firebase from 'firebase/app';\nimport { FirebaseApp } from '@angular/fire';\nimport { EnvConfig } from '../interface/env-config';\nimport { NzMessageService } from 'ng-zorro-antd';\nimport { Log } from '../interface/log';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AuthService {\n\n  user$: Observable<User>;\n  uid: string;\n  displayName: string;\n  email: string;\n  profileURL: string;\n  emailVerified : boolean;\n  lastLogin: Date;\n  role\n\n  constructor(\n    @Inject('env') private config: EnvConfig,\n    private afAuth: AngularFireAuth,\n    private message: NzMessageService,\n    private router: Router,\n    private afs: AngularFirestore\n  ) {\n    this.user$ = this.afAuth.authState.pipe(\n      tap(res => {\n        if (res) {\n          this.uid = res[\"uid\"]\n          this.email = res[\"email\"]\n          this.emailVerified = res[\"emailVerified\"]\n          this.lastLogin = new Date(res[\"metadata\"][\"lastSignInTime\"])\n        }\n      }),\n      switchMap(user => {\n        if (user) {\n          return this.afs.doc<User>(`users/${user.uid}`).valueChanges()\n        } else {\n          return of(null)\n        }\n      }),\n      tap(user => {\n        if (user) {\n          this.displayName = user[\"displayName\"]\n          this.profileURL = user[\"profileURL\"]\n          this.role = user[\"roles\"]\n        }\n      })\n    )\n  }\n\n  public login(username, password) {\n    let adminURL = this.config.adminURL || 'admin'\n    this.afAuth.auth.signInWithEmailAndPassword(username, password)\n    .then(res => {\n      this.router.navigate([`${adminURL}/dashboard`])\n    }).catch(err => {\n      this.message.error(err)\n    })\n  }\n\n  public signup(username, password) {\n    let adminURL = this.config.adminURL || 'admin'\n    this.afAuth.auth.createUserWithEmailAndPassword(username, password).then(res => {\n      let data = {\n        uid: res['user']['uid'],\n        email: res['user']['email'],\n        displayName: res['user']['email'],\n        emailVerified: false,\n        createdTime: firebase.firestore.FieldValue.serverTimestamp(),\n        updatedTime: firebase.firestore.FieldValue.serverTimestamp(),\n        lastLoginTime: firebase.firestore.FieldValue.serverTimestamp(),\n        roles: [\"Contributor\"]\n      }\n      if (res['user']['uid']) {\n        this.afs.collection(\"users\").doc(res['user']['uid']).set(data)\n        .then(res => {\n          this.router.navigate([`${adminURL}/dashboard`])\n        })\n        .catch(err => {\n          this.message.error(err)\n        })\n      }\n    })\n  }\n\n  signOut() {\n    return this.afAuth.auth.signOut()\n  }\n\n  private updateUserData(user) {\n    const userRef: AngularFirestoreDocument<any> = this.afs.doc(`users/${user.uid}`);\n    const data: User = {\n      uid: user.uid,\n      email: user.email,\n      roles: [\"Contributor\"] \n    }\n    return userRef.set(data, { merge: true })\n  }\n\n\n  ///// Role-based Authorization //////\n  canRead(user: User): boolean {\n    const allowed = ['Administrator', 'Editor', 'Author', 'Contributor']\n    return this.checkAuthorization(user, allowed)\n  }\n\n  canEdit(user: User): boolean {\n    const allowed = ['Administrator', 'Editor']\n    return this.checkAuthorization(user, allowed)\n  }\n\n  canDelete(user: User): boolean {\n    const allowed = ['Administrator']\n    return this.checkAuthorization(user, allowed)\n  }\n\n  // determines if user has matching role\n  private checkAuthorization(user: User, allowedRoles: string[]): boolean {\n    if (!user) return false\n    for (const role of allowedRoles) {\n      if (user.roles[role]) {\n        return true\n      }\n    }\n    return false\n  }\n\n  log (description: string) {\n    if (this.uid) {\n      this.afs.collection<Log>('log').add({\n        \"description\": description,\n        \"uid\": this.uid,\n        \"createdTime\": firebase.firestore.FieldValue.serverTimestamp()\n      })\n    }\n  }\n}\n"]}