gitea-issue/main.go

135 lines
3.3 KiB
Go
Raw Normal View History

2019-12-03 20:14:14 +00:00
package main
import (
"fmt"
2019-12-04 18:06:35 +00:00
"gitea-issue/controller"
2019-12-03 20:14:14 +00:00
"gitea-issue/giteaClient"
"github.com/caarlos0/env"
2019-12-03 20:53:52 +00:00
"github.com/gin-contrib/cors"
2019-12-03 20:14:14 +00:00
"github.com/gin-gonic/gin"
"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/sqlite"
2019-12-04 18:06:35 +00:00
ginSwagger "github.com/swaggo/gin-swagger"
"github.com/swaggo/gin-swagger/swaggerFiles"
2019-12-03 20:14:14 +00:00
"net/http"
"strconv"
2019-12-04 18:06:35 +00:00
"github.com/savaki/swag"
"github.com/savaki/swag/swagger"
2019-12-03 20:14:14 +00:00
)
var (
db *gorm.DB
giteaConfig giteaClient.GiteaConfig
2019-12-03 20:53:52 +00:00
proxyConfig ProxyConfig
2019-12-03 20:14:14 +00:00
)
2019-12-03 20:53:52 +00:00
type ProxyConfig struct {
ProjectOrigin string `env:"PROJECT_ORIGIN,required"`
}
2019-12-03 20:14:14 +00:00
func init() {
//open a db connection
var err error
db, err := gorm.Open("sqlite3", "./database.db")
if err != nil {
panic("failed to connect database")
}
if err := env.Parse(&giteaConfig); err != nil {
2019-12-04 17:04:06 +00:00
panic(fmt.Sprintf("ENV error: %+v", err.Error()))
2019-12-03 20:14:14 +00:00
}
2019-12-03 20:53:52 +00:00
if err := env.Parse(&proxyConfig); err != nil {
2019-12-04 17:04:06 +00:00
panic(fmt.Sprintf("ENV error: %+v", err.Error()))
2019-12-03 20:53:52 +00:00
}
2019-12-03 20:14:14 +00:00
giteaClient.SetUp(giteaConfig)
db.AutoMigrate(&userModel{})
}
func main() {
router := gin.Default()
2019-12-03 20:53:52 +00:00
config := cors.DefaultConfig()
config.AllowOrigins = []string{proxyConfig.ProjectOrigin}
2019-12-04 18:06:35 +00:00
router.Use(gin.Logger())
2019-12-03 20:53:52 +00:00
router.Use(cors.New(config))
2019-12-03 20:14:14 +00:00
2019-12-04 18:06:35 +00:00
proxyApi := swag.New(
swag.Title("Gitea issues proxy"),
swag.Description("Gitea issues proxy for separate projects"),
swag.ContactEmail("aleksander@cynarski.pl"),
swag.License("MIT", "https://opensource.org/licenses/MIT"),
swag.Tag("issues", "Gitea issues proxy endpoints"),
swag.Tag("labels", "Gites labels for issue"),
swag.Endpoints(
2019-12-04 21:37:18 +00:00
controller.PostIssueSwagger(),
2019-12-04 18:06:35 +00:00
controller.GetIssuesSwagger(),
controller.GetIssueSwagger(),
controller.GetIssueCommentsSwagger(),
controller.GetLabelsSwagger()),
)
2019-12-03 20:14:14 +00:00
2019-12-04 18:06:35 +00:00
proxyApi.Walk(func(path string, endpoint *swagger.Endpoint) {
h := endpoint.Handler.(func(c *gin.Context))
path = swag.ColonPath(path)
router.Handle(endpoint.Method, path, h)
})
2019-12-03 20:14:14 +00:00
2019-12-04 18:06:35 +00:00
router.GET("/swagger.json", gin.WrapH(proxyApi.Handler(true)))
url := ginSwagger.URL("/swagger.json")
router.GET("/swagger/*any", ginSwagger.WrapHandler(swaggerFiles.Handler, url))
2019-12-03 20:14:14 +00:00
_ = router.Run()
}
type (
userModel struct {
gorm.Model
Email string `json:"email"`
Token int `json:"token"`
}
)
func getIssues(c *gin.Context) {
issues, err := giteaClient.GetIssues();
if(err != nil){
c.AbortWithStatus(http.StatusNotFound)
}
c.AsciiJSON(http.StatusOK, issues)
}
func getIssue(c *gin.Context) {
issueId, err := strconv.ParseInt(c.Param("id"), 10, 64)
if err != nil {
fmt.Println(fmt.Sprintf("ParseInt err: %+v", err))
c.AsciiJSON(http.StatusNotFound, err.Error())
}
issue, err := giteaClient.GetIssue(issueId)
if err != nil {
c.AbortWithStatus(http.StatusNotFound)
}
c.AsciiJSON(http.StatusOK, issue)
}
func getIssueComments(c *gin.Context) {
issueId, err := strconv.ParseInt(c.Param("id"), 10, 64)
if err != nil {
fmt.Println(fmt.Sprintf("ParseInt err: %+v", err))
c.AsciiJSON(http.StatusNotFound, err.Error())
}
issueComments, err := giteaClient.GetIssueComments(issueId)
if err != nil {
c.AbortWithStatus(http.StatusNotFound)
}
c.AsciiJSON(http.StatusOK, issueComments)
2019-12-04 17:04:06 +00:00
}
func getLabels(c *gin.Context) {
labels, err := giteaClient.GetLabels()
if err != nil {
c.AbortWithStatus(http.StatusNotFound)
}
c.AsciiJSON(http.StatusOK, labels)
}