@csmart/ngc-smart-core 1.13.10 → 1.13.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -112,7 +112,7 @@ export class SmartAuthService {
112
112
  this.loginStaff = await this.xdmService.getLoginStaff();
113
113
  }
114
114
  const permissions = this.loginStaff.permissions;
115
- const resource = (route.url && route.url.length > 0) ? route.url[0].path : '';
115
+ const resource = route.url && route.url.length > 0 ? route.url[0].path : '';
116
116
  if (!this.selectedOffender) {
117
117
  this.selectedOffender = await this.xdmService.getSelectedOffender();
118
118
  }
@@ -128,8 +128,7 @@ export class SmartAuthService {
128
128
  this.xdmService.setSelectedOffender(this.selectedOffender);
129
129
  // }
130
130
  }
131
- const assignmentStaffRelationId = this.selectedOffender
132
- .assignmentStaffRelationId;
131
+ const assignmentStaffRelationId = this.selectedOffender.assignmentStaffRelationId;
133
132
  const elements = document.querySelectorAll('[class^="sac-"]');
134
133
  const pattern = /^sac-(\S+)-(\S+)$/i;
135
134
  Array.from(elements).forEach((element) => {
@@ -230,7 +229,8 @@ export class SmartAuthService {
230
229
  this.loginStaff = selData.loginStaff;
231
230
  this.selectedOffender = selData.selectedOffender;
232
231
  let routePath = '';
233
- if (accessControlConfig.route.url && accessControlConfig.route.url.length > 0) {
232
+ if (accessControlConfig.route.url &&
233
+ accessControlConfig.route.url.length > 0) {
234
234
  routePath = accessControlConfig.route.url[0].path;
235
235
  }
236
236
  const permissions = this.loginStaff.permissions;
@@ -244,10 +244,10 @@ export class SmartAuthService {
244
244
  ? 'N/A'
245
245
  : this.selectedOffender.assignmentStaffRelationId;
246
246
  const permission = permissions.find((p) => {
247
- return (p.appModuleId === accessControlConfig.appModuleId
248
- && p.resource === resource
249
- && (!roleId || p.roleId === roleId)
250
- && (p.assignmentStaffRelationId === 'N/A' ||
247
+ return (p.appModuleId === accessControlConfig.appModuleId &&
248
+ p.resource === resource &&
249
+ (!roleId || p.roleId === roleId) &&
250
+ (p.assignmentStaffRelationId === 'N/A' ||
251
251
  p.assignmentStaffRelationId === assignmentStaffRelationId));
252
252
  });
253
253
  if (permission) {
@@ -350,72 +350,87 @@ export class SmartAuthService {
350
350
  element.setAttribute('style', 'display: none;');
351
351
  }
352
352
  getStaff(userName) {
353
- const httpOptions = {
354
- headers: new HttpHeaders({
355
- 'Content-Type': 'application/json',
356
- 'No-Auth': 'True',
357
- }),
358
- };
359
- const queryString = `
360
- {
361
- findvStaffs(input: {where: {userName: "${userName}", activeFlag: true}}) {
362
- totalCount
363
- message
364
- data {
365
- staffId
366
- userName
367
- lastName
368
- firstName
369
- phone
370
- email
371
- roles {
372
- roleId
373
- role
374
- }
375
- permissions {
376
- roleId
377
- appModuleId
378
- resource
379
- assignmentStaffRelationId
380
- readFlag
381
- createFlag
382
- updateFlag
383
- deleteFlag
384
- assignFlag
385
- reopenFlag
386
- closeFlag
387
- expungeFlag
388
- }
389
- options {
390
- offenderListOptionId
391
- name
392
- serviceApiFieldName
393
- selectedFlag
394
- }
395
- }
396
- }
397
- }`;
398
- return this.http
399
- .post(this.smartDataServiceUrl, { query: queryString }, httpOptions)
400
- .pipe(take(1), map((result) => {
353
+ return this.query({
354
+ query: this.findStaffQuery,
355
+ variables: {
356
+ where: {
357
+ userName: userName,
358
+ activeFlag: true,
359
+ },
360
+ },
361
+ }).pipe(take(1), map((result) => {
401
362
  if (isDevMode) {
402
363
  console.log('##### getStaff() from service ', result);
403
364
  }
404
- if (result.data.findvStaffs.data.length > 0) {
405
- const data = result.data.findvStaffs.data[0];
365
+ if (result.findvStaffs.data.length > 0) {
366
+ const data = result.findvStaffs.data[0];
406
367
  this.xdmService.setLoginStaff(data);
407
368
  this.loginStaff = data;
408
369
  return data;
409
370
  }
410
371
  else {
411
372
  return of(null);
412
- // return throwError('No access right.');
413
373
  }
414
374
  }), catchError((error) => {
415
375
  console.log('error ' + error);
416
376
  return of(null);
417
377
  }));
418
378
  }
379
+ query(options) {
380
+ return this.http
381
+ .post(this.smartDataServiceUrl, {
382
+ query: options.query,
383
+ variables: options.variables,
384
+ }, {
385
+ headers: new HttpHeaders({
386
+ 'Content-Type': 'application/json',
387
+ 'No-Auth': 'True',
388
+ }),
389
+ })
390
+ .pipe(map((d) => d.data));
391
+ }
392
+ get findStaffQuery() {
393
+ return `
394
+ query findvStaffs($input: vStaffMultiInput) {
395
+ findvStaffs(input: $input) {
396
+ totalCount
397
+ message
398
+ data {
399
+ staffId
400
+ userName
401
+ lastName
402
+ firstName
403
+ phone
404
+ email
405
+ roles {
406
+ roleId
407
+ role
408
+ }
409
+ permissions {
410
+ roleId
411
+ appModuleId
412
+ resource
413
+ assignmentStaffRelationId
414
+ readFlag
415
+ createFlag
416
+ updateFlag
417
+ deleteFlag
418
+ assignFlag
419
+ reopenFlag
420
+ closeFlag
421
+ expungeFlag
422
+ }
423
+ options {
424
+ offenderListOptionId
425
+ name
426
+ serviceApiFieldName
427
+ selectedFlag
428
+ }
429
+ }
430
+ }
431
+ }
432
+ `;
433
+ }
419
434
  getStaffOffenderRelation(staffId, offenderId) {
420
435
  const queryString = `
421
436
  {
@@ -485,4 +500,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImpor
485
500
  type: Inject,
486
501
  args: [SMART_DOMAIN_FORMAT]
487
502
  }] }]; } });
488
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-auth.service.js","sourceRoot":"","sources":["../../../../../../projects/csmart/ngc-smart-core/src/lib/smart-auth/smart-auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, isDevMode } from '@angular/core';\r\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport { Observable, of, from, throwError, lastValueFrom } from 'rxjs';\r\nimport { map, switchMap, take, catchError} from 'rxjs/operators';\r\nimport { MsalService } from '@azure/msal-angular';\r\nimport { ActivatedRouteSnapshot } from '@angular/router';\r\n\r\nimport {\r\n  LoginStaff,\r\n  SelectedOffender,\r\n  SMART_DATA_SERVICE_URL,\r\n  SMART_DOMAIN_FORMAT,\r\n  Role,\r\n  Permission,\r\n} from '../smart-storage/smart-storage-model';\r\nimport { XdmService } from '../smart-storage/xdm.service';\r\nimport { SmartAccessControlConfig } from './smart-access-control-config';\r\nimport { nullSafeIsEquivalent } from '@angular/compiler/src/output/output_ast';\r\n// import { stringify } from 'querystring';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class SmartAuthService {\r\n  loginStaff: LoginStaff;\r\n  selectedOffender: SelectedOffender;\r\n\r\n  constructor(\r\n    private http: HttpClient,\r\n    private authnService: MsalService,\r\n    private xdmService: XdmService,\r\n    @Inject(SMART_DATA_SERVICE_URL) private smartDataServiceUrl,\r\n    @Inject(SMART_DOMAIN_FORMAT) private smartDomainFormatUrl: string,\r\n  ) {}\r\n\r\n  public getLoginStaff(): Observable<LoginStaff> {\r\n    if (isDevMode) {\r\n      console.log('SmartAuthService - getLoginStaff()');\r\n    }\r\n    if (!isDevMode && this.loginStaff) {\r\n      if (this.loginStaff.staffId) {\r\n        if (isDevMode) {\r\n          console.log(\r\n            '##### getLoginStaff(): get internal instance in service',\r\n            this.loginStaff,\r\n          );\r\n        }\r\n        return of(this.loginStaff);\r\n      } else if (this.loginStaff.userName) {\r\n        if (isDevMode) {\r\n          console.log(\r\n            '##### getLoginStaff(): get using preset user name',\r\n            this.loginStaff,\r\n          );\r\n        }\r\n        return this.getStaff(this.loginStaff.userName);\r\n      }\r\n    }\r\n    return from(this.xdmService.getLoginStaff()).pipe(\r\n      switchMap((storedResult) => {\r\n        if (storedResult && storedResult.staffId) {\r\n          if (isDevMode) {\r\n            console.log(\r\n              '##### getLoginStaff(): get from session.',\r\n              storedResult,\r\n            );\r\n          }\r\n          this.loginStaff = storedResult;\r\n          return of(storedResult);\r\n        } else if (storedResult && storedResult.userName) {\r\n          if (isDevMode) {\r\n            console.log(\r\n              '##### getLoginStaff(): get using preset user name',\r\n              this.loginStaff,\r\n            );\r\n          }\r\n          return this.getStaff(storedResult.userName);\r\n        } else {\r\n          const userName = this.userName;\r\n          const staffName = userName.substring(0, userName.indexOf('@'));\r\n          if (isDevMode) {\r\n            console.log(\r\n              '##### loginLoginStaff(): get using login staff name ',\r\n              staffName,\r\n            );\r\n          }\r\n          return this.getStaff(staffName);\r\n        }\r\n      }),\r\n    );\r\n  }\r\n\r\n   get userName() : string {\r\n    if (this.authnService.instance.getAllAccounts().length > 0) {\r\n      const account = this.authnService.instance.getAllAccounts()[0];\r\n      return account.username;\r\n     }\r\n     \r\n     return '';\r\n  }\r\n\r\n  private getTeamUrl(app: string, afterHash: string): string {\r\n    return this.smartDomainFormatUrl.replace('${APP}', app) + afterHash;\r\n  }\r\n  private isSameHost(url, app) {\r\n    return this.smartDomainFormatUrl.replace('${APP}', app) === url;\r\n  }\r\n\r\n  public redirectToTeam(loginStaff: LoginStaff) {\r\n    if (loginStaff.roles.findIndex((role) => role.roleId === 'EUUSPC') > -1) {\r\n      if (!this.isSameHost(window.location.origin, 'investigation')) {\r\n        window.location.href = this.getTeamUrl('investigation', '/assignment');\r\n      }\r\n    } else if (\r\n      loginStaff.roles.findIndex(\r\n        (role) => role.roleId.substring(0, 3) === 'RSC',\r\n      ) > -1\r\n    ) {\r\n      if (!this.isSameHost(window.location.origin, 'rsc')) {\r\n        window.location.href = this.getTeamUrl('rsc', '/offender-list');\r\n      }\r\n    }\r\n  }\r\n\r\n  public async setSelectedOffender(selectedOffender: SelectedOffender) {\r\n    if(!this.loginStaff){\r\n      return;\r\n    }\r\n    \r\n    if (selectedOffender) {\r\n      // if (!selectedOffender.assignmentStaffRelationId) {\r\n      const relation = await lastValueFrom(this.getStaffOffenderRelation(\r\n        this.loginStaff.staffId,\r\n        selectedOffender.offenderId,\r\n      ));\r\n      if (relation) {\r\n        selectedOffender.assignmentStaffRelationId = relation;\r\n      } else {\r\n        selectedOffender.assignmentStaffRelationId = 'NOASSIGN';\r\n      }\r\n      // }\r\n    }\r\n    this.xdmService.setSelectedOffender(selectedOffender);\r\n    this.selectedOffender = selectedOffender;\r\n  }\r\n\r\n  public logout(): void {\r\n    this.xdmService.clearAll();\r\n    this.authnService.logout();\r\n  }\r\n\r\n  public async setPermission(\r\n    appModuleId: string,\r\n    route: ActivatedRouteSnapshot,\r\n  ) {\r\n    if (!this.loginStaff) {\r\n      this.loginStaff = await this.xdmService.getLoginStaff();\r\n    }\r\n    const permissions = this.loginStaff.permissions;\r\n    const resource = (route.url && route.url.length > 0) ? route.url[0]!.path : '';\r\n\r\n    if (!this.selectedOffender) {\r\n      this.selectedOffender = await this.xdmService.getSelectedOffender();\r\n    }\r\n\r\n    if (this.selectedOffender) {\r\n      // if (!this.selectedOffender.assignmentStaffRelationId) {\r\n      const relation = await this.getStaffOffenderRelation(\r\n        this.loginStaff.staffId,\r\n        this.selectedOffender.offenderId,\r\n      ).toPromise();\r\n      if (relation) {\r\n        this.selectedOffender.assignmentStaffRelationId = relation;\r\n      } else {\r\n        this.selectedOffender.assignmentStaffRelationId = 'NOASSIGN';\r\n      }\r\n      this.xdmService.setSelectedOffender(this.selectedOffender);\r\n      // }\r\n    }\r\n\r\n    const assignmentStaffRelationId = this.selectedOffender\r\n      .assignmentStaffRelationId;\r\n\r\n    const elements = document.querySelectorAll('[class^=\"sac-\"]');\r\n    const pattern = /^sac-(\\S+)-(\\S+)$/i;\r\n\r\n    Array.from(elements).forEach((element) => {\r\n      let hide;\r\n      let disable;\r\n      element.classList.forEach((c) => {\r\n        const results = c.match(pattern);\r\n        // console.log(results);\r\n        if (results && results.length > 2) {\r\n          const roleId = results[1] ? results[1].toUpperCase() : null;\r\n          const right = results[2];\r\n          // console.log(results[0]);\r\n          // console.log(results[1]);\r\n          // console.log(results[2]);\r\n          const permission = permissions.find(function (p) {\r\n            return (\r\n              p.appModuleId === appModuleId &&\r\n              p.resource === resource &&\r\n              p.roleId === roleId &&\r\n              p.assignmentStaffRelationId === assignmentStaffRelationId\r\n            );\r\n          });\r\n          /*\r\n          console.log('##### setPermission() resource: ', resource);\r\n          console.log('##### setPermission() appModuleId: ', appModuleId);\r\n          console.log('##### setPermission() roleId: ', roleId);\r\n          console.log(\r\n            '##### setPermission() assignment relation: ',\r\n            assignmentStaffRelationId,\r\n          );\r\n          */\r\n          console.log('##### Matched permission: ', permission);\r\n\r\n          if (permission) {\r\n            if (right === 'read') {\r\n              if (!permission.readFlag) {\r\n                if (hide !== false) {\r\n                  hide = true;\r\n                }\r\n              } else {\r\n                hide = false;\r\n              }\r\n            } else if (\r\n              (right === 'create' && !permission.createFlag) ||\r\n              (right === 'update' && !permission.updateFlag) ||\r\n              (right === 'delete' && !permission.deleteFlag) ||\r\n              (right === 'assign' && !permission.assignFlag) ||\r\n              (right === 'close' && !permission.closeFlag) ||\r\n              (right === 'expunge' && !permission.expungeFlag) ||\r\n              (right === 'reopen' && !permission.reopenFlag)\r\n            ) {\r\n              if (element.nodeName === 'BUTTON') {\r\n                if (hide !== false) {\r\n                  hide = true;\r\n                }\r\n              } else {\r\n                if (disable !== false) {\r\n                  disable = true;\r\n                }\r\n              }\r\n            } else {\r\n              if (element.nodeName === 'BUTTON') {\r\n                hide = false;\r\n              } else {\r\n                disable = false;\r\n              }\r\n            }\r\n          } else {\r\n            if (right === 'read') {\r\n              if (hide !== false) {\r\n                hide = true;\r\n              }\r\n            } else if (element.nodeName === 'BUTTON') {\r\n              if (hide !== false) {\r\n                hide = true;\r\n              }\r\n            } else if (disable !== false) {\r\n              disable = true;\r\n            }\r\n          }\r\n        }\r\n      });\r\n      console.log('hide: ', hide);\r\n      console.log('disable: ', disable);\r\n      if (hide === true) {\r\n        this.hideHtmlElement(element);\r\n      } else if (disable === true) {\r\n        this.disableHtmlElement(element);\r\n      }\r\n    });\r\n  }\r\n\r\n  public checkPermission(accessControlConfig: SmartAccessControlConfig) {\r\n    const selData = accessControlConfig.route.data;\r\n    this.loginStaff = selData.loginStaff;\r\n    this.selectedOffender = selData.selectedOffender;\r\n    let routePath = '';\r\n    if(accessControlConfig.route.url && accessControlConfig.route.url.length > 0){\r\n      routePath = accessControlConfig.route.url[0]!.path;\r\n    }\r\n\r\n    const permissions = this.loginStaff.permissions;\r\n    const resource = routePath;\r\n    const roleId = accessControlConfig.roleId\r\n      ? accessControlConfig.roleId.toUpperCase()\r\n      : null;\r\n    const accessType = accessControlConfig.accessType;\r\n    const assignmentStaffRelationId = !this.selectedOffender\r\n      .assignmentStaffRelationId\r\n      ? 'N/A'\r\n      : this.selectedOffender.assignmentStaffRelationId;\r\n\r\n    const permission = permissions.find((p) => {\r\n      return (\r\n             p.appModuleId === accessControlConfig.appModuleId\r\n          && p.resource === resource\r\n          && (!roleId || p.roleId === roleId)\r\n          && (p.assignmentStaffRelationId === 'N/A' ||\r\n        p.assignmentStaffRelationId === assignmentStaffRelationId)\r\n      );\r\n    });\r\n\r\n    if (permission) {\r\n      if (accessType === 'read') {\r\n        if (!permission.readFlag) {\r\n          return false;\r\n        } else {\r\n          return true;\r\n        }\r\n      } else if (\r\n        (accessType === 'create' && !permission.createFlag) ||\r\n        (accessType === 'update' && !permission.updateFlag) ||\r\n        (accessType === 'delete' && !permission.deleteFlag) ||\r\n        (accessType === 'assign' && !permission.assignFlag) ||\r\n        (accessType === 'close' && !permission.closeFlag) ||\r\n        (accessType === 'expunge' && !permission.expungeFlag) ||\r\n        (accessType === 'reopen' && !permission.reopenFlag)\r\n      ) {\r\n        return false;\r\n      } else {\r\n        return true;\r\n      }\r\n    } else {\r\n      if (accessType === 'read') {\r\n        return false;\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public canAppFeatureActivate(\r\n    loginStaff: LoginStaff,\r\n    feature: string,\r\n    appModuleId = null,\r\n  ) {\r\n    // if (!this.isAuthEnable(loginStaff.roles, appModuleId)) {\r\n    //   return true;\r\n    // }\r\n    return this.hasAppFeaturePermission(\r\n      loginStaff.permissions,\r\n      feature,\r\n      appModuleId,\r\n    );\r\n  }\r\n\r\n  // public isAuthEnable(roles: Role[], appModuleId: string) {\r\n  //   if (roles && roles.length > 0) {\r\n  //     return roles.map(r => r.roleId).findIndex(this.isExternalRole) > -1 || appModuleId === 'RR';\r\n  //   }\r\n  //   return false;\r\n  // }\r\n\r\n  public hasIntakeRole(roles: Role[]) {\r\n    if (roles && roles.length > 0) {\r\n      return roles.findIndex(this.isIntakeRole) > -1;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  private hasAppFeaturePermission(\r\n    permissions: Permission[],\r\n    feature: string,\r\n    appModuleId: string,\r\n  ) {\r\n    if (permissions && permissions.length > 0) {\r\n      if (appModuleId) {\r\n        return (\r\n          permissions.findIndex(\r\n            (p) => p.resource === feature && p.appModuleId === appModuleId,\r\n          ) > -1\r\n        );\r\n      } else {\r\n        return permissions.findIndex((p) => p.resource === feature) > -1;\r\n      }\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  private isExternalRole(roleId) {\r\n    switch (roleId) {\r\n      case 'EUDTL':\r\n      case 'EUDUSM':\r\n      case 'EUJDG':\r\n      case 'EUMPD':\r\n      case 'EUSOTV':\r\n      case 'EUUSA2':\r\n      case 'EUUSAO':\r\n      case 'EUUSPC':\r\n        return true;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  private isIntakeRole(role: Role) {\r\n    switch (role.roleId) {\r\n      case 'OPA':\r\n      case 'OPS':\r\n      case 'SOPS':\r\n        return true;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  private disableHtmlElement(element: Element): void {\r\n    // console.log(element);\r\n    switch (element.nodeName) {\r\n      case 'A':\r\n        element.setAttribute(\r\n          'style',\r\n          'pointer-events: none;cursor: not-allowed;',\r\n        );\r\n        element.setAttribute('tabIndex', '-1');\r\n        break;\r\n      default:\r\n        element.setAttribute('disabled', 'disabled');\r\n        break;\r\n    }\r\n  }\r\n\r\n  private hideHtmlElement(element: Element): void {\r\n    // element.setAttribute('hidden', 'hidden');\r\n    element.setAttribute('style', 'display: none;');\r\n  }\r\n\r\n  private getStaff(userName: string): Observable<LoginStaff> {\r\n    const httpOptions = {\r\n      headers: new HttpHeaders({\r\n          'Content-Type': 'application/json',\r\n          'No-Auth': 'True',\r\n      }),\r\n    };\r\n    const queryString = `\r\n            {\r\n              findvStaffs(input: {where: {userName: \"${userName}\", activeFlag: true}}) {\r\n                totalCount\r\n                message\r\n                data {\r\n                  staffId\r\n                  userName\r\n                  lastName\r\n                  firstName\r\n                  phone\r\n                  email\r\n                  roles {\r\n                    roleId\r\n                    role\r\n                  }\r\n                  permissions {\r\n                    roleId\r\n                    appModuleId\r\n                    resource\r\n                    assignmentStaffRelationId\r\n                    readFlag\r\n                    createFlag\r\n                    updateFlag\r\n                    deleteFlag\r\n                    assignFlag\r\n                    reopenFlag\r\n                    closeFlag\r\n                    expungeFlag\r\n                  }\r\n                  options {\r\n                    offenderListOptionId\r\n                    name\r\n                    serviceApiFieldName\r\n                    selectedFlag\r\n                  }\r\n                }\r\n              }\r\n            }`;\r\n\r\n    return this.http\r\n      .post<any>(this.smartDataServiceUrl, { query: queryString }, httpOptions)\r\n      .pipe(\r\n        take(1),\r\n        map((result) => {\r\n          if (isDevMode) {\r\n            console.log('##### getStaff() from service ', result);\r\n          }\r\n          if (result.data.findvStaffs.data.length > 0) {\r\n            const data = result.data.findvStaffs.data[0];\r\n            this.xdmService.setLoginStaff(data);\r\n            this.loginStaff = data;\r\n            return data;\r\n          } else {\r\n            return of(null);\r\n            // return throwError('No access right.');\r\n          }\r\n        }),\r\n        catchError((error) => {\r\n          console.log('error ' + error);\r\n          return of(null);\r\n        }),\r\n      );\r\n  }\r\n\r\n  private getStaffOffenderRelation(\r\n    staffId: number,\r\n    offenderId: number,\r\n  ): Observable<string> {\r\n    const queryString = `\r\n            {\r\n              findvStaffOffenderRelations(input: {where: {staffId: ${staffId}, offenderId: ${offenderId}}}) {\r\n                data {\r\n                  assignmentStaffRelationId\r\n                }\r\n              }\r\n            }`;\r\n\r\n    return this.http\r\n      .post<any>(this.smartDataServiceUrl, { query: queryString })\r\n      .pipe(\r\n        take(1),\r\n        map((result) => {\r\n          if (isDevMode) {\r\n            console.log(\r\n              '##### getStaffOffenderRelation() from service ',\r\n              result,\r\n            );\r\n          }\r\n          if (result.data.findvStaffOffenderRelations.data.length > 0) {\r\n            const data = result.data.findvStaffOffenderRelations.data[0];\r\n            return data.assignmentStaffRelationId;\r\n          } else {\r\n            return null;\r\n            // return throwError('No access right.');\r\n          }\r\n        }),\r\n        catchError((error) => {\r\n          console.log('error ' + error);\r\n          return null;\r\n        }),\r\n      );\r\n  }\r\n\r\n  private getRolePermissions(\r\n    appModuleId: string,\r\n    resource: string,\r\n  ): Observable<boolean> {\r\n    const queryString = `\r\n           query findvRolePermissionPivots{\r\n            findvRolePermissionPivots(input: {where: {appModuleId: ${appModuleId}, resource: ${resource}}}){\r\n              totalCount\r\n              message\r\n            }\r\n          }`;\r\n\r\n    return this.http\r\n      .post<any>(this.smartDataServiceUrl, { query: queryString })\r\n      .pipe(\r\n        take(1),\r\n        map((result) => {\r\n          if (isDevMode) {\r\n            console.log(\r\n              '##### findvRolePermissionPivots() from service ',\r\n              result,\r\n            );\r\n          }\r\n          if (result.data.findvRolePermissionPivots.totalCount > 0) {\r\n            return true;\r\n          } else {\r\n            return false;\r\n            // return throwError('No access right.');\r\n          }\r\n        }),\r\n        catchError((error: any) => {\r\n          console.log('error ' + error);\r\n          return throwError(error);\r\n        }),\r\n      );\r\n  }\r\n}\r\n"]}
503
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-auth.service.js","sourceRoot":"","sources":["../../../../../../projects/csmart/ngc-smart-core/src/lib/smart-auth/smart-auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, isDevMode } from '@angular/core';\r\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport { Observable, of, from, throwError, lastValueFrom } from 'rxjs';\r\nimport { map, switchMap, take, catchError} from 'rxjs/operators';\r\nimport { MsalService } from '@azure/msal-angular';\r\nimport { ActivatedRouteSnapshot } from '@angular/router';\r\n\r\nimport {\r\n  LoginStaff,\r\n  SelectedOffender,\r\n  SMART_DATA_SERVICE_URL,\r\n  SMART_DOMAIN_FORMAT,\r\n  Role,\r\n  Permission,\r\n} from '../smart-storage/smart-storage-model';\r\nimport { XdmService } from '../smart-storage/xdm.service';\r\nimport { SmartAccessControlConfig } from './smart-access-control-config';\r\nimport { nullSafeIsEquivalent } from '@angular/compiler/src/output/output_ast';\r\n// import { stringify } from 'querystring';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class SmartAuthService {\r\n  loginStaff: LoginStaff;\r\n  selectedOffender: SelectedOffender;\r\n\r\n  constructor(\r\n    private http: HttpClient,\r\n    private authnService: MsalService,\r\n    private xdmService: XdmService,\r\n    @Inject(SMART_DATA_SERVICE_URL) private smartDataServiceUrl,\r\n    @Inject(SMART_DOMAIN_FORMAT) private smartDomainFormatUrl: string,\r\n  ) {}\r\n\r\n  public getLoginStaff(): Observable<LoginStaff> {\r\n    if (isDevMode) {\r\n      console.log('SmartAuthService - getLoginStaff()');\r\n    }\r\n    if (!isDevMode && this.loginStaff) {\r\n      if (this.loginStaff.staffId) {\r\n        if (isDevMode) {\r\n          console.log(\r\n            '##### getLoginStaff(): get internal instance in service',\r\n            this.loginStaff,\r\n          );\r\n        }\r\n        return of(this.loginStaff);\r\n      } else if (this.loginStaff.userName) {\r\n        if (isDevMode) {\r\n          console.log(\r\n            '##### getLoginStaff(): get using preset user name',\r\n            this.loginStaff,\r\n          );\r\n        }\r\n        return this.getStaff(this.loginStaff.userName);\r\n      }\r\n    }\r\n    return from(this.xdmService.getLoginStaff()).pipe(\r\n      switchMap((storedResult) => {\r\n        if (storedResult && storedResult.staffId) {\r\n          if (isDevMode) {\r\n            console.log(\r\n              '##### getLoginStaff(): get from session.',\r\n              storedResult,\r\n            );\r\n          }\r\n          this.loginStaff = storedResult;\r\n          return of(storedResult);\r\n        } else if (storedResult && storedResult.userName) {\r\n          if (isDevMode) {\r\n            console.log(\r\n              '##### getLoginStaff(): get using preset user name',\r\n              this.loginStaff,\r\n            );\r\n          }\r\n          return this.getStaff(storedResult.userName);\r\n        } else {\r\n          const userName = this.userName;\r\n          const staffName = userName.substring(0, userName.indexOf('@'));\r\n          if (isDevMode) {\r\n            console.log(\r\n              '##### loginLoginStaff(): get using login staff name ',\r\n              staffName,\r\n            );\r\n          }\r\n          return this.getStaff(staffName);\r\n        }\r\n      }),\r\n    );\r\n  }\r\n\r\n  get userName(): string {\r\n    if (this.authnService.instance.getAllAccounts().length > 0) {\r\n      const account = this.authnService.instance.getAllAccounts()[0];\r\n      return account.username;\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  private getTeamUrl(app: string, afterHash: string): string {\r\n    return this.smartDomainFormatUrl.replace('${APP}', app) + afterHash;\r\n  }\r\n  private isSameHost(url, app) {\r\n    return this.smartDomainFormatUrl.replace('${APP}', app) === url;\r\n  }\r\n\r\n  public redirectToTeam(loginStaff: LoginStaff) {\r\n    if (loginStaff.roles.findIndex((role) => role.roleId === 'EUUSPC') > -1) {\r\n      if (!this.isSameHost(window.location.origin, 'investigation')) {\r\n        window.location.href = this.getTeamUrl('investigation', '/assignment');\r\n      }\r\n    } else if (\r\n      loginStaff.roles.findIndex(\r\n        (role) => role.roleId.substring(0, 3) === 'RSC',\r\n      ) > -1\r\n    ) {\r\n      if (!this.isSameHost(window.location.origin, 'rsc')) {\r\n        window.location.href = this.getTeamUrl('rsc', '/offender-list');\r\n      }\r\n    }\r\n  }\r\n\r\n  public async setSelectedOffender(selectedOffender: SelectedOffender) {\r\n    if (!this.loginStaff) {\r\n      return;\r\n    }\r\n\r\n    if (selectedOffender) {\r\n      // if (!selectedOffender.assignmentStaffRelationId) {\r\n      const relation = await lastValueFrom(\r\n        this.getStaffOffenderRelation(\r\n          this.loginStaff.staffId,\r\n          selectedOffender.offenderId,\r\n        ),\r\n      );\r\n      if (relation) {\r\n        selectedOffender.assignmentStaffRelationId = relation;\r\n      } else {\r\n        selectedOffender.assignmentStaffRelationId = 'NOASSIGN';\r\n      }\r\n      // }\r\n    }\r\n    this.xdmService.setSelectedOffender(selectedOffender);\r\n    this.selectedOffender = selectedOffender;\r\n  }\r\n\r\n  public logout(): void {\r\n    this.xdmService.clearAll();\r\n    this.authnService.logout();\r\n  }\r\n\r\n  public async setPermission(\r\n    appModuleId: string,\r\n    route: ActivatedRouteSnapshot,\r\n  ) {\r\n    if (!this.loginStaff) {\r\n      this.loginStaff = await this.xdmService.getLoginStaff();\r\n    }\r\n    const permissions = this.loginStaff.permissions;\r\n    const resource =\r\n      route.url && route.url.length > 0 ? route.url[0]!.path : '';\r\n\r\n    if (!this.selectedOffender) {\r\n      this.selectedOffender = await this.xdmService.getSelectedOffender();\r\n    }\r\n\r\n    if (this.selectedOffender) {\r\n      // if (!this.selectedOffender.assignmentStaffRelationId) {\r\n      const relation = await this.getStaffOffenderRelation(\r\n        this.loginStaff.staffId,\r\n        this.selectedOffender.offenderId,\r\n      ).toPromise();\r\n      if (relation) {\r\n        this.selectedOffender.assignmentStaffRelationId = relation;\r\n      } else {\r\n        this.selectedOffender.assignmentStaffRelationId = 'NOASSIGN';\r\n      }\r\n      this.xdmService.setSelectedOffender(this.selectedOffender);\r\n      // }\r\n    }\r\n\r\n    const assignmentStaffRelationId =\r\n      this.selectedOffender.assignmentStaffRelationId;\r\n\r\n    const elements = document.querySelectorAll('[class^=\"sac-\"]');\r\n    const pattern = /^sac-(\\S+)-(\\S+)$/i;\r\n\r\n    Array.from(elements).forEach((element) => {\r\n      let hide;\r\n      let disable;\r\n      element.classList.forEach((c) => {\r\n        const results = c.match(pattern);\r\n        // console.log(results);\r\n        if (results && results.length > 2) {\r\n          const roleId = results[1] ? results[1].toUpperCase() : null;\r\n          const right = results[2];\r\n          // console.log(results[0]);\r\n          // console.log(results[1]);\r\n          // console.log(results[2]);\r\n          const permission = permissions.find(function (p) {\r\n            return (\r\n              p.appModuleId === appModuleId &&\r\n              p.resource === resource &&\r\n              p.roleId === roleId &&\r\n              p.assignmentStaffRelationId === assignmentStaffRelationId\r\n            );\r\n          });\r\n          /*\r\n          console.log('##### setPermission() resource: ', resource);\r\n          console.log('##### setPermission() appModuleId: ', appModuleId);\r\n          console.log('##### setPermission() roleId: ', roleId);\r\n          console.log(\r\n            '##### setPermission() assignment relation: ',\r\n            assignmentStaffRelationId,\r\n          );\r\n          */\r\n          console.log('##### Matched permission: ', permission);\r\n\r\n          if (permission) {\r\n            if (right === 'read') {\r\n              if (!permission.readFlag) {\r\n                if (hide !== false) {\r\n                  hide = true;\r\n                }\r\n              } else {\r\n                hide = false;\r\n              }\r\n            } else if (\r\n              (right === 'create' && !permission.createFlag) ||\r\n              (right === 'update' && !permission.updateFlag) ||\r\n              (right === 'delete' && !permission.deleteFlag) ||\r\n              (right === 'assign' && !permission.assignFlag) ||\r\n              (right === 'close' && !permission.closeFlag) ||\r\n              (right === 'expunge' && !permission.expungeFlag) ||\r\n              (right === 'reopen' && !permission.reopenFlag)\r\n            ) {\r\n              if (element.nodeName === 'BUTTON') {\r\n                if (hide !== false) {\r\n                  hide = true;\r\n                }\r\n              } else {\r\n                if (disable !== false) {\r\n                  disable = true;\r\n                }\r\n              }\r\n            } else {\r\n              if (element.nodeName === 'BUTTON') {\r\n                hide = false;\r\n              } else {\r\n                disable = false;\r\n              }\r\n            }\r\n          } else {\r\n            if (right === 'read') {\r\n              if (hide !== false) {\r\n                hide = true;\r\n              }\r\n            } else if (element.nodeName === 'BUTTON') {\r\n              if (hide !== false) {\r\n                hide = true;\r\n              }\r\n            } else if (disable !== false) {\r\n              disable = true;\r\n            }\r\n          }\r\n        }\r\n      });\r\n      console.log('hide: ', hide);\r\n      console.log('disable: ', disable);\r\n      if (hide === true) {\r\n        this.hideHtmlElement(element);\r\n      } else if (disable === true) {\r\n        this.disableHtmlElement(element);\r\n      }\r\n    });\r\n  }\r\n\r\n  public checkPermission(accessControlConfig: SmartAccessControlConfig) {\r\n    const selData = accessControlConfig.route.data;\r\n    this.loginStaff = selData.loginStaff;\r\n    this.selectedOffender = selData.selectedOffender;\r\n    let routePath = '';\r\n    if (\r\n      accessControlConfig.route.url &&\r\n      accessControlConfig.route.url.length > 0\r\n    ) {\r\n      routePath = accessControlConfig.route.url[0]!.path;\r\n    }\r\n\r\n    const permissions = this.loginStaff.permissions;\r\n    const resource = routePath;\r\n    const roleId = accessControlConfig.roleId\r\n      ? accessControlConfig.roleId.toUpperCase()\r\n      : null;\r\n    const accessType = accessControlConfig.accessType;\r\n    const assignmentStaffRelationId = !this.selectedOffender\r\n      .assignmentStaffRelationId\r\n      ? 'N/A'\r\n      : this.selectedOffender.assignmentStaffRelationId;\r\n\r\n    const permission = permissions.find((p) => {\r\n      return (\r\n        p.appModuleId === accessControlConfig.appModuleId &&\r\n        p.resource === resource &&\r\n        (!roleId || p.roleId === roleId) &&\r\n        (p.assignmentStaffRelationId === 'N/A' ||\r\n          p.assignmentStaffRelationId === assignmentStaffRelationId)\r\n      );\r\n    });\r\n\r\n    if (permission) {\r\n      if (accessType === 'read') {\r\n        if (!permission.readFlag) {\r\n          return false;\r\n        } else {\r\n          return true;\r\n        }\r\n      } else if (\r\n        (accessType === 'create' && !permission.createFlag) ||\r\n        (accessType === 'update' && !permission.updateFlag) ||\r\n        (accessType === 'delete' && !permission.deleteFlag) ||\r\n        (accessType === 'assign' && !permission.assignFlag) ||\r\n        (accessType === 'close' && !permission.closeFlag) ||\r\n        (accessType === 'expunge' && !permission.expungeFlag) ||\r\n        (accessType === 'reopen' && !permission.reopenFlag)\r\n      ) {\r\n        return false;\r\n      } else {\r\n        return true;\r\n      }\r\n    } else {\r\n      if (accessType === 'read') {\r\n        return false;\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public canAppFeatureActivate(\r\n    loginStaff: LoginStaff,\r\n    feature: string,\r\n    appModuleId = null,\r\n  ) {\r\n    // if (!this.isAuthEnable(loginStaff.roles, appModuleId)) {\r\n    //   return true;\r\n    // }\r\n    return this.hasAppFeaturePermission(\r\n      loginStaff.permissions,\r\n      feature,\r\n      appModuleId,\r\n    );\r\n  }\r\n\r\n  // public isAuthEnable(roles: Role[], appModuleId: string) {\r\n  //   if (roles && roles.length > 0) {\r\n  //     return roles.map(r => r.roleId).findIndex(this.isExternalRole) > -1 || appModuleId === 'RR';\r\n  //   }\r\n  //   return false;\r\n  // }\r\n\r\n  public hasIntakeRole(roles: Role[]) {\r\n    if (roles && roles.length > 0) {\r\n      return roles.findIndex(this.isIntakeRole) > -1;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  private hasAppFeaturePermission(\r\n    permissions: Permission[],\r\n    feature: string,\r\n    appModuleId: string,\r\n  ) {\r\n    if (permissions && permissions.length > 0) {\r\n      if (appModuleId) {\r\n        return (\r\n          permissions.findIndex(\r\n            (p) => p.resource === feature && p.appModuleId === appModuleId,\r\n          ) > -1\r\n        );\r\n      } else {\r\n        return permissions.findIndex((p) => p.resource === feature) > -1;\r\n      }\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  private isExternalRole(roleId) {\r\n    switch (roleId) {\r\n      case 'EUDTL':\r\n      case 'EUDUSM':\r\n      case 'EUJDG':\r\n      case 'EUMPD':\r\n      case 'EUSOTV':\r\n      case 'EUUSA2':\r\n      case 'EUUSAO':\r\n      case 'EUUSPC':\r\n        return true;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  private isIntakeRole(role: Role) {\r\n    switch (role.roleId) {\r\n      case 'OPA':\r\n      case 'OPS':\r\n      case 'SOPS':\r\n        return true;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  private disableHtmlElement(element: Element): void {\r\n    // console.log(element);\r\n    switch (element.nodeName) {\r\n      case 'A':\r\n        element.setAttribute(\r\n          'style',\r\n          'pointer-events: none;cursor: not-allowed;',\r\n        );\r\n        element.setAttribute('tabIndex', '-1');\r\n        break;\r\n      default:\r\n        element.setAttribute('disabled', 'disabled');\r\n        break;\r\n    }\r\n  }\r\n\r\n  private hideHtmlElement(element: Element): void {\r\n    // element.setAttribute('hidden', 'hidden');\r\n    element.setAttribute('style', 'display: none;');\r\n  }\r\n\r\n  private getStaff(userName: string): Observable<LoginStaff> {\r\n    return this.query<any>({\r\n      query: this.findStaffQuery,\r\n      variables: {\r\n        where: {\r\n          userName: userName,\r\n          activeFlag: true,\r\n        },\r\n      },\r\n    }).pipe(\r\n        take(1),\r\n        map((result) => {\r\n          if (isDevMode) {\r\n            console.log('##### getStaff() from service ', result);\r\n          }\r\n          if (result.findvStaffs.data.length > 0) {\r\n            const data = result.findvStaffs.data[0];\r\n            this.xdmService.setLoginStaff(data);\r\n            this.loginStaff = data;\r\n            return data;\r\n          } else {\r\n            return of(null);\r\n          }\r\n        }),\r\n        catchError((error) => {\r\n          console.log('error ' + error);\r\n          return of(null);\r\n        }),\r\n      );\r\n  }\r\n\r\n  private query<T>(options: {\r\n    query: string;\r\n    variables?: { [key: string]: any };\r\n  }): Observable<T> {\r\n    return this.http\r\n      .post<{ data: T }>(\r\n        this.smartDataServiceUrl,\r\n        {\r\n          query: options.query,\r\n          variables: options.variables,\r\n        },\r\n        {\r\n          headers: new HttpHeaders({\r\n            'Content-Type': 'application/json',\r\n            'No-Auth': 'True',\r\n          }),\r\n       }\r\n      )\r\n      .pipe(map((d) => d.data));\r\n  }\r\n\r\n  private get findStaffQuery(){\r\n    return `\r\n     query findvStaffs($input: vStaffMultiInput) {\r\n        findvStaffs(input: $input) {\r\n          totalCount\r\n          message\r\n          data {\r\n            staffId\r\n            userName\r\n            lastName\r\n            firstName\r\n            phone\r\n            email\r\n            roles {\r\n              roleId\r\n              role\r\n            }\r\n            permissions {\r\n              roleId\r\n              appModuleId\r\n              resource\r\n              assignmentStaffRelationId\r\n              readFlag\r\n              createFlag\r\n              updateFlag\r\n              deleteFlag\r\n              assignFlag\r\n              reopenFlag\r\n              closeFlag\r\n              expungeFlag\r\n            }\r\n            options {\r\n              offenderListOptionId\r\n              name\r\n              serviceApiFieldName\r\n              selectedFlag\r\n            }\r\n          }\r\n        }\r\n      }\r\n    `;\r\n  }\r\n\r\n  private getStaffOffenderRelation(\r\n    staffId: number,\r\n    offenderId: number,\r\n  ): Observable<string> {\r\n    const queryString = `\r\n            {\r\n              findvStaffOffenderRelations(input: {where: {staffId: ${staffId}, offenderId: ${offenderId}}}) {\r\n                data {\r\n                  assignmentStaffRelationId\r\n                }\r\n              }\r\n            }`;\r\n\r\n    return this.http\r\n      .post<any>(this.smartDataServiceUrl, { query: queryString })\r\n      .pipe(\r\n        take(1),\r\n        map((result) => {\r\n          if (isDevMode) {\r\n            console.log(\r\n              '##### getStaffOffenderRelation() from service ',\r\n              result,\r\n            );\r\n          }\r\n          if (result.data.findvStaffOffenderRelations.data.length > 0) {\r\n            const data = result.data.findvStaffOffenderRelations.data[0];\r\n            return data.assignmentStaffRelationId;\r\n          } else {\r\n            return null;\r\n            // return throwError('No access right.');\r\n          }\r\n        }),\r\n        catchError((error) => {\r\n          console.log('error ' + error);\r\n          return null;\r\n        }),\r\n      );\r\n  }\r\n\r\n  private getRolePermissions(\r\n    appModuleId: string,\r\n    resource: string,\r\n  ): Observable<boolean> {\r\n    const queryString = `\r\n           query findvRolePermissionPivots{\r\n            findvRolePermissionPivots(input: {where: {appModuleId: ${appModuleId}, resource: ${resource}}}){\r\n              totalCount\r\n              message\r\n            }\r\n          }`;\r\n\r\n    return this.http\r\n      .post<any>(this.smartDataServiceUrl, { query: queryString })\r\n      .pipe(\r\n        take(1),\r\n        map((result) => {\r\n          if (isDevMode) {\r\n            console.log(\r\n              '##### findvRolePermissionPivots() from service ',\r\n              result,\r\n            );\r\n          }\r\n          if (result.data.findvRolePermissionPivots.totalCount > 0) {\r\n            return true;\r\n          } else {\r\n            return false;\r\n            // return throwError('No access right.');\r\n          }\r\n        }),\r\n        catchError((error: any) => {\r\n          console.log('error ' + error);\r\n          return throwError(error);\r\n        }),\r\n      );\r\n  }\r\n}\r\n"]}
@@ -917,7 +917,7 @@ class SmartAuthService {
917
917
  this.loginStaff = yield this.xdmService.getLoginStaff();
918
918
  }
919
919
  const permissions = this.loginStaff.permissions;
920
- const resource = (route.url && route.url.length > 0) ? route.url[0].path : '';
920
+ const resource = route.url && route.url.length > 0 ? route.url[0].path : '';
921
921
  if (!this.selectedOffender) {
922
922
  this.selectedOffender = yield this.xdmService.getSelectedOffender();
923
923
  }
@@ -933,8 +933,7 @@ class SmartAuthService {
933
933
  this.xdmService.setSelectedOffender(this.selectedOffender);
934
934
  // }
935
935
  }
936
- const assignmentStaffRelationId = this.selectedOffender
937
- .assignmentStaffRelationId;
936
+ const assignmentStaffRelationId = this.selectedOffender.assignmentStaffRelationId;
938
937
  const elements = document.querySelectorAll('[class^="sac-"]');
939
938
  const pattern = /^sac-(\S+)-(\S+)$/i;
940
939
  Array.from(elements).forEach((element) => {
@@ -1036,7 +1035,8 @@ class SmartAuthService {
1036
1035
  this.loginStaff = selData.loginStaff;
1037
1036
  this.selectedOffender = selData.selectedOffender;
1038
1037
  let routePath = '';
1039
- if (accessControlConfig.route.url && accessControlConfig.route.url.length > 0) {
1038
+ if (accessControlConfig.route.url &&
1039
+ accessControlConfig.route.url.length > 0) {
1040
1040
  routePath = accessControlConfig.route.url[0].path;
1041
1041
  }
1042
1042
  const permissions = this.loginStaff.permissions;
@@ -1050,10 +1050,10 @@ class SmartAuthService {
1050
1050
  ? 'N/A'
1051
1051
  : this.selectedOffender.assignmentStaffRelationId;
1052
1052
  const permission = permissions.find((p) => {
1053
- return (p.appModuleId === accessControlConfig.appModuleId
1054
- && p.resource === resource
1055
- && (!roleId || p.roleId === roleId)
1056
- && (p.assignmentStaffRelationId === 'N/A' ||
1053
+ return (p.appModuleId === accessControlConfig.appModuleId &&
1054
+ p.resource === resource &&
1055
+ (!roleId || p.roleId === roleId) &&
1056
+ (p.assignmentStaffRelationId === 'N/A' ||
1057
1057
  p.assignmentStaffRelationId === assignmentStaffRelationId));
1058
1058
  });
1059
1059
  if (permission) {
@@ -1156,72 +1156,87 @@ class SmartAuthService {
1156
1156
  element.setAttribute('style', 'display: none;');
1157
1157
  }
1158
1158
  getStaff(userName) {
1159
- const httpOptions = {
1160
- headers: new HttpHeaders({
1161
- 'Content-Type': 'application/json',
1162
- 'No-Auth': 'True',
1163
- }),
1164
- };
1165
- const queryString = `
1166
- {
1167
- findvStaffs(input: {where: {userName: "${userName}", activeFlag: true}}) {
1168
- totalCount
1169
- message
1170
- data {
1171
- staffId
1172
- userName
1173
- lastName
1174
- firstName
1175
- phone
1176
- email
1177
- roles {
1178
- roleId
1179
- role
1180
- }
1181
- permissions {
1182
- roleId
1183
- appModuleId
1184
- resource
1185
- assignmentStaffRelationId
1186
- readFlag
1187
- createFlag
1188
- updateFlag
1189
- deleteFlag
1190
- assignFlag
1191
- reopenFlag
1192
- closeFlag
1193
- expungeFlag
1194
- }
1195
- options {
1196
- offenderListOptionId
1197
- name
1198
- serviceApiFieldName
1199
- selectedFlag
1200
- }
1201
- }
1202
- }
1203
- }`;
1204
- return this.http
1205
- .post(this.smartDataServiceUrl, { query: queryString }, httpOptions)
1206
- .pipe(take(1), map((result) => {
1159
+ return this.query({
1160
+ query: this.findStaffQuery,
1161
+ variables: {
1162
+ where: {
1163
+ userName: userName,
1164
+ activeFlag: true,
1165
+ },
1166
+ },
1167
+ }).pipe(take(1), map((result) => {
1207
1168
  if (isDevMode) {
1208
1169
  console.log('##### getStaff() from service ', result);
1209
1170
  }
1210
- if (result.data.findvStaffs.data.length > 0) {
1211
- const data = result.data.findvStaffs.data[0];
1171
+ if (result.findvStaffs.data.length > 0) {
1172
+ const data = result.findvStaffs.data[0];
1212
1173
  this.xdmService.setLoginStaff(data);
1213
1174
  this.loginStaff = data;
1214
1175
  return data;
1215
1176
  }
1216
1177
  else {
1217
1178
  return of(null);
1218
- // return throwError('No access right.');
1219
1179
  }
1220
1180
  }), catchError((error) => {
1221
1181
  console.log('error ' + error);
1222
1182
  return of(null);
1223
1183
  }));
1224
1184
  }
1185
+ query(options) {
1186
+ return this.http
1187
+ .post(this.smartDataServiceUrl, {
1188
+ query: options.query,
1189
+ variables: options.variables,
1190
+ }, {
1191
+ headers: new HttpHeaders({
1192
+ 'Content-Type': 'application/json',
1193
+ 'No-Auth': 'True',
1194
+ }),
1195
+ })
1196
+ .pipe(map((d) => d.data));
1197
+ }
1198
+ get findStaffQuery() {
1199
+ return `
1200
+ query findvStaffs($input: vStaffMultiInput) {
1201
+ findvStaffs(input: $input) {
1202
+ totalCount
1203
+ message
1204
+ data {
1205
+ staffId
1206
+ userName
1207
+ lastName
1208
+ firstName
1209
+ phone
1210
+ email
1211
+ roles {
1212
+ roleId
1213
+ role
1214
+ }
1215
+ permissions {
1216
+ roleId
1217
+ appModuleId
1218
+ resource
1219
+ assignmentStaffRelationId
1220
+ readFlag
1221
+ createFlag
1222
+ updateFlag
1223
+ deleteFlag
1224
+ assignFlag
1225
+ reopenFlag
1226
+ closeFlag
1227
+ expungeFlag
1228
+ }
1229
+ options {
1230
+ offenderListOptionId
1231
+ name
1232
+ serviceApiFieldName
1233
+ selectedFlag
1234
+ }
1235
+ }
1236
+ }
1237
+ }
1238
+ `;
1239
+ }
1225
1240
  getStaffOffenderRelation(staffId, offenderId) {
1226
1241
  const queryString = `
1227
1242
  {