summaryrefslogtreecommitdiff
path: root/src/mongo/crypto/SConscript
blob: 3271c7b0b732d01d5fb66dbeff87e8314b52d30f (plain)
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
# -*- mode: python -*-

Import([
    'env',
    'get_option',
    'ssl_provider',
])

env = env.Clone()

env.Library(
    'sha1_block',
    source=['sha1_block.cpp'],
    LIBDEPS=[
        '$BUILD_DIR/mongo/base',
        '$BUILD_DIR/mongo/util/secure_compare_memory',
    ],
)

env.Library(
    'sha256_block',
    source=['sha256_block.cpp'],
    LIBDEPS=[
        '$BUILD_DIR/mongo/base',
        '$BUILD_DIR/mongo/util/secure_compare_memory',
    ],
)

cryptoEnv = env.Clone()

if "tom" in env["MONGO_CRYPTO"]:
    cryptoEnv.InjectThirdParty(libraries=['tomcrypt'])
    cryptoEnv.Append(CPPDEFINES=[
        'LTC_NO_PROTOTYPES',
    ])

cryptoEnv.Library(
    target='sha_block_${MONGO_CRYPTO}',
    source=['sha_block_${MONGO_CRYPTO}.cpp'],
    LIBDEPS=[
        '$BUILD_DIR/mongo/base',
        'sha1_block',
        'sha256_block',
    ],
    LIBDEPS_PRIVATE=[
        '$BUILD_DIR/third_party/shim_tomcrypt' if "tom" in env["MONGO_CRYPTO"] else [],
    ],
)

cryptoEnv.Library(
    target='symmetric_crypto',
    source=[
        'symmetric_crypto.cpp',
        'symmetric_crypto_${MONGO_CRYPTO}.cpp',
        'symmetric_key.cpp',
    ],
    LIBDEPS=[
        '$BUILD_DIR/mongo/base/secure_allocator',
        '$BUILD_DIR/mongo/util/secure_zero_memory',
    ],
    LIBDEPS_PRIVATE=[
        '$BUILD_DIR/third_party/shim_tomcrypt' if "tom" in env["MONGO_CRYPTO"] else [],
    ],
)

env.Library(
    target="aead_encryption",
    source=[
        "aead_encryption.cpp",
    ],
    LIBDEPS=[
        'fle_fields',
        'sha_block_${MONGO_CRYPTO}',
        'symmetric_crypto',
    ],
)

env.Library(
    target='encrypted_field_config',
    source=[
        'encryption_fields.idl',
        'encryption_fields_validation.cpp',
    ],
    LIBDEPS=[
        '$BUILD_DIR/mongo/db/pipeline/value_idl',
    ],
    LIBDEPS_PRIVATE=[
        '$BUILD_DIR/mongo/db/common',
        '$BUILD_DIR/mongo/db/server_base',
    ],
)

fleCryptoEnv = env.Clone()
fleCryptoEnv.InjectThirdParty(libraries=['libmongocrypt'])
fleCryptoEnv.InjectThirdParty(libraries=['libbson'])

fleCryptoEnv.Library(
    target="fle_crypto",
    source=[
        "encryption_fields_util.cpp",
        "fle_crypto.cpp",
        "fle_options.idl",
        "fle_tags.cpp",
        "fle_stats.cpp",
        "fle_stats.idl",
    ],
    LIBDEPS=[
        '$BUILD_DIR/mongo/base/secure_allocator',
        '$BUILD_DIR/mongo/db/common',
    ],
    LIBDEPS_PRIVATE=[
        '$BUILD_DIR/mongo/bson/util/bson_extract',
        '$BUILD_DIR/mongo/db/commands/server_status_core',
        '$BUILD_DIR/mongo/db/exec/document_value/document_value',
        '$BUILD_DIR/mongo/db/query/query_knobs',
        '$BUILD_DIR/mongo/db/server_base',
        '$BUILD_DIR/mongo/idl/cluster_server_parameter',
        '$BUILD_DIR/mongo/shell/kms_idl',
        '$BUILD_DIR/mongo/util/testing_options',
        '$BUILD_DIR/third_party/shim_libmongocrypt',
        'aead_encryption',
        'encrypted_field_config',
        'fle_fields',
        'sha_block_${MONGO_CRYPTO}',
    ],
)

env.Library(
    target="fle_fields",
    source=[
        "fle_field_schema.idl",
        "fle_fields_util.cpp",
    ],
    LIBDEPS=[
        '$BUILD_DIR/mongo/idl/idl_parser',
        "encrypted_field_config",
    ],
)

env.CppUnitTest(
    target='crypto_test',
    source=[
        'aead_encryption_test.cpp',
        'encryption_fields_util_test.cpp',
        'encryption_fields_validation_test.cpp',
        'jwt_test.cpp' if ssl_provider == 'openssl' else [],
        'fle_crypto_test.cpp',
        'fle_crypto_test_vectors.cpp',
        'fle_stats_test.cpp',
        'mechanism_scram_test.cpp',
        'sha1_block_test.cpp',
        'sha256_block_test.cpp',
        'sha512_block_test.cpp',
        'symmetric_crypto_test.cpp',
    ],
    LIBDEPS=[
        '$BUILD_DIR/mongo/base',
        '$BUILD_DIR/mongo/base/secure_allocator',
        '$BUILD_DIR/mongo/db/concurrency/lock_manager',
        '$BUILD_DIR/mongo/shell/kms_idl',
        '$BUILD_DIR/mongo/util/net/http_client_impl',
        '$BUILD_DIR/mongo/util/net/openssl_init' if ssl_provider == 'openssl' else [],
        '$BUILD_DIR/mongo/util/testing_options',
        'aead_encryption',
        'encrypted_field_config',
        'fle_crypto',
        'jwt',
        'sha_block_${MONGO_CRYPTO}',
    ],
)

env.Library(
    target='jwt',
    source=[
        'jwks_fetcher_impl.cpp',
        'jwk_manager.cpp',
        'jwt_types.idl',
        'jws_validated_token.cpp',
        'jws_validator_{}.cpp'.format(ssl_provider),
    ],
    LIBDEPS=[
        '$BUILD_DIR/mongo/base',
    ],
    LIBDEPS_PRIVATE=[
        '$BUILD_DIR/mongo/client/sasl_client',
        '$BUILD_DIR/mongo/db/auth/oidc_protocol',
        '$BUILD_DIR/mongo/db/commands/test_commands_enabled',
        '$BUILD_DIR/mongo/idl/idl_parser',
        '$BUILD_DIR/mongo/util/net/http_client_impl',
    ],
)

if ssl_provider == 'openssl':
    env.CppUnitTest(
        target='jws_validator_test',
        source=[
            'jws_validator_test.cpp',
            'jws_validated_token_test.cpp',
        ],
        LIBDEPS=[
            '$BUILD_DIR/mongo/base',
            '$BUILD_DIR/mongo/util/net/openssl_init',
            'jwt',
        ],
    )

env.Benchmark(
    target='crypto_bm',
    source=[
        'crypto_bm.cpp',
    ],
    LIBDEPS=[
        'fle_crypto',
        'sha_block_${MONGO_CRYPTO}',
    ],
)