Skip to content

Commit

Permalink
Merge pull request #4783 from FlowFuse/4781-case-insensitive-email-lo…
Browse files Browse the repository at this point in the history
…okup

Make email matching case insensitive for external invites
  • Loading branch information
hardillb authored Nov 15, 2024
2 parents e173733 + 34823a1 commit 2fc508e
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 7 deletions.
4 changes: 2 additions & 2 deletions forge/db/controllers/Invitation.js
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ module.exports = {
if (!invitedUser && invitation.external) {
// This won't have a full user object attached as they had not registered
// when the invitation was created.
if (user.email === invitation.email) {
if (user.email.toLowerCase() === invitation.email.toLowerCase()) {
invitedUser = user
}
}
Expand Down Expand Up @@ -144,7 +144,7 @@ module.exports = {
if (!invitedUser && invitation.external) {
// This won't have a full user object attached as they had not registered
// when the invitation was created.
if (user.email === invitation.email) {
if (user.email.toLowerCase() === invitation.email.toLowerCase()) {
invitedUser = user
}
}
Expand Down
11 changes: 8 additions & 3 deletions forge/db/models/Invitation.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const { DataTypes } = require('sequelize')
const { DataTypes, fn, col, Op, where } = require('sequelize')

const { generateToken } = require('../utils')

Expand Down Expand Up @@ -120,8 +120,13 @@ module.exports = {
forExternalEmail: async (email) => {
return this.findAll({
where: {
external: true,
email
[Op.and]: [
{ external: true },
where(
fn('lower', col('Invitation.email')),
email.toLowerCase()
)
]
},
include: [
{ model: M.Team, as: 'team' },
Expand Down
4 changes: 2 additions & 2 deletions test/unit/forge/routes/auth/index_spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -454,14 +454,14 @@ describe('Accounts API', async function () {
// Create existing team
const existingTeam = await app.factory.createTeam({ name: 'ExistingTeam' })
await existingTeam.addUser(app.adminUser, { through: { role: app.factory.Roles.Roles.Owner } })
// Alice invite External User to ExistingTeam
// Alice invite External User to ExistingTeam - note mixed case of email to ensure we match case-insensitive
await login('alice', 'aaPassword')
const inviteResponse = await app.inject({
method: 'POST',
url: `/api/v1/teams/${existingTeam.hashid}/invitations`,
cookies: { sid: TestObjects.tokens.alice },
payload: {
user: 'user6@example.com',
user: 'user6@EXAMPLE.com',
role: app.factory.Roles.Roles.Owner
}
})
Expand Down

0 comments on commit 2fc508e

Please sign in to comment.