1
10
13
14
20
21
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
97
98
99
100
101
102
103
106
109
112
115
119
120
127
128
129
130
134
135
136
140
141
142
143
144
145
146
...
...
...
#define NX_SECURE_SOURCE_CODE
#include "nx_secure_x509.h"
...
...
UINT _nx_secure_x509_store_certificate_add(NX_SECURE_X509_CERT *certificate,
NX_SECURE_X509_CERTIFICATE_STORE *store, UINT location)
{
UINT status;
NX_SECURE_X509_CERT **store_ptr = NX_CRYPTO_NULL;
UINT duplicates_ok = NX_CRYPTO_FALSE;
if (certificate == NX_CRYPTO_NULL || store == NX_CRYPTO_NULL)
{
#ifdef NX_CRYPTO_STANDALONE_ENABLE
return(NX_CRYPTO_PTR_ERROR);
#else
return(NX_PTR_ERROR);
#endif
}if (certificate == NX_CRYPTO_NULL || store == NX_CRYPTO_NULL) { ... }
status = NX_SECURE_X509_SUCCESS;
switch (location)
{
case NX_SECURE_X509_CERT_LOCATION_LOCAL:
store_ptr = &store -> nx_secure_x509_local_certificates;
break;case NX_SECURE_X509_CERT_LOCATION_LOCAL:
case NX_SECURE_X509_CERT_LOCATION_REMOTE:
store_ptr = &store -> nx_secure_x509_remote_certificates;
break;case NX_SECURE_X509_CERT_LOCATION_REMOTE:
case NX_SECURE_X509_CERT_LOCATION_TRUSTED:
store_ptr = &store -> nx_secure_x509_trusted_certificates;
break;case NX_SECURE_X509_CERT_LOCATION_TRUSTED:
case NX_SECURE_X509_CERT_LOCATION_EXCEPTIONS:
store_ptr = &store -> nx_secure_x509_certificate_exceptions;
break;case NX_SECURE_X509_CERT_LOCATION_EXCEPTIONS:
case NX_SECURE_X509_CERT_LOCATION_FREE:
store_ptr = &store -> nx_secure_x509_free_certificates;
duplicates_ok = NX_CRYPTO_TRUE;
break;case NX_SECURE_X509_CERT_LOCATION_FREE:
case NX_SECURE_X509_CERT_LOCATION_NONE:
default:
#ifdef NX_CRYPTO_STANDALONE_ENABLE
status = NX_CRYPTO_INVALID_PARAMETER;
#else
status = NX_INVALID_PARAMETERS;
#endif
break;default
}switch (location) { ... }
if (certificate -> nx_secure_x509_cert_identifier != 0)
{
duplicates_ok = NX_CRYPTO_TRUE;
}if (certificate -> nx_secure_x509_cert_identifier != 0) { ... }
if (status)
{
return(status);
}if (status) { ... }
status = _nx_secure_x509_certificate_list_add(store_ptr, certificate, duplicates_ok);
return(status);
}{ ... }