-
Notifications
You must be signed in to change notification settings - Fork 5.6k
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
Unique repo path and permissions #8517
Unique repo path and permissions #8517
Conversation
Codecov Report
@@ Coverage Diff @@
## master #8517 +/- ##
==========================================
- Coverage 42.60% 42.59% -0.02%
==========================================
Files 176 183 +7
Lines 22941 23102 +161
==========================================
+ Hits 9774 9840 +66
- Misses 11770 11853 +83
- Partials 1397 1409 +12
Continue to review full report at Codecov.
|
958041d
to
81f7df8
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM!
81f7df8
to
7cecf78
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we go ahead an use the UUIDv4 path generator for this line, too?
argo-cd/reposerver/repository/repository.go
Line 758 in d7fbc91
file, err := ioutil.TempFile("", "values-*.yaml") |
@crenshaw-dev request about |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One small comment.
return "", err | ||
} | ||
tempDir := path.Join(os.TempDir(), newUUID.String()) | ||
if err := os.Mkdir(tempDir, 0755); err != nil { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do we need 755? Or just 700?
util/grpc/sanitizer.go
Outdated
for k, v := range s.replacements { | ||
val = strings.Replace(val, k, v, -1) | ||
} | ||
return val |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Rather than maintain the map everytime we clone a repo, I feel we could have a regexp replace this
func NewSanitizer(root string) {
return &sanitizer{
re: regexp.MustCompile(`(` + root + `/.*?)/`) // non-greedy until next slash after root
}
}
func (s *sanitizer) Replace(val string) string {
return s.re.ReplaceAllString(val, ".")
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To avoid missing relative paths, we could add a reasonably-unique prefix to the temp dir name and use a regex like this:
no-log-[0-9A-F]{8}-[0-9A-F]{4}-4[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}
(The end is just a regex for UUIDv4.)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Another benefit of a keyword-based replace would be that random paths outside the repo dir (like temporary values.yaml files' paths) could be sanitized as well.
empDir := path.Join(os.TempDir(), fmt.Sprintf("no-log-%s", newUUID.String()))
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Both approaches also help us completely avoid an attack where someone uses the sanitizer to leak valid paths by forcing errors containing lots of UUIDs. I think that attack is super impractical, but if we can solve two problems at once, great.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
New "sanitizer" is created and deleted every request. So this map will get 2~3 entries max.
Using the gprc interceptor and context was the least intrusive way to introduce sanitization. I really did not want to introduce a lot of copy-paste code. So it forced me to make sanitizer pretty generic . I think regex based sanitization will be useful. Implemented option suggested by @jessesuen because it is less coupled with how we generate unique paths .
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see that we sanitize the gRPC responses, but does this change sanitize the log outputs as well? Or do we not care?
…cation Signed-off-by: Alexander Matyushentsev <[email protected]>
…in active use Signed-off-by: Alexander Matyushentsev <[email protected]>
Signed-off-by: Alexander Matyushentsev <[email protected]>
…tory; change repo directory permissions Signed-off-by: Alexander Matyushentsev <[email protected]>
7cecf78
to
ec2e2c4
Compare
Signed-off-by: Alexander Matyushentsev <[email protected]>
ec2e2c4
to
278b27b
Compare
8687c23
to
4a1f628
Compare
Signed-off-by: Alexander Matyushentsev <[email protected]>
4a1f628
to
74001dd
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks a lot simpler than before. Thanks!
Unique repo path and permissions (#8517) Signed-off-by: Alexander Matyushentsev <[email protected]>
Unique repo path and permissions (argoproj#8517) Signed-off-by: Alexander Matyushentsev <[email protected]> Signed-off-by: wojtekidd <[email protected]>
Signed-off-by: Alexander Matyushentsev [email protected]
PR implements two changes: