diff options
| author | nsfisis <nsfisis@gmail.com> | 2024-08-03 22:18:38 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2024-08-03 22:18:38 +0900 |
| commit | c5f340afc2ecdbff9f0d2e0707f310fa88f5af12 (patch) | |
| tree | bdef0421d29b9ee737e869677166d4b3ebdadb0f /worker/handlers.go | |
| parent | db06c9332776b41b3fef537f9e6d76d38f0463b3 (diff) | |
| parent | 7a4171d021a709e0af1e0e13830514c67ec97702 (diff) | |
| download | phperkaigi-2025-albatross-c5f340afc2ecdbff9f0d2e0707f310fa88f5af12.tar.gz phperkaigi-2025-albatross-c5f340afc2ecdbff9f0d2e0707f310fa88f5af12.tar.zst phperkaigi-2025-albatross-c5f340afc2ecdbff9f0d2e0707f310fa88f5af12.zip | |
Merge branch 'feat/worker'
Diffstat (limited to 'worker/handlers.go')
| -rw-r--r-- | worker/handlers.go | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/worker/handlers.go b/worker/handlers.go new file mode 100644 index 0000000..e7ceef6 --- /dev/null +++ b/worker/handlers.go @@ -0,0 +1,67 @@ +package main + +import ( + "fmt" + "net/http" + + "github.com/labstack/echo/v4" +) + +func newBadRequestError(err error) *echo.HTTPError { + return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid request: %s", err.Error())) +} + +func handleSwiftCompile(c echo.Context) error { + var req swiftCompileRequestData + if err := c.Bind(&req); err != nil { + return newBadRequestError(err) + } + if err := req.validate(); err != nil { + return newBadRequestError(err) + } + + res := execSwiftCompile( + c.Request().Context(), + req.Code, + req.maxDuration(), + ) + + return c.JSON(http.StatusOK, res) +} + +func handleWasmCompile(c echo.Context) error { + var req wasmCompileRequestData + if err := c.Bind(&req); err != nil { + return newBadRequestError(err) + } + if err := req.validate(); err != nil { + return newBadRequestError(err) + } + + res := execWasmCompile( + c.Request().Context(), + req.Code, + req.maxDuration(), + ) + + return c.JSON(http.StatusOK, res) +} + +func handleTestRun(c echo.Context) error { + var req testRunRequestData + if err := c.Bind(&req); err != nil { + return newBadRequestError(err) + } + if err := req.validate(); err != nil { + return newBadRequestError(err) + } + + res := execTestRun( + c.Request().Context(), + req.Code, + req.Stdin, + req.maxDuration(), + ) + + return c.JSON(http.StatusOK, res) +} |
