2020-02-09 10:31:52 +00:00
|
|
|
package rest
|
|
|
|
|
|
|
|
import (
|
2020-03-11 11:02:37 +00:00
|
|
|
"context"
|
2020-03-20 10:06:14 +00:00
|
|
|
"log"
|
|
|
|
"net/http"
|
2020-04-04 07:18:10 +00:00
|
|
|
"time"
|
2020-02-09 10:31:52 +00:00
|
|
|
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
"github.com/ledgerwatch/turbo-geth/cmd/restapi/apis"
|
2020-03-24 02:12:55 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/ethdb"
|
2020-02-09 10:31:52 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func printError(name string, err error) {
|
|
|
|
if err != nil {
|
2020-03-20 10:06:14 +00:00
|
|
|
log.Printf("%v: SUCCESS", name)
|
2020-02-09 10:31:52 +00:00
|
|
|
} else {
|
2020-03-20 10:06:14 +00:00
|
|
|
log.Printf("%v: FAIL (err=%v)", name, err)
|
2020-02-09 10:31:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-04 07:18:10 +00:00
|
|
|
func ServeREST(ctx context.Context, localAddress, remoteDBAddress string) error {
|
2020-02-09 10:31:52 +00:00
|
|
|
r := gin.Default()
|
|
|
|
root := r.Group("api/v1")
|
|
|
|
allowCORS(root)
|
2020-03-20 10:06:14 +00:00
|
|
|
root.Use(func(c *gin.Context) {
|
|
|
|
c.Next()
|
|
|
|
if len(c.Errors) > 0 {
|
|
|
|
c.AbortWithStatusJSON(http.StatusInternalServerError, c.Errors)
|
|
|
|
}
|
|
|
|
})
|
2020-02-09 10:31:52 +00:00
|
|
|
|
2020-04-04 07:18:10 +00:00
|
|
|
db, err := ethdb.NewRemote().Path(remoteDBAddress).Open(ctx)
|
2020-02-09 10:31:52 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-04-04 07:18:10 +00:00
|
|
|
defer db.Close()
|
2020-03-20 10:06:14 +00:00
|
|
|
e := &apis.Env{
|
2020-04-04 07:18:10 +00:00
|
|
|
DB: db,
|
|
|
|
RemoteDBAddress: remoteDBAddress,
|
2020-03-20 10:06:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if err = apis.RegisterRemoteDBAPI(root.Group("remote-db"), e); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err = apis.RegisterAccountAPI(root.Group("accounts"), e); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err = apis.RegisterStorageAPI(root.Group("storage"), e); err != nil {
|
2020-02-09 10:31:52 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-03-20 10:06:14 +00:00
|
|
|
log.Printf("serving on %v... press ctrl+C to abort\n", localAddress)
|
2020-02-09 10:31:52 +00:00
|
|
|
|
2020-04-04 07:18:10 +00:00
|
|
|
srv := &http.Server{Addr: localAddress, Handler: r}
|
|
|
|
|
|
|
|
// Initializing the server in a goroutine so that
|
|
|
|
// it won't block the graceful shutdown handling below
|
|
|
|
go func() {
|
|
|
|
<-ctx.Done()
|
|
|
|
shutdownCtx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
|
|
|
|
defer cancel()
|
|
|
|
if err := srv.Shutdown(shutdownCtx); err != nil {
|
|
|
|
log.Fatal("Server forced to shutdown:", err)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
if err := srv.ListenAndServe(); err != nil && err != http.ErrServerClosed {
|
|
|
|
log.Fatalf("listen: %s\n", err)
|
2020-03-20 10:06:14 +00:00
|
|
|
}
|
2020-02-09 10:31:52 +00:00
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func allowCORS(r *gin.RouterGroup) {
|
|
|
|
r.Use(func(c *gin.Context) {
|
|
|
|
c.Header("Access-Control-Allow-Origin", "*")
|
|
|
|
c.Header("Access-Control-Allow-Headers", "Content-Type")
|
|
|
|
c.Header("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS")
|
|
|
|
c.Next()
|
|
|
|
})
|
|
|
|
}
|