summaryrefslogtreecommitdiff
path: root/Android.bp
blob: ae681e4039c3918c76b399f1021bf3c667b919fb (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
// Copyright (C) 2019 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_team: "trendy_team_android_permissions",
    default_applicable_licenses: ["Android-Apache-2.0"],
    default_visibility: [":__subpackages__"],
}

apex {
    name: "com.android.permission",
    defaults: ["com.android.permission-defaults"],
    manifest: "apex_manifest.json",
    compat_configs: [
        "framework-permission-s-compat-config"
    ],
}

apex_defaults {
    name: "com.android.permission-defaults",
    defaults: ["r-launched-apex-module"],
    bootclasspath_fragments: ["com.android.permission-bootclasspath-fragment"],
    systemserverclasspath_fragments: ["com.android.permission-systemserverclasspath-fragment"],
    prebuilts: [
        "current_sdkinfo",
    ],
    key: "com.android.permission.key",
    certificate: ":com.android.permission.certificate",
    apps: [
        "PermissionController",
        "SafetyCenterResources",
    ],
    // Indicates that pre-installed version of this apex can be compressed.
    // Whether it actually will be compressed is controlled on per-device basis.
    compressible: true,
}

apex_key {
    name: "com.android.permission.key",
    public_key: "com.android.permission.avbpubkey",
    private_key: "com.android.permission.pem",
}

android_app_certificate {
    name: "com.android.permission.certificate",
    certificate: "com.android.permission",
}

sdk {
    name: "permission-module-sdk",
    apexes: [
        // Adds exportable dependencies of the APEX to the sdk,
        // e.g. *classpath_fragments.
        "com.android.permission",
    ],
}

// Encapsulate the contributions made by the com.android.permission to the bootclasspath.
bootclasspath_fragment {
    name: "com.android.permission-bootclasspath-fragment",
    contents: [
        "framework-permission",
        "framework-permission-s",
    ],
    apex_available: ["com.android.permission"],

    // The bootclasspath_fragments that provide APIs on which this depends.
    fragments: [
        {
            apex: "com.android.art",
            module: "art-bootclasspath-fragment",
        },
    ],

    // Additional stubs libraries that this fragment's contents use which are
    // not provided by another bootclasspath_fragment.
    additional_stubs: [
        "android-non-updatable",
    ],

    hidden_api: {
        // The following packages contain classes from other modules on the
        // bootclasspath. That means that the hidden API flags for this module
        // has to explicitly list every single class this module provides in
        // that package to differentiate them from the classes provided by other
        // modules. That can include private classes that are not part of the
        // API.
        split_packages: [
            "android.permission",
        ],

        // The following packages and all their subpackages currently only
        // contain classes from this bootclasspath_fragment. Listing a package
        // here won't prevent other bootclasspath modules from adding classes in
        // any of those packages but it will prevent them from adding those
        // classes into an API surface, e.g. public, system, etc.. Doing so will
        // result in a build failure due to inconsistent flags.
        package_prefixes: [
            "android.app.role",
            "android.permission.jarjar",
            "android.safetycenter",
            "android.safetylabel",
        ],
    },
}

// Encapsulate the contributions made by the com.android.permission to the systemserverclasspath.
systemserverclasspath_fragment {
    name: "com.android.permission-systemserverclasspath-fragment",
    contents: ["service-permission"],
    apex_available: ["com.android.permission"],
}