-
-
Notifications
You must be signed in to change notification settings - Fork 752
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Added path and method in to express request for passport #1112
Conversation
+1 |
Thank you for the PR and fixing the test. I believe the const methodMap = {
find: 'GET',
get: 'GET',
create: 'POST',
update: 'PUT',
patch: 'PATCH',
remove: 'DELETE'
};
const httpMethod = methodMap[hook.method] || hook.method; |
@daffl You are right. I have added the normalization. Will the same be applicable to path also? Because normally express path is starting with a front slash and feathers path is not. Please share your thoughts. |
I don't think baking normalized method in is a good idea. At the least there should be the original feathers method somewhere.
And as far as path pased or method based strategies are concerned, can't they be done with hooks? export const authorize = () =>
iff(
every(ctx => !ctx.path.startsWith('auth'), isProvider('external')),
async ctx => {
let userPermissions = R.path(
['params', 'user', 'role', 'permissions'],
ctx
);
if (!userPermissions) {
throw new errors.Forbidden('This user has no permissions');
}
if (userPermissions) {
const hasPermissions = R.any(
p => p === `${ctx.path}:${ctx.method}`,
userPermissions
);
if (!hasPermissions) {
throw new errors.Forbidden('Not allowed to execute this action.');
}
}
return ctx;
}
); |
@subodhpareek18 This change is for the @fazilvp I think either way works, it depends what use-case prompted this PR. |
@daffl Path without slash is perfectly OK for our use-case. Let me know if you think any other changes are needed in this PR. |
@daffl that makes sense. Though I would still suggest the original feathersMethod can be passed without any normalization separately. But I guess that can always be done through middlewares for now. I'm having to do a similar thing for origin based auth. The code below is for an old app on feathers@2.x.x though export const rest = () => (req, res, next) => {
req.feathers = {
...req.feathers,
headers: req.headers,
origin: req.get('origin')
};
next();
};
export const socketio = () => (socket, next) => {
socket.feathers = {
...socket.feathers,
headers: socket.handshake.headers,
origin: socket.handshake.headers.origin
};
next();
}; |
Summary
This patch is for helping custom authentication strategy based on path and method. Presently we are not able to do it because these attributes are missing in request object. As per express documentation, an express request is supposed to have these fields.
Method: https://expressjs.com/en/api.html#req.method
Path: https://expressjs.com/en/api.html#req.path
But this fields are not included while creating an express like request object for passport in
@feathersjs/authentication hook.authenticate() function.
Currently there are no open issues for this.
This PR has no dependency to other PRs in other repos.