gRPC Service
Generate
Generate a protobuf definition for a gRPC service from a GraphQL schema
wgc router grpc-service generate
The generate
command generates a protobuf definition and mapping file for a gRPC service from a GraphQL schema,
which can be used to implement a gRPC service and can be used for the composition.
Usage
Arguments
Argument | Description | Default |
---|---|---|
service-name | Name of the gRPC service | service.v1 |
Options
Option | Description | Default |
---|---|---|
-i, --input <path-to-input> | The GraphQL schema file to generate a protobuf schema from | Required |
-o, --output <path-to-output> | The output directory for the protobuf schema | . |
-p, --package-name <name> | The name of the proto package | service.v1 |
-g, --go-package <name> | Adds an option go_package to the proto file | None |
Description
This command generates a protobuf definition for a gRPC service from a GraphQL schema.
Examples
Generate a protobuf definition for a gRPC service from a GraphQL schema
Define a custom package name
Define a custom go package name
Output
The command generates multiple files in the output directory:
service.proto
: The protobuf definition for the gRPC serviceservice.mapping.json
: The mapping file for the gRPC serviceservice.proto.lock.json
: The lock file for the protobuf definition
The generated protobuf definition can be used to implement a gRPC service in any language that supports protobuf.
The mapping and the protobuf definition is needed for the composition part.