mirror of
https://github.com/LukeHagar/ui-development-kit.git
synced 2025-12-06 12:57:44 +00:00
151 lines
4.0 KiB
TypeScript
151 lines
4.0 KiB
TypeScript
import { getFilters, getLimit, getPage, getSorters } from '$lib/Utils.js';
|
|
import { createConfiguration } from '$lib/sailpoint/sdk.js';
|
|
import { getToken } from '$lib/utils/oauth.js';
|
|
import {
|
|
SearchApi,
|
|
SourcesApi,
|
|
type EventDocument,
|
|
type Search,
|
|
type SourcesApiListSourcesRequest,
|
|
type Source
|
|
} from 'sailpoint-api-client';
|
|
|
|
export const load = async ({ cookies, url }) => {
|
|
const session = JSON.parse(cookies.get('session')!);
|
|
const idnSession = await getToken(cookies);
|
|
|
|
const config = createConfiguration(session.baseUrl, idnSession.access_token);
|
|
const sourceApi = new SourcesApi(config);
|
|
const searchApi = new SearchApi(config);
|
|
|
|
const page = getPage(url);
|
|
const filters = getFilters(url);
|
|
const limit = getLimit(url);
|
|
const sorters = getSorters(url);
|
|
|
|
const requestParams: SourcesApiListSourcesRequest = {
|
|
filters,
|
|
offset: Number(page) * Number(limit),
|
|
limit: Number(limit),
|
|
sorters,
|
|
count: true
|
|
};
|
|
|
|
const apiResponse = sourceApi.listSources(requestParams);
|
|
|
|
const sources = new Promise<Source[]>((resolve) => {
|
|
apiResponse
|
|
.then((response) => {
|
|
resolve(response.data);
|
|
})
|
|
.catch((err) => {
|
|
throw err;
|
|
});
|
|
});
|
|
|
|
const totalCount = new Promise<number>((resolve) => {
|
|
apiResponse
|
|
.then((response) => {
|
|
resolve(response.headers['x-total-count']);
|
|
})
|
|
.catch((err) => {
|
|
throw err;
|
|
});
|
|
});
|
|
|
|
type SourceEvents = {
|
|
accounts: { started: EventDocument | undefined; passed: EventDocument | undefined };
|
|
entitlements: { started: EventDocument | undefined; passed: EventDocument | undefined };
|
|
};
|
|
|
|
const eventNames: string[] = [
|
|
'Aggregate Source Account Passed',
|
|
'Aggregate Source Account Started',
|
|
'Aggregate Source Entitlement Passed',
|
|
'Aggregate Source Entitlement Started'
|
|
];
|
|
|
|
const eventsMap = new Promise<Map<string, SourceEvents>>((resolve) => {
|
|
sources.then(async (sources) => {
|
|
const sourceEventsMap = new Map<string, SourceEvents>();
|
|
|
|
for (const source of sources) {
|
|
const allEvents: EventDocument[] = [];
|
|
const promises: Promise<EventDocument[]>[] = [];
|
|
|
|
for (const event of eventNames) {
|
|
const search: Search = {
|
|
indices: ['events'],
|
|
query: {
|
|
query: `target.name: "${source.name}" AND name:"${event}"`
|
|
},
|
|
sort: ['created']
|
|
};
|
|
|
|
promises.push(
|
|
searchApi
|
|
.searchPost({
|
|
search
|
|
})
|
|
.then((response) => {
|
|
return response.data;
|
|
})
|
|
.catch((err) => {
|
|
throw err;
|
|
})
|
|
);
|
|
}
|
|
|
|
await Promise.allSettled(promises).then((results) => {
|
|
for (const event of results) {
|
|
if (event.status == 'fulfilled' && event.value.length > 0) {
|
|
allEvents.push(event.value[0]);
|
|
}
|
|
}
|
|
|
|
const sourceEvents: SourceEvents = {
|
|
accounts: { started: undefined, passed: undefined },
|
|
entitlements: { started: undefined, passed: undefined }
|
|
};
|
|
|
|
for (const event of allEvents) {
|
|
if (event.attributes!.sourceName === source.name) {
|
|
switch (event.technicalName) {
|
|
case 'SOURCE_ACCOUNT_AGGREGATE_STARTED':
|
|
if (!sourceEvents.accounts.started) {
|
|
sourceEvents.accounts.started = event || undefined;
|
|
}
|
|
break;
|
|
case 'SOURCE_ACCOUNT_AGGREGATE_PASSED':
|
|
if (!sourceEvents.accounts.passed) {
|
|
sourceEvents.accounts.passed = event || undefined;
|
|
}
|
|
break;
|
|
case 'SOURCE_ENTITLEMENT_AGGREGATE_STARTED':
|
|
if (!sourceEvents.entitlements.started) {
|
|
sourceEvents.entitlements.started = event || undefined;
|
|
}
|
|
break;
|
|
case 'SOURCE_ENTITLEMENT_AGGREGATE_PASSED':
|
|
if (!sourceEvents.entitlements.passed) {
|
|
sourceEvents.entitlements.passed = event || undefined;
|
|
}
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
sourceEventsMap.set(source.name, sourceEvents);
|
|
});
|
|
}
|
|
|
|
resolve(sourceEventsMap);
|
|
});
|
|
});
|
|
|
|
return { sources, eventsMap, totalCount, params: { page, limit, filters, sorters } };
|
|
};
|