xref: /onnv-gate/usr/src/lib/libkmsagent/common/ApplianceParameters.h (revision 12720:3db6e0082404)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 
22 /*
23  * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
24  */
25 
26 /*-----------------------------------------------------------------------------
27 * File: ApplianceParameters.h
28 -----------------------------------------------------------------------------*/
29 
30 #ifndef ApplianceParameters_h
31 #define ApplianceParameters_h
32 
33 // Server Config
34 
35 #define DEFAULT_SERVER_LOG_FILENAME                                 "KeyMgrLog.log"
36 #define DEFAULT_SERVER_CONFIG_FILENAME                              "ServerConfig.cfg"
37 #define DEFAULT_CONNECTION_QUEUE_SIZE                               100
38 #define DEFAULT_THREAD_POOL_SIZE                                    8
39 #define DEFAULT_THREAD_POOL_MIN_IDLE_THREADS                        8
40 #define DEFAULT_THREAD_POOL_MAX_IDLE_THREADS                        8
41 #define DEFAULT_THREAD_POOL_MAINTENANCE_FREQUENCY_IN_SECONDS        0
42 #define DEFAULT_THREAD_POOL_SHRINK_BY                               0
43 #define DEFAULT_THREAD_POOL_SPAWN_BY                                0
44 #define DEFAULT_THREAD_POOL_ORIGINAL_SIZE                           8
45 #define DEFAULT_SOCKET_TIMEOUT_IN_SECONDS                           60
46 // former default for SSL_Accept timeout was 10s - increased to 20s to support HP LTO-4
47 #define DEFAULT_SSL_ACCEPT_TIMEOUT_IN_SECONDS                       20
48 #define DEFAULT_SOCKET_CONNECTION_BACKLOG                           100
49 #define DEFAULT_MANAGEMENT_SERVICE_MAX_CONNECTIONS                  10
50 #define DEFAULT_CA_SERVICE_PORT_NUMBER                              3331
51 #define DEFAULT_CERTIFICATE_SERVICE_PORT_NUMBER                     3332
52 #define DEFAULT_MANAGEMENT_SERVICE_PORT_NUMBER                      3333
53 #define DEFAULT_AGENT_SERVICE_PORT_NUMBER                           3334
54 #define DEFAULT_DISCOVERY_SERVICE_PORT_NUMBER                       3335
55 #define DEFAULT_REPLICATION_SERVICE_PORT_NUMBER                     3336
56 #define EXTENDED_SSL_SESSION_CACHE_TIMEOUT                          86400
57 #define DEFAULT_DATABASE_MAINTENANCE_FREQUENCY_IN_SECONDS           86400
58 #define DEFAULT_TRIGGER_DATABASE_MAINTENANCE_TIMEOUT_IN_SECONDS     30
59 #define DEFAULT_AUDIT_LOG_MAINTENANCE_FREQUENCY_IN_SECONDS          3600
60 // see CR 6689920
61 #define DEFAULT_KEY_POOL_MAINTENANCE_FREQUENCY_IN_SECONDS           15
62 #define KEY_POOL_MINIMUM_SIZE                                       1000
63 #define KEY_POOL_MAXIMUM_SIZE                                       200000
64 #define DEFAULT_KEY_GENERATION_BATCH_SIZE                           10
65 #define DEFAULT_REPLICATION_ANTI_ENTROPY_FREQUENCY_IN_SECONDS       60
66 #define DEFAULT_MAXIMUM_REPLICATION_MESSAGE_SIZE_IN_BYTES           8192
67 #define DEFAULT_MAXIMUM_JOIN_CLUSTER_MESSAGE_SIZE_IN_BYTES          262144
68 #define DEFAULT_MAXIMUM_JOIN_CLUSTER_KMA_ENTRIES                    20
69 #define DEFAULT_REPLICATION_THROTTLE_TIME_IN_MILLISECONDS           1000
70 #define DEFAULT_REPLICATION_SPREAD_TIME_IN_MILLISECONDS             3000
71 #define DEFAULT_REPLICATION_TIMEOUT_IN_SECONDS                      15
72 #define DEFAULT_RETRIEVE_ROOT_CA_CERTIFICATE_TIMEOUT_IN_SECONDS     15
73 #define DEFAULT_RETRIEVE_APPLIANCE_CERTIFICATE_TIMEOUT_IN_SECONDS   15
74 #define DEFAULT_JOIN_CLUSTER_TIMEOUT_IN_SECONDS                     15
75 #define DEFAULT_JOIN_CLUSTER_REPLICATED_IN_SECONDS                  10
76 #define DEFAULT_REQUEST_ANTI_ENTROPY_PUSH_TIMEOUT_IN_SECONDS        60
77 #define DEFAULT_PUSH_UPDATES_TIMEOUT_IN_SECONDS                     60
78 #define DEFAULT_CLUSTER_PEER_STATUS_TIMEOUT_IN_SECONDS              10
79 #define DEFAULT_TABLE_LOCK_TIMEOUT_IN_SECONDS                       2
80 #define DEFAULT_REPLICATION_TABLE_LOCK_TIMEOUT_IN_SECONDS           8
81 #define DEFAULT_TRANSACTION_RETRY_TIMEOUT_IN_SECONDS                4
82 #define DEFAULT_KEY_STORE_GROW_SIZE_IN_SLOTS                        10000
83 // Since write-caching is disabled on the hard disk, this is not necessary to force overwrites to disk
84 #define DEFAULT_KEY_STORE_OVERWRITE_BUFFER_EXTRA_SIZE               0
85 #define DEFAULT_KEY_STORE_OVERWRITE_PASS_COUNT                      7
86 #define DEFAULT_CLOCK_ADJUSTMENT_LIMIT_IN_SECONDS                   300
87 #define DEFAULT_DATABASE_START_TIMEOUT_IN_SECONDS                   30
88 #define DEFAULT_DATABASE_TRANSACTION_RETRY_COUNT                    10
89 #define DEFAULT_DATABASE_TRANSACTION_RETRY_SLEEP_IN_MILLISECONDS    1000
90 #define DEFAULT_MAX_SNMP_TRAP_QUEUE_SIZE                            10000
91 #define DEFAULT_SNMP_TIMEOUT_IN_SECONDS                             10
92 #define DEFAULT_SNMP_RETRY_LIMIT                                    1
93 #define DEFAULT_FILE_TRANSFER_MAXIMUM_CHUNK_SIZE_IN_KILOBYTES       1024
94 #define DEFAULT_CERTIFICATE_START_TIME_SHIFT_IN_SECONDS             (60*60*24)
95 #define DEFAULT_DISCOVERY_FREQUENCY_IN_SECONDS                      (60*10)
96 #define DEFAULT_AUDIT_LOG_FAIL_BACK_FREQUENCY_IN_SECONDS            (60*10)
97 #define DEFAULT_NTP_PEER_UPDATE_FREQUENCY_IN_SECONDS                23
98 #define DEFAULT_NTP_PEER_UPDATE_QUERY_INTERVAL                      156
99 #define DEFAULT_SYSTEM_DUMP_LOG_LINE_COUNT                          5000
100 #define DEFAULT_MASTER_KEY_PROVIDER_MAINTENANCE_FREQUENCY_IN_SECONDS 3600
101 #define DEFAULT_SEND_PUSH_UPDATES_TO_JOIN_PEER_KMA_IN_SECONDS       3600
102 #define DEFAULT_PENDING_QUORUM_OPERATION_EXPIRATION_FREQUENCY_IN_SECONDS 600
103 #define DEFAULT_SUPPORT_ACCOUNT_MAX_PASSWORD_AGE_IN_DAYS            7
104 #define DEFAULT_REPLICATION_ACCELERATION_TIMEOUT_IN_SECONDS         300
105 
106 #define DEFAULT_DATABASE_ADMINISTRATOR_USERNAME                     "dbadmin"
107 #define DEFAULT_DATABASE_ADMINISTRATOR_PASSWORD                     "npwd4kms2"
108 #define DEFAULT_DATABASE_NAME                                       "keymgr"
109 #define DEFAULT_DATABASE_PARAMS                                     ""
110 #define DEFAULT_DATABASE_USERNAME                                   "keymgr"
111 #define DEFAULT_DATABASE_PASSWORD                                   "npwd4kms2"
112 #define DEFAULT_KEY_STORE_FILE_NAME                                 "KeyStore.dat"
113 #define DEFAULT_OPENSSL_ROOT_CA_CERTIFICATE_FILE_NAME               "RootCACertificate.crt"
114 #define DEFAULT_OPENSSL_APPLIANCE_KEY_PAIR_FILE_NAME                "KMAKeyPair.pem"
115 #ifndef WIN32
116 #define DEFAULT_OPENSSL_AGENT_PRIVATE_KEY_DIR                       "/var/opt/SUNWkms2/data/"
117 #endif
118 
119 #ifndef DEFAULT_SERVER_VERSION
120 #define DEFAULT_SERVER_VERSION                                      "2.1.04"
121 #endif
122 #define DEFAULT_SNMP_TRAP_GENERIC_TRAP_OID                          "1.3.6.1.4.1.42.2"
123 #define DEFAULT_SNMP_TRAP_DATE_TIME_OID                             "1.3.6.1.4.1.42.2.1"
124 #define DEFAULT_SNMP_TRAP_AUDIT_CLASS_OID                           "1.3.6.1.4.1.42.2.2"
125 #define DEFAULT_SNMP_TRAP_AUDIT_OPERATION_OID                       "1.3.6.1.4.1.42.2.3"
126 #define DEFAULT_SNMP_TRAP_AUDIT_CONDITION_OID                       "1.3.6.1.4.1.42.2.4"
127 #define DEFAULT_SNMP_TRAP_AUDIT_SEVERITY_OID                        "1.3.6.1.4.1.42.2.5"
128 #define DEFAULT_SNMP_TRAP_ENTITY_ID_OID                             "1.3.6.1.4.1.42.2.6"
129 #define DEFAULT_SNMP_TRAP_NETWORK_ADDRESS_OID                       "1.3.6.1.4.1.42.2.7"
130 #define DEFAULT_SNMP_TRAP_MESSAGE_OID                               "1.3.6.1.4.1.42.2.8"
131 #define DEFAULT_SNMP_TRAP_AUDIT_SOLUTION_OID                        "1.3.6.1.4.1.42.2.9"
132 #define DEFAULT_BACKUP_FILE_NAME                                    "BackupFile"
133 #define DEFAULT_RESTORE_FILE_NAME                                   "RestoreFile"
134 #define DEFAULT_CACHED_BACKUP_FILE_NAME                             "/var/opt/SUNWkms2/CachedBackupFile"
135 #define DEFAULT_CACHED_CORE_SECURITY_XML_FILE_NAME                  "/var/opt/SUNWkms2/CachedCoreSecurityXMLFile"
136 #define DEFAULT_CACHED_BACKUP_KEY_XML_FILE_NAME                     "/var/opt/SUNWkms2/CachedBackupKeyXMLFile"
137 #define DEFAULT_SOFTWARE_UPGRADE_FILE_NAME                          "/SUNWkms2/boxcar/SoftwareUpgradeFile"
138 #define DEFAULT_IMPORT_10KEYS_FILE_NAME                             "Import10KeysFile"
139 #define DEFAULT_KEY_SHARING_EXPORT_FILE_NAME                        "KeySharingExport.dat"
140 #define DEFAULT_KEY_SHARING_IMPORT_FILE_NAME                        "KeySharingImport.dat"
141 #define DEFAULT_JOIN_PEER_KMA_FILE_NAME                             "/var/opt/SUNWkms2/data/JoinPeerKMAFile"
142 
143 #define DEFAULT_PRIMARY_NETWORK_IF                                  "bge0"
144 #define DEFAULT_SECONDARY_NETWORK_IF                                "aggr1"
145 #define DEFAULT_AGGREGATE_NETWORK                                   "nge1 nge0"
146 #define DEFAULT_PRIMARY_ALIAS                                       "KMA-Mgmt"
147 #define DEFAULT_SECONDARY_ALIAS                                     "KMA-Service"
148 #define DEFAULT_DATABASE_FILE_SYSTEM_PATH                           "/var/lib/pgsql"
149 #define DEFAULT_BUNDLE_SOFTWARE_COMMAND                             "/opt/SUNWkms2/bin/BundleSoftwareUpgrade"
150 #define DEFAULT_FLAR_FILE_PATH                                      "/SUNWkms2/boxcar/SoftwareUpgrade.flar"
151 
152 // System Calls (Config)
153 
154 #define DEFAULT_SERVER_RESTART_COMMAND                              "/usr/sbin/svcadm restart kms2 > /dev/null 2>&1"
155 #define DEFAULT_SET_IP_CONFIGURATION_COMMAND                        "/opt/SUNWkms2/bin/SetIPAddresses"
156 #define DEFAULT_RESET_TO_FACTORY_DEFAULT_COMMAND                    "/opt/SUNWkms2/bin/ResetAndZeroizeLauncher > /dev/null 2>&1"
157 #define DEFAULT_RESET_TO_FACTORY_AND_ZEROIZE_DEFAULT_COMMAND        "/opt/SUNWkms2/bin/ResetAndZeroizeLauncher -zeroize > /dev/null 2>&1"
158 #define DEFAULT_SHUTDOWN_COMMAND                                    "/usr/sbin/shutdown -y -g 5 -i 5 'KMS is shutting down the system' > /dev/null 2>&1"
159 #define DEFAULT_ENABLE_SUPPORT_COMMAND                              "/bin/passwd -u support > /dev/null 2>&1"
160 #define DEFAULT_DISABLE_SUPPORT_COMMAND                             "/bin/passwd -l support > /dev/null 2>&1"
161 #define DEFAULT_REGENERATE_SSH_KEYS_COMMAND                         "/opt/SUNWkms2/bin/RegenerateSSHKeys > /dev/null 2>&1"
162 #define DEFAULT_DISPLAY_SSH_KEYS_COMMAND                            "/opt/SUNWkms2/bin/GetSSHKeys"
163 #define DEFAULT_ENABLE_SSH_COMMAND                                  "/usr/sbin/svcadm enable ssh > /dev/null 2>&1"
164 #define DEFAULT_DISABLE_SSH_COMMAND                                 "/opt/SUNWkms2/bin/DisableSSH > /dev/null 2>&1"
165 #define DEFAULT_GET_SUPPORT_STATUS_COMMAND                          "/opt/SUNWkms2/bin/StateOfSupport"
166 #define DEFAULT_GET_SSH_STATUS_COMMAND                              "/opt/SUNWkms2/bin/StateOfSSHD"
167 #define DEFAULT_ENABLE_SERVER_STARTUP_COMMAND                       "/bin/true"
168 #define DEFAULT_SERVER_STARTUP_COMMAND                              "/usr/sbin/svcadm enable kms2 > /dev/null 2>&1"
169 #define DEFAULT_SOFTWARE_UPGRADE_COMMAND                            "/opt/SUNWkms2/bin/InstallSoftwareVersion"
170 #define DEFAULT_LIST_SOFTWARE_VERSIONS_COMMAND                      "/opt/SUNWkms2/bin/ListSoftwareVersions"
171 #define DEFAULT_STOP_SOFTWARE_AND_RUN_COMMAND                       "echo Stop and run not implemented" // "/usr/local/bin/StopSoftwareAndRun"
172 #define DEFAULT_VERIFY_SOFTWARE_COMMAND                             "/opt/SUNWkms2/bin/VerifySoftwareFile"
173 #define DEFAULT_VERIFY_ACTIVATE_COMMAND                             "/opt/SUNWkms2/bin/VerifyActivateSoftware"
174 #define DEFAULT_CHANGE_SOFTWARE_COMMAND                             "/opt/SUNWkms2/bin/ChangeSoftwareVersion"
175 #define DEFAULT_REBOOT_SYSTEM_COMMAND                               "/usr/sbin/shutdown -y -g 5 -i 6 'KMS is rebooting the system' > /dev/null 2>&1"
176 #define DEFAULT_STOP_SERVER_COMMAND                                 "/usr/sbin/svcadm disable kms2"
177 #define DEFAULT_INTERFACE_CONFIG_COMMAND                            "/usr/sbin/ifconfig"
178 #define DEFAULT_SYSTEM_DUMP_COMMAND                                 "/opt/SUNWkms2/bin/SystemDump"
179 #define DEFAULT_CONFIGURE_NTP_COMMAND                               "/opt/SUNWkms2/bin/ConfigureNTP"
180 #define DEFAULT_SET_TIMEZONE_COMMAND                                "/opt/SUNWkms2/bin/SetTimezone"
181 #define DEFAULT_GET_KEYBOARD_LAYOUT_COMMAND                         "/opt/SUNWkms2/bin/GetKeyboardLayout"
182 #define DEFAULT_SET_KEYBOARD_LAYOUT_COMMAND                         "/opt/SUNWkms2/bin/SetKeyboardLayout"
183 #define DEFAULT_CONFIGURE_PRIMARY_ADMIN_COMMAND                     "/opt/SUNWkms2/bin/ConfigurePrimaryAdmin"
184 #define DEFAULT_GET_IPV6_ADDRESS_COMMAND                            "/opt/SUNWkms2/bin/GetIPv6Address"
185 #define DEFAULT_INITIALIZE_SCA6000_COMMAND                          "/opt/SUNWkms2/bin/InitializeSCA6000"
186 #define DEFAULT_QUERY_SYSTEM_MESSAGES_COMMAND                       "/opt/SUNWkms2/bin/QuerySystemMessages"
187 
188 // @see StringUtilities.cpp
189 #define DEFAULT_PENDING_QUORUM_OPERATION_TIMEOUT                    "P2D" // Default to 2 days (defined by ISO 8601)
190 #define PENDING_OPERATIONS_VERSION_STRING                           "2.2"
191 
192 // PKI
193 
194 #define KEY_SIZE                                                    2048
195 #define CRL_DAYS                                                    365
196 #define CRL_HOURS                                                   0
197 #define PKI_FORMAT                                                  FILE_FORMAT_PEM
198 #define DER_FORMAT                                                  FILE_FORMAT_DER
199 #define PKCS12_FORMAT                                               FILE_FORMAT_PKCS12
200 #define PKI_UNPROTECTED_PASSWORD                                    "password"
201 #define DN_O_ROOT_CA                                                "Oracle"
202 #define DN_OU_ROOT_CA                                               "KMS"
203 #define DN_CN_ROOT_CA                                               "RootCA"
204     // NOTE: Do not directly use the following values.
205     // Use the configurable Security Parameter values instead
206 #define DEFAULT_ROOT_CA_CERTIFICATE_LIFETIME                        "P49Y"
207 #define DEFAULT_CERTIFICATE_LIFETIME                                "P49Y"
208 #define AUTHENTICATION_SECRET_LENGTH                                20
209 #define AUTHENTICATION_CHALLENGE_LENGTH                             20
210 #define AUTHENTICATION_RESPONSE_LENGTH                              20
211 #define AUTHENTICATION_ITERATION_TIME_IN_MILLISECONDS               100
212 // reduce the time for agents since we support agents on embedded processors
213 #define AGENT_AUTHENTICATION_ITERATION_TIME_IN_MILLISECONDS         10
214 #define MIN_AUTHENTICATION_ITERATION_COUNT                          40000   // a bit less than 1/10 second on standard Appliance hardware
215 #define MAX_AUTHENTICATION_ITERATION_COUNT                          400000  // a bit less that 1 second on standard Appliance hardware
216 
217 // Core Security
218 
219 #define MAX_CORE_SECURITY_KEY_SPLIT_COUNT                           10
220 #define CORE_SECURITY_HMAC_LENGTH                                   64
221 #define MAX_CORE_SECURITY_PAD_LENGTH                                16
222 
223 //------------- to be removed: Transfer Partner code is obsolete -----------
224 #define MAX_KEY_DISTRIBUTION_PUBLIC_KEY_COUNT                       4
225 #define MAX_CORE_SECURITY_PUBLIC_KEY_LENGTH                         256
226 //--------------------------------------------------------------------------
227 
228 // SOAP Services
229 
230 // TODO: make functions instead of macros?
231 
232 #define SOAP_SERVER_ERROR( pstSoap )                                (soap_receiver_fault( pstSoap, "Server Error", NULL ))
233 // This has been replaced with SoapClientError:
234 //#define SOAP_CLIENT_ERROR( pstSoap, sMessage )                      (soap_sender_fault( pstSoap, sMessage, NULL ))
235 #define SOAP_IS_CLIENT_ERROR( pstSoap )                             (strcmp( *soap_faultcode( pstSoap ), pstSoap->version == 2 ? "SOAP-ENV:Sender" : "SOAP-ENV:Client" ) == 0)
236 #define GET_SOAP_FAULTCODE( pstSoap )                               ((soap_set_fault( pstSoap ),*soap_faultcode( pstSoap )) ? (*soap_faultcode( pstSoap )) : "Unknown")
237 #define GET_SOAP_FAULTSTRING( pstSoap )                             ((soap_set_fault( pstSoap ),*soap_faultstring( pstSoap )) ? (*soap_faultstring( pstSoap )) : "Unknown")
238 #define GET_SOAP_FAULTDETAIL( pstSoap )                             ((soap_set_fault( pstSoap ),*soap_faultdetail( pstSoap )) ? (*soap_faultdetail( pstSoap )) : "Unknown")
239 #define SOAP_AUDIT_LOG_MESSAGE( pStringTable, pstSoap )             ( CAuditMessage( CAuditLogger::AUDIT_VALUE_SOAP_FAULTCODE, GET_SOAP_FAULTCODE( pstSoap ) ) + CAuditMessage( CAuditLogger::AUDIT_VALUE_SOAP_FAULTSTRING, GET_SOAP_FAULTSTRING( pstSoap ) ) + CAuditMessage( CAuditLogger::AUDIT_VALUE_SOAP_FAULTDETAIL, GET_SOAP_FAULTDETAIL( pstSoap ) ) )
240 #define SOAP_HTTP_PROTOCOL                                          "http://"
241 #define SOAP_HTTPS_PROTOCOL                                         "https://"
242 
243 // Data Entry
244 
245 #define MINIMUM_WIDE_STRING_VALUE_LENGTH                            1
246 #define MAXIMUM_WIDE_STRING_VALUE_LENGTH                            64
247 #define MAXIMUM_UTF8_STRING_VALUE_LENGTH                            ( MAXIMUM_WIDE_STRING_VALUE_LENGTH * 6 )
248 #define MINIMUM_WIDE_TEXT_VALUE_LENGTH                              1
249 #define MAXIMUM_WIDE_TEXT_VALUE_LENGTH                              8192
250 #define MAXIMUM_UTF8_TEXT_VALUE_LENGTH                              ( MAXIMUM_WIDE_TEXT_VALUE_LENGTH * 6 )
251 
252 // Business Logic
253 
254 #define AUDIT_ID_BUFFER_LENGTH                                      16
255 #define CERTIFICATE_SERIAL_NUMBER_BUFFER_LENGTH                     16
256 #define BACKUP_ID_BUFFER_LENGTH                                     16
257 #define DATA_UNIT_ID_HEX_STRING_LENGTH                              32
258 #define DATA_UNIT_KEY_ID_BUFFER_LENGTH                              30
259 #define DATA_UNIT_KEY_ID_HEX_STRING_LENGTH                          (DATA_UNIT_KEY_ID_BUFFER_LENGTH*2)
260 #define MAXIMUM_QUERY_NEXT_PAGE_SIZE                                1000
261 #define MAXIMUM_QUERY_FILTER_PARAMS_COUNT                           100
262 #define MAXIMUM_LIST_DATA_UNIT_STATUS_PARAMS_COUNT                  ( MAXIMUM_QUERY_FILTER_PARAMS_COUNT )
263 #define MAXIMUM_LIST_AUDIT_LOGS_FOR_AGENTS_PARAMS_COUNT             ( MAXIMUM_QUERY_FILTER_PARAMS_COUNT )
264 #define MAXIMUM_LIST_AUDIT_LOGS_FOR_DATA_UNITS_PARAMS_COUNT         ( MAXIMUM_QUERY_FILTER_PARAMS_COUNT )
265 #define MAXIMUM_LIST_AUDIT_LOGS_FOR_KEYS_PARAMS_COUNT               ( MAXIMUM_QUERY_FILTER_PARAMS_COUNT )
266 // 0 allows unlimited # of DUs to be exported, positive int constricts the size
267 #define DEFAULT_KEYSHARING_MAXIMUM_EXPORT_DATA_UNITS_RESULT_SIZE    0
268 #define TRANSFER_PARTNER_KEY_ID_LENGTH                              32
269 #define TRANSFER_PARTNER_KEY_VALUE_LENGTH                           259
270 #define TRANSFER_PARTNER_KEY_VALUE_HEX_STRING_LENGTH                (TRANSFER_PARTNER_KEY_VALUE_LENGTH*2)
271     // NOTE: Do not directly use the following value.
272     // Use the configurable Security Parameter value instead
273 #define DEFAULT_MAX_FAILED_RETRIEVE_CERTIFICATE_ATTEMPTS            5
274     // The obvious logic for determining if a key's bits are on a backup is as follows:
275     // The key must have been created before the backup was created:
276     //    Backup.CreatedDate >= DataUnitKey.CreatedDate
277     // And the key must not have been destroyed before the backup was created:
278     //    (DataUnitKey.DestroyedDate IS NULL) OR (Backup.CreatedDate <= DataUnitKey.DestroyedDate)
279     // This logic would be fine in a single-appliance cluster, or if we had (or when we have)
280     // time synchronization. But right now the appliances in a cluster may have different
281     // times from each other, and that makes it dangerous to use a simple date comparison.
282     // (Note that when determining if a key is on a backup, we *really* don't want false
283     // negatives, but we don't mind false positives so much, within reason.)
284     // To address this, the best solution we came up with is to use a "backup date window".
285     // Instead of simply using the CreatedDate of a backup in our logic, we'll use:
286     //    (Backup.CreatedDate + BACKUP_DATE_WINDOW_INTERVAL) >= DataUnitKey.CreatedDate
287     // and
288     //    (DataUnitKey.DestroyedDate IS NULL) OR ((Backup.CreatedDate - BACKUP_DATE_WINDOW_INTERVAL) <= DataUnitKey.DestroyedDate)
289     // Note that the adding and subtracting of BACKUP_DATE_WINDOW_INTERVAL effectively increases
290     // the chance that the calculation will show that a key's bits are on a backup.
291     // It's still possible to get false negatives, and there will be more false positives,
292     // but if BACKUP_DATE_WINDOW_INTERVAL is set to the largest reasonable value that
293     // appliances' clocks could differ by, then we can eliminate false negatives to a
294     // fairly high degree of probability. (We can raise the probability to any arbitrary
295     // amount by increasing the window, but the trade-off is that we'll have more and more
296     // false positives.)
297 #define DEFAULT_BACKUP_DATE_WINDOW_IN_SECONDS                       300
298 
299 // Security Parameter Constraints
300 
301 #define MINIMUM_LONG_TERM_RETENTION_AUDIT_LOG_SIZE_LIMIT            1000
302 #define MAXIMUM_LONG_TERM_RETENTION_AUDIT_LOG_SIZE_LIMIT            1000000
303 #define MINIMUM_LONG_TERM_RETENTION_AUDIT_LOG_LIFETIME              "P7D"
304 #define MINIMUM_MEDIUM_TERM_RETENTION_AUDIT_LOG_SIZE_LIMIT          1000
305 #define MAXIMUM_MEDIUM_TERM_RETENTION_AUDIT_LOG_SIZE_LIMIT          1000000
306 #define MINIMUM_MEDIUM_TERM_RETENTION_AUDIT_LOG_LIFETIME            "P7D"
307 #define MINIMUM_SHORT_TERM_RETENTION_AUDIT_LOG_SIZE_LIMIT           1000
308 #define MAXIMUM_SHORT_TERM_RETENTION_AUDIT_LOG_SIZE_LIMIT           1000000
309 #define MINIMUM_SHORT_TERM_RETENTION_AUDIT_LOG_LIFETIME             "P7D"
310 #define MINIMUM_AUDIT_LOG_MAINTENANCE_FREQUENCY                     "PT1M"
311 #define MINIMUM_ROOT_CA_CERTIFICATE_LIFETIME                        "P1M"
312 #define MINIMUM_CERTIFICATE_LIFETIME                                "P1M"
313 #define MINIMUM_RETRIEVE_CERTIFICATE_ATTEMPT_LIMIT                  1
314 #define MAXIMUM_RETRIEVE_CERTIFICATE_ATTEMPT_LIMIT                  1000
315 #define MINIMUM_PASSPHRASE_MINIMUM_LENGTH                           8
316 #define MAXIMUM_PASSPHRASE_MINIMUM_LENGTH                           ( MAXIMUM_WIDE_STRING_VALUE_LENGTH )
317 #define MINIMUM_MANAGEMENT_SESSION_TIMEOUT_IN_MINUTES               0
318 #define MAXIMUM_MANAGEMENT_SESSION_TIMEOUT_IN_MINUTES               60
319 
320 // The SYSTEM_FIPS_MODE_ONLY_ values must match those in
321 // enum KMS_Management__FIPSModeOnly in KMS_Management_SOAP.h and
322 // enum KMSManagement_FIPSModeOnly in KMSManagement.h
323 #define SYSTEM_FIPS_MODE_ONLY_UNCHANGED                             (-1)
324 #define SYSTEM_FIPS_MODE_ONLY_FALSE                                 0
325 #define SYSTEM_FIPS_MODE_ONLY_TRUE                                  1
326 #define MINIMUM_FIPS_MODE_ONLY                                      ( SYSTEM_FIPS_MODE_ONLY_FALSE )
327 #define MAXIMUM_FIPS_MODE_ONLY                                      ( SYSTEM_FIPS_MODE_ONLY_TRUE )
328 
329 #define DEFAULT_MINIMUM_PASSPHRASE_LENGTH                           8
330 #define DEFAULT_MANAGEMENT_SESSION_TIMEOUT_IN_MINUTES               15
331 #define DEFAULT_FIPS_MODE_ONLY                                      ( SYSTEM_FIPS_MODE_ONLY_FALSE )
332 
333 // To limit maximum query size, we limit # created
334 // this is probably (hopefully) temporary
335 #define MAXIMUM_CREATION_COUNT                                      999
336 
337 // Audit Log
338 
339 #define AUDIT_LOG_DEFAULT_SIZE_LONG_TERM_RETENTION                  1000000
340 #define AUDIT_LOG_DEFAULT_SIZE_MEDIUM_TERM_RETENTION                100000
341 #define AUDIT_LOG_DEFAULT_SIZE_SHORT_TERM_RETENTION                 10000
342 #define AUDIT_LOG_DEFAULT_LIFETIME_DAYS_LONG_TERM_RETENTION         "P2Y"
343 #define AUDIT_LOG_DEFAULT_LIFETIME_DAYS_MEDIUM_TERM_RETENTION       "P3M"
344 #define AUDIT_LOG_DEFAULT_LIFETIME_DAYS_SHORT_TERM_RETENTION        "P7D"
345 
346 // Replication
347 
348 // schema version 7: change to soap Discovery Service for supporting DNS
349 // schema version 8: change to soap Agent Service for RetrieveDataUnitKeys
350 // schema version 9: ensure that Ready keys appear in current backup
351 // schema version 10: IPv6 support and AES key wrap
352 // schema version 11: ICSF integration, distributed quorum, SNMP v2
353 // schema version 12: replication acceleration
354 #define REPLICATION_SCHEMA_VERSION_MIN                              8
355 #define REPLICATION_SCHEMA_VERSION_MAX                             12
356 #define REPLICATION_SCHEMA_VERSION_KEYS_IN_BACKUP                   9
357 #define REPLICATION_SCHEMA_VERSION_IPV6_ADDRESSES                  10
358 #define REPLICATION_SCHEMA_VERSION_AES_KEY_WRAP                    10
359 #define REPLICATION_SCHEMA_VERSION_MASTER_KEY_MODE                 11
360 #define REPLICATION_SCHEMA_VERSION_DISTRIBUTED_QUORUM              11
361 #define REPLICATION_SCHEMA_VERSION_SNMP_PROTOCOL_VERSION_TWO       11
362 #define REPLICATION_SCHEMA_VERSION_REPLICATION_ACCELERATION        12
363 // value to return on inactive software versions
364 #define REPLICATION_SCHEMA_VERSION_INVALID                          0
365 
366 // Key Sharing Transfer Formats
367 
368 #define TRANSFER_FORMAT_INVALID                                       (-100)
369 #define TRANSFER_FORMAT_DEFAULT                                       (-1)
370 #define TRANSFER_FORMAT_LEGACY                                        0
371 #define TRANSFER_FORMAT_LEGACY_VERSION_STRING                         "2.0.1"
372 #define TRANSFER_FORMAT_FIPS                                          1
373 #define TRANSFER_FORMAT_FIPS_VERSION_STRING                           "2.1"
374 
375 // Master Key Modes
376 #define _MASTER_KEY_MODE_OFF                                         0
377 #define _MASTER_KEY_MODE_ALL_KEYS                                    1
378 #define _MASTER_KEY_MODE_RECOVER_KEYS_ONLY                           2
379 
380 // Derived/Master Key stuff
381 #define KEY_VERSION_PREFIX_LENGTH                                   2
382 #define KEY_VERSION_PREFIX_HEX_LENGTH                               (KEY_VERSION_PREFIX_LENGTH*2)
383 #define NON_DERIVED_KEY_VERSION                                     0x0000
384 #define NON_DERIVED_KEY_VERSION_HEX                                 (L"0000")
385 #define DERIVED_KEY_VERSION                                         0x0001
386 #define DERIVED_KEY_VERSION_HEX                                     (L"0001")
387 #define MASTER_KEY_ID_PREFIX_HEX                                    (L"0000")
388 #define MASTER_KEY_ID_PREFIX_LENGTH                                 2
389 #define MASTER_KEY_ID_PREFIX_HEX_LENGTH                             (MASTER_KEY_ID_PREFIX_LENGTH*2)
390 #define MASTER_KEY_ID_KMAID_LENGTH                                  8
391 #define MASTER_KEY_ID_KMAID_HEX_LENGTH                              (MASTER_KEY_ID_KMAID_LENGTH*2)
392 #define MASTER_KEY_ID_RANDOM_LENGTH                                 8
393 #define MASTER_KEY_ID_LENGTH                                        (MASTER_KEY_ID_PREFIX_LENGTH + MASTER_KEY_ID_KMAID_LENGTH + MASTER_KEY_ID_RANDOM_LENGTH)
394 #define MASTER_KEY_ID_HEX_LENGTH                                    (MASTER_KEY_ID_LENGTH*2)	// ICSF can only handle 32-byte string IDs for keys
395 #define MASTER_KEY_ID_BASE64_LENGTH                                 32
396 #define DATA_UNIT_KEY_ID_HEX_LENGTH                                 (DATA_UNIT_KEY_ID_BUFFER_LENGTH*2)
397 
398 // SNMP Manager protocol version stuff
399 #define SYSTEM_SNMP_PROTOCOL_VERSION_THREE                          0
400 #define SYSTEM_SNMP_PROTOCOL_VERSION_TWO                            1
401 
402 #endif //ApplianceParameters_h
403