-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
58 lines (49 loc) · 1.43 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
package main
import (
"fmt"
_ "github.com/asyauqi1511/test/docs"
"github.com/asyauqi1511/test/internal/controller"
empMod "github.com/asyauqi1511/test/internal/model/employees"
"github.com/asyauqi1511/test/internal/pkg"
"github.com/gin-gonic/gin"
swaggerFiles "github.com/swaggo/files"
ginSwagger "github.com/swaggo/gin-swagger"
"log"
"os"
)
func main() {
// Load config.
appConfig, err := pkg.LoadConfig()
if err != nil {
panic(fmt.Sprintf("Failed load config: %v", err))
}
// Init log.
f, err := os.OpenFile("app.log", os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666)
if err != nil {
log.Fatalf("error opening file: %v", err)
}
defer f.Close()
log.SetOutput(f)
// Connect database.
db, err := pkg.ConnectDB(appConfig.DB)
if err != nil {
panic(fmt.Sprintf("Failed connect database: %v", err))
}
// Initialize models.
employeeModel, err := empMod.New(db)
if err != nil {
panic(fmt.Sprintf("Failed initialize employee model: %v", err))
}
// Initialize controllers.
control := controller.New(employeeModel)
// Route.
r := gin.Default()
r.GET("/employees", pkg.Wrap(control.EmployeeGetAll))
r.GET("/employees/:id", pkg.Wrap(control.EmployeeGet))
r.POST("/employees", pkg.Wrap(control.EmployeeInsert))
r.PUT("/employees/:id", pkg.Wrap(control.EmployeeUpdate))
r.DELETE("/employees/:id", pkg.Wrap(control.EmployeeDelete))
// Documentation.
r.GET("/docs/*any", ginSwagger.WrapHandler(swaggerFiles.Handler))
r.Run(":8000")
}