Merge pull request 'Refactor time variable and exclude system users' (#1) from fsb/misskey-gooner-remover:time_and_exclusions into main
Reviewed-on: #1
This commit is contained in:
commit
7c08cf12d4
1 changed files with 10 additions and 6 deletions
12
main.js
12
main.js
|
@ -8,6 +8,8 @@ if (!USER_TOKEN) {
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const PERIOD = process.env.PERIOD; // Time in days: int
|
||||||
|
|
||||||
const INSTANCE_URL = process.env.INSTANCE_URL;
|
const INSTANCE_URL = process.env.INSTANCE_URL;
|
||||||
const API_BASE = `${INSTANCE_URL}/api`;
|
const API_BASE = `${INSTANCE_URL}/api`;
|
||||||
|
|
||||||
|
@ -49,17 +51,19 @@ async function main() {
|
||||||
|
|
||||||
const users = response.data;
|
const users = response.data;
|
||||||
const now = new Date();
|
const now = new Date();
|
||||||
const fiveDaysAgo = new Date(now - 5 * 24 * 60 * 60 * 1000);
|
const timeAgo = new Date(now - PERIOD * 24 * 60 * 60 * 1000);
|
||||||
|
|
||||||
const usersToDelete = users.filter(user => {
|
const usersToDelete = users.filter(user => {
|
||||||
const createdAt = new Date(user.createdAt);
|
const createdAt = new Date(user.createdAt);
|
||||||
const updatedAt = new Date(user.updatedAt);
|
const updatedAt = new Date(user.updatedAt);
|
||||||
|
const excludedUsers = ['instance.actor', 'relay.actor'];
|
||||||
return user.notesCount === 0 &&
|
return user.notesCount === 0 &&
|
||||||
createdAt < fiveDaysAgo &&
|
createdAt < timeAgo &&
|
||||||
updatedAt < fiveDaysAgo;
|
updatedAt < timeAgo &&
|
||||||
|
!excludedUsers.includes(user.username)
|
||||||
});
|
});
|
||||||
|
|
||||||
console.log(`Found ${usersToDelete.length} users matching criteria (no posts, not updated, and older than 5 days)`);
|
console.log(`Found ${usersToDelete.length} users matching criteria (no posts, not updated, and older than ${PERIOD} days)`);
|
||||||
|
|
||||||
console.log('\nUsers to be deleted:');
|
console.log('\nUsers to be deleted:');
|
||||||
usersToDelete.forEach(user => {
|
usersToDelete.forEach(user => {
|
||||||
|
|
Loading…
Reference in a new issue