type Jira = {
username: string;
password: string;
domain: string;
};
/**
* Search for dashboards
* Returns a [paginated](#pagination) list of dashboards.
*/
export async function main(
auth: Jira,
dashboardName: string | undefined,
accountId: string | undefined,
owner: string | undefined,
groupname: string | undefined,
groupId: string | undefined,
projectId: string | undefined,
orderBy:
| "description"
| "-description"
| "+description"
| "favorite_count"
| "-favorite_count"
| "+favorite_count"
| "id"
| "-id"
| "+id"
| "is_favorite"
| "-is_favorite"
| "+is_favorite"
| "name"
| "-name"
| "+name"
| "owner"
| "-owner"
| "+owner"
| undefined,
startAt: string | undefined,
maxResults: string | undefined,
status: "active" | "archived" | "deleted" | undefined,
expand: string | undefined
) {
const url = new URL(
`https://${auth.domain}.atlassian.net/rest/api/2/dashboard/search`
);
for (const [k, v] of [
["dashboardName", dashboardName],
["accountId", accountId],
["owner", owner],
["groupname", groupname],
["groupId", groupId],
["projectId", projectId],
["orderBy", orderBy],
["startAt", startAt],
["maxResults", maxResults],
["status", status],
["expand", expand],
]) {
if (v !== undefined && v !== "") {
url.searchParams.append(k, v);
}
}
const response = await fetch(url, {
method: "GET",
headers: {
Authorization: "Basic " + btoa(`${auth.username}:${auth.password}`),
},
body: undefined,
});
if (!response.ok) {
const text = await response.text();
throw new Error(`${response.status} ${text}`);
}
return await response.json();
}
Submitted by hugo697 396 days ago
type Jira = {
username: string;
password: string;
domain: string;
};
/**
* Search for dashboards
* Returns a [paginated](#pagination) list of dashboards.
*/
export async function main(
auth: Jira,
dashboardName: string | undefined,
accountId: string | undefined,
owner: string | undefined,
groupname: string | undefined,
groupId: string | undefined,
projectId: string | undefined,
orderBy:
| "description"
| "-description"
| "+description"
| "favorite_count"
| "-favorite_count"
| "+favorite_count"
| "id"
| "-id"
| "+id"
| "is_favorite"
| "-is_favorite"
| "+is_favorite"
| "name"
| "-name"
| "+name"
| "owner"
| "-owner"
| "+owner"
| undefined,
startAt: string | undefined,
maxResults: string | undefined,
status: "active" | "archived" | "deleted" | undefined,
expand: string | undefined
) {
const url = new URL(
`https://${auth.domain}.atlassian.net/rest/api/2/dashboard/search`
);
for (const [k, v] of [
["dashboardName", dashboardName],
["accountId", accountId],
["owner", owner],
["groupname", groupname],
["groupId", groupId],
["projectId", projectId],
["orderBy", orderBy],
["startAt", startAt],
["maxResults", maxResults],
["status", status],
["expand", expand],
]) {
if (v !== undefined && v !== "") {
url.searchParams.append(k, v);
}
}
const response = await fetch(url, {
method: "GET",
headers: {
Authorization: "Basic " + btoa(`${auth.username}:${auth.password}`),
},
body: undefined,
});
if (!response.ok) {
const text = await response.text();
throw new Error(`${response.status} ${text}`);
}
return await response.json();
}
Submitted by hugo697 948 days ago