getStatistics handler, db-interface and ts API
This commit is contained in:
		
							parent
							
								
									2d2b63938c
								
							
						
					
					
						commit
						fe9d5f74bb
					
				
					 8 changed files with 188 additions and 1 deletions
				
			
		|  | @ -2,11 +2,13 @@ package database | |||
| 
 | ||||
| import ( | ||||
| 	"embed" | ||||
| 	"encoding/json" | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"path/filepath" | ||||
| 	"ttime/internal/types" | ||||
| 
 | ||||
| 	"github.com/gofiber/fiber/v2/log" | ||||
| 	"github.com/jmoiron/sqlx" | ||||
| 	_ "modernc.org/sqlite" | ||||
| ) | ||||
|  | @ -41,6 +43,7 @@ type Database interface { | |||
| 	SignWeeklyReport(reportId int, projectManagerId int) error | ||||
| 	IsSiteAdmin(username string) (bool, error) | ||||
| 	IsProjectManager(username string, projectname string) (bool, error) | ||||
| 	ReportStatistics(username string, projectName string) (*types.Statistics, error) | ||||
| 	GetProjectTimes(projectName string) (map[string]int, error) | ||||
| 	UpdateWeeklyReport(projectName string, userName string, week int, developmentTime int, meetingTime int, adminTime int, ownWorkTime int, studyTime int, testingTime int) error | ||||
| 	RemoveProject(projectname string) error | ||||
|  | @ -94,6 +97,17 @@ const removeUserFromProjectQuery = `DELETE FROM user_roles | |||
| 									WHERE user_id = (SELECT id FROM users WHERE username = ?)  | ||||
| 									AND project_id = (SELECT id FROM projects WHERE name = ?)` | ||||
| 
 | ||||
| const reportStatistics = `SELECT SUM(development_time) AS total_development_time, | ||||
| 							SUM(meeting_time) AS total_meeting_time, | ||||
| 							SUM(admin_time) AS total_admin_time, | ||||
| 							SUM(own_work_time) AS total_own_work_time, | ||||
| 							SUM(study_time) AS total_study_time, | ||||
| 							SUM(testing_time) AS total_testing_time | ||||
| 							FROM weekly_reports | ||||
| 							WHERE user_id = (SELECT id FROM users WHERE username = ?) | ||||
| 							AND project_id = (SELECT id FROM projects WHERE name = ?) | ||||
| 							GROUP BY user_id, project_id` | ||||
| 
 | ||||
| // DbConnect connects to the database | ||||
| func DbConnect(dbpath string) Database { | ||||
| 	// Open the database | ||||
|  | @ -111,6 +125,24 @@ func DbConnect(dbpath string) Database { | |||
| 	return &Db{db} | ||||
| } | ||||
| 
 | ||||
| func (d *Db) ReportStatistics(username string, projectName string) (*types.Statistics, error) { | ||||
| 	var result types.Statistics | ||||
| 
 | ||||
| 	err := d.Get(&result, reportStatistics, username, projectName) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	serialized, err := json.Marshal(result) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	log.Info(string(serialized)) | ||||
| 
 | ||||
| 	return &result, nil | ||||
| } | ||||
| 
 | ||||
| func (d *Db) CheckUser(username string, password string) bool { | ||||
| 	var dbPassword string | ||||
| 	err := d.Get(&dbPassword, "SELECT password FROM users WHERE username = ?", username) | ||||
|  |  | |||
							
								
								
									
										50
									
								
								backend/internal/handlers/reports/Statistics.go
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								backend/internal/handlers/reports/Statistics.go
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,50 @@ | |||
| package reports | ||||
| 
 | ||||
| import ( | ||||
| 	db "ttime/internal/database" | ||||
| 
 | ||||
| 	"github.com/gofiber/fiber/v2" | ||||
| 	"github.com/gofiber/fiber/v2/log" | ||||
| 	"github.com/golang-jwt/jwt/v5" | ||||
| ) | ||||
| 
 | ||||
| func GetStatistics(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) | ||||
| 
 | ||||
| 	// Extract project name from query parameters | ||||
| 	projectName := c.Query("projectName") | ||||
| 
 | ||||
| 	log.Info(username, " trying to get statistics for project: ", projectName) | ||||
| 
 | ||||
| 	if projectName == "" { | ||||
| 		log.Info("Missing project name") | ||||
| 		return c.Status(400).SendString("Missing project name") | ||||
| 	} | ||||
| 
 | ||||
| 	// If the user is not a project manager, they can't view statistics | ||||
| 	pm, err := db.GetDb(c).IsProjectManager(username, projectName) | ||||
| 	if err != nil { | ||||
| 		log.Info("Error checking if user is project manager:", err) | ||||
| 		return c.Status(500).SendString(err.Error()) | ||||
| 	} | ||||
| 
 | ||||
| 	if !pm { | ||||
| 		log.Info("Unauthorized access") | ||||
| 		return c.Status(403).SendString("Unauthorized access") | ||||
| 	} | ||||
| 
 | ||||
| 	// Retrieve statistics for the project from the database | ||||
| 	statistics, err := db.GetDb(c).ReportStatistics(username, projectName) | ||||
| 	if err != nil { | ||||
| 		log.Error("Error getting statistics for project:", projectName, ":", err) | ||||
| 		return c.Status(500).SendString(err.Error()) | ||||
| 	} | ||||
| 
 | ||||
| 	log.Info("Returning statistics") | ||||
| 	// Return the retrieved statistics | ||||
| 	return c.JSON(statistics) | ||||
| 
 | ||||
| } | ||||
|  | @ -66,6 +66,15 @@ type WeeklyReport struct { | |||
| 	SignedBy *int `json:"signedBy" db:"signed_by"` | ||||
| } | ||||
| 
 | ||||
| type Statistics struct { | ||||
| 	TotalDevelopmentTime int `json:"totalDevelopmentTime" db:"total_development_time"` | ||||
| 	TotalMeetingTime     int `json:"totalMeetingTime" db:"total_meeting_time"` | ||||
| 	TotalAdminTime       int `json:"totalAdminTime" db:"total_admin_time"` | ||||
| 	TotalOwnWorkTime     int `json:"totalOwnWorkTime" db:"total_own_work_time"` | ||||
| 	TotalStudyTime       int `json:"totalStudyTime" db:"total_study_time"` | ||||
| 	TotalTestingTime     int `json:"totalTestingTime" db:"total_testing_time"` | ||||
| } | ||||
| 
 | ||||
| type UpdateWeeklyReport struct { | ||||
| 	// The name of the project, as it appears in the database | ||||
| 	ProjectName string `json:"projectName"` | ||||
|  |  | |||
|  | @ -126,12 +126,12 @@ func main() { | |||
| 	api.Delete("/removeProject/:projectName", projects.RemoveProject) | ||||
| 	api.Delete("/project/:projectID", projects.DeleteProject) | ||||
| 
 | ||||
| 
 | ||||
| 	// All report related routes | ||||
| 	// reportGroup := api.Group("/report") // Not currently in use | ||||
| 	api.Get("/getWeeklyReport", reports.GetWeeklyReport) | ||||
| 	api.Get("/getUnsignedReports/:projectName", reports.GetUnsignedReports) | ||||
| 	api.Get("/getAllWeeklyReports/:projectName", reports.GetAllWeeklyReports) | ||||
| 	api.Get("/getStatistics", reports.GetStatistics) | ||||
| 	api.Post("/submitWeeklyReport", reports.SubmitWeeklyReport) | ||||
| 	api.Put("/signReport/:reportId", reports.SignReport) | ||||
| 	api.Put("/updateWeeklyReport", reports.UpdateWeeklyReport) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Imbus
						Imbus