summaryrefslogtreecommitdiff
path: root/lib/swp/project-utils.ts
blob: 682c8da0dcb667eea45d0e29a2aa37495340f47c (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
40
41
42
43
44
45
46
47
// lib/swp/project-utils.ts
import db from "@/db/db"
import { projects } from "@/db/schema"
import { eq } from "drizzle-orm"

/**
 * 프로젝트 코드(PROJ_NO)로 프로젝트 ID 조회
 * 
 * @param projectCode - 프로젝트 코드 (PROJ_NO)
 * @returns 프로젝트 ID 또는 null
 */
export async function getProjectIdByCode(projectCode: string): Promise<number | null> {
  try {
    const [project] = await db
      .select({ id: projects.id })
      .from(projects)
      .where(eq(projects.code, projectCode))
      .limit(1)

    return project?.id || null
  } catch (error) {
    console.error(`❌ 프로젝트 ID 조회 실패 (코드: ${projectCode}):`, error)
    return null
  }
}

/**
 * 프로젝트 코드로 프로젝트 전체 정보 조회
 * 
 * @param projectCode - 프로젝트 코드 (PROJ_NO)
 * @returns 프로젝트 정보 또는 null
 */
export async function getProjectByCode(projectCode: string) {
  try {
    const [project] = await db
      .select()
      .from(projects)
      .where(eq(projects.code, projectCode))
      .limit(1)

    return project || null
  } catch (error) {
    console.error(`❌ 프로젝트 정보 조회 실패 (코드: ${projectCode}):`, error)
    return null
  }
}