/
kms-tls-options.tsx
74 lines (69 loc) · 2.4 KB
/
kms-tls-options.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
import React, { useCallback } from 'react';
import type { AutoEncryptionOptions, AutoEncryptionTlsOptions } from 'mongodb';
import TLSCertificateAuthority from '../tls-ssl-tab/tls-certificate-authority';
import TLSClientCertificate from '../tls-ssl-tab/tls-client-certificate';
import type { UpdateConnectionFormField } from '../../../hooks/use-connect-form';
function KMSTLSOptions({
updateConnectionFormField,
autoEncryptionOptions,
kmsProvider,
clientCertIsOptional
}: {
updateConnectionFormField: UpdateConnectionFormField;
autoEncryptionOptions: AutoEncryptionOptions;
kmsProvider: keyof NonNullable<AutoEncryptionOptions['tlsOptions']>;
clientCertIsOptional?: boolean;
}): React.ReactElement {
const currentOptions: AutoEncryptionTlsOptions =
autoEncryptionOptions.tlsOptions?.[kmsProvider] ?? {};
const handleFieldChanged = useCallback(
(key: keyof AutoEncryptionTlsOptions, value?: string) => {
return updateConnectionFormField({
type: 'update-csfle-kms-tls-param',
kms: kmsProvider,
key: key,
value,
});
},
[updateConnectionFormField, kmsProvider]
);
return (
<>
<TLSCertificateAuthority
tlsCAFile={currentOptions.tlsCAFile}
useSystemCA={false /* COMPASS-5635 */}
disabled={false}
handleTlsOptionChanged={(key, value) =>
handleFieldChanged(
key as 'tlsCAFile' /* COMPASS-5635 */,
value ?? undefined
)
}
displayDatabaseConnectionUserHints={false}
/>
{/* TODO: Update UI messages for TLS situation (e.g. drop reference to X.509 auth) */}
<TLSClientCertificate
tlsCertificateKeyFile={currentOptions.tlsCertificateKeyFile}
tlsCertificateKeyFilePassword={
currentOptions.tlsCertificateKeyFilePassword
}
disabled={false}
updateTLSClientCertificate={(newCertificatePath: string | null) => {
handleFieldChanged(
'tlsCertificateKeyFile',
newCertificatePath ?? undefined
);
}}
updateTLSClientCertificatePassword={(newPassword: string | null) => {
handleFieldChanged(
'tlsCertificateKeyFilePassword',
newPassword ?? undefined
);
}}
displayDatabaseConnectionUserHints={false}
optional={clientCertIsOptional ?? true}
/>
</>
);
}
export default KMSTLSOptions;