1/*
2 * Copyright (C) 2020 Google LLC
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 *      http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16syntax = "proto2";
17
18package com.google.carrier;
19
20option java_multiple_files = true;
21option java_outer_classname = "CarrierSettingsProtos";
22
23// Settings of one carrier, including apns and configs
24// This is the payload to be delivered from server
25message CarrierSettings {
26  // A unique canonical carrier name
27  optional string canonical_name = 1;
28
29  // Version number of current carrier’s settings
30  optional int64 version = 2;
31
32  // Carrier APNs
33  optional CarrierApns apns = 3;
34
35  // Carrier configs
36  optional CarrierConfig configs = 4;
37
38  reserved 5;
39
40  // Vendor carrier configs
41  optional VendorConfigs vendor_configs = 6;
42}
43
44// A collection of multiple carriers’ settings
45message MultiCarrierSettings {
46  // Version number
47  optional int64 version = 1;
48
49  // List of CarrierSettings
50  repeated CarrierSettings setting = 2;
51}
52
53// An access point name (aka. APN) entry
54message ApnItem {
55  // The name of APN, map to xml apn "carrier" attribute
56  // eg. Verizon Internet, may visible to user in Settings
57  optional string name = 1;
58  // The value of APN, eg. send to modem for data call. map to xml
59  // "apn" attribute, eg. vzwinternet
60  optional string value = 2;
61
62  // Next two fields type and bearer_bitmask affect how APN is selected by
63  // platform. eg. type means APN capability and bearer_bitmask specifies
64  // which RATs apply.
65  // Note mcc/mnc and mvno data doesn't belong to this proto because they
66  // define a carrier.
67  // APN types as defined in Android code PhoneConstants.java
68  enum ApnType {
69    ALL = 0;      // this APN can serve all kinds of data connections
70    DEFAULT = 1;  // internet data
71    MMS = 2;
72    SUPL = 3;
73    DUN = 4;
74    HIPRI = 5;
75    FOTA = 6;
76    IMS = 7;
77    CBS = 8;
78    IA = 9;  // Initial attach
79    EMERGENCY = 10;
80    XCAP = 11;
81    UT = 12;
82    RCS = 13;
83  }
84  repeated ApnType type = 3;
85
86  // Network types that this APN applies to, separated by "|". A network type
87  // is represented as an integer defined in TelephonyManager.NETWORK_TYPE_*.
88  // Default value "0" means all network types.
89  optional string bearer_bitmask = 4 [default = "0"];
90
91  // Below are all parameters for the APN
92  // APN server / auth parameters.
93  optional string server = 5;
94  optional string proxy = 6;
95  optional string port = 7;
96  optional string user = 8;
97  optional string password = 9;
98  optional int32 authtype = 10 [default = -1];
99
100  // MMS configuration.
101  optional string mmsc = 11;
102  optional string mmsc_proxy = 12;
103  optional string mmsc_proxy_port = 13;
104
105  // Protocols allowed to connect to the APN.
106  enum Protocol {
107    IP = 0;
108    IPV6 = 1;
109    IPV4V6 = 2;
110    PPP = 3;
111  }
112  optional Protocol protocol = 14 [default = IP];
113  optional Protocol roaming_protocol = 15 [default = IP];
114
115  // MTU for the connections.
116  optional int32 mtu = 16 [default = 0];
117  // An ID used to sync the APN in modem.
118  optional int32 profile_id = 17;
119  // Max connections.
120  optional int32 max_conns = 18 [default = 0];
121  // The wait time required between disconnecting and connecting, in seconds.
122  optional int32 wait_time = 19 [default = 0];
123  // The time to limit max connection, in seconds.
124  optional int32 max_conns_time = 20 [default = 0];
125  reserved 21;
126  // Whether to be persisted to modem.
127  optional bool modem_cognitive = 22 [default = false];
128  // Whether visible in APN settings.
129  optional bool user_visible = 23 [default = true];
130  // Whether editable in APN settings.
131  optional bool user_editable = 24 [default = true];
132
133  // If > 0: when an APN becomes a preferred APN on user/framework
134  // selection, other APNs with the same apn_set_id will also be preferred
135  // by framework when selecting APNs.
136  optional int32 apn_set_id = 25 [default = 0];
137
138  // The skip 464xlat flag. Flag works as follows.
139  // SKIP_464XLAT_DEFAULT: the APN will skip 464xlat only if the APN has type
140  //                       IMS and does not support INTERNET which has type
141  //                       DEFAULT or HIPRI.
142  // SKIP_464XLAT_DISABLE: the APN will NOT skip 464xlat
143  // SKIP_464XLAT_ENABLE: the APN will skip 464xlat
144  enum Xlat {
145    SKIP_464XLAT_DEFAULT = 0;
146    SKIP_464XLAT_DISABLE = 1;
147    SKIP_464XLAT_ENABLE = 2;
148  }
149  optional Xlat skip_464xlat = 26 [default = SKIP_464XLAT_DEFAULT];
150}
151
152// A collection of all APNs for a carrier
153message CarrierApns {
154  reserved 1;
155
156  // APNs belong to this carrier
157  repeated ApnItem apn = 2;
158}
159
160// An array of text
161message TextArray {
162  repeated string item = 1;
163}
164
165// An array of int
166message IntArray {
167  repeated int32 item = 1;
168}
169
170// Carrier configs
171message CarrierConfig {
172  reserved 1, 3;
173
174  // Key-Value pair as a config entry
175  message Config {
176    optional string key = 1;
177
178    oneof value {
179      string text_value = 2;
180      int32 int_value = 3;
181      int64 long_value = 4;
182      bool bool_value = 5;
183      TextArray text_array = 6;
184      IntArray int_array = 7;
185      CarrierConfig bundle = 8;
186      double double_value = 9;
187    }
188  }
189
190  // Key-value pairs, holding all config entries
191  repeated Config config = 2;
192}
193
194// The configs of one vendor client.
195message VendorConfigClient {
196  // Name of the client for which the configuration items need to
197  // be stored
198  required string name = 1;
199
200  // Binary blob containing the configuration. The format
201  // of the configuration depends on the specific client.
202  // For some clients, the proto representation of {@link VendorConfigData}
203  // defined in vendorconfigdata.proto is used.
204  optional bytes value = 2;
205
206  // Range of extensions. The extensions from 100 to 1000 are reserved for
207  // Google's internal usage.
208  extensions 100 to 5000;
209}
210
211// A collection of configs from vendor clients.
212message VendorConfigs {
213  reserved 1;
214
215  // Configuration
216  repeated VendorConfigClient client = 2;
217}
218