summaryrefslogtreecommitdiff
path: root/invoice/invoice_router.go
diff options
context:
space:
mode:
authorVidhu Kant Sharma <vidhukant@vidhukant.xyz>2022-09-25 15:29:13 +0530
committerVidhu Kant Sharma <vidhukant@vidhukant.xyz>2022-09-25 15:29:13 +0530
commit2326633e76aaf9c5e733e08045c0a26b81f9f4e6 (patch)
tree270fbbb8a71d0dd0c7281fb6becc0d67f1368590 /invoice/invoice_router.go
parent82d9a0f82bc776bf5b026f64c5bf63b89719906a (diff)
Added endpoints to add and delete data
Diffstat (limited to 'invoice/invoice_router.go')
-rw-r--r--invoice/invoice_router.go97
1 files changed, 97 insertions, 0 deletions
diff --git a/invoice/invoice_router.go b/invoice/invoice_router.go
new file mode 100644
index 0000000..d3f2d82
--- /dev/null
+++ b/invoice/invoice_router.go
@@ -0,0 +1,97 @@
+package invoice
+
+import (
+ "github.com/gin-gonic/gin"
+ "github.com/MikunoNaka/OpenBills-lib/invoice"
+ "log"
+ "net/http"
+)
+
+func Routes(route *gin.Engine) {
+ i := route.Group("/invoice")
+ {
+ i.POST("/", func(ctx *gin.Context) {
+ var x invoice.Invoice
+ ctx.Bind(&x)
+ err := x.Save()
+ if err != nil {
+ ctx.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
+ log.Printf("ERROR: Failed to generate new invoice #%d: %v", x.InvoiceNumber, err.Error())
+ }
+
+ log.Printf("Generated new invoice #%d.\n", x.InvoiceNumber)
+ ctx.JSON(http.StatusOK, nil)
+ })
+
+ i.DELETE("/", func(ctx *gin.Context) {
+ var x invoice.Invoice
+ ctx.Bind(&x)
+ err := x.Delete()
+ if err != nil {
+ ctx.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
+ log.Printf("ERROR: Failed to delete invoice #%d: %v", x.InvoiceNumber, err.Error())
+ }
+
+ log.Printf("Deleted invoice invoice #%d.\n", x.InvoiceNumber)
+ ctx.JSON(http.StatusOK, nil)
+ })
+ }
+
+ transport := route.Group("/transport")
+ {
+ transport.POST("/", func(ctx *gin.Context) {
+ var x invoice.Transport
+ ctx.Bind(&x)
+ err := x.Save()
+ if err != nil {
+ ctx.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
+ log.Printf("ERROR: Failed to add transport vehicle \"%s\": %v", x.VehicleNum, err.Error())
+ }
+
+ log.Printf("Added new transport vehicle to database: \"%s\"\n", x.VehicleNum)
+ ctx.JSON(http.StatusOK, nil)
+ })
+
+ transport.DELETE("/", func(ctx *gin.Context) {
+ var x invoice.Transport
+ ctx.Bind(&x)
+ err := x.Delete()
+ if err != nil {
+ ctx.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
+ log.Printf("ERROR: Failed to delete transport vehicle \"%s\": %v", x.VehicleNum, err.Error())
+ }
+
+ log.Printf("Deleted transport vehicle: \"%s\"\n", x.VehicleNum)
+ ctx.JSON(http.StatusOK, nil)
+ })
+ }
+
+ transporter := route.Group("/transporter")
+ {
+ transporter.POST("/", func(ctx *gin.Context) {
+ var x invoice.Transporter
+ ctx.Bind(&x)
+ err := x.Save()
+ if err != nil {
+ ctx.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
+ log.Printf("ERROR: Failed to add transporter \"%s\": %v", x.Name, err.Error())
+ }
+
+ log.Printf("Added new transporter to database: \"%s\"\n", x.Name)
+ ctx.JSON(http.StatusOK, nil)
+ })
+
+ transporter.DELETE("/", func(ctx *gin.Context) {
+ var x invoice.Transporter
+ ctx.Bind(&x)
+ err := x.Delete()
+ if err != nil {
+ ctx.JSON(http.StatusInternalServerError, gin.H{"error": err.Error()})
+ log.Printf("ERROR: Failed to delete transporter \"%s\": %v", x.Name, err.Error())
+ }
+
+ log.Printf("Deleted transporter: \"%s\"\n", x.Name)
+ ctx.JSON(http.StatusOK, nil)
+ })
+ }
+}