История изменений

AppMetrica SDK

Версия 6.5.0

Релиз 26 апреля 2024 г.

Версия 6.4.0

Релиз 11 апреля 2024 г.

  • Добавлена поддержка автоматического получения impression level revenue data из источников: Ironsource V7, Fyber V3.
  • Исправлена ошибка, которая выводилась в системный лог:
    E ActivityThread: Failed to find provider info for com.yandex.preinstallsatellite.appmetrica.provider
    

Версия 6.3.0

Релиз 18 марта 2024 г.

  • Добавлены дополнительная валидация формата UUID и восстановление некорректного значения UUID.
  • Улучшен алгоритм детекта ANR — теперь ANR фиксируется только в том случае, если за отведенное время на главном потоке не смог выполниться единственный Runnable. Алгоритм находит “тяжелые“ задачи, приводящие к зависанию главного потока. Ранее детект ANR срабатывал, когда на главном потоке исполнялось большое количество небольших Runnable — в таких ситуациях стектрейс ANR обычно был неинформативен и малополезен.
  • Теперь в результате подвисания одного Runnable будет формироваться один ANR отчет. Это уменьшит количество отчетов об ANR, но повысит их полезность.
  • Исправлен возможный ANR at io.appmetrica.analytics.internal.AppMetricaService.onCreate (issue#3).
  • Исправлено возможное падение org.json.JSONException: Forbidden numeric value: NaN при отправке external атрибуций (AppMetrica#reportExternalAttribution(...)).

Версия 6.2.1

Релиз 26 января 2024 г.

  • Исправлена ошибка в сериализации внешних атрибуций.

Версия 6.2.0

Релиз 22 января 2024 г.

  • Добавлен метод AppMetrica.reportExternalAttribution для отправки атрибуций из сторонних библиотек. Подробности в статье Импорт атрибуций из других SDK.
  • Исправлена проблема, которая приводила к тому, что не выводились логи о сохранении и отправке событий на сервер.

Версия 6.1.0

Релиз 28 ноября 2023 г.

  • Увеличен buildToolsVersion до 34.0.0.
  • Увеличен targetSdkVersion и compileSdkVersion до 34.
  • Обновлена версия kotlin-плагина до org.jetbrains.kotlin:kotlin-gradle-plugin:1.6.21.
  • Поддержан автосбор покупок и подписок, совершаемых через библиотеку com.android.billingclient:billing:6.0.0. Удален автосбор покупок и подписок, совершаемых через библиотеку com.android.billingclient:billing:4.+. Теперь автосбор покупок и подписок доступен для версий com.android.billingclient:billing:5.0.0 и выше.
  • Исправлен возможный deadlock at io.appmetrica.analytics.networktasks.internal.NetworkCore.onDestroy.

Версия 6.0.0

Релиз 13 сентября 2023 г.

  • Обновлены идентификатор библиотеки, корневой пакет и API. Подробнее в инструкции по миграции.
  • Удалена интеграция с breakpad. Сейчас используется только Crashpad. Для отлова нативных крэшей нужно использовать зависимость io.appmetrica.analytics:analytics-ndk-crashes:3.0.0. Подробнее в разделе про нативные крэши.
  • В модуле io.appmetrica.analytics:analytics-ndk-crashes обновлен крэшпад до коммита 9158eb7caa811b684c6bec7f9e9b5f52389d0ce0.
  • Разрешение com.google.android.gms.permission.AD_ID перемещено в модуль io.appmetrica.analytics:analytics-identifiers.
  • Исправлен возможный warning при установке и запуске приложения Class io.appmetrica.analytics.impl.ob.Zh failed lock verification and will run slower и аналогичные ему.
  • Исправлен возможный ANR at io.appmetrica.analytics.impl.ob.p3$b.onServiceConnected(SourceFile:2).
  • Работа с гео вынесена в отдельную зависимость: io.appmetrica.analytics:analytics-location. Теперь при необходимости можно отказаться от сбора координат AppMetrica SDK на этапе сборки приложения. Это может быть необходимо для отдельных категорий приложений в соответствии с политиками Google Play. Подробности в документации.
  • Поддержан API для получения различных идентификаторов AppMetrica SDK (DeviceId, DeviceIdHash, UUID) — метод AppMetrica#requestStartupParams. Подробности в документации.
  • Поддержан API для указания типа устройства (телефон, планшет, ТV, авто). Подробности в документации.

Версия 5.3.0

Релиз 3 марта 2023 г.

  • Исправлен возможный warning при установке и запуске приложения Class com.yandex.metrica.impl.ob.Zh failed lock verification and will run slower и аналогичные.
  • Исправлен возможный ANR at com.yandex.metrica.impl.ob.p3$b.onServiceConnected(SourceFile:2).
  • Исправлены ошибки и повышена стабильность.

Версия 5.2.0

Релиз 19 сентября 2022 г.

  • Добавлен API AdRevenue для передачи доходов рекламной монетизации на уровне показа (Impression-Level Revenue Data):
    • классы AdRevenue, AdRevenue.Builder.
    • Методы reportAdRevenue(AdRevenue adRevenue) в классе YandexMetrica, reportAdRevenue(AdRevenue adRevenue) в интерфейсе IReportet.
    • перечисление AdType.
  • Версия targetSdkVersion = 33.

Версия 5.0.1

Релиз 29 июля 2022 г.

  • Исправлена проблема, которая могла приводить к повторным ложным установкам.

Версия 5.0.0

Релиз 20 мая 2022 г.

Примечание

Начиная с версии AppMetrica Android SDK 5.0.0 и выше при переустановке приложения на смартфоне меняется appmetrica_device_id. Это обусловлено новыми политиками Google. Подробности в документации.

  • Получение рекламных идентификаторов вынесено в отдельную библиотеку com.yandex.android:mobmetricalib-identifiers. Подробнее в разделе Получение рекламных идентификаторов.
  • По умолчанию выключен признак отправки информации о локации устройства. Чтобы включить отправку локации с событиями используйте один из методов: withLocationTracking(boolean enabled) или setLocationTracking(boolean enabled).
  • Добавлены @NonNull-аннотации для аргументов методов интерфейса DeferredDeeplinkParametersListener.
  • Метод reportNativeCrash устарел и в будущих версиях будет удален.

Версия 4.2.0

Релиз 17 февраля 2022 г.

  • Добавлен новый API для отслеживания крэшей и ошибок из произвольных плагинов.

    Интерфейсы:

    • YandexMetricaPlugins;
    • IPluginReporter.

    Классы:

    • PluginErrorDetails;
    • PluginErrorDetails.Builder;
    • StackTraceItem;
    • StackTraceItem.Builder.
  • Поддержан даунгрейд на версию 4.2.0 и выше с сохранением важных данных: идентификаторов устройства и т. д. Использовать даунгрейд не рекомендуется, это может привести к потере и искажению данных. Повторная атрибуция для таких пользователей не произойдет.

  • Добавлена поддержка Google Play Billing Library версии 4.0.0. Поддержка версий 3.x продолжается.

  • В методе DeferredDeeplinkParametersListener аргумент referrer стал @NonNull. В случае его отсутствия придет пустая строка.

  • Убрали определение ROOT-статуса на устройствах с Android 12 и выше. На текущий момент все устройства с Android 12 будут считаться устройствами без ROOT-доступа.

  • Исправлены ошибки и повышена стабильность:

    • Исправлен возможный крэш при попытке подключения к сервису MetricaService:
      Process: com.yandex :Metrica java.lang.RuntimeException: Unable to bind to service com.yandex.metrica.MetricaService Caused by: java.lang.IllegalArgumentException at android.os.Parcel.nativeAppendFrom(Native Method).
      
    • Исправлен возможный ANR в процессе:
      Metrica: at com.yandex.metrica.impl.ob.jg.a (jg.java) at com.yandex.metrica.MetricaService.onConfigurationChanged(MetricaService.java:2)
      
    • Исправлен возможный крэш:
      java.lang.NullPointerException: Attempt to read from null array at com.yandex.metrica.impl.ob.tz.a
      

Версия 4.1.1

Релиз 17 декабря 2021 г.

  • Добавлено разрешение com.google.android.gms.permission.AD_ID. Подробности читайте в документации.
  • В DeferredDeeplinkListener.Error и DeferredDeeplinkParametersListener.Error добавлено значение NO_REFERRER. Добавлена предварительная поддержка App Set ID для получения реферрера из Google Play (зависимость com.google.android.gms:play-services-appset:16.0.0).
  • Поддержана оптимизация SDK из-за исправления возможных VerifyError при инициализации классов.
  • Отключен сбор mac адресов.

Версия 4.0.0

Релиз 20 сентября 2021 г.

  • Google Play Install Referrer через BroadcastReceiver больше не поддерживается:

    • удален из AndroidManifest MetricaEventHandler;
    • удален метод YandexMetrica#registerReferrerBroadcastReceivers;
    • удален флаг YandexMetricaConfig#installedAppCollecting;
    • удалены методы YandexMetricaConfig.Builder#withInstalledAppCollecting.
  • Добавлен метод YandexMetricaConfig.Builder#withSessionsAutoTrackingEnabled(boolean enabled) для автоматического отслеживания сессий.

  • Добавлен метод revenueAutoTrackingEnabled для автоматического сбора данных по in-app покупкам.

  • Поддержана публикация ".module" файла для Google Play SDK Console.

  • Реализован и включен по умолчанию автотрекинг диплинков.

  • AppMetrica SDK смигрирован на AndroidX.

  • Добавлена базовая поддержка Android 12 — основной функционал AppMetrica SDK доступен на устройствах с Android 12 в приложениях с targetSdkVersion = 31.

  • minSdkVersion повышен до 14.

Крэш-плагин (AppMetrica Build Plugin для Gradle)

Версия 0.11.0

Релиз 2 мая 2024 г.

  • Исправлена ошибка Cannot write a file to a location pointing at a directory.
  • Удалено использование Deprecated класса VersionNumber.

Версия 0.10.0

Релиз 26 апреля 2024 г.

  • Добавлен keep для ресурсов, добавляемых плагином для AGP 8.2.+.

Версия 0.9.0

Релиз 26 февраля 2024 г.

  • Добавлена поддержка AGP до версии 8.2.+ (кроме 8.0.+) и gradle до 8.6.

Версия 0.8.2

Релиз 31 октября 2023 г.

  • Исправлен StackOverflowError при наличии циклических зависимостей.

Версия 0.8.1

Релиз 4 октября 2023 г.

  • Исправлено возможное падение при проверке использования двух версий AppMetrica, если в проекте несколько модулей.

Версия 0.8.0

Релиз 14 сентября 2023 г.

  • Изменено название плагина на io.appmetrica.analytics:gradle:0.8.0.
  • Зависимость com.yandex.android:mobmetricalib-ndk-crashes:1.1.0 обновлена до io.appmetrica.analytics:analytics-ndk-crashes:3.0.0.
  • Добавлена поддержка работы с io.appmetrica.analytics:analytics:6.0.0.
  • Добавлен параметр allowTwoAppMetricas, позволяющий убрать проверку на использование разных версий AppMetrica.

Версия 0.7.0

Релиз 19 апреля 2023 г.

  • Дополнена ошибка об отсутствии mapping файлов.
  • Добавлена поддержка AGP до версии 7.4.+ и gradle до 7.5.

Версия 0.6.2

Релиз 28 июля 2022 г.

  • Улучшена работа плагина.

Версия 0.6.1

Релиз 20 мая 2022 г.

  • Улучшена работа плагина.

Версия 0.6.0

Релиз 17 мая 2022 г.

  • Добавлен параметр mappingFile.
  • Исправлена ошибка Cannot query the value of this property because it has no value available при получении mapping файла.

AppMetrica Push SDK

Версия 3.2.0

Релиз 22 апреля 2024 г.

  • Обновлена поддерживаемая версия RuStore до ru.rustore.sdk:pushclient:2.1.1.
  • Добавлен модуль plugin-adapter для корректной работы Push SDK при использовании в плагинах.
  • Добавлено сохранение для названий переменных в публичном API.

Версия 3.1.1

Релиз 9 апреля 2024 г.

  • Удалены отладочные логи.

Версия 3.1.0

Релиз 2 апреля 2024 г.

  • Исправлена доставка silent-пушей при отключенных уведомлениях.

Версия 3.0.0

Релиз 18 ноября 2023 г.

  • Обновлены идентификатор библиотеки, корневой пакет и API. Подробнее в инструкции по миграции.
  • Добавлено API для кастомизации нотификации, создаваемой SDK.
  • Удалена поддержка com.yandex.android:mobmetricalib.

Версия 2.3.3

Релиз 10 ноября 2023 г.

  • Исправлено падение при наличии двух версий AppMetrica SDK в приложении одновременно.

Версия 2.3.2

Релиз 4 октября 2023 г.

  • Исправлена ошибка

    No field Companion of type Lio/appmetrica/analytics/ModuleEvent$Companion
    

Версия 2.3.1

Релиз 31 июля 2023 г.

  • Повышены производительность и стабильность работы библиотеки.

Версия 2.2.0

Релиз 2 июня 2022 г.

  • minSdkVersionappmetricapush-provider-hms) увеличена до 17.
  • Обновлена версия hms до 6.5.0.300.
  • Ускорена активация PushSDK.

Версия 2.1.1

Релиз 14 марта 2022 г.

  • Исправлена ошибка BadParcelableException: Parcelable protocol requires a Parcelable.Creator object called CREATOR.

Версия 2.1.0

Релиз 24 февраля 2022 г.

  • Улучшено получение токенов.
  • Метод YandexMetricaPush.getTokens возвращает новые токены при вызове из TokenUpdateListener.onTokenUpdated.
  • Повышены производительность и стабильность работы библиотеки.

Версия 2.0.0

Релиз 28 октября 2021 г.

  • Исправлена ошибка, возникающая в некоторых случаях при обработке клика по пушу на Android 12.
  • Переход с support-зависимостей на AndroidX.