Skip to content
This repository has been archived by the owner on Feb 22, 2022. It is now read-only.

Latest commit

 

History

History
75 lines (48 loc) · 2.97 KB

README.md

File metadata and controls

75 lines (48 loc) · 2.97 KB

Azure Active Directory Organization Chart Viewer

example.png

In A Galaxy Far Far Away...

It is a dark time for the Galaxy. Active Directory holds crucial troop information but is seemingly impenetrable even to those with access to the force.

A group of developers led by @kendaleiv has established a new project based on D3.js, Node.js, and other tools on the remote ice world of GitHub designed to infiltrate and free the data.

Obsessed with finding more information, the developers have dispatched remote probes into the far reaches of space...

Usage

  • Install Node.js and npm (if they are not already installed).
  • Configure Azure Active Directory:
    • Enable client credentials authentication
    • Allow necessary directory access
  • Clone this repository, or download and extract it.
  • Next, in the repository root folder create a .env text file matching the following:
ENDPOINT_ID=the_endpoint_id_value
CLIENT_ID=the_client_id_value
CLIENT_SECRET=the_client_secret_value

With the following optional items:

GOOGLE_ANALYTICS_TRACKING_ID=UA-X-X
DIRECTORY_FILTERS=has-department,ignore-list
[email protected],051dc3b4-28a9-4285-8842-4405bd4c40c8
IMAGE_RETRIEVER=Office365GetPersonaPhotoImageRetriever
OFFICE_365_GET_PERSONA_PHOTO_COOKIE=the_value
LOGO_URL=https://example.com/logo.png

(The IGNORE_LIST setting is used by the ignore-list directory filter. The OFFICE_365_GET_PERSONA_PHOTO_COOKIE setting is used by the Office365GetPersonaPhotoImageRetriever image retriever.)

  • Install, build, and start:
> npm install
> npm run build
> npm start

Organization size note

A reasonable upper limit of users at this time is approximately 150. Currently the graph does not scale well to higher numbers and provides no sizing or zooming mechanisms to fit additional data. Enhancements and/or changes may be necessary for this project to work well with larger data sets, which may even include disabling animation for the graph.

Supporting a large graph is currently outside the scope of this project, but if your needs dictate displaying a larger data set perhaps we can work something out -- let's talk in an issue before you invest in creating a PR!

Development notes

The application consists of two components, a client and a server.

For local development npm run start:watch can be useful. This will watch both src/client and src/server directories and react as necessary. For src/server changes the server will be restarted -- which includes retrieving data as part of server startup.

Attribution

Author

Ritter Insurance Marketing https://rimdev.io

License

Contributing

Contributions are highly welcome!