package main import ( "fmt" "os" "context" "github.com/micro/cli/v2" proto "github.com/micro/go-micro/examples/service/proto" "github.com/micro/go-micro/v2" ) /* Example usage of top level service initialisation */ type Greeter struct{} func (g *Greeter) Hello(ctx context.Context, req *proto.Request, rsp *proto.Response) error { rsp.Greeting = "Hello " + req.Name return nil } // Setup and the client func runClient(service micro.Service) { // Create new greeter client greeter := proto.NewGreeterService("greeter", service.Client()) // Call the greeter rsp, err := greeter.Hello(context.TODO(), &proto.Request{Name: "John"}) if err != nil { fmt.Println(err) return } // Print response fmt.Println(rsp.Greeting) } func main() { // Create a new service. Optionally include some options here. service := micro.NewService( micro.Name("greeter"), micro.Version("latest"), micro.Metadata(map[string]string{ "type": "helloworld", }), // Setup some flags. Specify --run_client to run the client // Add runtime flags // We could do this below too micro.Flags(&cli.BoolFlag{ Name: "run_client", Usage: "Launch the client", }), ) // Init will parse the command line flags. Any flags set will // override the above settings. Options defined here will // override anything set on the command line. service.Init( // Add runtime action // We could actually do this above micro.Action(func(c *cli.Context) error { if c.Bool("run_client") { runClient(service) os.Exit(0) } return nil }), ) // By default we'll run the server unless the flags catch us // Setup the server // Register handler proto.RegisterGreeterHandler(service.Server(), new(Greeter)) // Run the server if err := service.Run(); err != nil { fmt.Println(err) } }