Операторы могут обновлять информацию об имени точки доступа (APN) и параметры конфигурации, специфичные для оператора ( CarrierConfig ), в проекте Android Open Source Project (AOSP).
Аккаунт Google с вашим корпоративным адресом электронной почты
Чтобы обновить информацию APN или CarrierConfig, вам необходимо отправить запрос, используя учетную запись Google с активным корпоративным адресом электронной почты (например, запрос на обновление APN от компании Acme должен поступать с такого адреса электронной почты, как foobar@acme.com ).
Если у вас нет учетной записи Google, связанной с вашим корпоративным адресом электронной почты, выйдите из всех учетных записей Gmail в своем браузере (мы рекомендуем использовать функцию приватного просмотра, например окно в режиме инкогнито, чтобы избежать путаницы с другими вашими учетными записями), а затем создайте учетную запись Google с вашим корпоративным адресом электронной почты .
Подготовьте локальную среду разработки
Если вы никогда раньше не отправляли код в AOSP, вам необходимо инициализировать среду сборки, ознакомиться с инструментами и понять, как отправлять исправления:
Кроме того, мы настоятельно рекомендуем вам использовать Google Issue Tracker для отслеживания изменений.
Сообщить об ошибке
- Перейдите на сайт issuetracker.google.com и войдите в систему, используя свой корпоративный адрес электронной почты (см. раздел Учетная запись Google с вашим корпоративным адресом электронной почты ).
- После входа в систему нажмите «Создать задачу» в левой части экрана.
- В Component выберите Android Public Tracker > Framework.
- Продолжайте обновлять APN или CarrierConfig , в зависимости от ситуации, чтобы ввести заголовок и описание.
Ошибка APN
Установите атрибуты ошибки следующим образом:
Название: Добавить / Изменить / Удалить APN для CarrierXYZ
Описание: Добавьте подробное описание запрашиваемых вами изменений, включая сами настройки APN.
Ошибка CarrierConfig
Установите атрибуты ошибки следующим образом:
Название: Изменения конфигурации для CarrierXYZ
Описание: Добавьте подробное описание запрашиваемых вами изменений.
Внести изменения
Чтобы внести изменения:
- Определите, какой файл следует изменить.
- Внесите изменения в файл.
- Зафиксируйте изменения в локальном репозитории, следуя инструкциям по отправке исправлений , обращая внимание на правила отправки сообщений о фиксации, включая рекомендуемый формат.
- После того, как вы внесете изменения в свою личную историю, загрузите их в Gerrit с помощью команды
repo upload
. - После успешной загрузки repo предоставляет URL новой страницы на Gerrit. Используйте этот URL для:
- Посмотрите свой патч на сервере отзывов
- Добавить комментарии
- Запросите конкретных рецензентов для вашего патча
Синтаксис APN
Название проекта Android - устройство/пример
Имя(я) файла - etc/apns-full-conf.xml (основная ссылка Google Git )
Файл содержит настройки APN в формате XML и служит в качестве примера, поэтому никаких изменений в поведении устройств Android не происходит.
Типичная конфигурация APN выглядит так:
<apn carrier="CarrierXYZ" mcc="123" mnc="123" apn="carrierxyz" type="default,supl,mms,ims,cbs" mmsc="http://mms.carrierxyz.com" mmsproxy="0.0.0.0" mmsport="80" bearer_bitmask="4|5|6|7|8|12" />
Тестирование
- Подключите любое Android-устройство, к которому у вас есть root-доступ.
- Добавьте настройки в /etc/apns-conf.xml.
- Сбросьте настройки APN.
- В настройках APN убедитесь, что профили загружены правильно.
- Для каждого профиля проверьте подключение к данным, точку доступа Wi-Fi и MMS, чтобы убедиться, что они работают правильно.
Сообщение о фиксации
[Example - "Add CarrierXYZ apns to sample apns"] Bug: [Issue ID from Google Issue Tracker] Test: No change to behavior as this is only a sample file
Образец CL
Пример CL см. в разделе «Примеры BICS APN» .
Синтаксис CarrierConfig
Название проекта - platform/packages/apps/CarrierConfig
Имя(я) файла - assets/carrier_config_
Определите соответствующие файлы XML в папке assets по соответствующим кортежам MCC/MNC. Файл содержит объект конфигурации оператора в формате XML. Имена атрибутов определяются как ключи в CarrierConfigManager , а тип значения (int/string/bool) указывается суффиксами.
Типичные атрибуты int/string/bool выглядят следующим образом:
<int name="vvm_port_number_int" value="5499" /> <string name="vvm_type_string">vvm_type_omtp</string > <boolean name="vvm_cellular_data_required_bool" value="true" />
Сообщение о фиксации
[Example - "Add VVM settings for CarrierXYZ"] [Example - "Updated <mccmnc> carrier config file to include VVM settings as defined by CarrierXYZ."] Bug: [Issue ID from Google Issue Tracker] Test: [Testing notes]
Образец CL
Пример CL см. в обновленном файле конфигурации оператора .
Запросить отзыв
Чтобы запросить обзор:
- Перейдите по URL-адресу Gerrit вашего изменения и добавьте android-carrier-config-review@google.com в качестве рецензента.
- Вы также можете добавить свой контакт Google в список копий на Gerrit.
- Для отслеживания вы можете изменить ответственного за проблему на android-carrier-config-review@google.com .
После того, как отправка проходит процесс проверки и верификации, Gerrit автоматически объединяет изменение в общедоступном репозитории. Другие пользователи могут запустить repo sync
, чтобы перенести обновление в свой локальный клиент.