cd78f72f33
Complete rename of all technical identifiers across the codebase: Package names (11 packages): - @planarchy/* → @capakraken/* in all package.json, tsconfig, imports Import statements: 277 files, 548 occurrences replaced Database & Docker: - PostgreSQL user/db: planarchy → capakraken - Docker volumes: planarchy_pgdata → capakraken_pgdata - Connection strings updated in docker-compose, .env, CI CI/CD: - GitHub Actions workflow: all filter commands updated - Test database credentials updated Infrastructure: - Redis channel: planarchy:sse → capakraken:sse - Logger service name: planarchy-api → capakraken-api - Anonymization seed updated - Start/stop/restart scripts updated Test data: - Seed emails: @planarchy.dev → @capakraken.dev - E2E test credentials: all 11 spec files updated - Email defaults: @planarchy.app → @capakraken.app - localStorage keys: planarchy_* → capakraken_* Documentation: 30+ .md files updated Verification: - pnpm install: workspace resolution works - TypeScript: only pre-existing TS2589 (no new errors) - Engine: 310/310 tests pass - Staffing: 37/37 tests pass Co-Authored-By: claude-flow <ruv@ruv.net>
78 lines
2.5 KiB
TypeScript
78 lines
2.5 KiB
TypeScript
import { prisma } from "@capakraken/db";
|
|
|
|
type PrismaClient = typeof prisma;
|
|
|
|
export interface TaskActionResult {
|
|
success: boolean;
|
|
message: string;
|
|
}
|
|
|
|
export interface TaskActionHandler {
|
|
/** PermissionKey string value required to execute this action */
|
|
permission: string;
|
|
execute: (entityId: string, db: PrismaClient, executorId: string) => Promise<TaskActionResult>;
|
|
}
|
|
|
|
export const TASK_ACTION_REGISTRY: Record<string, TaskActionHandler> = {
|
|
approve_vacation: {
|
|
permission: "approveVacations",
|
|
execute: async (vacationId, db, _executorId) => {
|
|
const vacation = await db.vacation.findUnique({
|
|
where: { id: vacationId },
|
|
select: { id: true, status: true },
|
|
});
|
|
if (!vacation) return { success: false, message: "Vacation not found" };
|
|
if (vacation.status !== "PENDING") {
|
|
return { success: false, message: `Vacation is ${vacation.status}, not PENDING` };
|
|
}
|
|
await db.vacation.update({
|
|
where: { id: vacationId },
|
|
data: { status: "APPROVED" },
|
|
});
|
|
return { success: true, message: "Vacation approved" };
|
|
},
|
|
},
|
|
|
|
reject_vacation: {
|
|
permission: "approveVacations",
|
|
execute: async (vacationId, db, _executorId) => {
|
|
const vacation = await db.vacation.findUnique({
|
|
where: { id: vacationId },
|
|
select: { id: true, status: true },
|
|
});
|
|
if (!vacation) return { success: false, message: "Vacation not found" };
|
|
if (vacation.status !== "PENDING") {
|
|
return { success: false, message: `Vacation is ${vacation.status}, not PENDING` };
|
|
}
|
|
await db.vacation.update({
|
|
where: { id: vacationId },
|
|
data: { status: "REJECTED" },
|
|
});
|
|
return { success: true, message: "Vacation rejected" };
|
|
},
|
|
},
|
|
|
|
confirm_assignment: {
|
|
permission: "manageAllocations",
|
|
execute: async (assignmentId, db, _executorId) => {
|
|
const assignment = await db.assignment.findUnique({
|
|
where: { id: assignmentId },
|
|
select: { id: true, status: true },
|
|
});
|
|
if (!assignment) return { success: false, message: "Assignment not found" };
|
|
if (assignment.status === "CONFIRMED") {
|
|
return { success: false, message: "Assignment is already CONFIRMED" };
|
|
}
|
|
await db.assignment.update({
|
|
where: { id: assignmentId },
|
|
data: { status: "CONFIRMED" },
|
|
});
|
|
return { success: true, message: "Assignment confirmed" };
|
|
},
|
|
},
|
|
};
|
|
|
|
export function getTaskAction(actionName: string): TaskActionHandler | undefined {
|
|
return TASK_ACTION_REGISTRY[actionName];
|
|
}
|