summaryrefslogtreecommitdiffstats
path: root/security/apps/moz.build
blob: ea75973f8be81535c4c02cd00f975826dcfb8ce8 (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
# -*- Mode: python; indent-tabs-mode: nil; tab-width: 40 -*-
# vim: set filetype=python:
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.

with Files("**"):
    BUG_COMPONENT = ("Core", "Security: PSM")

UNIFIED_SOURCES += [
    "AppSignatureVerification.cpp",
    "AppTrustDomain.cpp",
]

include("/ipc/chromium/chromium-config.mozbuild")

FINAL_LIBRARY = "xul"

LOCAL_INCLUDES += [
    "/security/certverifier",
    "/security/manager/ssl",
    "/third_party/rust/cose-c/include",
]

DEFINES["NSS_ENABLE_ECC"] = "True"
for var in ("DLL_PREFIX", "DLL_SUFFIX"):
    DEFINES[var] = '"%s"' % CONFIG[var]

if CONFIG["CC_TYPE"] in ("clang", "gcc"):
    CXXFLAGS += [
        "-Wextra",
    ]

    # Gecko headers aren't warning-free enough for us to enable these warnings.
    CXXFLAGS += [
        "-Wno-unused-parameter",
    ]

test_ssl_path = "/security/manager/ssl/tests/unit"

headers_arrays_certs = [
    (
        "xpcshell.inc",
        "xpcshellRoot",
        test_ssl_path + "/test_signed_apps/xpcshellTestRoot.der",
    ),
    ("addons-public.inc", "addonsPublicRoot", "addons-public.crt"),
    (
        "addons-public-intermediate.inc",
        "addonsPublicIntermediate",
        "addons-public-intermediate.crt",
    ),
    ("addons-stage.inc", "addonsStageRoot", "addons-stage.crt"),
]

for header, array_name, cert in headers_arrays_certs:
    GeneratedFile(
        header, script="gen_cert_header.py", entry_point=array_name, inputs=[cert]
    )