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

Proper use of state parameter for the OAuth CSRF protection #1435

Closed
1 of 6 tasks
seratch opened this issue Feb 25, 2022 · 0 comments · Fixed by #1436
Closed
1 of 6 tasks

Proper use of state parameter for the OAuth CSRF protection #1435

seratch opened this issue Feb 25, 2022 · 0 comments · Fixed by #1436
Assignees
Labels
bug M-T: A confirmed bug report. Issues are confirmed when the reproduction steps are documented pkg:oauth applies to `@slack/oauth-helper`

Comments

@seratch
Copy link
Member

seratch commented Feb 25, 2022

As of Feb 2022, @slack/oauth (~ v2.4) and @slack/bolt (~ v3.10) do not use state parameter for the purpose of CSRF protection in the Slack OAuth flow. Refer to the RFC https://datatracker.ietf.org/doc/html/rfc6749#section-10.12 for the details of state parameter in general.

Currently, the only things that InstallProvider does are adding state parameter to the Slack authorize URL, and then decoding the underlying value from the string. There is no way for developers to check if the state parameter in query string is valid for the accessing user-agent (=the web browser).

To improve this, @slack/oauth module can provide a new way to serve the install path (/slack/install) in a way to manage user-agent state by setting cookies. With that, the Redirect URL (/slack/oauth_redirect) can check if the user-agent is the same person in the OAuth flow.

We will add a new method handleInstallPath(), which handles all the above. Also, the existing handleCallback() verifies both the query string and browser cookies. Newer versions of bolt-js (v3.11 or newer) will switch to this new way.

Packages:

Select all that apply:

  • @slack/web-api
  • @slack/rtm-api
  • @slack/webhooks
  • @slack/oauth
  • @slack/socket-mode
  • I don't know
@seratch seratch added bug M-T: A confirmed bug report. Issues are confirmed when the reproduction steps are documented pkg:oauth applies to `@slack/oauth-helper` labels Feb 25, 2022
@seratch seratch added this to the [email protected] milestone Feb 25, 2022
@seratch seratch self-assigned this Feb 25, 2022
seratch added a commit to seratch/node-slack-sdk that referenced this issue Feb 25, 2022
seratch added a commit to seratch/node-slack-sdk that referenced this issue Mar 1, 2022
seratch added a commit to seratch/node-slack-sdk that referenced this issue Mar 1, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug M-T: A confirmed bug report. Issues are confirmed when the reproduction steps are documented pkg:oauth applies to `@slack/oauth-helper`
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant