This guide shows you to view One Identity Manager HTML applications as code and how to understand their internal functionality. You will discover how to create your own HTML applications and implement them.
You can use existing HTML applications from a GitHub repository as templates for this (see Developing HTML applications with the GitHub repository).
Available documentation
The online version of One Identity Manager documentation is available in the Support portal under Technical Documentation. You will find videos with additional information at www.YouTube.com/OneIdentity.
Architecture of One Identity Manager HTML applications
The HTML applications are structured as nodeJS applications that use the Angular framework. Generally, any HTML applications that can be compiled as nodeJS applications are supported.
HTML applications use the API Client to communicate with the One Identity Manager API. The API Client is an npm library that is automatically generated and stored to the database during API compilation. The API Client controls all network access on the API Server.
For more information about API development, see the One Identity Manager API Development Guide.
Developing HTML applications with the GitHub repository
You can develop your own HTML applications using the source code of a default HTML applications as a template.
The source code of the standard HTML applications is available in a GitHub repository.
Detailed information about this topic
The GitHub repository contains the source code for the HTML applications in One Identity Manager. It is a monorepo that contains the Angular workspace, which consists of applications and libraries.
The Angular workspace integrates the Nx tool. This tool makes it easier to work with monorepo environments. Nx is installed automatically. One Identity recommends you use Nx to achieve better build speed and simplify the management of project dependencies. For more information, see here.
Note the following when using Nx:
-
The Nx workspace is defined in the nx.json file.
-
Each project has its own project.json declaration file. Nx uses these files to manage dependencies between projects and to determine the compilation order.
TIP: To visualize the dependencies between projects, run the nx graph command from the command line.
Each Angular library and application belongs to a folder in the projects directory. The Angular workspace is defined in the angular.json file.
Table 1: Angular libraries
qbm |
Angular library |
none |
qer |
Angular library |
qbm |
dpr |
Angular library |
qbm |
apc |
Angular plugin library |
qbm, qer |
hds |
Angular plugin library |
qbm, qer |
olg |
Angular plugin library |
qbm, qer |
rmb |
Angular plugin library |
qbm, qer |
rps |
Angular plugin library |
qbm, qer |
sac |
Angular plugin library |
qbm, qer |
qam |
Angular plugin library |
qbm, qer |
tsb |
Angular plugin library |
qbm, qer |
att |
Angular plugin library |
qbm, qer |
rms |
Angular plugin library |
qbm, qer |
aad |
Angular plugin library |
qbm, qer, tsb |
aob |
Angular plugin library |
qbm, qer |
uci |
Angular plugin library |
qbm, qer |
cpl |
Angular plugin library |
qbm, qer |
o3t |
Angular plugin library |
qbm, qer, tsb |
pol |
Angular plugin library |
qbm, qer |
Each Angular library belongs to the One Identity Manager module of the same name.
An Angular library behaves like a regular compile-time dependency.
A plugin library is loaded dynamically at runtime. This is specified in the plugin's imx-plugin-config.json files.
Table 2: Angular applications
qbm-app-landingpage |
API Server landing page and server management |
Angular application |
qbm |
qer-app-portal |
Web Portal |
Angular application |
qbm, qer |
qer-app-operationssupport |
Operations Support Web Portal |
Angular application |
qbm, qer |
qer-app-pwdportal |
Password Reset Portal |
Angular application |
qbm, qer |