Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix including interval in response of device authorization request #1410

Merged
merged 21 commits into from
Dec 20, 2024

Conversation

hafezdivandari
Copy link
Contributor

@hafezdivandari hafezdivandari commented May 22, 2024

This PR does:

  • Fix a typo on DeviceCodeRepositoryInterface::getDeviceCodeEntityByDeviceCode() argument, string $deviceCodeEntity -> string $deviceCode. TBD later.
  • Fix a bug where enabling the interval visibility is ignored:
  • Fix a bug where the new poll date is not persisted when slow_down error happens, because the exception is thrown before calling persistDeviceCode.
  • Increase interval by 5 when slow_down error happens according to section 3.5 of RFC8628.
  • Fix a bug where slow_down error response may have been returned even after the user has completed the auth flow (already approved / denied the request).
  • Include the interval value on authorization_pending and slow_down error responses.

@Sephster
Copy link
Member

Sephster commented Jul 2, 2024

@hafezdivandari apologies I've not forgotten about this. My partner is sick just now and my son has a sickness bug so I have little time but will get to it as soon as she is better. Apologies for the delay. Just wanted to give you an update

@hafezdivandari
Copy link
Contributor Author

@Sephster No worries at all! Take all the time you need. I hope your family feels better soon.

@hafezdivandari
Copy link
Contributor Author

Hi @Sephster, hope you’re doing well. Any progress on the PRs related to Laravel Passport? I’ve listed them all here.

@hafezdivandari hafezdivandari mentioned this pull request Oct 10, 2024
8 tasks
Copy link
Member

@Sephster Sephster left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for this Hafez. I think there are some bugs that have been fixed here that aren't actual bugs. I'll try to outline them as best I can below:

  • Fix typo is grand. Thank you!
  • For a long time I debated whether to have a "setIntervalVisibility" function. Intially I just thought we could have the default as five and if you wanted to increase or decrease this, you could set the value to something different and we'd then report it in the response as the absence of it implies 5 seconds anyway. I think this is probably why the code is the way it is now but appreciate it is confusing to set visibility and then have it do nothing. I think the easiest fix here is to change the condition that adds the interval to the response to check for if the interval visibility has been set, which should be non-breaking.
  • I think it is correct to not record a new poll date if we issue a slowdown. The slowdown message just informs the client they've polled too quickly. If we logged the poll date, we'd reset the timer to 5 second again which we don't want to do.
  • The interval increase of five is supposed to be followed by the client, not enforced by the server so we shouldn't need to make a change here as far as I'm aware
  • Can you highlight where the issue is with us returning a slow_down after the request has been approved? I wasn't too clear where this was happening
  • Because we don't need to change the interval, we shouldn't need to report new interval values so don't need to include these in the error response, and can hopefully avoid these breaking changes

Hope all this makes sense but I think we probably only need to fix the visibility honouring and the typo. Cheers for all your work on this!

src/Exception/OAuthServerException.php Outdated Show resolved Hide resolved
CHANGELOG.md Show resolved Hide resolved
src/Exception/OAuthServerException.php Outdated Show resolved Hide resolved
src/Grant/DeviceCodeGrant.php Outdated Show resolved Hide resolved
@hafezdivandari
Copy link
Contributor Author

@Sephster I've applied the requested changes, please review again.

src/Grant/DeviceCodeGrant.php Outdated Show resolved Hide resolved
src/Repositories/DeviceCodeRepositoryInterface.php Outdated Show resolved Hide resolved
@Sephster Sephster merged commit 34a14d3 into thephpleague:master Dec 20, 2024
19 checks passed
@hafezdivandari hafezdivandari deleted the master-fix-some-bugs branch December 29, 2024 15:39
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Add an option to always expose the interval param for the device code grant
2 participants