//native
/**
* Get System Log Events
* Query the Okta System Log. Bound the window with `since` / `until` (ISO 8601, e.g. 2026-06-01T00:00:00Z), narrow with a `filter` expression or free-text `q`, and order with `sort_order` (ASCENDING is the default). `limit` defaults to 100 (max 1000); page with the `after` cursor from the previous response's Link header.
*/
export async function main(
auth: RT.Okta,
since: string | undefined,
until: string | undefined,
filter: string | undefined,
q: string | undefined,
sort_order: "ASCENDING" | "DESCENDING" | undefined,
limit: number | undefined,
after: string | undefined
) {
const url = new URL(`${auth.org_url}/api/v1/logs`)
if (since !== undefined && since !== "")
url.searchParams.append("since", since)
if (until !== undefined && until !== "")
url.searchParams.append("until", until)
if (filter !== undefined && filter !== "")
url.searchParams.append("filter", filter)
if (q !== undefined && q !== "") url.searchParams.append("q", q)
if (sort_order !== undefined) url.searchParams.append("sortOrder", sort_order)
if (limit !== undefined) url.searchParams.append("limit", String(limit))
if (after !== undefined && after !== "")
url.searchParams.append("after", after)
const response = await fetch(url, {
method: "GET",
headers: {
Authorization: `SSWS ${auth.token}`,
Accept: "application/json",
},
})
if (!response.ok) {
throw new Error(`${response.status} ${await response.text()}`)
}
return await response.json()
}
Submitted by hugo989 5 days ago