2024-08-14 20:33:40 +00:00
import { db } from "@/lib/db"
import { NextResponse } from "next/server" ;
import fetchUserWithImpersonation from "@/lib/fetch-user-impersonation" ;
2024-08-25 21:35:46 +00:00
import { z } from "zod" ;
2024-08-14 20:33:40 +00:00
export async function GET ( req : Request ) {
try {
const user = await fetchUserWithImpersonation ( req )
if ( ! user ) {
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'Unauthorized.' , error : null , value : null } , { status : 401 } ) ;
2024-08-14 20:33:40 +00:00
}
const actions = await db . group . findMany ( {
where : {
userId : user.id
}
} )
2024-08-25 21:35:46 +00:00
return NextResponse . json ( actions . map ( ( { userId , . . . attrs } ) = > attrs ) ) ;
2024-08-14 20:33:40 +00:00
} catch ( error ) {
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'Something went wrong' , error : error , value : null } , { status : 500 } )
2024-08-14 20:33:40 +00:00
}
}
2024-08-25 21:35:46 +00:00
const groupNameSchema = z . string ( {
required_error : "Group name is required." ,
invalid_type_error : "Group name must be a string"
} ) . regex ( /^[\w\-\s]{1,20}$/ , "Group name must contain only letters, numbers, spaces, dashes, and underscores." )
2024-08-14 20:33:40 +00:00
export async function POST ( req : Request ) {
try {
const user = await fetchUserWithImpersonation ( req )
if ( ! user ) {
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'Unauthorized.' , error : null , value : null } , { status : 401 } ) ;
2024-08-14 20:33:40 +00:00
}
const { name , priority } : { name : string , priority : number } = await req . json ( ) ;
if ( ! name )
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'name does not exist.' , error : null , value : null } , { status : 400 } ) ;
const groupNameValidation = await groupNameSchema . safeParseAsync ( name )
if ( ! groupNameValidation . success )
return NextResponse . json ( { message : 'name does not meet requirements.' , error : JSON.parse ( groupNameValidation . error [ 'message' ] ) [ 0 ] , value : null } , { status : 400 } )
2024-08-14 20:33:40 +00:00
const group = await db . group . create ( {
data : {
userId : user.id ,
name : name.toLowerCase ( ) ,
priority
}
} ) ;
return NextResponse . json ( group , { status : 200 } ) ;
} catch ( error ) {
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'Something went wrong' , error : error , value : null } , { status : 500 } )
2024-08-14 20:33:40 +00:00
}
}
export async function PUT ( req : Request ) {
try {
const user = await fetchUserWithImpersonation ( req )
if ( ! user ) {
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'Unauthorized.' , error : null , value : null } , { status : 401 } ) ;
2024-08-14 20:33:40 +00:00
}
const { id , name , priority } : { id : string , name : string , priority : number } = await req . json ( ) ;
if ( ! id )
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'id does not exist.' , error : null , value : null } , { status : 400 } ) ;
2024-08-14 20:33:40 +00:00
if ( ! name && ! priority )
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'Either name or priority must not be null.' , error : null , value : null } , { status : 400 } ) ;
if ( name ) {
const groupNameValidation = await groupNameSchema . safeParseAsync ( name )
if ( ! groupNameValidation . success )
return NextResponse . json ( { message : 'name does not meet requirements.' , error : JSON.parse ( groupNameValidation . error [ 'message' ] ) [ 0 ] , value : null } , { status : 400 } )
}
2024-08-14 20:33:40 +00:00
let data : any = { }
2024-08-25 21:35:46 +00:00
if ( name )
2024-08-14 20:33:40 +00:00
data = { . . . data , name : name.toLowerCase ( ) }
2024-08-25 21:35:46 +00:00
if ( priority )
2024-08-14 20:33:40 +00:00
data = { . . . data , priority }
const group = await db . group . update ( {
where : {
id
} ,
data : data
} ) ;
return NextResponse . json ( group , { status : 200 } ) ;
} catch ( error ) {
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'Something went wrong' , error : error , value : null } , { status : 500 } )
2024-08-14 20:33:40 +00:00
}
}
export async function DELETE ( req : Request ) {
try {
const user = await fetchUserWithImpersonation ( req )
if ( ! user ) {
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'Unauthorized.' , error : null , value : null } , { status : 401 } ) ;
2024-08-14 20:33:40 +00:00
}
const { searchParams } = new URL ( req . url )
const id = searchParams . get ( 'id' ) as string
const group = await db . group . delete ( {
where : {
id
}
} )
return NextResponse . json ( group ) ;
} catch ( error ) {
2024-08-25 21:35:46 +00:00
return NextResponse . json ( { message : 'Something went wrong' , error : error , value : null } , { status : 500 } )
2024-08-14 20:33:40 +00:00
}
}