michael@0: /* This Source Code Form is subject to the terms of the Mozilla Public michael@0: * License, v. 2.0. If a copy of the MPL was not distributed with this michael@0: * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ michael@0: michael@0: #ifndef __SEC_ERR_H_ michael@0: #define __SEC_ERR_H_ michael@0: michael@0: #include "utilrename.h" michael@0: michael@0: #define SEC_ERROR_BASE (-0x2000) michael@0: #define SEC_ERROR_LIMIT (SEC_ERROR_BASE + 1000) michael@0: michael@0: #define IS_SEC_ERROR(code) \ michael@0: (((code) >= SEC_ERROR_BASE) && ((code) < SEC_ERROR_LIMIT)) michael@0: michael@0: #ifndef NO_SECURITY_ERROR_ENUM michael@0: typedef enum { michael@0: SEC_ERROR_IO = SEC_ERROR_BASE + 0, michael@0: SEC_ERROR_LIBRARY_FAILURE = SEC_ERROR_BASE + 1, michael@0: SEC_ERROR_BAD_DATA = SEC_ERROR_BASE + 2, michael@0: SEC_ERROR_OUTPUT_LEN = SEC_ERROR_BASE + 3, michael@0: SEC_ERROR_INPUT_LEN = SEC_ERROR_BASE + 4, michael@0: SEC_ERROR_INVALID_ARGS = SEC_ERROR_BASE + 5, michael@0: SEC_ERROR_INVALID_ALGORITHM = SEC_ERROR_BASE + 6, michael@0: SEC_ERROR_INVALID_AVA = SEC_ERROR_BASE + 7, michael@0: SEC_ERROR_INVALID_TIME = SEC_ERROR_BASE + 8, michael@0: SEC_ERROR_BAD_DER = SEC_ERROR_BASE + 9, michael@0: SEC_ERROR_BAD_SIGNATURE = SEC_ERROR_BASE + 10, michael@0: SEC_ERROR_EXPIRED_CERTIFICATE = SEC_ERROR_BASE + 11, michael@0: SEC_ERROR_REVOKED_CERTIFICATE = SEC_ERROR_BASE + 12, michael@0: SEC_ERROR_UNKNOWN_ISSUER = SEC_ERROR_BASE + 13, michael@0: SEC_ERROR_BAD_KEY = SEC_ERROR_BASE + 14, michael@0: SEC_ERROR_BAD_PASSWORD = SEC_ERROR_BASE + 15, michael@0: SEC_ERROR_RETRY_PASSWORD = SEC_ERROR_BASE + 16, michael@0: SEC_ERROR_NO_NODELOCK = SEC_ERROR_BASE + 17, michael@0: SEC_ERROR_BAD_DATABASE = SEC_ERROR_BASE + 18, michael@0: SEC_ERROR_NO_MEMORY = SEC_ERROR_BASE + 19, michael@0: SEC_ERROR_UNTRUSTED_ISSUER = SEC_ERROR_BASE + 20, michael@0: SEC_ERROR_UNTRUSTED_CERT = SEC_ERROR_BASE + 21, michael@0: SEC_ERROR_DUPLICATE_CERT = (SEC_ERROR_BASE + 22), michael@0: SEC_ERROR_DUPLICATE_CERT_NAME = (SEC_ERROR_BASE + 23), michael@0: SEC_ERROR_ADDING_CERT = (SEC_ERROR_BASE + 24), michael@0: SEC_ERROR_FILING_KEY = (SEC_ERROR_BASE + 25), michael@0: SEC_ERROR_NO_KEY = (SEC_ERROR_BASE + 26), michael@0: SEC_ERROR_CERT_VALID = (SEC_ERROR_BASE + 27), michael@0: SEC_ERROR_CERT_NOT_VALID = (SEC_ERROR_BASE + 28), michael@0: SEC_ERROR_CERT_NO_RESPONSE = (SEC_ERROR_BASE + 29), michael@0: SEC_ERROR_EXPIRED_ISSUER_CERTIFICATE = (SEC_ERROR_BASE + 30), michael@0: SEC_ERROR_CRL_EXPIRED = (SEC_ERROR_BASE + 31), michael@0: SEC_ERROR_CRL_BAD_SIGNATURE = (SEC_ERROR_BASE + 32), michael@0: SEC_ERROR_CRL_INVALID = (SEC_ERROR_BASE + 33), michael@0: SEC_ERROR_EXTENSION_VALUE_INVALID = (SEC_ERROR_BASE + 34), michael@0: SEC_ERROR_EXTENSION_NOT_FOUND = (SEC_ERROR_BASE + 35), michael@0: SEC_ERROR_CA_CERT_INVALID = (SEC_ERROR_BASE + 36), michael@0: SEC_ERROR_PATH_LEN_CONSTRAINT_INVALID = (SEC_ERROR_BASE + 37), michael@0: SEC_ERROR_CERT_USAGES_INVALID = (SEC_ERROR_BASE + 38), michael@0: SEC_INTERNAL_ONLY = (SEC_ERROR_BASE + 39), michael@0: SEC_ERROR_INVALID_KEY = (SEC_ERROR_BASE + 40), michael@0: SEC_ERROR_UNKNOWN_CRITICAL_EXTENSION = (SEC_ERROR_BASE + 41), michael@0: SEC_ERROR_OLD_CRL = (SEC_ERROR_BASE + 42), michael@0: SEC_ERROR_NO_EMAIL_CERT = (SEC_ERROR_BASE + 43), michael@0: SEC_ERROR_NO_RECIPIENT_CERTS_QUERY = (SEC_ERROR_BASE + 44), michael@0: SEC_ERROR_NOT_A_RECIPIENT = (SEC_ERROR_BASE + 45), michael@0: SEC_ERROR_PKCS7_KEYALG_MISMATCH = (SEC_ERROR_BASE + 46), michael@0: SEC_ERROR_PKCS7_BAD_SIGNATURE = (SEC_ERROR_BASE + 47), michael@0: SEC_ERROR_UNSUPPORTED_KEYALG = (SEC_ERROR_BASE + 48), michael@0: SEC_ERROR_DECRYPTION_DISALLOWED = (SEC_ERROR_BASE + 49), michael@0: /* Fortezza Alerts */ michael@0: XP_SEC_FORTEZZA_BAD_CARD = (SEC_ERROR_BASE + 50), michael@0: XP_SEC_FORTEZZA_NO_CARD = (SEC_ERROR_BASE + 51), michael@0: XP_SEC_FORTEZZA_NONE_SELECTED = (SEC_ERROR_BASE + 52), michael@0: XP_SEC_FORTEZZA_MORE_INFO = (SEC_ERROR_BASE + 53), michael@0: XP_SEC_FORTEZZA_PERSON_NOT_FOUND = (SEC_ERROR_BASE + 54), michael@0: XP_SEC_FORTEZZA_NO_MORE_INFO = (SEC_ERROR_BASE + 55), michael@0: XP_SEC_FORTEZZA_BAD_PIN = (SEC_ERROR_BASE + 56), michael@0: XP_SEC_FORTEZZA_PERSON_ERROR = (SEC_ERROR_BASE + 57), michael@0: SEC_ERROR_NO_KRL = (SEC_ERROR_BASE + 58), michael@0: SEC_ERROR_KRL_EXPIRED = (SEC_ERROR_BASE + 59), michael@0: SEC_ERROR_KRL_BAD_SIGNATURE = (SEC_ERROR_BASE + 60), michael@0: SEC_ERROR_REVOKED_KEY = (SEC_ERROR_BASE + 61), michael@0: SEC_ERROR_KRL_INVALID = (SEC_ERROR_BASE + 62), michael@0: SEC_ERROR_NEED_RANDOM = (SEC_ERROR_BASE + 63), michael@0: SEC_ERROR_NO_MODULE = (SEC_ERROR_BASE + 64), michael@0: SEC_ERROR_NO_TOKEN = (SEC_ERROR_BASE + 65), michael@0: SEC_ERROR_READ_ONLY = (SEC_ERROR_BASE + 66), michael@0: SEC_ERROR_NO_SLOT_SELECTED = (SEC_ERROR_BASE + 67), michael@0: SEC_ERROR_CERT_NICKNAME_COLLISION = (SEC_ERROR_BASE + 68), michael@0: SEC_ERROR_KEY_NICKNAME_COLLISION = (SEC_ERROR_BASE + 69), michael@0: SEC_ERROR_SAFE_NOT_CREATED = (SEC_ERROR_BASE + 70), michael@0: SEC_ERROR_BAGGAGE_NOT_CREATED = (SEC_ERROR_BASE + 71), michael@0: XP_JAVA_REMOVE_PRINCIPAL_ERROR = (SEC_ERROR_BASE + 72), michael@0: XP_JAVA_DELETE_PRIVILEGE_ERROR = (SEC_ERROR_BASE + 73), michael@0: XP_JAVA_CERT_NOT_EXISTS_ERROR = (SEC_ERROR_BASE + 74), michael@0: SEC_ERROR_BAD_EXPORT_ALGORITHM = (SEC_ERROR_BASE + 75), michael@0: SEC_ERROR_EXPORTING_CERTIFICATES = (SEC_ERROR_BASE + 76), michael@0: SEC_ERROR_IMPORTING_CERTIFICATES = (SEC_ERROR_BASE + 77), michael@0: SEC_ERROR_PKCS12_DECODING_PFX = (SEC_ERROR_BASE + 78), michael@0: SEC_ERROR_PKCS12_INVALID_MAC = (SEC_ERROR_BASE + 79), michael@0: SEC_ERROR_PKCS12_UNSUPPORTED_MAC_ALGORITHM = (SEC_ERROR_BASE + 80), michael@0: SEC_ERROR_PKCS12_UNSUPPORTED_TRANSPORT_MODE = (SEC_ERROR_BASE + 81), michael@0: SEC_ERROR_PKCS12_CORRUPT_PFX_STRUCTURE = (SEC_ERROR_BASE + 82), michael@0: SEC_ERROR_PKCS12_UNSUPPORTED_PBE_ALGORITHM = (SEC_ERROR_BASE + 83), michael@0: SEC_ERROR_PKCS12_UNSUPPORTED_VERSION = (SEC_ERROR_BASE + 84), michael@0: SEC_ERROR_PKCS12_PRIVACY_PASSWORD_INCORRECT = (SEC_ERROR_BASE + 85), michael@0: SEC_ERROR_PKCS12_CERT_COLLISION = (SEC_ERROR_BASE + 86), michael@0: SEC_ERROR_USER_CANCELLED = (SEC_ERROR_BASE + 87), michael@0: SEC_ERROR_PKCS12_DUPLICATE_DATA = (SEC_ERROR_BASE + 88), michael@0: SEC_ERROR_MESSAGE_SEND_ABORTED = (SEC_ERROR_BASE + 89), michael@0: SEC_ERROR_INADEQUATE_KEY_USAGE = (SEC_ERROR_BASE + 90), michael@0: SEC_ERROR_INADEQUATE_CERT_TYPE = (SEC_ERROR_BASE + 91), michael@0: SEC_ERROR_CERT_ADDR_MISMATCH = (SEC_ERROR_BASE + 92), michael@0: SEC_ERROR_PKCS12_UNABLE_TO_IMPORT_KEY = (SEC_ERROR_BASE + 93), michael@0: SEC_ERROR_PKCS12_IMPORTING_CERT_CHAIN = (SEC_ERROR_BASE + 94), michael@0: SEC_ERROR_PKCS12_UNABLE_TO_LOCATE_OBJECT_BY_NAME = (SEC_ERROR_BASE + 95), michael@0: SEC_ERROR_PKCS12_UNABLE_TO_EXPORT_KEY = (SEC_ERROR_BASE + 96), michael@0: SEC_ERROR_PKCS12_UNABLE_TO_WRITE = (SEC_ERROR_BASE + 97), michael@0: SEC_ERROR_PKCS12_UNABLE_TO_READ = (SEC_ERROR_BASE + 98), michael@0: SEC_ERROR_PKCS12_KEY_DATABASE_NOT_INITIALIZED = (SEC_ERROR_BASE + 99), michael@0: SEC_ERROR_KEYGEN_FAIL = (SEC_ERROR_BASE + 100), michael@0: SEC_ERROR_INVALID_PASSWORD = (SEC_ERROR_BASE + 101), michael@0: SEC_ERROR_RETRY_OLD_PASSWORD = (SEC_ERROR_BASE + 102), michael@0: SEC_ERROR_BAD_NICKNAME = (SEC_ERROR_BASE + 103), michael@0: SEC_ERROR_NOT_FORTEZZA_ISSUER = (SEC_ERROR_BASE + 104), michael@0: SEC_ERROR_CANNOT_MOVE_SENSITIVE_KEY = (SEC_ERROR_BASE + 105), michael@0: SEC_ERROR_JS_INVALID_MODULE_NAME = (SEC_ERROR_BASE + 106), michael@0: SEC_ERROR_JS_INVALID_DLL = (SEC_ERROR_BASE + 107), michael@0: SEC_ERROR_JS_ADD_MOD_FAILURE = (SEC_ERROR_BASE + 108), michael@0: SEC_ERROR_JS_DEL_MOD_FAILURE = (SEC_ERROR_BASE + 109), michael@0: SEC_ERROR_OLD_KRL = (SEC_ERROR_BASE + 110), michael@0: SEC_ERROR_CKL_CONFLICT = (SEC_ERROR_BASE + 111), michael@0: SEC_ERROR_CERT_NOT_IN_NAME_SPACE = (SEC_ERROR_BASE + 112), michael@0: SEC_ERROR_KRL_NOT_YET_VALID = (SEC_ERROR_BASE + 113), michael@0: SEC_ERROR_CRL_NOT_YET_VALID = (SEC_ERROR_BASE + 114), michael@0: SEC_ERROR_UNKNOWN_CERT = (SEC_ERROR_BASE + 115), michael@0: SEC_ERROR_UNKNOWN_SIGNER = (SEC_ERROR_BASE + 116), michael@0: SEC_ERROR_CERT_BAD_ACCESS_LOCATION = (SEC_ERROR_BASE + 117), michael@0: SEC_ERROR_OCSP_UNKNOWN_RESPONSE_TYPE = (SEC_ERROR_BASE + 118), michael@0: SEC_ERROR_OCSP_BAD_HTTP_RESPONSE = (SEC_ERROR_BASE + 119), michael@0: SEC_ERROR_OCSP_MALFORMED_REQUEST = (SEC_ERROR_BASE + 120), michael@0: SEC_ERROR_OCSP_SERVER_ERROR = (SEC_ERROR_BASE + 121), michael@0: SEC_ERROR_OCSP_TRY_SERVER_LATER = (SEC_ERROR_BASE + 122), michael@0: SEC_ERROR_OCSP_REQUEST_NEEDS_SIG = (SEC_ERROR_BASE + 123), michael@0: SEC_ERROR_OCSP_UNAUTHORIZED_REQUEST = (SEC_ERROR_BASE + 124), michael@0: SEC_ERROR_OCSP_UNKNOWN_RESPONSE_STATUS = (SEC_ERROR_BASE + 125), michael@0: SEC_ERROR_OCSP_UNKNOWN_CERT = (SEC_ERROR_BASE + 126), michael@0: SEC_ERROR_OCSP_NOT_ENABLED = (SEC_ERROR_BASE + 127), michael@0: SEC_ERROR_OCSP_NO_DEFAULT_RESPONDER = (SEC_ERROR_BASE + 128), michael@0: SEC_ERROR_OCSP_MALFORMED_RESPONSE = (SEC_ERROR_BASE + 129), michael@0: SEC_ERROR_OCSP_UNAUTHORIZED_RESPONSE = (SEC_ERROR_BASE + 130), michael@0: SEC_ERROR_OCSP_FUTURE_RESPONSE = (SEC_ERROR_BASE + 131), michael@0: SEC_ERROR_OCSP_OLD_RESPONSE = (SEC_ERROR_BASE + 132), michael@0: /* smime stuff */ michael@0: SEC_ERROR_DIGEST_NOT_FOUND = (SEC_ERROR_BASE + 133), michael@0: SEC_ERROR_UNSUPPORTED_MESSAGE_TYPE = (SEC_ERROR_BASE + 134), michael@0: SEC_ERROR_MODULE_STUCK = (SEC_ERROR_BASE + 135), michael@0: SEC_ERROR_BAD_TEMPLATE = (SEC_ERROR_BASE + 136), michael@0: SEC_ERROR_CRL_NOT_FOUND = (SEC_ERROR_BASE + 137), michael@0: SEC_ERROR_REUSED_ISSUER_AND_SERIAL = (SEC_ERROR_BASE + 138), michael@0: SEC_ERROR_BUSY = (SEC_ERROR_BASE + 139), michael@0: SEC_ERROR_EXTRA_INPUT = (SEC_ERROR_BASE + 140), michael@0: /* error codes used by elliptic curve code */ michael@0: SEC_ERROR_UNSUPPORTED_ELLIPTIC_CURVE = (SEC_ERROR_BASE + 141), michael@0: SEC_ERROR_UNSUPPORTED_EC_POINT_FORM = (SEC_ERROR_BASE + 142), michael@0: SEC_ERROR_UNRECOGNIZED_OID = (SEC_ERROR_BASE + 143), michael@0: SEC_ERROR_OCSP_INVALID_SIGNING_CERT = (SEC_ERROR_BASE + 144), michael@0: /* new revocation errors */ michael@0: SEC_ERROR_REVOKED_CERTIFICATE_CRL = (SEC_ERROR_BASE + 145), michael@0: SEC_ERROR_REVOKED_CERTIFICATE_OCSP = (SEC_ERROR_BASE + 146), michael@0: SEC_ERROR_CRL_INVALID_VERSION = (SEC_ERROR_BASE + 147), michael@0: SEC_ERROR_CRL_V1_CRITICAL_EXTENSION = (SEC_ERROR_BASE + 148), michael@0: SEC_ERROR_CRL_UNKNOWN_CRITICAL_EXTENSION = (SEC_ERROR_BASE + 149), michael@0: SEC_ERROR_UNKNOWN_OBJECT_TYPE = (SEC_ERROR_BASE + 150), michael@0: SEC_ERROR_INCOMPATIBLE_PKCS11 = (SEC_ERROR_BASE + 151), michael@0: SEC_ERROR_NO_EVENT = (SEC_ERROR_BASE + 152), michael@0: SEC_ERROR_CRL_ALREADY_EXISTS = (SEC_ERROR_BASE + 153), michael@0: SEC_ERROR_NOT_INITIALIZED = (SEC_ERROR_BASE + 154), michael@0: SEC_ERROR_TOKEN_NOT_LOGGED_IN = (SEC_ERROR_BASE + 155), michael@0: SEC_ERROR_OCSP_RESPONDER_CERT_INVALID = (SEC_ERROR_BASE + 156), michael@0: SEC_ERROR_OCSP_BAD_SIGNATURE = (SEC_ERROR_BASE + 157), michael@0: michael@0: SEC_ERROR_OUT_OF_SEARCH_LIMITS = (SEC_ERROR_BASE + 158), michael@0: SEC_ERROR_INVALID_POLICY_MAPPING = (SEC_ERROR_BASE + 159), michael@0: SEC_ERROR_POLICY_VALIDATION_FAILED = (SEC_ERROR_BASE + 160), michael@0: /* No longer used. Unknown AIA location types are now silently ignored. */ michael@0: SEC_ERROR_UNKNOWN_AIA_LOCATION_TYPE = (SEC_ERROR_BASE + 161), michael@0: SEC_ERROR_BAD_HTTP_RESPONSE = (SEC_ERROR_BASE + 162), michael@0: SEC_ERROR_BAD_LDAP_RESPONSE = (SEC_ERROR_BASE + 163), michael@0: SEC_ERROR_FAILED_TO_ENCODE_DATA = (SEC_ERROR_BASE + 164), michael@0: SEC_ERROR_BAD_INFO_ACCESS_LOCATION = (SEC_ERROR_BASE + 165), michael@0: michael@0: SEC_ERROR_LIBPKIX_INTERNAL = (SEC_ERROR_BASE + 166), michael@0: michael@0: SEC_ERROR_PKCS11_GENERAL_ERROR = (SEC_ERROR_BASE + 167), michael@0: SEC_ERROR_PKCS11_FUNCTION_FAILED = (SEC_ERROR_BASE + 168), michael@0: SEC_ERROR_PKCS11_DEVICE_ERROR = (SEC_ERROR_BASE + 169), michael@0: michael@0: SEC_ERROR_BAD_INFO_ACCESS_METHOD = (SEC_ERROR_BASE + 170), michael@0: SEC_ERROR_CRL_IMPORT_FAILED = (SEC_ERROR_BASE + 171), michael@0: michael@0: SEC_ERROR_EXPIRED_PASSWORD = (SEC_ERROR_BASE + 172), michael@0: SEC_ERROR_LOCKED_PASSWORD = (SEC_ERROR_BASE + 173), michael@0: michael@0: SEC_ERROR_UNKNOWN_PKCS11_ERROR = (SEC_ERROR_BASE + 174), michael@0: michael@0: SEC_ERROR_BAD_CRL_DP_URL = (SEC_ERROR_BASE + 175), michael@0: michael@0: SEC_ERROR_CERT_SIGNATURE_ALGORITHM_DISABLED = (SEC_ERROR_BASE + 176), michael@0: michael@0: SEC_ERROR_LEGACY_DATABASE = (SEC_ERROR_BASE + 177), michael@0: michael@0: SEC_ERROR_APPLICATION_CALLBACK_ERROR = (SEC_ERROR_BASE + 178), michael@0: michael@0: /* Add new error codes above here. */ michael@0: SEC_ERROR_END_OF_LIST michael@0: } SECErrorCodes; michael@0: #endif /* NO_SECURITY_ERROR_ENUM */ michael@0: michael@0: #endif /* __SEC_ERR_H_ */