50 lines
1.3 KiB
Go
50 lines
1.3 KiB
Go
// Program http demonstrates how to set up a JSON-RPC 2.0 server using the
|
|
// github.com/creachadair/jrpc2 package with an HTTP transport.
|
|
//
|
|
// Usage (see also the client example):
|
|
//
|
|
// go build github.com/creachadair/jrpc2/cmd/examples/http
|
|
// ./http -port 8080
|
|
//
|
|
// The server accepts RPCs on http://localhost:<port>/rpc.
|
|
package main
|
|
|
|
import (
|
|
"context"
|
|
"flag"
|
|
"fmt"
|
|
"log"
|
|
"net/http"
|
|
"os"
|
|
"strings"
|
|
|
|
"github.com/creachadair/jrpc2"
|
|
"github.com/creachadair/jrpc2/handler"
|
|
"github.com/creachadair/jrpc2/jhttp"
|
|
"github.com/creachadair/jrpc2/metrics"
|
|
"github.com/creachadair/jrpc2/server"
|
|
)
|
|
|
|
var port = flag.Int("port", 0, "Service port")
|
|
|
|
func main() {
|
|
flag.Parse()
|
|
if *port <= 0 {
|
|
log.Fatal("You must provide a positive -port to listen on")
|
|
}
|
|
|
|
// Start a local server with a single trivial method and bridge it to HTTP.
|
|
local := server.NewLocal(handler.Map{
|
|
"Ping": handler.New(func(ctx context.Context, msg ...string) string {
|
|
return "OK: " + strings.Join(msg, ", ")
|
|
}),
|
|
}, &server.LocalOptions{
|
|
Server: &jrpc2.ServerOptions{
|
|
Logger: log.New(os.Stderr, "[jhttp.Bridge] ", log.LstdFlags|log.Lshortfile),
|
|
Metrics: metrics.New(),
|
|
},
|
|
})
|
|
http.Handle("/rpc", jhttp.NewBridge(local.Client))
|
|
log.Fatal(http.ListenAndServe(fmt.Sprintf(":%d", *port), nil))
|
|
}
|