type Cloudflare = {
token: string;
email: string;
key: string;
};
/**
* Create Certificate
* Create an Origin CA certificate. Use your Origin CA Key as your User Service Key when calling this endpoint ([see above](#requests)).
*/
export async function main(
auth: Cloudflare,
body: {
csr?: string;
hostnames?: unknown[];
request_type?: "origin-rsa" | "origin-ecc" | "keyless-certificate";
requested_validity?: 7 | 30 | 90 | 365 | 730 | 1095 | 5475;
[k: string]: unknown;
}
) {
const url = new URL(`https://api.cloudflare.com/client/v4/certificates`);
const response = await fetch(url, {
method: "POST",
headers: {
"X-AUTH-EMAIL": auth.email,
"X-AUTH-KEY": auth.key,
"Content-Type": "application/json",
Authorization: "Bearer " + auth.token,
},
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 383 days ago
type Cloudflare = {
token: string;
email: string;
key: string;
};
/**
* Create Certificate
* Create an Origin CA certificate. Use your Origin CA Key as your User Service Key when calling this endpoint ([see above](#requests)).
*/
export async function main(
auth: Cloudflare,
body: {
csr?: string;
hostnames?: unknown[];
request_type?: "origin-rsa" | "origin-ecc" | "keyless-certificate";
requested_validity?: 7 | 30 | 90 | 365 | 730 | 1095 | 5475;
[k: string]: unknown;
}
) {
const url = new URL(`https://api.cloudflare.com/client/v4/certificates`);
const response = await fetch(url, {
method: "POST",
headers: {
"X-AUTH-EMAIL": auth.email,
"X-AUTH-KEY": auth.key,
"Content-Type": "application/json",
Authorization: "Bearer " + auth.token,
},
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 920 days ago