From b3b45f328c86a208dcc907123287c4b8acea9391 Mon Sep 17 00:00:00 2001 From: Ian Bolton Date: Mon, 15 Jan 2024 17:40:49 -0500 Subject: [PATCH] :ghost: Add questionnare required field to assessment (#588) This is needed to aid UI in computing status for an assessment given a questionnaire is marked as not required. If an assessment exists for an archived questionnaire on an app or archetype, the assessment status is no longer valid & the assessment will need to be filtered from status consideration. https://issues.redhat.com/browse/MTA-1956 Signed-off-by: ibolton336 --- api/application.go | 2 +- api/archetype.go | 2 +- api/assessment.go | 2 ++ 3 files changed, 4 insertions(+), 2 deletions(-) diff --git a/api/application.go b/api/application.go index 5de64271c..c8a1bb653 100644 --- a/api/application.go +++ b/api/application.go @@ -959,7 +959,7 @@ func (h ApplicationHandler) StakeholdersUpdate(ctx *gin.Context) { func (h ApplicationHandler) AssessmentList(ctx *gin.Context) { m := &model.Application{} id := h.pk(ctx) - db := h.preLoad(h.DB(ctx), clause.Associations, "Assessments.Stakeholders", "Assessments.StakeholderGroups") + db := h.preLoad(h.DB(ctx), clause.Associations, "Assessments.Stakeholders", "Assessments.StakeholderGroups", "Assessments.Questionnaire") db = db.Omit("Analyses") result := db.First(m, id) if result.Error != nil { diff --git a/api/archetype.go b/api/archetype.go index c1c6dea91..f647395ec 100644 --- a/api/archetype.go +++ b/api/archetype.go @@ -254,7 +254,7 @@ func (h ArchetypeHandler) Update(ctx *gin.Context) { func (h ArchetypeHandler) AssessmentList(ctx *gin.Context) { m := &model.Archetype{} id := h.pk(ctx) - db := h.preLoad(h.DB(ctx), clause.Associations, "Assessments.Stakeholders", "Assessments.StakeholderGroups") + db := h.preLoad(h.DB(ctx), clause.Associations, "Assessments.Stakeholders", "Assessments.StakeholderGroups", "Assessments.Questionnaire") result := db.First(m, id) if result.Error != nil { _ = ctx.Error(result.Error) diff --git a/api/assessment.go b/api/assessment.go index 4f34de7d9..ee1d73631 100644 --- a/api/assessment.go +++ b/api/assessment.go @@ -164,6 +164,7 @@ type Assessment struct { Status string `json:"status"` Thresholds assessment.Thresholds `json:"thresholds"` RiskMessages assessment.RiskMessages `json:"riskMessages" yaml:"riskMessages"` + Required bool `json:"required"` } // @@ -187,6 +188,7 @@ func (r *Assessment) With(m *model.Assessment) { } a := assessment.Assessment{} a.With(m) + r.Required = a.Questionnaire.Required r.Risk = a.Risk() r.Confidence = a.Confidence() r.RiskMessages = a.RiskMessages