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

Manually construct pop URL when using iampg auth #9538

Merged
merged 7 commits into from
Nov 8, 2022
Merged

Conversation

ahobson
Copy link
Contributor

@ahobson ahobson commented Nov 7, 2022

Summary

After gobuffalo/pop#774 iam password auth no longer works because pop is query escaping the password. Manually construct the pg url when iam auth is enabled

Verification Steps for Author

These are to be checked by the author.

  • Tested in the Loadtest environment (for changes to containers, app startup, or connection to data stores)
  • Request review from a member of a different team.

@ahobson ahobson requested a review from reggieriser November 7, 2022 14:06
@robot-mymove
Copy link

robot-mymove commented Nov 7, 2022

Warnings
⚠️ Please add the JIRA issue key to the PR title (e.g. MB-123)

Generated by 🚫 dangerJS against 73d13c0

* Manually construct pop URL when using iampg auth
* Use pop store to ping the db instead of making a new connection
@ahobson ahobson force-pushed the adh-fix-pop-url-iam branch from 9f0e0e4 to d9b2149 Compare November 7, 2022 15:15
dbConnectionDetails.URL = fmt.Sprintf(s,
dbConnectionDetails.User, dbConnectionDetails.Password,
dbConnectionDetails.Host, dbConnectionDetails.Port,
dbConnectionDetails.Database, dbConnectionDetails.OptionsString(""))
Copy link
Contributor Author

Choose a reason for hiding this comment

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

If we changed the passHolder to something that does not need query escaping, we wouldn't have to do this assignment to URL, but that seems like leaving a footgun around, even if we comment on it.

Copy link
Contributor

@jesset-truss jesset-truss left a comment

Choose a reason for hiding this comment

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

@ahobson I think we might be moving quickly on this. I'm concerned this may have a downstream effect on to an issue that I'm currently working with others in the Platform team on an issue with iampostgres.go not being able to exit. Could we please discuss the desired outcome and how this will be testable and ensure no downstream effect?

@rogeruiz
Copy link
Contributor

rogeruiz commented Nov 7, 2022

Also, @jesset-truss I believe you're right here with the issue of how this will affect our DMS security solution with ECS. We should be leveraging the AppContext package and the DB Connection library from within our custom ECS solution. We should add this to our system architecture diagrams around our DMS ECS task solution.

@ahobson
Copy link
Contributor Author

ahobson commented Nov 7, 2022

@ahobson I think we might be moving quickly on this. I'm concerned this may have a downstream effect on to an issue that I'm currently working with others in the Platform team on an issue with iampostgres.go not being able to exit. Could we please discuss the desired outcome and how this will be testable and ensure no downstream effect?

Sure, but this isn't changing any behavior that would affect iampostgres.go, it's just about escaping the placeholder password. The reason iampostgres doesn't quit is because the code is using go channels and the code in dbconn.go isn't providing a way to quit even though the iampostgres code provides that capability.

I feel these are unrelated issues, but can work through how to fix the shutdown issue with you if you want

@reggieriser
Copy link
Contributor

Talked to @ahobson and decided to cherry-pick my previous Pop 6.0.8 changes from #9390 (which we reverted in #9534) into this PR since we'll need his IAM fixes from this PR, the Pop 6.0.8 upgrade changes, and the fixes I previously made in #9390 for Pop 6.0.8. We'll test all this together in experimental before we consider merging anything.

* Before the migration code expected in that certain errors would
  return both a connection and an error, which is very much not
  idomatic go and was confusing. Now we always retry, regardless of
  error.
Copy link
Contributor

@reggieriser reggieriser left a comment

Choose a reason for hiding this comment

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

LGTM! Walked through things with @ahobson and the latest code gets past all checks on experimental. Note that this PR has some of my code from #9390, but that had already been vetted in that PR.

@ahobson ahobson merged commit f2bd9da into main Nov 8, 2022
@ahobson ahobson deleted the adh-fix-pop-url-iam branch November 8, 2022 17:12
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

Successfully merging this pull request may close these issues.

5 participants