generate protobuf for asynq payload.
# first install protobuf, then install
go get -d google.golang.org/protobuf/cmd/protoc-gen-go
go get -d google.golang.org/grpc/cmd/protoc-gen-go-grpc
# install protoc-gen-go-asynq
go install github.com/gopkg-dev/protoc-gen-go-asynq@latest
syntax = "proto3";
package example;
// import copy asynq.proto
import "asynq/asynq.proto";
import "google/protobuf/empty.proto";
option go_package = ".;example";
option java_multiple_files = true;
option java_package = "example";
service User {
rpc CreateUser(CreateUserPayload) returns (google.protobuf.Empty) {
option (asynq.task) = {
typename: "user:create" // define asynq.task typename, it is unique.
};
};
rpc UpdateUser(UpdateUserPayload) returns (google.protobuf.Empty) {
option (asynq.task) = {
typename: "user:update"
};
};
}
message CreateUserPayload {
string name = 1;
}
message UpdateUserPayload {
string name = 1;
}
protoc --proto_path=. \
--proto_path=./{copy_dir} \
--go_out=paths=source_relative:. \
--go-asynq_out=paths=source_relative:. \
example/example.proto
Don't care about encode/decode, you just implement your define method.