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(NODE-6407): use conversationId returned by the server instead of hardcoded integer in SASL implementation for MONGODB-AWS. #4258

Merged
merged 1 commit into from
Jan 14, 2025

Conversation

kggau
Copy link

@kggau kggau commented Sep 30, 2024

Description

MONGODB-AWS authentication mechanism should follow SASL spec. Current implementation ignores the conversationId sent by the server and uses a hardcoded integer for all saslContinue messages across all conversations.

What is changing?

Changing the hardcoded integer for conversationId to utilize the one that gets returned in the saslStart response.

Is there new documentation needed for these changes?

No. This change brings the implementation to spec.

What is the motivation for this change?

This is a bug. MONGODB-AWS authentication failed on database emulating MongoDB.

Release Highlight

Fixes SASL implementation for MONGODB-AWS to use conversationId returned by the server instead of hardcoded integer.

Double check the following

  • Ran npm run check:lint script
  • Self-review completed using the steps outlined here
  • PR title follows the correct format: type(NODE-xxxx)[!]: description
    • Example: feat(NODE-1234)!: rewriting everything in coffeescript
  • Changes are covered by tests
  • New TODOs have a related JIRA ticket

integer in SASL implementation for MONGODB-AWS.
@alexbevi
Copy link
Contributor

alexbevi commented Oct 1, 2024

Hey @kggau, thanks for sharing this patch. Our team will give it a once over to validate it addresses the problem (it looks like it does on a quick inspection).

This is a bug. MONGODB-AWS authentication failed on database emulating MongoDB.

Can you clarify which emulating database this issue occurred in?

@kggau
Copy link
Author

kggau commented Oct 1, 2024

Thanks @alexbevi!

Can you clarify which emulating database this issue occurred in?

This issue happened when using MONGODB-AWS auth mechanism with Amazon DocumentDB. Given loss of conversationId information, I am not sure why it is functional with MongoDB (assuming it works).

@dariakp dariakp added tracked-in-jira Ticket filed in MongoDB's Jira system External Submission PR submitted from outside the team labels Oct 1, 2024
@dariakp dariakp changed the title fix: use conversationId returned by the server instead of hardcoded integer in SASL implementation for MONGODB-AWS. fix(NODE-6407): use conversationId returned by the server instead of hardcoded integer in SASL implementation for MONGODB-AWS. Oct 1, 2024
@alexbevi
Copy link
Contributor

Given loss of conversationId information, I am not sure why it is functional with MongoDB (assuming it works).

@kggau just to clarify, this does work with the MONGODB-AWS authentication mechanism within the MongoDB server.

@todd
Copy link

todd commented Dec 6, 2024

Would anyone be able to provide an update on when this might get released? We're eagerly awaiting this functionality.

@nbbeeken
Copy link
Contributor

nbbeeken commented Dec 6, 2024

@todd Thanks for reaching out. We're currently at capacity with our end-of-year wrap-up, but we plan to look into this early next year. The changes here are pending further testing. We appreciate your patience and you'll be notified here or on the JIRA ticket NODE-6407 of our progress.

@W-A-James W-A-James changed the base branch from main to NODE-6407/saslContinue-testing January 14, 2025 18:54
@W-A-James
Copy link
Contributor

@kggau I've put up a PR with test for this change (#4368) and will be merging this PR into that new branch to have the change and the test in one PR for review by the team

@W-A-James W-A-James self-assigned this Jan 14, 2025
@W-A-James W-A-James merged commit d914111 into mongodb:NODE-6407/saslContinue-testing Jan 14, 2025
16 of 30 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
External Submission PR submitted from outside the team tracked-in-jira Ticket filed in MongoDB's Jira system
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants