-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathcleanup-team.js
More file actions
55 lines (45 loc) · 1.65 KB
/
cleanup-team.js
File metadata and controls
55 lines (45 loc) · 1.65 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
const mongoose = require('mongoose');
require('dotenv').config();
const TeamMember = require('./models/teamMemberModel');
async function cleanupDuplicates() {
try {
await mongoose.connect(process.env.MONGO_URL);
console.log('Connected to MongoDB\n');
// Find test members or duplicates
const testMembers = await TeamMember.find({
$or: [
{ displayName: /test/i },
{ displayName: /john doe/i },
{ category: /test/i },
{ email: /test@/i }
]
});
console.log(`Found ${testMembers.length} test/duplicate members:\n`);
testMembers.forEach((member, index) => {
console.log(`${index + 1}. ${member.displayName} (${member.email || 'no email'})`);
console.log(` ID: ${member._id}`);
console.log(` Member ID: ${member.memberId}\n`);
});
if (testMembers.length === 0) {
console.log('No test members found!');
process.exit(0);
}
// Delete all test members
const deleteResult = await TeamMember.deleteMany({
$or: [
{ displayName: /test/i },
{ displayName: /john doe/i },
{ category: /test/i },
{ email: /test@/i }
]
});
console.log(`\n✅ Deleted ${deleteResult.deletedCount} test members`);
await mongoose.disconnect();
console.log('Disconnected from MongoDB');
process.exit(0);
} catch (error) {
console.error('Error:', error);
process.exit(1);
}
}
cleanupDuplicates();