gonito/Handler/Swagger.hs
2021-08-31 22:39:24 +02:00

45 lines
1.1 KiB
Haskell

module Handler.Swagger where
import Import
import Data.Swagger
import Handler.ListChallenges
import Handler.ShowChallenge
import Handler.Query
import Handler.Tags
import Handler.Team
import Control.Lens hiding ((.=))
getSwaggerR :: Handler Value
getSwaggerR = return $ toJSON apiDescription
apiDescription :: Swagger
apiDescription = generalApi
<> addUserApi
<> userInfoApi
<> myEvaluationTriggerTokenApi
<> listChallengesApi
<> leaderboardApi
<> allSubmissionsApi
<> mySubmissionsApi
<> challengeReadmeInMarkdownApi
<> queryApi
<> challengeSubmissionApi
<> versionInfoApi
<> listTagsApi
<> myTeamsApi
<> challengeImgApi
<> challengeRepoApi
<> testProgressApi
<> viewProgressWithWebSockets
<> viewProgressLog
generalApi :: Swagger
generalApi = (mempty :: Swagger)
& info .~ (mempty &
title .~ "Gonito API" &
version .~ "3.8.0")