mirror of
https://github.com/fleetdm/fleet
synced 2026-04-21 21:47:20 +00:00
**Related issue:** Resolves #34521 Updated NDES add/edit modal: <img width="649" height="592" alt="Screenshot 2026-01-27 at 11 29 20 PM" src="https://github.com/user-attachments/assets/88a083e5-0ba3-40b9-9668-5cd0bfa427a1" /> Also - CA descriptions made consistent between modal and list: <img width="1424" height="934" alt="Screenshot 2026-01-28 at 10 13 43 AM" src="https://github.com/user-attachments/assets/b2266e45-30e7-40ad-b5b1-d1fa2cf97952" /> <img width="738" height="572" alt="Screenshot 2026-01-28 at 11 19 13 AM" src="https://github.com/user-attachments/assets/b7e133a8-a055-41f7-b074-2f0db74f257c" /> - [x] Changes file added for user-visible changes in `changes/` - [x] Added/updated automated tests - [x] QA'd all new/changed functionality manually <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit * **New Features** * Added support for dynamic SCEP challenges for Okta certificates. * **Improvements** * Enhanced help text for NDES form fields with clearer references to Network Device Enrollment Service configuration details. * Align CA descriptions between cert list and cert options dropdown in Add/Edit CA modal * Improve organization of relevant code <sub>✏️ Tip: You can customize this high-level summary in your review settings.</sub> <!-- end of auto-generated comment: release notes by coderabbit.ai -->
215 lines
4.6 KiB
TypeScript
215 lines
4.6 KiB
TypeScript
import { IListSort } from "./list_options";
|
|
|
|
export interface IHostCertificate {
|
|
id: number;
|
|
not_valid_after: string;
|
|
not_valid_before: string;
|
|
certificate_authority: boolean;
|
|
common_name: string;
|
|
key_algorithm: string;
|
|
key_strength: number;
|
|
key_usage: string;
|
|
serial: string;
|
|
signing_algorithm: string;
|
|
subject: {
|
|
country: string;
|
|
organization: string;
|
|
organizational_unit: string;
|
|
common_name: string;
|
|
};
|
|
issuer: {
|
|
country: string;
|
|
organization: string;
|
|
organizational_unit: string;
|
|
common_name: string;
|
|
};
|
|
source: string;
|
|
username: string;
|
|
}
|
|
|
|
export const CERTIFICATES_DEFAULT_SORT: IListSort = {
|
|
order_key: "common_name",
|
|
order_direction: "asc",
|
|
} as const;
|
|
|
|
/** This interface represent the smaller subset of cert authority data that is
|
|
returned for some of the cert authority endpoints */
|
|
export interface ICertificateAuthorityPartial {
|
|
id: number;
|
|
name: string;
|
|
type: ICertificateAuthorityType;
|
|
}
|
|
|
|
export interface ICertificatesNDES {
|
|
id?: number;
|
|
type?: "ndes_scep_proxy";
|
|
url: string;
|
|
admin_url: string;
|
|
username: string;
|
|
password: string;
|
|
}
|
|
|
|
export interface ICertificatesDigicert {
|
|
id?: number;
|
|
type?: "digicert";
|
|
name: string;
|
|
url: string;
|
|
api_token: string;
|
|
profile_id: string;
|
|
certificate_common_name: string;
|
|
certificate_user_principal_names: string[] | null;
|
|
certificate_seat_id: string;
|
|
}
|
|
|
|
export interface ICertificatesHydrant {
|
|
id?: number;
|
|
type?: "hydrant";
|
|
name: string;
|
|
url: string;
|
|
client_id: string;
|
|
client_secret: string;
|
|
}
|
|
|
|
export interface ICertificatesCustomSCEP {
|
|
id?: number;
|
|
type?: "custom_scep_proxy";
|
|
name: string;
|
|
url: string;
|
|
challenge: string;
|
|
}
|
|
|
|
export interface ICertificatesSmallstep {
|
|
id?: number;
|
|
type?: "smallstep";
|
|
name: string;
|
|
url: string;
|
|
challenge_url: string;
|
|
username: string;
|
|
password: string;
|
|
}
|
|
|
|
export interface ICertificatesCustomEST {
|
|
id?: number;
|
|
type?: "custom_est_proxy";
|
|
name: string;
|
|
url: string;
|
|
username: string;
|
|
password: string;
|
|
}
|
|
|
|
export type ICertificateAuthorityType =
|
|
| "ndes_scep_proxy"
|
|
| "digicert"
|
|
| "custom_scep_proxy"
|
|
| "hydrant"
|
|
| "smallstep"
|
|
| "custom_est_proxy";
|
|
|
|
/** all the types of certificates */
|
|
export type ICertificateAuthority =
|
|
| ICertificatesNDES
|
|
| ICertificatesDigicert
|
|
| ICertificatesHydrant
|
|
| ICertificatesCustomSCEP
|
|
| ICertificatesSmallstep
|
|
| ICertificatesCustomEST;
|
|
|
|
export const isNDESCertAuthority = (
|
|
integration: ICertificateAuthority
|
|
): integration is ICertificatesNDES => {
|
|
return (
|
|
"admin_url" in integration &&
|
|
"username" in integration &&
|
|
"password" in integration
|
|
);
|
|
};
|
|
|
|
export const isDigicertCertAuthority = (
|
|
integration: ICertificateAuthority
|
|
): integration is ICertificatesDigicert => {
|
|
return (
|
|
"profile_id" in integration &&
|
|
"certificate_common_name" in integration &&
|
|
"certificate_user_principal_names" in integration &&
|
|
"certificate_seat_id" in integration
|
|
);
|
|
};
|
|
|
|
export const isHydrantCertAuthority = (
|
|
integration: ICertificateAuthority
|
|
): integration is ICertificatesHydrant => {
|
|
return (
|
|
"name" in integration &&
|
|
"url" in integration &&
|
|
"client_id" in integration &&
|
|
"client_secret" in integration
|
|
);
|
|
};
|
|
|
|
export const isCustomSCEPCertAuthority = (
|
|
integration: ICertificateAuthority
|
|
): integration is ICertificatesCustomSCEP => {
|
|
return (
|
|
"name" in integration && "url" in integration && "challenge" in integration
|
|
);
|
|
};
|
|
|
|
export const isSmallstepCertAuthority = (
|
|
integration: ICertificateAuthority
|
|
): integration is ICertificatesSmallstep => {
|
|
return (
|
|
"name" in integration &&
|
|
"url" in integration &&
|
|
"challenge_url" in integration &&
|
|
"username" in integration &&
|
|
"password" in integration
|
|
);
|
|
};
|
|
|
|
export const isCustomESTCertAuthority = (
|
|
integration: ICertificateAuthority
|
|
): integration is ICertificatesCustomEST => {
|
|
return (
|
|
"name" in integration &&
|
|
"url" in integration &&
|
|
// differentiates from smallstep
|
|
!("challenge_url" in integration) &&
|
|
"username" in integration &&
|
|
"password" in integration
|
|
);
|
|
};
|
|
|
|
export const createMockCertificateAuthorities = (): ICertificateAuthorityPartial[] => {
|
|
return [
|
|
{
|
|
id: 1,
|
|
name: "Test NDES SCEP Proxy",
|
|
type: "ndes_scep_proxy",
|
|
},
|
|
{
|
|
id: 2,
|
|
name: "Test DigiCert",
|
|
type: "digicert",
|
|
},
|
|
{
|
|
id: 3,
|
|
name: "Test Custom SCEP Proxy",
|
|
type: "custom_scep_proxy",
|
|
},
|
|
{
|
|
id: 4,
|
|
name: "Test Hydrant",
|
|
type: "hydrant",
|
|
},
|
|
{
|
|
id: 5,
|
|
name: "Test Smallstep",
|
|
type: "smallstep",
|
|
},
|
|
{
|
|
id: 6,
|
|
name: "Test Custom EST Proxy",
|
|
type: "custom_est_proxy",
|
|
},
|
|
];
|
|
};
|