update: revision for endpoint get average score aspect and grouping sub aspect, revision permission access for assessments

This commit is contained in:
falendikategar 2024-10-17 09:20:58 +07:00
parent 9b71ecbef3
commit a799769af2
2 changed files with 65 additions and 35 deletions

View File

@ -83,13 +83,16 @@ const permissionsData = [
{
code: "assessmentResult.create",
},
{
{
code: "assessmentRequest.read",
},
{
code: "assessmentRequest.create",
},
{
},
{
code: "assessments.readAspect",
},
{
code: "assessments.readAssessmentScore",
},
{

View File

@ -45,7 +45,7 @@ const assessmentsRoute = new Hono<HonoEnv>()
// Get all aspects
.get(
"/aspect",
// checkPermission("managementAspect.readAll"),
checkPermission("assessments.readAspect"),
requestValidator(
"query",
z.object({
@ -172,7 +172,7 @@ const assessmentsRoute = new Hono<HonoEnv>()
// Get data for current Assessment Score from submitted options By Assessment Id
.get(
"/getCurrentAssessmentScore",
// checkPermission("assessments.readAssessmentScore"),
checkPermission("assessments.readAssessmentScore"),
requestValidator(
"query",
z.object({
@ -599,7 +599,7 @@ const assessmentsRoute = new Hono<HonoEnv>()
// Get data for One Sub Aspect average score By Sub Aspect Id and Assessment Id
.get(
'/average-score/sub-aspects/:subAspectId/assessments/:assessmentId',
// checkPermission("assessments.readAssessmentScore"),
checkPermission("assessments.readAssessmentScore"),
async (c) => {
const { subAspectId, assessmentId } = c.req.param();
@ -630,7 +630,7 @@ const assessmentsRoute = new Hono<HonoEnv>()
// Get data for All Sub Aspects average score By Assessment Id
.get(
'/average-score/sub-aspects/assessments/:assessmentId',
// checkPermission("assessments.readAssessmentScore"),
checkPermission("assessments.readAssessmentScore"),
async (c) => {
const { assessmentId } = c.req.param();
@ -664,7 +664,7 @@ const assessmentsRoute = new Hono<HonoEnv>()
// Get data for One Aspect average score By Aspect Id and Assessment Id
.get(
"/average-score/aspects/:aspectId/assessments/:assessmentId",
// checkPermission("assessments.readAverageAspect"),
checkPermission("assessments.readAssessmentScore"),
async (c) => {
const { aspectId, assessmentId } = c.req.param();
@ -693,36 +693,63 @@ const assessmentsRoute = new Hono<HonoEnv>()
}
)
// Get data for All Aspects average score By Assessment Id
// Get data for Aspects average score and all related Sub Aspects average score By Assessment Id
.get(
'/average-score/aspects/assessments/:assessmentId',
// checkPermission("assessments.readAssessmentScore"),
checkPermission("assessments.readAssessmentScore"),
async (c) => {
const { assessmentId } = c.req.param();
const averageScores = await db
.select({
AspectId: aspects.id,
AspectName: aspects.name,
average: sql`AVG(options.score)`
})
.from(answers)
.innerJoin(options, eq(answers.optionId, options.id))
.innerJoin(questions, eq(options.questionId, questions.id))
.innerJoin(subAspects, eq(questions.subAspectId, subAspects.id))
.innerJoin(aspects, eq(subAspects.aspectId, aspects.id))
.innerJoin(assessments, eq(answers.assessmentId, assessments.id))
.where(eq(assessments.id, assessmentId))
.groupBy(aspects.id);
return c.json({
assessmentId,
aspects: averageScores.map(score => ({
AspectId: score.AspectId,
AspectName: score.AspectName,
averageScore: score.average
}))
});
const { assessmentId } = c.req.param();
// Query untuk mendapatkan average score per aspect
const aspectScores = await db
.select({
aspectId: aspects.id,
aspectName: aspects.name,
averageScore: sql`AVG(options.score)`,
})
.from(answers)
.innerJoin(options, eq(answers.optionId, options.id))
.innerJoin(questions, eq(options.questionId, questions.id))
.innerJoin(subAspects, eq(questions.subAspectId, subAspects.id))
.innerJoin(aspects, eq(subAspects.aspectId, aspects.id))
.innerJoin(assessments, eq(answers.assessmentId, assessments.id))
.where(eq(assessments.id, assessmentId))
.groupBy(aspects.id);
// Query untuk mendapatkan average score per sub-aspect
const subAspectScores = await db
.select({
aspectId: subAspects.aspectId,
subAspectId: subAspects.id,
subAspectName: subAspects.name,
averageScore: sql`AVG(options.score)`,
})
.from(answers)
.innerJoin(options, eq(answers.optionId, options.id))
.innerJoin(questions, eq(options.questionId, questions.id))
.innerJoin(subAspects, eq(questions.subAspectId, subAspects.id))
.innerJoin(assessments, eq(answers.assessmentId, assessments.id))
.where(eq(assessments.id, assessmentId))
.groupBy(subAspects.id);
// Menggabungkan sub-aspects ke dalam masing-masing aspect
const aspectsWithSubAspects = aspectScores.map((aspect) => ({
aspectId: aspect.aspectId,
aspectName: aspect.aspectName,
averageScore: aspect.averageScore,
subAspects: subAspectScores
.filter((sub) => sub.aspectId === aspect.aspectId)
.map((sub) => ({
subAspectId: sub.subAspectId,
subAspectName: sub.subAspectName,
averageScore: sub.averageScore,
})),
}));
return c.json({
assessmentId,
aspects: aspectsWithSubAspects,
});
}
)