2024-03-17 16:55:40 +01:00
|
|
|
package handlers
|
|
|
|
|
|
|
|
import (
|
2024-03-17 18:05:54 +01:00
|
|
|
"strconv"
|
2024-03-17 16:55:40 +01:00
|
|
|
"ttime/internal/types"
|
|
|
|
|
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
"github.com/golang-jwt/jwt/v5"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (gs *GState) SubmitWeeklyReport(c *fiber.Ctx) error {
|
|
|
|
// Extract the necessary parameters from the token
|
|
|
|
user := c.Locals("user").(*jwt.Token)
|
|
|
|
claims := user.Claims.(jwt.MapClaims)
|
|
|
|
username := claims["name"].(string)
|
|
|
|
|
|
|
|
report := new(types.NewWeeklyReport)
|
|
|
|
if err := c.BodyParser(report); err != nil {
|
|
|
|
return c.Status(400).SendString(err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
// Make sure all the fields of the report are valid
|
|
|
|
if report.Week < 1 || report.Week > 52 {
|
|
|
|
return c.Status(400).SendString("Invalid week number")
|
|
|
|
}
|
|
|
|
if report.DevelopmentTime < 0 || report.MeetingTime < 0 || report.AdminTime < 0 || report.OwnWorkTime < 0 || report.StudyTime < 0 || report.TestingTime < 0 {
|
|
|
|
return c.Status(400).SendString("Invalid time report")
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := gs.Db.AddWeeklyReport(report.ProjectName, username, report.Week, report.DevelopmentTime, report.MeetingTime, report.AdminTime, report.OwnWorkTime, report.StudyTime, report.TestingTime); err != nil {
|
|
|
|
return c.Status(500).SendString(err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.Status(200).SendString("Time report added")
|
|
|
|
}
|
2024-03-17 18:05:54 +01:00
|
|
|
|
|
|
|
// Handler for retrieving weekly report
|
|
|
|
func (gs *GState) GetWeeklyReport(c *fiber.Ctx) error {
|
|
|
|
// Extract the necessary parameters from the request
|
2024-03-17 22:57:19 +01:00
|
|
|
println("GetWeeklyReport")
|
2024-03-17 18:05:54 +01:00
|
|
|
user := c.Locals("user").(*jwt.Token)
|
|
|
|
claims := user.Claims.(jwt.MapClaims)
|
|
|
|
username := claims["name"].(string)
|
|
|
|
|
|
|
|
// Extract project name and week from query parameters
|
|
|
|
projectName := c.Query("projectName")
|
2024-03-17 22:57:19 +01:00
|
|
|
println(projectName)
|
2024-03-17 18:05:54 +01:00
|
|
|
week := c.Query("week")
|
2024-03-17 22:57:19 +01:00
|
|
|
println(week)
|
2024-03-17 18:05:54 +01:00
|
|
|
|
|
|
|
// Convert week to integer
|
|
|
|
weekInt, err := strconv.Atoi(week)
|
|
|
|
if err != nil {
|
|
|
|
return c.Status(400).SendString("Invalid week number")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Call the database function to get the weekly report
|
|
|
|
report, err := gs.Db.GetWeeklyReport(username, projectName, weekInt)
|
|
|
|
if err != nil {
|
|
|
|
return c.Status(500).SendString(err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return the retrieved weekly report
|
|
|
|
return c.JSON(report)
|
|
|
|
}
|