Esta librería es un cliente para angular, donde se gestiona el llamado a los servicios del componente de autorización para EPM, así como el manejo de la información del árbol de menú en el localStorage y la validación de rutas por medio de guardianes.
Use npm:
$ npm install epm-client
import { EpmConfiguracionService } from 'epm-client';
Para configurar los servicios del cliente, se requiere llamar el método configuración el cual se encuentra en “EpmConfiguracionService”. Este requiere la especificación del ambiente, una bandera para traza de log y la key de suscripción a API Management.
- Ejemplo
this.epmConfiguracionService.configuracion(environment.production, !environment.production, environment.subscriptionKey);
// *****************************
// Verifica si se encuentra información del menú almacenada en el storage.
// *****************************
this.epmClientService.getStorageMenu()
// *****************************
// Elimina la información del menú almacenada en el storage.
// *****************************
this.epmClientService.deleteStorageMenu();
// *****************************
// Almacena la información obtenida por el servicio en el storage.
// *****************************
this.epmClientService.saveStorageMenu(<Recurso[]>);
// *****************************
// Servicio que obtiene la información del menú correspondiente al ClientId suministrado como parámetro, esto determina la visibilidad de acceso a las entidades.
// *****************************
this.epmClientService.getMenu(<"ClientId">)
Es responsabilidad de cada aplicación eliminar la información almacenada en el storage, cuando se realice el proceso de deslogueo y cuando la aplicación necesite cambiar los privilegios del menú.
// *****************************
// OBTENER Y ALMACENAR ARBOL DE MENU
// *****************************
import {EpmClientService,Recurso } from 'epm-client';
export class SidebarComponent implements OnInit {
arbolMenu: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
const menu = this.epmClientService.getStorageMenu();
if (!menu) {
this.epmClientService.getMenu(<"ClientId">)
.subscribe(res => {
this.arbolMenu = res;
this.epmClientService.deleteStorageMenu();
this.epmClientService.saveStorageMenu(this.arbolMenu);
},
error => {
console.log('error: ', error);
});
} else {
this.arbolMenu= menu;
}
{}
Servicio que provee la verificación de las rutas a la cuales se tiene acceso dentro de la aplicación.
// *****************************
// Verifica si la url pasada como parámetro tiene permisos de visualización o no por el usuario.
// *****************************
this.epmClientService.validarRuta(<"url">); Result => true or false
// *****************************
// VALIDANDO RUTAS CON GUARDIANES
// *****************************
import { EpmClientService } from 'epm-client';
permitir = false;
constructor(private epmClientService: EpmClientService,
private router: Router) {
}
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
this.permitir = this.epmClientService.validarRuta(route['_routerState'].url);
if (!this.permitir) {
this.router.navigate(['/no-autorizado']);
}
return this.permitir;
}
true or false
// *****************************
// Obtiene la información de las entidades, con el fin de que se pueda verificar acciones permitidas en la misma.
// *****************************
this.epmClientService.getEntidad(<"ClientId">)
// *****************************
// Obtiene una Lista de las Entidades almacenadas en el storage.
// *****************************
this.epmClientService.getStorageEntidad();
// *****************************
// Elimina la información almacenada de la entidad en el storage.
// *****************************
this.epmClientService.deleteStorageEntidad();
// *****************************
// Almacena la información de la entidad proporcionada por el servicio en el storage.
// *****************************
this.epmClientService.saveStorageEntidad(<Recurso[]>);
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
const result = this.epmClientService.getStorageEntidad();
if(!result) {
this.epmClientService.getEntidad(<"ClientId">).subscribe(res=>{
this.epmClientService.deleteStorageEntidad();
this.epmClientService.saveStorageEntidad(res);
})
}
{}
// *****************************
// Verifica los permisos registrados sobre una entidad pasada como parametro el nombre.
// *****************************
this.epmClientService.validarEntidad(<"entidad">); Result => string[]
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
const result = this.epmClientService.validarEntidad(<"boton">); Result => string[]
}
{}
Es recomendable validar preexistencia del listado de entidades, para evitar llamados innecesarios al servicio y dependiendo de las acciones o permisos que se estén brindando sobre la entidad, eliminarla y sobreescribirla en el storage, esto con la finalidad de tener un listado actualizado con los cambios.
// *****************************
// Verifica los permisos del boton, con su nombre ingresado como parametro.
// *****************************
this.epmClientService.validarBoton(<"boton">) Result => true or false
// *****************************
// Obtiene un listado de los botones (recursos) almacenado en el storage.
// *****************************
this.epmClientService.getStorageBotones(); Result => Recursos[]
// *****************************
// Elimina el listado de botones (recursos) almacenados en el storage.
// *****************************
this.epmClientService.deleteStorageBotones()
// *****************************
// Almacena el listado de botones (recursos) en el storage.
// *****************************
this.epmClientService.saveStorageBotones(<Recurso[]>)
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
botones: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
const result = this.epmClientService.getStorageBotones();
if(result === null){
this.epmClientService.getBotones(<"ClientId">).subscribe(res=>{
this.epmClientService.deleteStorageBotones();
this.epmClientService.saveStorageBotones(res);
})
}
this.botones= result;
}
{}
// *****************************
// Obtiene el Manifiesto con la información del usuario.
// *****************************
this.epmClientService.getManifiesto(<"ClientId">);
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.getManifiesto(<"ClientId">).subscribe(res=>{
var result = res;
})
}
}
{}
// *****************************
// Obtiene el listado de codigos de los permisos.
// *****************************
this.epmClientService.getListCodigosPermisos(<"ClientId">);
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.getListCodigosPermisos(<"ClientId">).subscribe(res=>{
var result = res;
})
}
{}
// *****************************
// Obtiene un listado de permisos por el tipo.
// *****************************
this.epmClientService.getPermisosPorTipo(<"ClientId">,<"tipoRecurso">); Result => Recurso[]
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
botones: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.getPermisosPorTipo(<ClientId>,"menu").subscribe(res => {
var result = res;
})
}
{}
// *****************************
// Obtiene el listado de permisos por Rol.
// *****************************
this.epmClientService.getPermisosPorRol(<"ClientId">,<"rol">,<"tipoRecurso">); Result => Recurso[]
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
botones: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.getPermisosPorRol(<"ClientId">,<"rol">,<"tipoRecurso">).subscribe(res => {
var result = res;
})
}
{}
// *****************************
// Verifica los permisos actuales por su codigo.
// *****************************
this.epmClientService.validarPermisoCodigo(<"ClientId">,<"Codigo">); Result => RespuestaAutorizacion
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
botones: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.validarPermisoCodigo(<"ClientId">,<"Codigo">).subscribe(res => {
var result = res;
})
}
{}
// *****************************
// Verifica los permisos actuales por su Nombre.
// *****************************
this.epmClientService.validarPermisoNombre(<"ClientId">,<"tipoRecurso">,<"recurso">); Result => RespuestaAutorizacion
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
botones: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.validarPermisoNombre(<"ClientId">,<"tipoRecurso">,<"recurso">).subscribe(res => {
var result = res;
})
}
{}
// *****************************
// Obtiene un listado de Roles.
// *****************************
this.epmClientService.getListRoles(<"ClientId">); Result => Rol[]
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
botones: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.getListRoles(<"ClientId">).subscribe(res => {
var result = res;
})
}
{}
// *****************************
// Valida los roles por codigo.
// *****************************
this.epmClientService.validarRol(<"ClientId">,<"Codigo">); Result => RespuestaAutorizacion
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
botones: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.validarRol(<"ClientId">,<"Codigo">).subscribe(res => {
var result = res;
})
}
{}
// *****************************
// Valida los permisos en una Url.
// *****************************
this.epmClientService.validarUrl(<"ClientId">,<"url">); Result => RespuestaAutorizacion
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
botones: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.validarUrl(<"ClientId">,<"url">).subscribe(res => {
var result = res;
})
}
{}
// *****************************
// Permite Realizar peticiones POST a un recurso.
// *****************************
this.epmClientService.post(<"url">, body, <"recurso">, <"operacion">); Result => object
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
botones: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.post(<"url">, body, <"recurso">, <"operacion">).subscribe(res => {
var result = res;
})
}
{}
// *****************************
// Permite Realizar peticiones GET a un recurso.
// *****************************
this.epmClientService.get(<"url">, <"recurso">, <"operacion">); Result => object
import {EpmClientService } from 'epm-client';
export class SidebarComponent implements OnInit {
botones: Recurso[];
constructor(private epmClientService: EpmClientService) { }
ngOnInit(): void {
this.epmClientService.get(<"url">, <"recurso">, <"operacion">).subscribe(res => {
var result = res;
})
}
{}
Este paquete cuenta con las siguientes API's
// *****************************
// ClientId: Identificador único de cada aplicación cuando se registra en el componente de autorización.
// tipoRecurso: Codigo tipo de recurso a filtrar.
// recurso: Nombre o código del recurso a validar.
// url_recurso: Dirección URL del recurso.
// Codigo: Código del recurso a validar.
// Recurso[]: Listado de recursos.
// *****************************
getStorageMenu()
deleteStorageMenu()
saveStorageMenu(<Recurso[]>)
getMenu("<ClientId>")
validarRuta("url")
getEntidad("<ClientId>")
getStorageEntidad()
deleteStorageEntidad()
saveStorageEntidad(<Recurso[]>)
validarEntidad(<"entidad">)
validarEntidad(<"boton">)
validarBoton(<"boton">)
getStorageBotones()
deleteStorageBotones()
saveStorageBotones(<Recurso[]>)
getManifiesto("<ClientId>")
getListCodigosPermisos("<ClientId>")
getPermisosPorTipo("<ClientId>","tipoRecurso")
getPermisosPorRol("<ClientId>",<"rol">,<"TipoRecurso">)
validarPermisoCodigo("<ClientId>",<"codigo">)
validarPermisoNombre("<ClientId>",<"TipoRecurso">,<"recurso">)
getListRoles("<ClientId>")
validarRol("<ClientId>","codigoRol")
validarUrl("<ClientId>","url")