Skip to content

NICE Identity and Access Management - this replaces NICE Accounts

License

Notifications You must be signed in to change notification settings

nice-digital/identity

Repository files navigation

Nice Identity

NICE Identity and Access Management

IdAM is currently used in the following services:

Browser support

  • IE: 11 and above
  • Chrome: (Current - 1) and Current
  • Edge: (Current - 1) and Current
  • Firefox: (Current - 1) and Current
  • Safari: (Current - 1) and Current

Technical stack

Getting Started

Solution is only tested in Visual Studio 2019. Your experience may differ in other IDE's.

Install NPM Task Runner Visual Studio Extension

Install KDiff3 kdiff is currently expected to be installed here: C:\Program Files\KDiff3\kdiff3.exe changing this install location will mean the integration test diffing will fallback to vsDiffMerge.

Install Node.js

In Visual Studio, go to Tools > Options > Projects and Solutions > Web Package Management add the path to the Node installation at the top of the list. It'll be either C:\Program Files\nodejs or C:\Program Files (x86)\nodejs depending on whether you installed the x64 or x86 version of Node.js.

If you do not want to run the WebAPI from the command line (so not using IIS Express), you need to change the dropdown next to the green play button to "NICE.RoleManagement.WebAPI". You might also need to disable you local IIS server so as to free up port 80.

Database

You will need a copy of the test database, try to aquire this from another developer. If you are unable to do so, you can run the entity framework codefirst migrations. This will generate a barebones database.

If you want to connect to the API with the front end (identity-management) You will need to add a record to the Users table with your Auth0|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx username in the NameIdentifier field. You can Then associate yourself with every role in the roles table using the "UserRoles" table. You can pick and choose the specific roles for Identity Admin if you want to be a bit more delicate.

Redis server

This application uses a data store called Redis to capture and store Tokens from Auth0. You will need to run a local version of Redis using WSL in a command prompt or Chocolatey. Go to https://redis.io/docs/getting-started/ to get started, the instructions are well written.

Secrets.json

The application's uses appsettings.json to store configuration. However, since this is a public repository, confidential configuration information (e.g. db connection string) is stored in secrets.json In order to run the application correctly (with it having access to a database), you'll need to acquire (from another dev) or create a secrets.json file with the correct configuration information in. For more information see: https://docs.microsoft.com/en-us/aspnet/core/security/app-secrets?tabs=visual-studio

The key sections are:

  • ConnectionStrings (The database connection for the roles database)
  • Logging (The RabbitMQ server to send logs to)
  • IdentityApiConfiguration (see below...)
  • Auth0ManagementApiConfiguration (see below...)
  • Email (settings for the smtp server used by the emailing functionality)

IdentityApiConfiguration The Identity API itself needs to authenticate and authorise people who are using it. So like any other implementation (Consultations/EPPI/etc...) it needs to be set up with a link to an application in Auth0, there should be one called "Identity Admin"

Auth0ManagementApiConfiguration The Identity API also needs the ability to edit/update/delete users in Auth0. This needs elevated privileges and is done through a different endpoint, that appears by default (and is not deletable) on the tenant. It will be called "API Explorer Application".

If you have access to the Auth0 tenant, you can get the client IDs and secrets from Applications > Applications on the left hand menu.

Nuget sources

The application currently uses a logging nuget package located on a local nuget server. You'll need to ask another developer on the project to get access to this nuget server.

Webpack bundling

The Javascript in the project should be written in ES6 syntax. It gets transpiled to ES5 by babel, using webpack. The project has been configured via Task Runner Explorer in Visual Studio to run webpack --watch when the project is opened. If you don't use Visual Studio, you'll need to start a command prompt running that command in order to build the javascript and CSS.

About

NICE Identity and Access Management - this replaces NICE Accounts

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published