type Jira = {
username: string;
password: string;
domain: string;
};
/**
* Create permission scheme
* Creates a new permission scheme. You can create a permission scheme with or without defining a set of permission grants.
**[Permissions](#permissions) required:** *Administer Jira* [global permission](https://confluence.atlassian.com/x/x4dKLg).
*/
export async function main(
auth: Jira,
expand: string | undefined,
body: {
description?: string;
expand?: string;
id?: number;
name: string;
permissions?: {
holder?: {
expand?: string;
parameter?: string;
type: string;
value?: string;
};
id?: number;
permission?: string;
self?: string;
[k: string]: unknown;
}[];
scope?: {
project?: {
avatarUrls?: {
"16x16"?: string;
"24x24"?: string;
"32x32"?: string;
"48x48"?: string;
};
id?: string;
key?: string;
name?: string;
projectCategory?: {
description?: string;
id?: string;
name?: string;
self?: string;
};
projectTypeKey?: "software" | "service_desk" | "business";
self?: string;
simplified?: boolean;
};
type?: "PROJECT" | "TEMPLATE";
[k: string]: unknown;
};
self?: string;
[k: string]: unknown;
}
) {
const url = new URL(
`https://${auth.domain}.atlassian.net/rest/api/2/permissionscheme`
);
for (const [k, v] of [["expand", expand]]) {
if (v !== undefined && v !== "") {
url.searchParams.append(k, v);
}
}
const response = await fetch(url, {
method: "POST",
headers: {
"Content-Type": "application/json",
Authorization: "Basic " + btoa(`${auth.username}:${auth.password}`),
},
body: JSON.stringify(body),
});
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;
};
/**
* Create permission scheme
* Creates a new permission scheme. You can create a permission scheme with or without defining a set of permission grants.
**[Permissions](#permissions) required:** *Administer Jira* [global permission](https://confluence.atlassian.com/x/x4dKLg).
*/
export async function main(
auth: Jira,
expand: string | undefined,
body: {
description?: string;
expand?: string;
id?: number;
name: string;
permissions?: {
holder?: {
expand?: string;
parameter?: string;
type: string;
value?: string;
};
id?: number;
permission?: string;
self?: string;
[k: string]: unknown;
}[];
scope?: {
project?: {
avatarUrls?: {
"16x16"?: string;
"24x24"?: string;
"32x32"?: string;
"48x48"?: string;
};
id?: string;
key?: string;
name?: string;
projectCategory?: {
description?: string;
id?: string;
name?: string;
self?: string;
};
projectTypeKey?: "software" | "service_desk" | "business";
self?: string;
simplified?: boolean;
};
type?: "PROJECT" | "TEMPLATE";
[k: string]: unknown;
};
self?: string;
[k: string]: unknown;
}
) {
const url = new URL(
`https://${auth.domain}.atlassian.net/rest/api/2/permissionscheme`
);
for (const [k, v] of [["expand", expand]]) {
if (v !== undefined && v !== "") {
url.searchParams.append(k, v);
}
}
const response = await fetch(url, {
method: "POST",
headers: {
"Content-Type": "application/json",
Authorization: "Basic " + btoa(`${auth.username}:${auth.password}`),
},
body: JSON.stringify(body),
});
if (!response.ok) {
const text = await response.text();
throw new Error(`${response.status} ${text}`);
}
return await response.json();
}
Submitted by hugo697 948 days ago