fix(backend): group toch niet deel van primaire sleutel van vragen en submissions gemaakt, maar verplicht veld
This commit is contained in:
parent
b1df95da63
commit
7b79348985
10 changed files with 21 additions and 20 deletions
|
@ -4,7 +4,6 @@ import { FALLBACK_LANG, FALLBACK_SEQ_NUM } from '../config.js';
|
|||
import { LearningObjectIdentifier } from '../entities/content/learning-object-identifier.js';
|
||||
import { QuestionDTO, QuestionId } from '@dwengo-1/common/interfaces/question';
|
||||
import { Language } from '@dwengo-1/common/util/language';
|
||||
import {getGroup} from "../services/groups";
|
||||
|
||||
function getObjectId(req: Request, res: Response): LearningObjectIdentifier | null {
|
||||
const { hruid, version } = req.params;
|
||||
|
@ -22,18 +21,16 @@ function getObjectId(req: Request, res: Response): LearningObjectIdentifier | nu
|
|||
};
|
||||
}
|
||||
|
||||
async function getQuestionId(req: Request, res: Response): Promise<QuestionId | null> {
|
||||
const { seq, classId, assignmentId, groupId } = req.params
|
||||
function getQuestionId(req: Request, res: Response): QuestionId | null {
|
||||
const seq = req.params.seq;
|
||||
const learningObjectIdentifier = getObjectId(req, res);
|
||||
const groupIdentifier = await getGroup(classId, parseInt(assignmentId), parseInt(groupId), false);
|
||||
|
||||
if (!learningObjectIdentifier || !groupIdentifier) {
|
||||
if (!learningObjectIdentifier) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return {
|
||||
learningObjectIdentifier,
|
||||
inGroup: groupIdentifier,
|
||||
sequenceNumber: seq ? Number(seq) : FALLBACK_SEQ_NUM,
|
||||
};
|
||||
}
|
||||
|
@ -56,7 +53,7 @@ export async function getAllQuestionsHandler(req: Request, res: Response): Promi
|
|||
}
|
||||
|
||||
export async function getQuestionHandler(req: Request, res: Response): Promise<void> {
|
||||
const questionId = await getQuestionId(req, res);
|
||||
const questionId = getQuestionId(req, res);
|
||||
|
||||
if (!questionId) {
|
||||
return;
|
||||
|
@ -72,7 +69,7 @@ export async function getQuestionHandler(req: Request, res: Response): Promise<v
|
|||
}
|
||||
|
||||
export async function getQuestionAnswersHandler(req: Request, res: Response): Promise<void> {
|
||||
const questionId = await getQuestionId(req, res);
|
||||
const questionId = getQuestionId(req, res);
|
||||
const full = req.query.full === 'true';
|
||||
|
||||
if (!questionId) {
|
||||
|
@ -106,7 +103,7 @@ export async function createQuestionHandler(req: Request, res: Response): Promis
|
|||
}
|
||||
|
||||
export async function deleteQuestionHandler(req: Request, res: Response): Promise<void> {
|
||||
const questionId = await getQuestionId(req, res);
|
||||
const questionId = getQuestionId(req, res);
|
||||
|
||||
if (!questionId) {
|
||||
return;
|
||||
|
|
|
@ -22,8 +22,7 @@ export class Submission {
|
|||
submissionNumber?: number;
|
||||
|
||||
@ManyToOne({
|
||||
entity: () => Group,
|
||||
primary: true
|
||||
entity: () => Group
|
||||
})
|
||||
onBehalfOf!: Group;
|
||||
|
||||
|
|
|
@ -21,7 +21,7 @@ export class Question {
|
|||
@PrimaryKey({ type: 'integer', autoincrement: true })
|
||||
sequenceNumber?: number;
|
||||
|
||||
@ManyToOne({ entity: () => Group, primary: true })
|
||||
@ManyToOne({ entity: () => Group })
|
||||
inGroup!: Group;
|
||||
|
||||
@ManyToOne({
|
||||
|
|
|
@ -33,7 +33,6 @@ export function mapToQuestionDTOId(question: Question): QuestionId {
|
|||
|
||||
return {
|
||||
learningObjectIdentifier,
|
||||
inGroup: mapToGroupDTO(question.inGroup),
|
||||
sequenceNumber: question.sequenceNumber!,
|
||||
};
|
||||
}
|
||||
|
|
|
@ -38,7 +38,6 @@ export function mapToSubmission(submissionDTO: SubmissionDTO): Submission {
|
|||
submission.submitter = mapToStudent(submissionDTO.submitter);
|
||||
// Submission.submissionTime = submissionDTO.time;
|
||||
// Submission.onBehalfOf = submissionDTO.group!;
|
||||
// TODO fix group
|
||||
submission.content = submissionDTO.content;
|
||||
|
||||
return submission;
|
||||
|
|
|
@ -15,11 +15,11 @@ router.get('/', getAllQuestionsHandler);
|
|||
|
||||
router.post('/', createQuestionHandler);
|
||||
|
||||
router.delete('/:classId/assignment/:assignmentId/group/:groupId/:seq', deleteQuestionHandler);
|
||||
router.delete('/:seq', deleteQuestionHandler);
|
||||
|
||||
// Information about a question with id
|
||||
router.get('/:classId/assignment/:assignmentId/group/:groupId/:seq', getQuestionHandler);
|
||||
router.get('/:seq', getQuestionHandler);
|
||||
|
||||
router.get('/:classId/assignment/:assignmentId/group/:groupId/answers/:seq', getQuestionAnswersHandler);
|
||||
router.get('/answers/:seq', getQuestionAnswersHandler);
|
||||
|
||||
export default router;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue