Прежде, чем ответить на вопрос: «Что такое «ошибка токена»?», нужно понять, что такое токен. Так вот, токен (также может быть в виде аппаратного токена, USB-ключа, криптографического токена) в виде компактного устройства предназначен для того, чтобы обеспечить информационную безопасность пользователя, также чтобы можно было идентифицировать его владельца. Как правило, токен является физическим устройством, которое используется для того, чтобы упростить аутентификацию. Поэтому, если произошла ошибка токена, то это вопрос серьёзный и требует непростого подхода. Чтобы исправить такую ошибку, нужно обратиться к специалистам.
Иногда в банках меняется информация, что приводит к необходимости обновления подключения
Уведомление на обновление токена загорается в разделе «Деньги».
Чек-лист:
1. Проверьте, что проходите авторизацию именно под той учетной записью, у которой есть доступ к этому счету.
2. Проверьте, соответствуют ли введенные данные для авторизации в банке тому токену, который требуется обновить (ИНН, КПП, номер телефона).
3. Убедитесь, что в момент обновления токена никто не находится в личном кабинете банка.
4. Обратите внимание, что под одним токеном можно получить доступ только к одной компании (один ИНН).
Решение: создать дополнительный аккаунт в Банке (добавить нового пользователя в личном кабинете банка), предоставить ему доступ к счету и получить второй токен уже под этой новой учетной записью.
📦 Для создания дополнительного аккаунта в Банке потребуются паспортные данные этого человека, номер мобильного телефона и адрес почты.
💡 Обратите внимание, какой именно токен запрашивается обновить, т.е. для какой организации? Вводя не те данные, обновление токена будет запрашиваться снова.
I’ve been pulling my hair out over this issue lately.
Some background
- using the oauth2client library to manage tokens of users. The tokens are used to do a variety of background tasks periodically and concurrently.
- each time one of these tasks is about to run for a user, we get the Credentials object from storage and do a refresh if the expiry is ~5 minutes away. Otherwise the current access token is re-used.
- it happens that sometimes multiple tasks for 1 user are running at the same time
- for a while everything works fine, the tokens get refreshed normally
- intermittently and seemingly out of the blue, during one of these attempted refresh, an «invalid_grant» error is returned, and it completely invalidates the refresh token in storage. (When/how/why it happens is what I hope to figure out with this question)
Searching around, there are a lot of threads/reports about this issue. But all I’ve found so far don’t apply to our case. I’ll try to list the ones I have looked into so far:
- User has revoked permissions
This one is the most obvious, most documented and is easily reproducible, but unfortunately in our case our users (or ourselves, while testing), didn’t revoke permissions at all.
- Refreshing an «old» access token
At first I thought that there can only be 1 valid access token at a time for a user. That is false, and verified on OAuth2 Playground.
- User has too many active access tokens
There’s a limit of 25 active tokens per user per client. Once that limit is reached, older access tokens are invalidated silently, even if their expiration date hasn’t passed yet.
This is a dead end for us as well, since our issue happens when refreshing, not using the oldest access token. And this limit only affects access tokens, not refresh tokens.
- Requesting a refresh too many times in a short amount of time
Not documented at all. Only mentioned in passing with no references. Tried to emulate it by doing a refresh 25 times in 7 seconds, but all went well. But with no references, this is a shot in a dark. And our background tasks only ever max at ~10 tasks every several minutes. Moving on.
- Concurrent refreshes cause a race condition on which token succeeds
I’ve asked a question here, but this wasn’t the case. Tested on AppEngine by running two tasks scheduled at the same time.
I’m at my wit’s end trying to pin down this issue. The fact that we can’t readily reproduce it is a pain. I’d really like some insight on what could possibly be causing this that I’ve missed?
Here’s our refresh code:
def refresh_oauth_credentials(user, credentials, force=False):
if not credentials:
return None
logging.debug(credentials.token_expiry)
do_refresh = credentials._expires_in() < 300
if force or do_refresh:
h = httplib2.Http()
try:
logging.debug('Refreshing %s's oauth2 credentials...' % user.email)
credentials.refresh(h)
except AccessTokenRefreshError:
logging.warning('Failed to refresh.')
return None
return credentials
Тут создаю instance и при первом входе все работает нормально, но при просрочке токена возникает проблема, выдает ошибку 400 при запросе на UPDATE_TOKEN, при этом при проверке всего того же в postman все работает
‘token’ в localStorage — refresh token
const $api = axios.create({
baseURL: LOCAL_API
})
$api.interceptors.request.use((config) => {
config.headers.Authorization = `Bearer ${localStorage.getItem('accessToken')}`
return config
})
$api.interceptors.response.use((config) => {
return config
}, async (error) => {
const originalRequest = error.config
if (error.response.status == 401 && error.config && !error._isRetry) {
originalRequest._isRetry = true
try {
const response = await axios({
method: 'post',
url: UPDATE_TOKEN,
data: localStorage.getItem('token')
})
console.log(response.data)
localStorage.setItem('accessToken', response.data.accessToken)
return $api.request(originalRequest)
} catch (e) {
console.log('Не авторизован')
}
}
throw error
}
)
export default $api
При установке параметра withCredentials: true, выходит вот такая ошибка
Запрос из постороннего источника заблокирован: Политика одного источника запрещает чтение удаленного ресурса на «тут url». (Причина: Учётные данные не поддерживаются, если заголовок CORS «Access-Control-Allow-Origin» установлен в «*»
Не совсем понимаю Access-Control-Allow-Origin должен устанавливаться на сервере, потому что его установить в headers запроса, это не помогает
Как посмотреть ошибки автосинхронизации
При настройке автосинхронизации для приложений на базе SAML могут возникать следующие ошибки:
-
Ошибки этапа настройки
-
Ошибки выполнения автосинхронизации
-
Ошибки на уровне ресурсов
Ниже описано, как их устранить.
Примечание. Если вам не удается устранить ошибку с помощью инструкций из этой статьи, обратитесь в службу поддержки.
Ошибки этапа настройки
Ошибка кода авторизации
Такая ошибка может появиться, если код авторизации не удалось заменить на токен обновления. Причиной может послужить неправильный код авторизации или длительный промежуток времени с момента авторизации до нажатия кнопки Сохранить изменения. Чтобы устранить эту ошибку, повторите авторизацию и сохраните изменения.
Сообщение об ошибке | Решение |
---|---|
Не удалось сгенерировать токен авторизации. | Повторите попытку и сохраните изменения. |
Ошибка устаревшей страницы
Эта ошибка возникает, если страница браузера не обновлялась, в то время как настройки были изменены в другом окне браузера или другим пользователем. При этом появляются следующие сообщения:
Сообщение об ошибке | Решение |
---|---|
Данные на странице устарели. Конфигурация синхронизации настроена. | Чтобы переопределить существующие настройки, обновите страницу. |
Данные на странице устарели. Конфигурация синхронизации отсутствует. | Чтобы переопределить существующие настройки, обновите страницу. |
Данные на странице устарели. Активировать ненастроенную конфигурацию синхронизации нельзя. | Чтобы переопределить существующие настройки, обновите страницу. |
Данные на странице устарели. Удалить ненастроенную конфигурацию синхронизации нельзя. | Чтобы переопределить существующие настройки, обновите страницу. |
Временная ошибка страницы
Временные ошибки обычно устраняются сами собой. Обновите страницу или повторите попытку немного позже.
Сообщение об ошибке | Решение |
---|---|
Не удалось загрузить настройки синхронизации. | Обновите страницу. |
Не удалось загрузить предварительные настройки синхронизации. | Обновите страницу. |
Не удалось загрузить статус синхронизации. | Обновите страницу. |
Не удалось активировать синхронизацию. | Повторите попытку. |
Не удалось удалить настройки синхронизации. | Повторите попытку. |
Не удалось создать настройку синхронизации. | Повторите попытку и сохраните изменения. |
Не удалось обновить настройку синхронизации. | Повторите попытку и сохраните изменения. |
Не удалось загрузить настраиваемые атрибуты. | Повторите попытку. |
Не удалось обновить сопоставление атрибутов. | Повторите попытку. |
Не удалось обновить настройки группы для автосинхронизации. | Повторите попытку. |
Не удалось обновить конфигурацию отключения. | Повторите попытку. |
Конфигурация удалена, но запретить доступ клиента API не удалось. |
При удалении конфигурации отменяются разрешения, которые позволяют приложению обращаться к вашим данным в сервисах Google. Эту ошибку можно устранить вручную: нажмите Управлять доступом клиента API в разделе Безопасность. Если вы планируете позже восстановить конфигурацию, ничего не делайте. |
Не удалось обновить настройки синхронизации. | Обновите страницу. |
Ошибка аутентификации. | Учетные данные для аутентификации (например, токен владельца) указаны неверно. Задайте правильные учетные данные. |
Введенный вами URL конечной точки системы кросс-доменного управления учетными данными (SCIM) недействителен. | URL конечной точки недействителен. Введите правильный URL. |
Не удалось включить синхронизацию. | Переведите ползунок Автосинхронизация в положение Активный. |
Не удалось удалить настройки синхронизации. |
|
Не удалось загрузить атрибуты целевого поставщика услуг. |
|
Не удалось загрузить набор атрибутов целевого ресурса. | Проверьте URL конечной точки, указанный при настройке автосинхронизации, и повторите сопоставление атрибутов облачного каталога с атрибутами целевого приложения. |
Ошибки выполнения автосинхронизации
Ошибки выполнения автосинхронизации возникают из-за проблем с доступом к API, авторизацией и конфигурацией.
Ошибки внутренних сервисов Google
Код ошибки | Описание и решение |
---|---|
17003 17006 17008 |
Описание Не удалось пройти аутентификацию во внутренних сервисах Google. Причина Аннулированы разрешения у следующего идентификатора клиента синхронизации пользователей: 910835873219-es01p47a1ks618hgp59q26cnc6sv33r3.apps.googleusercontent.com Решение Убедитесь, что у данного идентификатора есть разрешения на доступ к следующим областям: https://www.googleapis.com/auth/admin.directory.user.readonly, В разделе Безопасность консоли администратора нажмите Управлять доступом клиента API и перейдите в раздел Расширенные настройки. Проверьте доступ идентификатора к указанным областям и при необходимости добавьте их. |
17007 |
Описание Не удалось предоставить доступ приложениям, которые поддерживают автосинхронизацию с делегированием прав на уровне домена. Не удалось делегировать права на уровне домена сервису автосинхронизации. Без этих прав сервис автосинхронизации не сможет читать каталог Google. Причины Причина 1: аннулированы разрешения у идентификатора клиента синхронизации пользователей. Решения В разделе Безопасность консоли администратора нажмите Управлять доступом клиента API и перейдите в раздел Расширенные настройки. Добавьте идентификатор клиента и области действия: Идентификатор клиента: Области действия: https://www.googleapis.com/auth/admin.directory.user.readonly, Вы также можете удалить приложение, с которым возникла проблема, а затем добавить его снова. Причина 2: непредвиденные системные ошибки. Решение Как правило, эта проблема решается автоматически. Если она не решилась через несколько часов, добавьте идентификатор клиента и области действия или удалите и повторно добавьте приложение, как описано выше в инструкциях для причины 1. |
Ошибки токена авторизации
Код ошибки | Описание и причина | Решение |
---|---|---|
17010 |
Недостаточно учетных данных для вызова конечной точки SCIM. Причина: токен авторизации аннулирован. |
Повторите попытку авторизации. Для этого нажмите Автосинхронизация и в настройках выберите Авторизовать повторно. |
17013 |
Ошибка получения токена доступа у поставщика услуг. Причина: токен авторизации аннулирован. |
Если проблема не решится автоматически, повторите попытку авторизации. Для этого нажмите Автосинхронизация и в настройках выберите Авторизовать повторно. |
Ошибки доступа к токену
Код ошибки | Описание и причина | Решение |
---|---|---|
17002 17011 |
Не удалось создать токен доступа. Причина: сейчас некоторые внутренние сервисы Google недоступны. |
Проблема должна устраниться автоматически. |
17009 | Не удалось создать токен доступа из токена обновления. | Повторите попытку авторизации. Для этого нажмите Автосинхронизация и в настройках выберите Авторизовать повторно. |
Общие ошибки
Код ошибки | Описание и причина | Решение |
---|---|---|
1200x |
Внутренняя ошибка |
Проблема должна устраниться автоматически. |
25001 | Сервер или сервис Google временно недоступны. | Настройте автосинхронизацию ещё раз. |
25002 |
Сервер или сервис Google временно недоступны. Причина: у клиента не установлено приложение. |
Установите приложение и настройте автосинхронизацию ещё раз. |
25005 | Сервер или сервис Google временно недоступны. | Проблема должна устраниться автоматически. |
25016 | Сервер или сервис Google временно недоступны. | Настройте автосинхронизацию ещё раз. |
50001 | Внутренняя ошибка | Проблема должна устраниться автоматически. |
50003 | Внутренняя ошибка | Проблема должна устраниться автоматически. |
50005 | Удаленная группа присутствует в фильтрах групп. | Удалите данную группу из области синхронизации. |
50006 | Внутренняя ошибка | Проблема должна устраниться автоматически. |
Ошибки на уровне ресурсов
Если в разделе «Автосинхронизация» на странице настроек приложения SAML есть ошибки, нажмите Скачать список. В скачанном файле будут перечислены операции создания, удаления или изменения, которые завершились сбоем, а также приведены коды и описания всех ошибок.
Эти ошибки влияют только на конкретные ресурсы, указанные в файле.
Код ошибки | Описание ошибки | Решение |
---|---|---|
45003 |
Приложение на базе системы кросс-доменного управления учетными данными (SCIM) не принимает запрос на обновление, создание или удаление ресурса. Подробное описание ошибки содержится в файле, который можно скачать. Возможные причины:
|
После устранения ошибки сохраните изменения и повторите попытку. |
45004 |
Произошла ошибка при передаче данных между поставщиком услуг и Google в качестве поставщика идентификационной информации. Текст ошибки: «Внутренняя ошибка – превышена квота». Возможные причины:
|
Обратитесь к поставщику услуг. |
45005 | Конечная точка системы кросс-доменного управления учетными данными (SCIM) недоступна. Проверьте данные в консоли администратора. | После устранения ошибки сохраните изменения и повторите попытку. |
45006 |
Приложение на базе системы кросс-доменного управления учетными данными (SCIM) не принимает запрос на обновление, создание или удаление ресурса. Подробное описание ошибки содержится в файле, который можно скачать. Возможные причины:
|
После устранения ошибки сохраните изменения и повторите попытку. |
45016 |
Приложение на базе системы кросс-доменного управления учетными данными (SCIM) не принимает запрос на обновление, создание или удаление ресурса, поскольку обязательное поле не заполнено. Подробное описание ошибки содержится в файле, который можно скачать. |
После устранения ошибки сохраните изменения и повторите попытку. |
Эта информация оказалась полезной?
Как можно улучшить эту статью?