-
-
Notifications
You must be signed in to change notification settings - Fork 753
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
When using custom authentication service paths, express+rest doesn't parse authorization header by default #1415
Comments
Interesting - I'm using custom services and not seeing this behavior. |
If the configuration key and service path are the same this will work automatically. So in @nborko's case, app.use('/custom/authentication', authService)
app.set('defaultAuthentication', '/custom/authenticaton'); |
Why do we need to have a So, if I have 2 auth services, and I'm using explicit configurations like the OP is doing, I either need to name my app.set config setting the same as the service endpoint or set a defaultAuthentication? e.g.
if I had called my config |
In my case, the actual config key doesn't match the service name. My example did for the sake of simplicity in explaining the issue. In actuality my configurations are generated programmatically because my services are also generated dynamically from a database. The generated service names are something like 'foo/service' and 'bar/service' for the same service for two different databases and sites, both using the same models. They don't share a common authentication configuration: the entity services are different, as are the secrets etc. So although I recognize that in a simple case you can explicitly set the defaultAuthentication service, that doesn't work for me. So I'm not really lamenting the complexity of what I need to do to support such a scheme, but I wanted to point out that there's an extra, undocumented step that's needed if you don't want/use a default authentication service and/or configuration. |
Allright. I added a fix for this in #1470 because that restriction was indeed weird. With those changes it should always reliable find the default service we want. |
For 4.0.0 (crow):
I have a case where I'm using express and rest services only. I have multiple authentication service paths (though you only need to set up any one custom service path) with their own configuration keys, and therefore no default authentication service. For example,
(also all my services under this authentication service are subpaths of /custom)
Anything using the authenticate hook, e.g.
gets a 401, because at no point does the Authorization header get parsed.
After tracing the source, I resolved this by adding the following line:
Since custom service points and configurations is prominently highlighted in the documentation, at the very least this needs to be documented, since it's a pretty huge gotcha (and took me hours to track down). It would be even better to take care of this when app.use is called to add the authentication service, but that would probably require extra configuration information.
The text was updated successfully, but these errors were encountered: