mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-11 00:08:30 +01:00
fix: inactive users query was too wide (#6133)
Knex wasn't formatting the query like I expected. This changes the query to use more AND, less ORs
This commit is contained in:
parent
ea38877b0c
commit
1da59abb2d
@ -42,20 +42,15 @@ export class InactiveUsersStore implements IInactiveUsersStore {
|
|||||||
)
|
)
|
||||||
.leftJoin(
|
.leftJoin(
|
||||||
'personal_access_tokens AS pat',
|
'personal_access_tokens AS pat',
|
||||||
'users.id',
|
|
||||||
'pat.user_id',
|
'pat.user_id',
|
||||||
|
'users.id',
|
||||||
)
|
)
|
||||||
.where('deleted_at', null)
|
.where('deleted_at', null)
|
||||||
.andWhereRaw(`users.seen_at < now() - INTERVAL '?? DAYS'`, [
|
|
||||||
daysInactive,
|
|
||||||
])
|
|
||||||
.orWhereRaw(
|
|
||||||
`users.seen_at IS NULL AND users.created_at < now() - INTERVAL '?? DAYS'`,
|
|
||||||
[daysInactive],
|
|
||||||
)
|
|
||||||
.andWhereRaw(
|
.andWhereRaw(
|
||||||
`pat.seen_at IS NULL OR pat.seen_at < now() - INTERVAL '?? DAYS'`,
|
`(users.seen_at IS NULL OR users.seen_at < now() - INTERVAL '?? days')
|
||||||
[daysInactive],
|
AND (users.created_at IS NULL OR users.created_at < now() - INTERVAL '?? days')
|
||||||
|
AND (pat.seen_at IS NULL OR pat.seen_at < now() - INTERVAL '?? days')`,
|
||||||
|
[daysInactive, daysInactive, daysInactive],
|
||||||
);
|
);
|
||||||
stopTimer();
|
stopTimer();
|
||||||
return inactiveUsers;
|
return inactiveUsers;
|
||||||
|
@ -110,7 +110,8 @@ describe('Inactive users service', () => {
|
|||||||
VALUES (9595, 'test user with active PAT', 'nedryerson', 'ned@ryerson.com',
|
VALUES (9595, 'test user with active PAT', 'nedryerson', 'ned@ryerson.com',
|
||||||
now() - INTERVAL '200 DAYS')`);
|
now() - INTERVAL '200 DAYS')`);
|
||||||
await db.rawDatabase.raw(
|
await db.rawDatabase.raw(
|
||||||
`INSERT INTO personal_access_tokens(secret, user_id, expires_at, seen_at, created_at) VALUES ('user:somefancysecret', 9595, now() + INTERVAL '6 MONTHS', now() - INTERVAL '1 WEEK', now() - INTERVAL '8 MONTHS')`,
|
`INSERT INTO personal_access_tokens(secret, user_id, expires_at, seen_at, created_at)
|
||||||
|
VALUES ('user:somefancysecret', 9595, now() + INTERVAL '6 MONTHS', now() - INTERVAL '1 WEEK', now() - INTERVAL '8 MONTHS')`,
|
||||||
);
|
);
|
||||||
const users = await inactiveUserService.getInactiveUsers();
|
const users = await inactiveUserService.getInactiveUsers();
|
||||||
expect(users).toBeTruthy();
|
expect(users).toBeTruthy();
|
||||||
@ -127,6 +128,17 @@ describe('Inactive users service', () => {
|
|||||||
expect(users).toBeTruthy();
|
expect(users).toBeTruthy();
|
||||||
expect(users).toHaveLength(1);
|
expect(users).toHaveLength(1);
|
||||||
});
|
});
|
||||||
|
test('A user with a pat that was seen 7 months ago, but logged in yesterday should not be inactive', async () => {
|
||||||
|
await db.rawDatabase.raw(
|
||||||
|
`INSERT INTO users(id, name, username, email, created_at, seen_at) VALUES (9595, 'test user with active login and old PAT', 'nedryerson', 'ned@ryerson.com', now() - INTERVAL '1 YEAR', now() - INTERVAL '1 DAY')`,
|
||||||
|
);
|
||||||
|
await db.rawDatabase.raw(
|
||||||
|
`INSERT INTO personal_access_tokens(secret, user_id, expires_at, seen_at, created_at) VALUES ('user:somefancysecret', 9595, now() + INTERVAL '6 MONTHS', now() - INTERVAL '7 MONTHS', now() - INTERVAL '8 MONTHS')`,
|
||||||
|
);
|
||||||
|
const users = await inactiveUserService.getInactiveUsers();
|
||||||
|
expect(users).toBeTruthy();
|
||||||
|
expect(users).toHaveLength(0);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
describe('Deleting inactive users', () => {
|
describe('Deleting inactive users', () => {
|
||||||
test('Deletes users that have never logged in but was created before our deadline', async () => {
|
test('Deletes users that have never logged in but was created before our deadline', async () => {
|
||||||
|
Loading…
Reference in New Issue
Block a user