mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-12 02:58:20 +08:00
101b99f4a7
Summary: This is a small patch but it's pretty complex, because of the numbers of moving parts. Gmail has two types of tokens, access and refresh tokens. Access tokens have a limited shelf life of one hour. After that they expire and you need to use your refresh token to get a new one. We've decided to do the access token generation on the server, because we don't feel comfortable giving our users both our Google client id and secret. To do that, I've added an endpoint, `/gmail/auth/refresh` which returns a valid access token as well as an expiration date for the token. The only place where we handle token expiration is in the sync workers. Before trying opening a new connection we check if our access token is expired. If yes, we get a new one from the API. If there's an issue doing this, we notify N1 using `NylasAPIHelpers.handleAuthenticationFailure`. There's a second patch for N1 with tiny related fixes. Test Plan: Tested manually. Will need to test more in the real world. Reviewers: evan, jackie, juan Reviewed By: juan Differential Revision: https://phab.nylas.com/D3522 |
||
---|---|---|
.. | ||
isomorphic-core | ||
local-private | ||
local-sync |