Skip to content

Commit

Permalink
Don't pass the request headers to 3scale backend in native OAuth flow
Browse files Browse the repository at this point in the history
  • Loading branch information
mayorova committed Sep 29, 2017
1 parent 111f5e7 commit 772c46d
Show file tree
Hide file tree
Showing 3 changed files with 86 additions and 1 deletion.
6 changes: 5 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,13 +11,17 @@ and this project adheres to [Semantic Versioning](http://semver.org/).
- Upgraded to OpenResty 1.11.2.5-1 [PR #428](https://github.com/3scale/apicast/pull/428)
- `/oauth/token` endpoint returns an error status code, when the access token couldn't be stored in 3scale backend [PR #436](https://github.com/3scale/apicast/pull/436)]

### Fixed

- Request headers are not passed to the backend, preventing sending invalid Content-Type to the access token store endpoint [PR #433](https://github.com/3scale/apicast/pull/433)

## [3.1.0-rc1] - 2017-09-14

### Added

- Support for extending APIcast location block with snippets of nginx configuration [PR #407](https://github.com/3scale/apicast/pull/407)

### Fixes
### Fixed

- Crash on empty OIDC Issuer endpoint [PR #408](https://github.com/3scale/apicast/pull/408)
- Handle partial credentials [PR #409](https://github.com/3scale/apicast/pull/409)
Expand Down
2 changes: 2 additions & 0 deletions apicast/conf.d/apicast.conf
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@ location / {

location = /_threescale/oauth_store_token {
internal;
proxy_pass_request_headers off;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host "$backend_host";
Expand All @@ -108,6 +109,7 @@ location = /_threescale/oauth_store_token {
location = /_threescale/check_credentials {
internal;

proxy_pass_request_headers off;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host "$backend_host";
Expand Down
79 changes: 79 additions & 0 deletions t/005-apicast-oauth.t
Original file line number Diff line number Diff line change
Expand Up @@ -715,3 +715,82 @@ GET /t
--- no_error_log
[error]

=== TEST 18: when calling /oauth/token request headers are not passed to the backend
--- main_config
env REDIS_HOST=$TEST_NGINX_REDIS_HOST;
env RESOLVER=$TEST_NGINX_RESOLVER;
--- http_config
lua_package_path "$TEST_NGINX_LUA_PATH";
init_by_lua_block {
require('configuration_loader').mock({
services = {
{ id = 42, backend_version = 'oauth' }
}
})
}
--- config
include $TEST_NGINX_APICAST_CONFIG;

lua_need_request_body on;
location = /t {
content_by_lua_block {
local authorize = require('oauth.apicast_oauth.authorize')
local authorized_callback = require('oauth.apicast_oauth.authorized_callback')
local code = 'authcode'
local params = { user_id = 'someuser' }
local client_data = {
client_id = 'foo',
secret_id = 'bar',
redirect_uri = 'redirect',
access_token = 'token'
}
assert(authorized_callback.persist_code(client_data, params, code))
ngx.req.set_method(ngx.HTTP_POST)
ngx.req.set_body_data('grant_type=authorization_code&client_id=foo&client_secret=bar&redirect_uri=redirect&code=' .. code)
ngx.exec('/oauth/token')
}
}
set $backend_endpoint 'http://127.0.0.1:$TEST_NGINX_SERVER_PORT/backend';
set $backend_host '127.0.0.1';
set $service_id 42;
set $backend_authentication_type 'provider_key';
set $backend_authentication_value 'fookey';
location = /backend/transactions/oauth_authorize.xml {
content_by_lua_block {
expected = "provider_key=fookey&service_id=42&app_key=bar&app_id=foo&redirect_uri=redirect"
if ngx.var.args == expected and ngx.var.host == ngx.var.backend_host then
ngx.say('<?xml version="1.0" encoding="UTF-8"?><status><authorized>true</authorized><application><key>bar</key></application></status>')
ngx.exit(200)
else
ngx.log(ngx.ERR, 'expected: ' .. expected .. ' got: ' .. ngx.var.args)
ngx.exit(403)
end
}
}

location = /backend/services/42/oauth_access_tokens.xml {
content_by_lua_block {
if ngx.var.http_content_type then
ngx.log(ngx.ERR, 'Invalid Content-Type: ', ngx.var.http_content_type)
ngx.status = 400
ngx.print('invalid content-type')
ngx.exit(400)
else
ngx.exit(200)
end
}
}

--- request
GET /t
--- more_headers
Content-Type: application/json
--- error_code: 200
--- response_body
{"token_type":"bearer","expires_in":604800,"access_token":"token"}
--- no_error_log
[error]

0 comments on commit 772c46d

Please sign in to comment.