-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathindex.js
57 lines (49 loc) · 4.34 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
const paths = location.pathname.split('/');
const id = paths.pop() || paths.pop();
if (location.pathname.includes('/admin/user/')) {
showUserInfo();
} else if (location.pathname.includes('/admin/group/')) {
showGroupInfo();
}
async function showUserInfo() {
const user = await getJson('/api/v1/users/' + id);
var html = '<br>';
// `googleAccount` and `adAccount` are 'boolean' (TRUE/FALSE) attributes that indicate an account has been provisioned each respectively
// `employeeStatus` is an HR-sourced attribute indicating Active, Terminated, or Leave of Absence status
// `manager` is the user manager's `email` value
// The following icons are hard-coded in here for ease of portability. Converted using: https://www.site24x7.com/tools/image-to-datauri.html
if (user.profile.googleAccount) html += '<img src="" alt="Google Workspace Icon" height="20"/> | ';
if (user.profile.adAccount) html += '<img src="" alt="Active Directory Icon" height="20"/> | ';
html += 'HR Status: ' + user.profile.employeeStatus + ' | ';
if (user.profile.manager) {
const users = await getJson(`/api/v1/users?search=profile.email eq "${user.profile.manager}"`);
if (users.length > 0) {
html += `Manager: <a href="/admin/user/profile/view/${users[0].id}#tab-account" target="_blank">${user.profile.manager}</a> | `;
} else {
html += 'Manager: ' + user.profile.manager + ' | ';
}
} else html += 'Manager: (none) | ';
html += 'Type: ' + user.profile.userType;
document.querySelector('.subheader').innerHTML += html;
}
async function showGroupInfo() {
const group = await getJson('/api/v1/groups/' + id);
var html = '<div style="display: block; margin-top: 0.428571425rem; color: #272727; font-size: 1.1487rem; font-weight: 400; line-height: 1.7142857">'
// The following group profile attributes are used in our Okta org.
// Create these in the Okta Admin Console -> Directory -> Profile Editor -> Groups tab
// Documentation: https://help.okta.com/en-us/content/topics/users-groups-profiles/usgp-add-custom-group-attributes.htm
// Or update this code to use yours
if (group.profile.dynamic) html += 'Dynamic ⚡ | ';
if (group.profile.forAppAssignment) html += 'For App Assignment 📲 | ';
if (group.profile.pushToApp) html += 'Push Group 🫸🏼 ➡ | ';
if (group.profile.forUserProvisioning) html += 'Acct Provisioning ➡👷🏽 | ';
if (group.profile.policy) html += 'For Policy ✒️📜 | ';
if (group.profile.forAppAdmin) html += 'App Admins 🧑🏼💻 | ';
html += '<br>Note to Admins: ' + group.profile.NoteToAdmins;
html += '<div>'
document.querySelector('.group-desc').innerHTML += html;
}
async function getJson(url) {
const res = await fetch(url);
return res.json();
}