ym88659208ym87991671
Перечень конфигураций SDK | Документация для разработчиков

Перечень конфигураций SDK

Обновлено 11 декабря 2024

Стилизация кнопки "Войти по Сбер ID"

Для стилизации кнопки "Войти по Сбер ID" необоходимо при создании экземпляра SberidSDK в параметр buttonProps передать настройки по инструкции ниже.

Параметры стилизации кнопки

ПараметрТипОписание
typeStringвариант отображаемого на кнопке текста (возможные значения: 'default', 'resume', 'login', 'fill', 'custom')
loaderBooleanотображение лоадера на кнопке
logoBooleanотображение логотипа Сбер ID на кнопке
customObject (Только при type == custom)

{

anonymous: String (текст для обычной кнопки),

personal: String (текст для персонализированной кнопки)

}

sizeStringвариант отображения кнопки (возможные значения: 'default', 'long', 'small')

Возможные значения и описание параметра type

    default: {
anonymous: 'Войти по Сбер ID',
personal: 'Войти как {{userName}}',
}

resume: {
anonymous: 'Продолжить со Сбер ID',
personal: 'Продолжить как {{userName}}',
}

login: {
anonymous: 'Сбер ID',
personal: 'Войти как {{userName}}',
}

fill: {
anonymous: 'Заполнить со Сбер ID',
personal: 'Войти как {{userName}}',
}

custom: {
anonymous: 'Войти по Сбер ID',
personal: 'Войти как {{userName}}',
}

Пример стилизации кнопки

buttonProps: {
type: 'default',
custom: {
anonymous: 'Вход',
personal: 'Вход как {{userName}}',
},
}

Пример объекта params

const params = {
oidc: oidcParams,
container: '.preview',
// другие параметры
buttonProps: {
type: 'default',
custom: {
anonymous: 'Вход',
personal: 'Вход как {{userName}}',
},
},
// другие параметры
};

Персональная кнопка "Войти как"

Для реализации персональной кнопки, например, "Войти как Дмитрий", необходимо:

  • при инициалиции SDK в параметр personalization передать значение true
  • направить запрос на support@ecom.sberbank.ru для добавления ваших доменов в список доверенных.

В запросе добавления домена в список доверенных укажите client_id и список доменов, с которых будут выполняться запросы на получение данных для персонализации кнопки.

Адрес домена не должен заканчиваться символом "/".

Пример объекта params

const params = {
oidc: oidcParams,
container: '.preview',
// другие параметры
personalization: true,
onPersonalizationStatus: (personalization) => {
if (personalization) {
console.log('Отобразилась перс. кнопка');
} else {
console.log('Отобразилась обычная кнопка');
}
},
// другие параметры
};

Персонализированный баннер

Пример обновленного дизайна перс баннера

Для реализации персонализированного баннера неободимо при создании экземпляра SberidSDK в параметр notification передать настройки по инструкции ниже.

ПараметрТипОписание
enableBoolenвключение персонализированного баннера. Если включен, то баннер показывается сразу после инициализации SDK
onNotificationBannerCloseFunctionфункция обратного вызова при закрытие баннера
onNotificationBannerOpenFunctionфункция обратного вызова при открытие баннера
position?NotificationPositionрасположение баннера на экране, только для десктоп версии, возможные значения top-right, bottom-right, top-left, bottom-left, значение по умолчанию bottom-right
theme?NotificationThemeтема баннера, возможные значения white, dark, значение по умолчанию white
serviceName?stringпозволяет указать название сервиса для входа, только для персонализированного баннера, длинна не должна превышать 15 символов, иначе будет использоваться значение по умолчанию 'сервис'
positionStringрасположение баннера (возможноные значения left, right)
autoCloseDelayNumberзадержка до скрытия баннера в мобильной версии браузера в секундах
autoCloseBoolenвключение скрытия баннера в мобильной версии
textType?NotificationTextTypeпозволяет выбрать вариант текста на баннере, возможные значения default и loyalty, значение по умолчанию default

Пример использования баннера

new SberidSDK({
...params,
notification: {
enable: true,
serviceName: "",
autoClose: false,
autoCloseDelay: 90,
theme: NotificationTheme.white,
textType: NotificationTextType.default
}
})

Важно!

Для выполнения быстрого входа должна быть включена настройка персонализированной кнопки

Конфигурация автоподогрева Cookies

Автоподогрев Cookies осущетсвляется только после успешного входа пользователя по Сбер ID (Шаг № 19. Сервер партнера авторизует клиента у себя в сервисе)

Пост-логин зона сервиса ДомКлик

Когда пользователя перенаправили в пост-логин зону, необходимо создать новый экземпляр SDK из которых обязательным является только набор параметров oidc и параметр autoUpdateCookie: true

ПараметрОбязательноОписание
oidcДапереиспользовать объект из инициализации SDK
autoUpdateCookieДаtrue - включение автоподогрева
updateCookiePeriodНетпо дефолту значение 6 дней. Если требуется изменить период, то передать параметр и значение
onUpdateCookieНетпри необходимости отслеживания сallback'а подогрева, реализуйте функцию onUpdateCookie ипередайте название функции в качетсве параметра

Пример дефолтного SberidSDK

const params = {
oidc: oidcParams,
cloud: {
⁣enable: true // true - если вы переключены на наше целевое решение Cloud Сбер ID (id.sber.ru)
}
autoUpdateCookie: true,
};

var sbSDK = new SberidSDK(params);

Если вы переключены на наше целевое решение Cloud Сбер ID (id.sber.ru), то в параметр cloud необходимо передавать true. Подробнее по ссылке

Пример кастомизации параметров SberidSDK

const onUpdateCookie = () => {
console.log('Автоподогрев выполнен.');
};

const params = {
oidc: oidcParams,
autoUpdateCookie: true,
updateCookiePeriod: 10,
onUpdateCookie,
};

var sbSDK = new SberidSDK(params);

Конфигурация для быстрого входа

Для реализации функционала быстрого входа необходимо при инициализации SDK в параметр fastLogin добавить объект по инструкции ниже:

ПараметрТипОписание
enableBoolenвключение быстрого входа
timeoutNumberзадержка до принудительного завершения быстрого входа при проблемах с создание запроса на сервер
modeStringрежим работы быстрого входа (auto - автоматически запускай быстрый вход после инициализации SDK, default - запускай быстрый вход по нажатию на кнопку)
onErrorAutoModeFunctionфункция обратного вызова при не успехе выполнения автоматического входа
onErrorDefaultModeFunctionфункция обратного вызова при не успехе выполнения быстрого входа

Пример объекта params

const params = {
oidc: oidcParams,
container: '.preview',
// другие параметры
fastLogin: {
enable: true,
timeout: 1000,
mode: 'default',
onErrorDefaultMode: () => {
console.log(`Не удалось выполнить быстрый вход вход`);

if('продолжаем вход через SDK '){
// В зависимости от настроек откроется OIDC страница или модальное окно
return true;
}

else {
// SDK прерывает вход, пользователь остается на странице партнера
return false;
}
}
},
// другие параметры
};

Важно!

  • Для выполнения быстрого входа должна быть включена настройка персонализированной кнопки
  • При использовании быстрого входа в функции onErrorDefaultMode обязательно нужно вернуть true или false
  • При использовании авто входа при выходе пользователя из сервиса необходимо вызвать функцию sdk.logout() чтобы прервать авто вход

Параметры для генерации универсальных ссылок

  • params (Object) - параметры OIDC;
  • baseUrl (String) - Базовый адрес адрес для формирования ссылки входа по Сбер ID. Адрес по умолчанию https://online.sberbank.ru/CSAFront/oidc/authorize.do. Если вы используйте тестовый режим, укажите адрес тестовой страницы без параметров;
  • deeplinkUrl (String) - Базовый адрес адрес для формирования deeplink на мобильное приложение. Адрес по умолчанию sberbankidlogin://sberbankidsso. Если вы используйте тестовый режим, укажите тестовый deeplink без параметров;
  • universalLinkUrl (String) - Базовый адрес адрес для формирования универсальной ссылки входа по Сбер ID. Адрес по умолчанию https://online.sberbank.ru/CSAFront/oidc/sberbank_id/authorize.do. Если вы используйте тестовый режим, укажите адрес тестовой страницы без параметров;
  • needAdditionalRedirect (Boolean) - Включить формирования адреса дополнительного редиректа у универсальных ссылках для возврата в браузер из которого начался сценарий авторизации.

Если вы используете наше целевое решение Cloud, то нужно изменить url в параметрах:

Ссылка для входа по Сбер ID

SberidSDK.getUrl (Function) - статичный метод класса SberidSDK позволяет получить ссылку для входа по Сбер ID, метод возвращает Promise c объектом {link, deeplink}


const {link, deeplink} = await SberidSDK.getUrl(baseUrl, currentOIDC )

ПАО Сбербанк использует cookie для персонализации сервисов и удобства пользователей.
Вы можете запретить сохранение cookie в настройках своего браузера.