type Cloudflare = {
token: string;
email: string;
key: string;
};
/**
* Add an Access identity provider
* Adds a new identity provider to Access.
*/
export async function main(
auth: Cloudflare,
identifier: string,
body:
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & {
conditional_access_enabled?: boolean;
directory_id?: string;
support_groups?: boolean;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & {
centrify_account?: string;
centrify_app_id?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & { apps_domain?: string; [k: string]: unknown };
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & {
auth_url?: string;
certs_url?: string;
claims?: string[];
scopes?: string[];
token_url?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & { okta_account?: string; [k: string]: unknown };
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & { onelogin_account?: string; [k: string]: unknown };
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & { ping_env_id?: string; [k: string]: unknown };
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
attributes?: string[];
email_attribute_name?: string;
header_attributes?: {
attribute_name?: string;
header_name?: string;
[k: string]: unknown;
}[];
idp_public_certs?: string[];
issuer_url?: string;
sign_request?: boolean;
sso_target_url?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
) {
const url = new URL(
`https://api.cloudflare.com/client/v4/zones/${identifier}/access/identity_providers`
);
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;
};
/**
* Add an Access identity provider
* Adds a new identity provider to Access.
*/
export async function main(
auth: Cloudflare,
identifier: string,
body:
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & {
conditional_access_enabled?: boolean;
directory_id?: string;
support_groups?: boolean;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & {
centrify_account?: string;
centrify_app_id?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & { apps_domain?: string; [k: string]: unknown };
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & {
auth_url?: string;
certs_url?: string;
claims?: string[];
scopes?: string[];
token_url?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & { okta_account?: string; [k: string]: unknown };
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & { onelogin_account?: string; [k: string]: unknown };
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
} & { ping_env_id?: string; [k: string]: unknown };
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
attributes?: string[];
email_attribute_name?: string;
header_attributes?: {
attribute_name?: string;
header_name?: string;
[k: string]: unknown;
}[];
idp_public_certs?: string[];
issuer_url?: string;
sign_request?: boolean;
sso_target_url?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
| ({
config: { [k: string]: unknown };
id?: string;
name: string;
scim_config?: {
enabled?: boolean;
group_member_deprovision?: boolean;
seat_deprovision?: boolean;
secret?: string;
user_deprovision?: boolean;
[k: string]: unknown;
};
type: string;
[k: string]: unknown;
} & {
config?: {
client_id?: string;
client_secret?: string;
[k: string]: unknown;
};
[k: string]: unknown;
})
) {
const url = new URL(
`https://api.cloudflare.com/client/v4/zones/${identifier}/access/identity_providers`
);
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