-
Notifications
You must be signed in to change notification settings - Fork 365
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
feat: add CORS to SecurityPolicy #2065
Conversation
Signed-off-by: huabing zhao <zhaohuabing@gmail.com>
Signed-off-by: huabing zhao <zhaohuabing@gmail.com>
ec1822c
to
8497f86
Compare
ec11803
to
0e21c1d
Compare
ade088a
to
84add96
Compare
Signed-off-by: huabing zhao <zhaohuabing@gmail.com>
84add96
to
fc2b8ca
Compare
faa63b5
to
244afe8
Compare
46d164b
to
74f5b8d
Compare
Codecov Report
@@ Coverage Diff @@
## main #2065 +/- ##
==========================================
+ Coverage 65.01% 65.13% +0.12%
==========================================
Files 99 99
Lines 14536 14598 +62
==========================================
+ Hits 9450 9509 +59
- Misses 4498 4502 +4
+ Partials 588 587 -1
|
// CORS defines the configuration for Cross-Origin Resource Sharing (CORS). | ||
type CORS struct { | ||
// AllowOrigins defines the origins that are allowed to make requests. | ||
AllowOrigins []StringMatch `json:"allowOrigins,omitempty" yaml:"allowOrigins,omitempty"` |
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.
min length for AllowOrigins
should be 1
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 think an empty AllowOrigins could be useful if the backend service allows CORS but we want to explicitly disable it at the Gateway.
I remember we discussed this at the ir PR.
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.
not setting CORS
disables CORS :)
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.
Yes, it's a bit tricky. Maybe we should add some comments on the API.
// AllowOrigins defines the origins that are allowed to make requests. | ||
AllowOrigins []StringMatch `json:"allowOrigins,omitempty" yaml:"allowOrigins,omitempty"` | ||
// AllowMethods defines the methods that are allowed to make requests. | ||
AllowMethods []string `json:"allowMethods,omitempty" yaml:"allowMethods,omitempty"` |
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.
what happens when AllowMethods
is empty ?
are all requests types allowed or none ?
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.
None, just like empty AllowOrigins.
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 did some experiments, the CORS filter won't set "Access-Control-Request-Headers" in the preflight response if AllowMethods
is empty. So it means none Method Types are allowed.
curl -H "Origin: http://example.com" \
-H "Access-Control-Request-Method: GET" \
-H "Access-Control-Request-Headers: X-Requested-With" \
-X OPTIONS --verbose \
http://localhost:8002/cors/open
* Trying 127.0.0.1:8002...
* Connected to localhost (127.0.0.1) port 8002 (#0)
> OPTIONS /cors/open HTTP/1.1
> Host: localhost:8002
> User-Agent: curl/8.1.2
> Accept: */*
> Origin: http://example.com
> Access-Control-Request-Method: GET
> Access-Control-Request-Headers: X-Requested-With
>
< HTTP/1.1 200 OK
< access-control-allow-origin: http://example.com
< date: Wed, 25 Oct 2023 17:32:39 GMT
< server: envoy
< content-length: 0
<
* Connection #0 to host localhost left intact
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.
cool, so its opt in, thanks for running the test
looking good @zhaohuabing ! added some comments |
Signed-off-by: huabing zhao <zhaohuabing@gmail.com>
a657bfc
to
983c794
Compare
Signed-off-by: huabing zhao <zhaohuabing@gmail.com>
Signed-off-by: huabing zhao <zhaohuabing@gmail.com>
Signed-off-by: huabing zhao <zhaohuabing@gmail.com>
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 thanks !
Need to retrigger the coverage-test. |
/retest |
@@ -60,7 +60,7 @@ type ProxyPrometheusProvider struct { | |||
} | |||
|
|||
// Match defines the stats match configuration. | |||
type Match struct { | |||
type Match struct { // TODO: zhaohuabing this type should be renamed to StatsMatch |
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.
can you open an issue to track this?
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.
What this PR does:
Relate issues:
Related PRs:
BTW, the string match types are a bit messy. They're defined in multiple APIs but look similar. For most of EG APIs(Ratelimit and CORS for now, more in the future), the match types are just used to represent the StringMatcher XDS API. I think we can have one common string match structure used by all the EG APIs. I would like to raise a PR to refactor it if it makes sense.