Handler and TS API for SignReport
This commit is contained in:
parent
b7523cf04d
commit
ecce80babc
3 changed files with 38 additions and 8 deletions
|
@ -89,13 +89,13 @@ func (gs *GState) SignReport(c *fiber.Ctx) error {
|
||||||
|
|
||||||
log.Info("Signing report for: ", projectManagerUsername)
|
log.Info("Signing report for: ", projectManagerUsername)
|
||||||
|
|
||||||
// Extract report ID from the request query parameters
|
// Extract report ID from the request
|
||||||
// reportID := c.Query("reportId")
|
rid, err := strconv.Atoi(c.Params("reportId"))
|
||||||
rid := new(ReportId)
|
if err != nil {
|
||||||
if err := c.BodyParser(rid); err != nil {
|
log.Info("Invalid report ID:", err)
|
||||||
return err
|
return c.Status(400).SendString("Invalid report ID")
|
||||||
}
|
}
|
||||||
log.Info("Signing report for: ", rid.ReportId)
|
log.Info("Signing report for: ", rid)
|
||||||
|
|
||||||
// Get the project manager's ID
|
// Get the project manager's ID
|
||||||
projectManagerID, err := gs.Db.GetUserId(projectManagerUsername)
|
projectManagerID, err := gs.Db.GetUserId(projectManagerUsername)
|
||||||
|
@ -106,7 +106,7 @@ func (gs *GState) SignReport(c *fiber.Ctx) error {
|
||||||
log.Info("Project manager ID: ", projectManagerID)
|
log.Info("Project manager ID: ", projectManagerID)
|
||||||
|
|
||||||
// Call the database function to sign the weekly report
|
// Call the database function to sign the weekly report
|
||||||
err = gs.Db.SignWeeklyReport(rid.ReportId, projectManagerID)
|
err = gs.Db.SignWeeklyReport(rid, projectManagerID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Info("Error signing weekly report:", err)
|
log.Info("Error signing weekly report:", err)
|
||||||
return c.Status(500).SendString(err.Error())
|
return c.Status(500).SendString(err.Error())
|
||||||
|
|
|
@ -92,7 +92,7 @@ func main() {
|
||||||
server.Get("/api/project/:projectId", gs.GetProject)
|
server.Get("/api/project/:projectId", gs.GetProject)
|
||||||
server.Get("/api/project/getAllUsers", gs.GetAllUsersProject)
|
server.Get("/api/project/getAllUsers", gs.GetAllUsersProject)
|
||||||
server.Get("/api/getWeeklyReport", gs.GetWeeklyReport)
|
server.Get("/api/getWeeklyReport", gs.GetWeeklyReport)
|
||||||
server.Post("/api/signReport", gs.SignReport)
|
server.Post("/api/signReport/:reportId", gs.SignReport)
|
||||||
server.Put("/api/addUserToProject", gs.AddUserToProjectHandler)
|
server.Put("/api/addUserToProject", gs.AddUserToProjectHandler)
|
||||||
server.Put("/api/changeUserName", gs.ChangeUserName)
|
server.Put("/api/changeUserName", gs.ChangeUserName)
|
||||||
server.Post("/api/promoteToAdmin", gs.PromoteToAdmin)
|
server.Post("/api/promoteToAdmin", gs.PromoteToAdmin)
|
||||||
|
|
|
@ -127,6 +127,11 @@ interface API {
|
||||||
* @returns {Promise<APIResponse<string[]>>} A promise resolving to an API response containing the list of users.
|
* @returns {Promise<APIResponse<string[]>>} A promise resolving to an API response containing the list of users.
|
||||||
*/
|
*/
|
||||||
getAllUsers(token: string): Promise<APIResponse<string[]>>;
|
getAllUsers(token: string): Promise<APIResponse<string[]>>;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sign a report
|
||||||
|
*/
|
||||||
|
signReport(reportId: number, token: string): Promise<APIResponse<boolean>>;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** An instance of the API */
|
/** An instance of the API */
|
||||||
|
@ -448,4 +453,29 @@ export const api: API = {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
async signReport(
|
||||||
|
reportId: number,
|
||||||
|
token: string,
|
||||||
|
): Promise<APIResponse<boolean>> {
|
||||||
|
try {
|
||||||
|
const response = await fetch(`/api/signReport/${reportId}`, {
|
||||||
|
method: "POST",
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
Authorization: "Bearer " + token,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
if (!response.ok) {
|
||||||
|
return {
|
||||||
|
success: false,
|
||||||
|
message: "Failed to sign report:" + response.status,
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
return { success: true };
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
return { success: false, message: "Failed to sign report" };
|
||||||
|
}
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue