SDK Push-уведомления для React Native (версия 2.1.1)
Ниже перечислены условия работы push-уведомлений.
- Подпись и package name различных типов сборок вашего приложения (debug, release и т.д.) могут отличаться друг от друга. В таком случае вы должны создать в разделе Push-уведомления > Проекты из RuStore Консоль проект под каждый тип сборки..
- Используется актуальная версия SDK.
- Загружены данные о приложении в разделе Push-уведомления > Проекты из RuStore Консоль.
- На устройстве пользователя установлено приложение-дистрибьютор (RuStore и т.д.) Для проверки того, что приложение-дистрибьютор установлено на устройстве пользователя, используйте метод- RuStorePushClient.checkPushAvailability..
- Если установлено приложение RuStore, то ему разрешен доступ к работе в фоновом режиме. Без этого разрешения push-уведомления будут приходить, но со значительной задержкой.
- Отпечаток подписи приложения, установленного на девайсе, совпадает с отпечатком подписи приложения, которое добавлено в разделе Push-уведомления > Проекты из RuStore Консоль.
Пример реализации
Ознакомьтесь с приложением-примером, чтобы узнать, как правильно интегрировать SDK push-уведомлений.
Подключение в проект
Для подключения пакета к проекту выполните следующую команду.
// HTTPS
npm install git+https://git@gitflic.ru/project/rustore/react-native-rustore-push-sdk.git
// SSH
npm install git+ssh://git@gitflic.ru/project/rustore/react-native-rustore-push-sdk.git
Редактирование манифеста приложения
Если нужно изменить иконку или цвет стандартной нотификации, добавьте следующий код.
<meta-data
    android:name="ru.rustore.sdk.pushclient.default_notification_icon"
    android:resource="@drawable/ic_baseline_android_24" />
<meta-data
    android:name="ru.rustore.sdk.pushclient.default_notification_color"
    android:resource="@color/your_favorite_color" />
Если нужно переопределить канал уведомлений, добавьте следующий код.
<meta-data
    android:name="ru.rustore.sdk.pushclient.default_notification_channel_id"
    android:value="@string/pushes_notification_channel_id" />
При добавлении канала push-уведомлений вы должны создать канал самостоятельно.
Запрос разрешения на показ уведомлений в Android 13+
В версии Android 13 появилось новое разрешение для отображения push-уведомлений. Это затронет все приложения, которые работают на Android 13 или выше и используют RuStore Push SDK.
По умолчанию RuStore Push SDK версии 1.4.0 и выше включает разрешение POST_NOTIFICATIONS, определённое в манифесте.
Однако приложению также нужно запросить это разрешение во время выполнения через константу android.permission.POST_NOTIFICATIONS.
Приложение сможет показывать push-уведомления, только когда пользователь предоставит на это разрешение.
Запрос разрешения на показ push-уведомлений.
const requestNotificationPermission = async () => {
    try {
        const granted = await PermissionsAndroid.request(
            PermissionsAndroid.PERMISSIONS.POST_NOTIFICATIONS,
            {
            title: 'Разрешение на показ уведомлений',
            message: 'Приложению необходимо предоставить разрешение на показ уведомлений',
            buttonNeutral: 'Спросить меня позже',
            buttonNegative: 'Отменить',
            buttonPositive: 'OK',
            },
        );
        if (granted === PermissionsAndroid.RESULTS.GRANTED) {
            console.log('Вы можете показывать уведомления');
        } else {
            console.log('Разрешение на показ уведомлений отклонено');
        }
    } catch (err) {
        console.warn(err);
    }
};
Инициализация
Для инициализации понадобится идентификатор проекта из RuStore Консоль. Чтобы получить его, на странице приложения перейдите в раздел Push-уведомления > Проекты и скопируйте значение в поле ID проекта.
 
Обратите внимание, что Push SDK не поддерживает работу в нескольких процессах одновременно.
Если ваше приложение  использует несколько процессов, необходимо инициализировать SDK только в главном процессе.
Если инициализация происходит в дополнительном процессе, это может привести к некорректной работе push-уведомлений.
Инициализация SDK push-уведомлений
Добавьте в AndroidManifest.xml следующий код.
<meta-data
    android:name="ru.rustore.sdk.pushclient.project_id"
    android:value="i5UTx96jw6c1C9LvdlE4cdNrWHMNyRBt" />
<meta-data
    android:name="ru.rustore.sdk.pushclient.params_class"
    android:value="com.example.ReactRuStorePushClientParams" />
- projectId— идентификатор проекта из RuStore Консоль. Чтобы получить его, на странице приложения перейдите в раздел Push-уведомления > Проекты и скопируйте значение в поле ID проекта.
- (опционально) com.example.ReactRuStorePushClientParams— полное имя класса своей реализацииReactRuStorePushClientParams. Параметр нужен для указания дополнительных параметров инициализации push-клиента.
Класс – наследник AbstractRuStorePushClientParams, он по умолчанию реализован на стороне SDK и имеет вид.
class RuStorePushClientParams(context: Context) : AbstractRuStorePushClientParams(context) {
    override fun getLogger(): Logger = DefaultLogger("ReactRuStorePushClient")
    override fun getTestModeEnabled(): Boolean = false
}
Вы можете переопределить его в своем приложении. Для этого добавьте в Android-модуль зависимости.
repositories {
    maven {
        url = uri("https://artifactory-external.vkpartner.ru/artifactory/maven")
    }
}
dependencies {
    implementation("ru.rustore.sdk:pushclient:2.1.1")
}
Пример реализации ReactRuStorePushClientParams.
class ReactRuStorePushClientParams(context: Context) : AbstractRuStorePushClientParams(context) {
    override fun getLogger(): Logger = DefaultLogger("your_tag")
    override fun getTestModeEnabled(): Boolean = false
    override fun getClientIdCallback(): ClientIdCallback =
        ClientIdCallback { ClientId("your_gaid_or_oaid", ClientIdType.GAID) }
}
Далее поместите в AndroidManifest.xml следующий код.
<meta-data
    android:name="ru.rustore.sdk.pushclient.params_class"
    android:value="com.example.ReactRuStorePushClientParams" />