summaryrefslogtreecommitdiff
path: root/db/seeds_2/userSeed.ts
blob: c0258d5e2706c8572afa9de95ef6cd318a2e7ef7 (plain)
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
import db from "@/db/db"
import { NewUser } from "@/lib/admin-users/repository"
import { faker } from "@faker-js/faker"
import { users } from "../schema/users"

function generateRandomUser(): NewUser {
  return {
    name: faker.person.fullName(),        // 또는 faker.company.name()
    email: faker.internet.email(),        // 필수 notNull 필드
    domain: "evcp",                      // domain을 evcp로 고정
    companyId: null,                     // companyId는 null로(빈칸)
    imageUrl: null,                      // imageUrl은 null로(빈칸)
    createdAt: faker.date.past()         // 과거 임의 날짜
  }
}

export async function seedUsers(input: { count: number }) {
  try {
    const allUsers: NewUser[] = []

    for (let i = 0; i < input.count; i++) {
      allUsers.push(generateRandomUser())
    }

    console.log("📝 Inserting users", allUsers.length)

    // onConflictDoNothing을 사용하여 중복되는 데이터는 건너뛰고 새로운 데이터만 추가
    const result = await db.insert(users)
      .values(allUsers)
      .onConflictDoNothing()
      .returning()

    console.log(`✅ Successfully added ${result.length} new users`)
    return result
  } catch (err) {
    console.error("Failed to seed users:", err)
    throw err
  }
}