mirror of
https://github.com/onsonr/sonr.git
synced 2025-03-10 13:07:09 +00:00
refactor: refactor hway command to use echo framework for server
This commit is contained in:
parent
e94ce3b1cc
commit
1250468f69
2
Makefile
2
Makefile
@ -329,7 +329,7 @@ build-motr:
|
|||||||
GOOS=js GOARCH=wasm go build -o static/wasm/app.wasm ./cmd/motr/main.go
|
GOOS=js GOARCH=wasm go build -o static/wasm/app.wasm ./cmd/motr/main.go
|
||||||
|
|
||||||
build-hway: gen-templ
|
build-hway: gen-templ
|
||||||
go build -o build/hway ./cmd/hway/main.go
|
go build -o build/hway ./cmd/hway
|
||||||
|
|
||||||
logs-hway: init-env
|
logs-hway: init-env
|
||||||
bin/process-compose process logs hway --port $(PC_PORT_NUM) --follow
|
bin/process-compose process logs hway --port $(PC_PORT_NUM) --follow
|
||||||
|
@ -1,7 +1,19 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
|
"log"
|
||||||
|
"net/http"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"github.com/labstack/echo/v4"
|
||||||
|
"github.com/labstack/echo/v4/middleware"
|
||||||
|
"github.com/onsonr/sonr/crypto/ucan"
|
||||||
|
"github.com/onsonr/sonr/internal/database/sessions"
|
||||||
|
"github.com/onsonr/sonr/internal/gateway"
|
||||||
"github.com/onsonr/sonr/internal/gateway/config"
|
"github.com/onsonr/sonr/internal/gateway/config"
|
||||||
|
"github.com/onsonr/sonr/pkg/common/ipfs"
|
||||||
|
"github.com/onsonr/sonr/pkg/didauth/producer"
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -22,17 +34,29 @@ func NewRootCmd() *cobra.Command {
|
|||||||
Use: "hway",
|
Use: "hway",
|
||||||
Short: "Sonr DID gateway",
|
Short: "Sonr DID gateway",
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
cmd.Help()
|
env, err := loadEnvImplFromArgs(args)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
e, err := setupServer(env)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
if err := e.Start(fmt.Sprintf(":%d", env.GetServePort())); err != http.ErrServerClosed {
|
||||||
|
log.Fatal(err)
|
||||||
|
os.Exit(1)
|
||||||
|
return
|
||||||
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
cmd.Flags().IntVar(&servePort, "serve-port", 8080, "Port to serve the gateway on")
|
cmd.Flags().IntVar(&servePort, "serve-port", 3000, "Port to serve the gateway on")
|
||||||
cmd.Flags().StringVar(&configDir, "config-dir", "", "Directory to store config files")
|
cmd.Flags().StringVar(&configDir, "config-dir", "hway", "Directory to store config files")
|
||||||
cmd.Flags().StringVar(&sqliteFile, "sqlite-file", "", "File to store sqlite database")
|
cmd.Flags().StringVar(&sqliteFile, "sqlite-file", "hway.db", "File to store sqlite database")
|
||||||
cmd.Flags().StringVar(&chainId, "chain-id", "", "Chain ID")
|
cmd.Flags().StringVar(&chainId, "chain-id", "sonr-testnet-1", "Chain ID")
|
||||||
cmd.Flags().StringVar(&ipfsGatewayUrl, "ipfs-gateway-url", "", "IPFS gateway URL")
|
cmd.Flags().StringVar(&ipfsGatewayUrl, "ipfs-gateway-url", "localhost:8080", "IPFS gateway URL")
|
||||||
cmd.Flags().StringVar(&sonrApiUrl, "sonr-api-url", "", "Sonr API URL")
|
cmd.Flags().StringVar(&sonrApiUrl, "sonr-api-url", "localhost:1317", "Sonr API URL")
|
||||||
cmd.Flags().StringVar(&sonrGrpcUrl, "sonr-grpc-url", "", "Sonr gRPC URL")
|
cmd.Flags().StringVar(&sonrGrpcUrl, "sonr-grpc-url", "localhost:9090", "Sonr gRPC URL")
|
||||||
cmd.Flags().StringVar(&sonrRpcUrl, "sonr-rpc-url", "", "Sonr RPC URL")
|
cmd.Flags().StringVar(&sonrRpcUrl, "sonr-rpc-url", "localhost:26657", "Sonr RPC URL")
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -54,3 +78,22 @@ func loadEnvImplFromArgs(args []string) (config.Env, error) {
|
|||||||
}
|
}
|
||||||
return env, nil
|
return env, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// setupServer sets up the server
|
||||||
|
func setupServer(env config.Env) (*echo.Echo, error) {
|
||||||
|
ipc, err := ipfs.NewClient()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
db, err := sessions.NewGormDB(env)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
e := echo.New()
|
||||||
|
e.IPExtractor = echo.ExtractIPDirect()
|
||||||
|
e.Use(middleware.Logger())
|
||||||
|
e.Use(middleware.Recover())
|
||||||
|
e.Use(producer.Middleware(ipc, ucan.ServicePermissions))
|
||||||
|
gateway.RegisterRoutes(e, env, db)
|
||||||
|
return e, nil
|
||||||
|
}
|
||||||
|
@ -1 +0,0 @@
|
|||||||
amends "https://pkl.sh/sonr.hway/0.0.3/Env.pkl"
|
|
@ -3,61 +3,15 @@ package main
|
|||||||
import (
|
import (
|
||||||
_ "embed"
|
_ "embed"
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
|
||||||
"net/http"
|
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
"github.com/labstack/echo/v4"
|
|
||||||
"github.com/labstack/echo/v4/middleware"
|
|
||||||
"github.com/onsonr/sonr/crypto/ucan"
|
|
||||||
"github.com/onsonr/sonr/internal/database/sessions"
|
|
||||||
"github.com/onsonr/sonr/internal/gateway"
|
|
||||||
"github.com/onsonr/sonr/internal/gateway/config"
|
|
||||||
"github.com/onsonr/sonr/pkg/common/ipfs"
|
|
||||||
"github.com/onsonr/sonr/pkg/didauth/producer"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
//go:embed config.pkl
|
|
||||||
var configBz []byte
|
|
||||||
|
|
||||||
func loadConfig() (config.Env, error) {
|
|
||||||
return config.LoadFromBytes(configBz)
|
|
||||||
}
|
|
||||||
|
|
||||||
// setupServer sets up the server
|
|
||||||
func setupServer(env config.Env) (*echo.Echo, error) {
|
|
||||||
ipc, err := ipfs.NewClient()
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
db, err := sessions.NewGormDB(env)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
e := echo.New()
|
|
||||||
e.IPExtractor = echo.ExtractIPDirect()
|
|
||||||
e.Use(middleware.Logger())
|
|
||||||
e.Use(middleware.Recover())
|
|
||||||
e.Use(producer.Middleware(ipc, ucan.ServicePermissions))
|
|
||||||
gateway.RegisterRoutes(e, env, db)
|
|
||||||
return e, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// main is the entry point for the application
|
// main is the entry point for the application
|
||||||
func main() {
|
func main() {
|
||||||
env, err := loadConfig()
|
cmd := NewRootCmd()
|
||||||
if err != nil {
|
if err := cmd.Execute(); err != nil {
|
||||||
panic(err)
|
fmt.Println(err)
|
||||||
}
|
|
||||||
|
|
||||||
e, err := setupServer(env)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := e.Start(fmt.Sprintf(":%d", env.GetServePort())); err != http.ErrServerClosed {
|
|
||||||
log.Fatal(err)
|
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
os.Exit(0)
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user