summaryrefslogtreecommitdiff
path: root/API-level-policy/Android.bp
blob: 0397a2fa11adee5165c346292fd2547b294fcb1e (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
//
// Copyright (C) 2021 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//      http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package {
    default_applicable_licenses: ["Android-Apache-2.0"],
}

genrule_defaults {
    name: "sepolicy_sig_gen_default",
    tool_files: [":SEPolicyKeyPem", ":SEPolicyCertPem"],
    // openssl dgst -sign com.android.sepolicy.pem -keyform PEM -sha256 -out foo.sign
    // -binary $OUT/apex/com.android.sepolicy/etc/SEPolicy-33/SEPolicy-33.zip
    cmd: "openssl dgst -sign $(location :SEPolicyKeyPem) -keyform PEM -sha256 " +
        "-out $(out) -binary $(in)"
}

genrule_defaults {
    name: "sepolicy_verity_sig_gen_default",
    tools: ["fsverity"],
    tool_files: [":SEPolicyKeyPem", ":SEPolicyCertPem"],
    // Use fsverity tool to generate the signature file which
    // will be stored in the apex.
    // https://git.kernel.org/pub/scm/linux/kernel/git/ebiggers/fsverity-utils.git/tree/README.md
    cmd: "$(location fsverity) sign $(in) $(out) " +
        "--key=$(location :SEPolicyKeyPem) " +
        "--cert=$(location :SEPolicyCertPem) " +
        "> /dev/null",
}

genrule_defaults {
    name: "sepolicy_create_zip_gen_default",
    tools: ["soong_zip"],
    cmd: "mkdir $(genDir)/files && " +
        "cp $(in) $(genDir)/files && " +
        "$(location soong_zip) -o $(out) -C $(genDir)/files -D $(genDir)/files",
}

filegroup {
    name: "sepolicy_proto_def",
    srcs: [ "sepolicy.proto" ],
}

genrule_defaults {
    name: "sepolicy_info_bin_gen_default",
    tools: ["aprotoc"],
    tool_files: [ ":sepolicy_proto_def" ],
    cmd: "$(location aprotoc) --encode=com.android.sepolicy.SepolicyInfo " +
        "-I $$(dirname $(location :sepolicy_proto_def)) $(location :sepolicy_proto_def) < $(in) > $(out)",
}

prebuilt_etc {
    name: "sepolicy_apex_test_file",
    src: "sepolicy_apex_test_file",
    filename: "apex_test",
    installable: false,
}