Skip to content
This repository has been archived by the owner on Jan 30, 2023. It is now read-only.

Facing 'Cannot complete OAuth process' when client time is not correct #88

Closed
hparth opened this issue Apr 5, 2021 · 5 comments
Closed

Comments

@hparth
Copy link

hparth commented Apr 5, 2021

Issue summary

Facing 'Cannot complete OAuth process' while /auth call when client machine (browser) time is not correct. Like when it is out of sync.

Expected behavior

Auth should not be dependent on client's machine time.

Actual behavior

Facing 'Cannot complete OAuth process' while /auth call when client machine (browser) time is not correct. Like when it is out of sync.

Error as below -

Cannot complete OAuth process. Could not find an OAuth cookie for shop url: xxxxx.myshopify.com
0|shopify- | at Object.throw (/var/www/html/shopify-app/node_modules/koa/lib/context.js:97:11)
0|shopify- | at /var/www/html/shopify-app/node_modules/@shopify/koa-shopify-auth/dist/src/auth/index.js:100:42
0|shopify- | at step (/var/www/html/shopify-app/node_modules/tslib/tslib.js:141:27)
0|shopify- | at Object.throw (/var/www/html/shopify-app/node_modules/tslib/tslib.js:122:57)
0|shopify- | at rejected (/var/www/html/shopify-app/node_modules/tslib/tslib.js:113:69)

Version I am using - "@shopify/koa-shopify-auth": "^4.1.2",

@paulomarg
Copy link
Contributor

Hey @hparth, I understand the issue, but I suspect we may not be able to work around this. The OAuth process uses cookies, and it sets them to expire within a minute of starting the process to reduce the risk of attacks.

If the client browser's date is in such a state that it interprets that cookie as expired, we can't really do much from the server side, as we rely on the cookie being sent back from the client to know which client is going through OAuth.

@benfarhner
Copy link

@paulomarg This is also an issue when the client machine's time is correct, but the end user waits 60s before continuing the OAuth process, just like #130 on @shopify/shopify-api. I commented on that issue but I'm actually using koa-shopify-auth and would prefer to see it fixed in this library if possible by allowing us to handle the error rather than forcing a 500 server error. We're facing app rejections by Shopify because of this.

@tolgap
Copy link

tolgap commented Jun 23, 2021

This is a kind of a big issue for me during development. I keep having to do full page reloads in order to get a valid token. I am receiving JSON Web Tokens from app bridge with an nbf value in the future: Shopify/shopify-app-bridge#59

@contributors: please consider adding a clockTolerance https://github.com/auth0/node-jsonwebtoken#jwtverifytoken-secretorpublickey-options-callback to the OAuth setup.

I am not doing anything crazy with my development machine time(zone). It is synchronised with time.apple.com. Yet in the example of the linked issue from me, you can see that my JWT nbf is in the future quite often.

@david-wb
Copy link

david-wb commented Aug 24, 2021

I too am seeing this error. If someone waits too long on the install confirm page before clicking the green button this error happens. How can we resolve this?

Screenshot from 2021-08-24 12-36-14

@github-actions
Copy link

Note that this repo is no longer maintained and this issue will not be reviewed. Prefer the official JavaScript API library. If you still want to use Koa, see simple-koa-shopify-auth for a potential community solution.

@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Jan 30, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

6 participants