//native
/**
* Caution
This endpoint may change in the future without notice.
* Return a set of points representing a normalized timestamp and the
number of events seen in the period.
Query ranges are limited to Sentry's configured time-series resolutions.
*/
export async function main(
auth: RT.Sentry,
project_id_or_slug: string,
stat?: 'received' | 'rejected' | 'blacklisted' | 'generated' | undefined,
since?: string | undefined,
until?: string | undefined,
resolution?: '10s' | '1h' | '1d' | undefined
) {
const url = new URL(
`https://${auth.region}.sentry.io/api/0/projects/${auth.organizationSlug}/${project_id_or_slug}/stats/`
)
for (const [k, v] of [
['stat', stat],
['since', since],
['until', until],
['resolution', resolution]
]) {
if (v !== undefined && v !== '') {
url.searchParams.append(k, v)
}
}
const response = await fetch(url, {
method: 'GET',
headers: {
Authorization: 'Bearer ' + auth.token
},
body: undefined
})
if (!response.ok) {
const text = await response.text()
throw new Error(`${response.status} ${text}`)
}
return await response.json()
}
Submitted by hugo697 235 days ago