2020-07-26 17:09:05 +08:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"zero/core/conf"
|
|
|
|
"zero/core/logx"
|
|
|
|
"zero/core/service"
|
|
|
|
"zero/example/tracing/remote/portal"
|
2020-07-31 11:14:48 +08:00
|
|
|
"zero/rest"
|
|
|
|
"zero/rest/httpx"
|
2020-07-26 17:09:05 +08:00
|
|
|
"zero/rpcx"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
configFile = flag.String("f", "config.json", "the config file")
|
|
|
|
client *rpcx.RpcClient
|
|
|
|
)
|
|
|
|
|
|
|
|
func handle(w http.ResponseWriter, r *http.Request) {
|
|
|
|
conn, ok := client.Next()
|
|
|
|
if !ok {
|
|
|
|
log.Fatal("no server")
|
|
|
|
}
|
|
|
|
|
|
|
|
greet := portal.NewPortalClient(conn)
|
|
|
|
resp, err := greet.Portal(r.Context(), &portal.PortalRequest{
|
|
|
|
Name: "kevin",
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
httpx.WriteJson(w, http.StatusInternalServerError, http.StatusText(http.StatusInternalServerError))
|
|
|
|
} else {
|
|
|
|
httpx.OkJson(w, resp.Response)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
flag.Parse()
|
|
|
|
|
|
|
|
var c rpcx.RpcClientConf
|
|
|
|
conf.MustLoad(*configFile, &c)
|
|
|
|
client = rpcx.MustNewClient(c)
|
2020-07-31 11:45:16 +08:00
|
|
|
engine := rest.MustNewServer(rest.RestConf{
|
2020-07-26 17:09:05 +08:00
|
|
|
ServiceConf: service.ServiceConf{
|
|
|
|
Log: logx.LogConf{
|
|
|
|
Mode: "console",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Port: 3333,
|
|
|
|
})
|
|
|
|
defer engine.Stop()
|
|
|
|
|
2020-07-31 11:14:48 +08:00
|
|
|
engine.AddRoute(rest.Route{
|
2020-07-26 17:09:05 +08:00
|
|
|
Method: http.MethodGet,
|
|
|
|
Path: "/",
|
|
|
|
Handler: handle,
|
|
|
|
})
|
|
|
|
engine.Start()
|
|
|
|
}
|