vuesion/vuesion

View on GitHub
_templates/new/crud-entity/server.[id].delete.ts.t

Summary

Maintainability
Test Coverage
---
to: "src/server/api/<%= h.inflection.dasherize(h.inflection.underscore(name)) %>/[id].delete.ts"
unless_exists: true
---
import { defineEventHandler } from 'h3';
import { PrismaClient } from '@prisma/client';
<% if(auth === true) { -%>
import { getServerSession } from '#auth';
import { checkUserSession, checkUserAuthorization } from '~/server/utils/accessControl';
<% } %>
export default defineEventHandler(async (event) => {
<% if(auth === true) { -%>
  const session = await getServerSession(event);

  checkUserSession(session);

<% } -%>
  const <%= h.inflection.camelize(name, true) %>Id = event.context.params?.id;
  const prisma = new PrismaClient();
  <% if(auth === true) { -%>
const current<%= h.inflection.camelize(name) %> = await prisma.<%= h.inflection.camelize(name, true) %>.findFirst({ where: { id: <%= h.inflection.camelize(name, true) %>Id } });

  checkUserAuthorization(session?.user?.id, current<%= h.inflection.camelize(name) %>?.ownerId);
  <% } %>
  return prisma.<%= h.inflection.camelize(name, true) %>.delete({ where: { id: <%= h.inflection.camelize(name, true) %>Id } });
});