aboutsummaryrefslogblamecommitdiff
path: root/example/main.go
blob: ec3c5a4ca75f6d892e7c64da66d0fa562b1ecb32 (plain) (tree)
1
2
3
4
5
6
7
8
9




                 


                   
 


                                              


             



                                                                                   
 
                                        

                          
                           
                                    










                                                                  

                                     









                                                                 
                         
                  



















                                                                                      


                              

                                                                 

                                                                     
         
 

                                               
                                          






                                                                                        















                                                                 



                                                 








                            
package main

import (
	"context"
	"errors"
	"log"
	"os"
	"os/signal"

	"neonxp.ru/go/jsonrpc2/rpc"
	"neonxp.ru/go/jsonrpc2/rpc/middleware"
	"neonxp.ru/go/jsonrpc2/transport"
)

func main() {
	s := rpc.New(
		rpc.WithLogger(rpc.StdLogger),
		rpc.WithTransport(&transport.HTTP{Bind: ":8000", CORSOrigin: "*"}),
	)

	// Set options after constructor
	serviceSchema := `
	{
		"divide": {
			"request": {
				"type": "object",
				"properties": {
					"a": {
						"type": "integer"
					},
					"b": {
						"type": "integer",
						"not":{"const":0}
					}
				},
				"required": ["a", "b"]
			},
			"response": {
				"type": "object",
				"properties": {
					"quo": {
						"type": "integer"
					},
					"rem": {
						"type": "integer"
					}
				},
				"required": ["quo", "rem"]
			}
		},
		"multiply": {
			"request": {
				"type": "object",
				"properties": {
					"a": {
						"type": "integer"
					},
					"b": {
						"type": "integer"
					}
				},
				"required": ["a", "b"]
			},
			"response": {
				"type": "integer"
			}
		}
	}`

	validation, err := middleware.Validation(middleware.MustSchema(serviceSchema))
	if err != nil {
		log.Fatal(err)
	}
	s.Use(
		rpc.WithTransport(&transport.TCP{Bind: ":3000"}),
		rpc.WithMiddleware(middleware.Logger(rpc.StdLogger)),
		rpc.WithMiddleware(validation),
	)

	s.Register("multiply", rpc.H(Multiply))
	s.Register("divide", rpc.H(Divide))
	s.Register("hello", rpc.HS(Hello))

	ctx, cancel := signal.NotifyContext(context.Background(), os.Interrupt, os.Kill)
	defer cancel()

	if err := s.Run(ctx); err != nil {
		log.Fatal(err)
	}
}

func Multiply(ctx context.Context, args *Args) (int, error) {
	return args.A * args.B, nil
}

func Divide(ctx context.Context, args *Args) (*Quotient, error) {
	if args.B == 0 {
		return nil, errors.New("divide by zero")
	}
	quo := new(Quotient)
	quo.Quo = args.A / args.B
	quo.Rem = args.A % args.B
	return quo, nil
}

func Hello(ctx context.Context) (string, error) {
	return "world", nil
}

type Args struct {
	A int `json:"a"`
	B int `json:"b"`
}

type Quotient struct {
	Quo int `json:"quo"`
	Rem int `json:"rem"`
}