package status import ( "git.0x7f.app/WOJ/woj-server/internal/e" "git.0x7f.app/WOJ/woj-server/internal/model" "github.com/gin-gonic/gin" ) type queryOneRequest struct { SubmissionID uint `form:"sid" json:"sid" binding:"required"` } // QueryBySubmissionID // @Summary query status via submission id // @Description Query the detailed results of the judgement based on the submission ID. // @Tags status // @Accept application/x-www-form-urlencoded // @Produce json // @Param sid formData uint true "submission id" // @Response 200 {object} e.Response[model.Status] "submission status" // @Security Authentication // @Router /v1/status/query/submission [post] func (h *handler) QueryBySubmissionID(c *gin.Context) { claim, exist := c.Get("claim") if !exist { e.Pong[any](c, e.UserUnauthenticated, nil) return } req := new(queryOneRequest) if err := c.ShouldBind(req); err != nil { e.Pong(c, e.InvalidParameter, err.Error()) return } // query status submitStatus, status := h.statusService.Query(req.SubmissionID, true) if status != e.Success { e.Pong[any](c, status, nil) return } // check permission role := claim.(*model.Claim).Role uid := claim.(*model.Claim).UID if role >= model.RoleAdmin || submitStatus.Submission.UserID == uid { // full status e.Pong(c, status, submitStatus) return } else { // strip out code submitStatus.Submission.Code = "" e.Pong(c, status, submitStatus) return } }