From 36e5b935e6b4e33da0113824898b94e41cd1adc5 Mon Sep 17 00:00:00 2001 From: netscrawler Date: Sun, 30 Jun 2024 21:25:12 +0300 Subject: [PATCH] v0.0.1 --- README.md | 4 +- Taskfile.yaml | 9 + gen/go/changeAPI/changeAPI.pb.go | 255 ++++++++++++++++++++++++++ gen/go/changeAPI/changeAPI_grpc.pb.go | 110 +++++++++++ go.mod | 15 ++ go.sum | 14 ++ proto/changeAPI/changeAPI.proto | 25 +++ 7 files changed, 430 insertions(+), 2 deletions(-) create mode 100644 Taskfile.yaml create mode 100644 gen/go/changeAPI/changeAPI.pb.go create mode 100644 gen/go/changeAPI/changeAPI_grpc.pb.go create mode 100644 go.mod create mode 100644 go.sum create mode 100644 proto/changeAPI/changeAPI.proto diff --git a/README.md b/README.md index 8c345c0..e3ba111 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,2 @@ -# protoss - +# protos + proto files and genfiles for use in ChangeApi. diff --git a/Taskfile.yaml b/Taskfile.yaml new file mode 100644 index 0000000..10a41fc --- /dev/null +++ b/Taskfile.yaml @@ -0,0 +1,9 @@ +version: "3" + +tasks: + generate: + aliases: + - gen + desc: "Generate code from proto files" + cmds: + - protoc -I proto proto/changeAPI/*.proto --go_out=./gen/go/ --go_opt=paths=source_relative --go-grpc_out=./gen/go/ --go-grpc_opt=paths=source_relative \ No newline at end of file diff --git a/gen/go/changeAPI/changeAPI.pb.go b/gen/go/changeAPI/changeAPI.pb.go new file mode 100644 index 0000000..6f308ea --- /dev/null +++ b/gen/go/changeAPI/changeAPI.pb.go @@ -0,0 +1,255 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// versions: +// protoc-gen-go v1.34.2 +// protoc v5.27.1 +// source: changeAPI/changeAPI.proto + +package cnvrtv1 + +import ( + protoreflect "google.golang.org/protobuf/reflect/protoreflect" + protoimpl "google.golang.org/protobuf/runtime/protoimpl" + reflect "reflect" + sync "sync" +) + +const ( + // Verify that this generated code is sufficiently up-to-date. + _ = protoimpl.EnforceVersion(20 - protoimpl.MinVersion) + // Verify that runtime/protoimpl is sufficiently up-to-date. + _ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20) +) + +type ConvertRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + Amount uint32 `protobuf:"varint,1,opt,name=amount,proto3" json:"amount,omitempty"` + TargetCurrency string `protobuf:"bytes,2,opt,name=target_currency,json=targetCurrency,proto3" json:"target_currency,omitempty"` +} + +func (x *ConvertRequest) Reset() { + *x = ConvertRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_changeAPI_changeAPI_proto_msgTypes[0] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ConvertRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ConvertRequest) ProtoMessage() {} + +func (x *ConvertRequest) ProtoReflect() protoreflect.Message { + mi := &file_changeAPI_changeAPI_proto_msgTypes[0] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ConvertRequest.ProtoReflect.Descriptor instead. +func (*ConvertRequest) Descriptor() ([]byte, []int) { + return file_changeAPI_changeAPI_proto_rawDescGZIP(), []int{0} +} + +func (x *ConvertRequest) GetAmount() uint32 { + if x != nil { + return x.Amount + } + return 0 +} + +func (x *ConvertRequest) GetTargetCurrency() string { + if x != nil { + return x.TargetCurrency + } + return "" +} + +type ConvertResponse struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + BaseAmount uint32 `protobuf:"varint,1,opt,name=base_amount,json=baseAmount,proto3" json:"base_amount,omitempty"` + ConvertedAmount uint32 `protobuf:"varint,2,opt,name=converted_amount,json=convertedAmount,proto3" json:"converted_amount,omitempty"` + ConvertedCurrency string `protobuf:"bytes,3,opt,name=converted_currency,json=convertedCurrency,proto3" json:"converted_currency,omitempty"` + Rate float32 `protobuf:"fixed32,4,opt,name=rate,proto3" json:"rate,omitempty"` +} + +func (x *ConvertResponse) Reset() { + *x = ConvertResponse{} + if protoimpl.UnsafeEnabled { + mi := &file_changeAPI_changeAPI_proto_msgTypes[1] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ConvertResponse) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ConvertResponse) ProtoMessage() {} + +func (x *ConvertResponse) ProtoReflect() protoreflect.Message { + mi := &file_changeAPI_changeAPI_proto_msgTypes[1] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ConvertResponse.ProtoReflect.Descriptor instead. +func (*ConvertResponse) Descriptor() ([]byte, []int) { + return file_changeAPI_changeAPI_proto_rawDescGZIP(), []int{1} +} + +func (x *ConvertResponse) GetBaseAmount() uint32 { + if x != nil { + return x.BaseAmount + } + return 0 +} + +func (x *ConvertResponse) GetConvertedAmount() uint32 { + if x != nil { + return x.ConvertedAmount + } + return 0 +} + +func (x *ConvertResponse) GetConvertedCurrency() string { + if x != nil { + return x.ConvertedCurrency + } + return "" +} + +func (x *ConvertResponse) GetRate() float32 { + if x != nil { + return x.Rate + } + return 0 +} + +var File_changeAPI_changeAPI_proto protoreflect.FileDescriptor + +var file_changeAPI_changeAPI_proto_rawDesc = []byte{ + 0x0a, 0x19, 0x63, 0x68, 0x61, 0x6e, 0x67, 0x65, 0x41, 0x50, 0x49, 0x2f, 0x63, 0x68, 0x61, 0x6e, + 0x67, 0x65, 0x41, 0x50, 0x49, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x12, 0x05, 0x63, 0x6e, 0x76, + 0x72, 0x74, 0x22, 0x51, 0x0a, 0x0e, 0x43, 0x6f, 0x6e, 0x76, 0x65, 0x72, 0x74, 0x52, 0x65, 0x71, + 0x75, 0x65, 0x73, 0x74, 0x12, 0x16, 0x0a, 0x06, 0x61, 0x6d, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x01, + 0x20, 0x01, 0x28, 0x0d, 0x52, 0x06, 0x61, 0x6d, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x27, 0x0a, 0x0f, + 0x74, 0x61, 0x72, 0x67, 0x65, 0x74, 0x5f, 0x63, 0x75, 0x72, 0x72, 0x65, 0x6e, 0x63, 0x79, 0x18, + 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0e, 0x74, 0x61, 0x72, 0x67, 0x65, 0x74, 0x43, 0x75, 0x72, + 0x72, 0x65, 0x6e, 0x63, 0x79, 0x22, 0xa0, 0x01, 0x0a, 0x0f, 0x43, 0x6f, 0x6e, 0x76, 0x65, 0x72, + 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x1f, 0x0a, 0x0b, 0x62, 0x61, 0x73, + 0x65, 0x5f, 0x61, 0x6d, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x0a, + 0x62, 0x61, 0x73, 0x65, 0x41, 0x6d, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x29, 0x0a, 0x10, 0x63, 0x6f, + 0x6e, 0x76, 0x65, 0x72, 0x74, 0x65, 0x64, 0x5f, 0x61, 0x6d, 0x6f, 0x75, 0x6e, 0x74, 0x18, 0x02, + 0x20, 0x01, 0x28, 0x0d, 0x52, 0x0f, 0x63, 0x6f, 0x6e, 0x76, 0x65, 0x72, 0x74, 0x65, 0x64, 0x41, + 0x6d, 0x6f, 0x75, 0x6e, 0x74, 0x12, 0x2d, 0x0a, 0x12, 0x63, 0x6f, 0x6e, 0x76, 0x65, 0x72, 0x74, + 0x65, 0x64, 0x5f, 0x63, 0x75, 0x72, 0x72, 0x65, 0x6e, 0x63, 0x79, 0x18, 0x03, 0x20, 0x01, 0x28, + 0x09, 0x52, 0x11, 0x63, 0x6f, 0x6e, 0x76, 0x65, 0x72, 0x74, 0x65, 0x64, 0x43, 0x75, 0x72, 0x72, + 0x65, 0x6e, 0x63, 0x79, 0x12, 0x12, 0x0a, 0x04, 0x72, 0x61, 0x74, 0x65, 0x18, 0x04, 0x20, 0x01, + 0x28, 0x02, 0x52, 0x04, 0x72, 0x61, 0x74, 0x65, 0x32, 0x47, 0x0a, 0x09, 0x43, 0x6f, 0x6e, 0x76, + 0x65, 0x72, 0x74, 0x65, 0x72, 0x12, 0x3a, 0x0a, 0x07, 0x43, 0x6f, 0x6e, 0x76, 0x65, 0x72, 0x74, + 0x12, 0x15, 0x2e, 0x63, 0x6e, 0x76, 0x72, 0x74, 0x2e, 0x43, 0x6f, 0x6e, 0x76, 0x65, 0x72, 0x74, + 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x16, 0x2e, 0x63, 0x6e, 0x76, 0x72, 0x74, 0x2e, + 0x43, 0x6f, 0x6e, 0x76, 0x65, 0x72, 0x74, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, + 0x00, 0x42, 0x1e, 0x5a, 0x1c, 0x6e, 0x65, 0x74, 0x73, 0x63, 0x72, 0x61, 0x77, 0x6c, 0x65, 0x72, + 0x2e, 0x63, 0x6e, 0x76, 0x72, 0x74, 0x2e, 0x76, 0x31, 0x3b, 0x63, 0x6e, 0x76, 0x72, 0x74, 0x76, + 0x31, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33, +} + +var ( + file_changeAPI_changeAPI_proto_rawDescOnce sync.Once + file_changeAPI_changeAPI_proto_rawDescData = file_changeAPI_changeAPI_proto_rawDesc +) + +func file_changeAPI_changeAPI_proto_rawDescGZIP() []byte { + file_changeAPI_changeAPI_proto_rawDescOnce.Do(func() { + file_changeAPI_changeAPI_proto_rawDescData = protoimpl.X.CompressGZIP(file_changeAPI_changeAPI_proto_rawDescData) + }) + return file_changeAPI_changeAPI_proto_rawDescData +} + +var file_changeAPI_changeAPI_proto_msgTypes = make([]protoimpl.MessageInfo, 2) +var file_changeAPI_changeAPI_proto_goTypes = []any{ + (*ConvertRequest)(nil), // 0: cnvrt.ConvertRequest + (*ConvertResponse)(nil), // 1: cnvrt.ConvertResponse +} +var file_changeAPI_changeAPI_proto_depIdxs = []int32{ + 0, // 0: cnvrt.Converter.Convert:input_type -> cnvrt.ConvertRequest + 1, // 1: cnvrt.Converter.Convert:output_type -> cnvrt.ConvertResponse + 1, // [1:2] is the sub-list for method output_type + 0, // [0:1] is the sub-list for method input_type + 0, // [0:0] is the sub-list for extension type_name + 0, // [0:0] is the sub-list for extension extendee + 0, // [0:0] is the sub-list for field type_name +} + +func init() { file_changeAPI_changeAPI_proto_init() } +func file_changeAPI_changeAPI_proto_init() { + if File_changeAPI_changeAPI_proto != nil { + return + } + if !protoimpl.UnsafeEnabled { + file_changeAPI_changeAPI_proto_msgTypes[0].Exporter = func(v any, i int) any { + switch v := v.(*ConvertRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_changeAPI_changeAPI_proto_msgTypes[1].Exporter = func(v any, i int) any { + switch v := v.(*ConvertResponse); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + } + type x struct{} + out := protoimpl.TypeBuilder{ + File: protoimpl.DescBuilder{ + GoPackagePath: reflect.TypeOf(x{}).PkgPath(), + RawDescriptor: file_changeAPI_changeAPI_proto_rawDesc, + NumEnums: 0, + NumMessages: 2, + NumExtensions: 0, + NumServices: 1, + }, + GoTypes: file_changeAPI_changeAPI_proto_goTypes, + DependencyIndexes: file_changeAPI_changeAPI_proto_depIdxs, + MessageInfos: file_changeAPI_changeAPI_proto_msgTypes, + }.Build() + File_changeAPI_changeAPI_proto = out.File + file_changeAPI_changeAPI_proto_rawDesc = nil + file_changeAPI_changeAPI_proto_goTypes = nil + file_changeAPI_changeAPI_proto_depIdxs = nil +} diff --git a/gen/go/changeAPI/changeAPI_grpc.pb.go b/gen/go/changeAPI/changeAPI_grpc.pb.go new file mode 100644 index 0000000..0a5ddab --- /dev/null +++ b/gen/go/changeAPI/changeAPI_grpc.pb.go @@ -0,0 +1,110 @@ +// Code generated by protoc-gen-go-grpc. DO NOT EDIT. +// versions: +// - protoc-gen-go-grpc v1.4.0 +// - protoc v5.27.1 +// source: changeAPI/changeAPI.proto + +package cnvrtv1 + +import ( + context "context" + grpc "google.golang.org/grpc" + codes "google.golang.org/grpc/codes" + status "google.golang.org/grpc/status" +) + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the grpc package it is being compiled against. +// Requires gRPC-Go v1.62.0 or later. +const _ = grpc.SupportPackageIsVersion8 + +const ( + Converter_Convert_FullMethodName = "/cnvrt.Converter/Convert" +) + +// ConverterClient is the client API for Converter service. +// +// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://pkg.go.dev/google.golang.org/grpc/?tab=doc#ClientConn.NewStream. +type ConverterClient interface { + Convert(ctx context.Context, in *ConvertRequest, opts ...grpc.CallOption) (*ConvertResponse, error) +} + +type converterClient struct { + cc grpc.ClientConnInterface +} + +func NewConverterClient(cc grpc.ClientConnInterface) ConverterClient { + return &converterClient{cc} +} + +func (c *converterClient) Convert(ctx context.Context, in *ConvertRequest, opts ...grpc.CallOption) (*ConvertResponse, error) { + cOpts := append([]grpc.CallOption{grpc.StaticMethod()}, opts...) + out := new(ConvertResponse) + err := c.cc.Invoke(ctx, Converter_Convert_FullMethodName, in, out, cOpts...) + if err != nil { + return nil, err + } + return out, nil +} + +// ConverterServer is the server API for Converter service. +// All implementations must embed UnimplementedConverterServer +// for forward compatibility +type ConverterServer interface { + Convert(context.Context, *ConvertRequest) (*ConvertResponse, error) + mustEmbedUnimplementedConverterServer() +} + +// UnimplementedConverterServer must be embedded to have forward compatible implementations. +type UnimplementedConverterServer struct { +} + +func (UnimplementedConverterServer) Convert(context.Context, *ConvertRequest) (*ConvertResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method Convert not implemented") +} +func (UnimplementedConverterServer) mustEmbedUnimplementedConverterServer() {} + +// UnsafeConverterServer may be embedded to opt out of forward compatibility for this service. +// Use of this interface is not recommended, as added methods to ConverterServer will +// result in compilation errors. +type UnsafeConverterServer interface { + mustEmbedUnimplementedConverterServer() +} + +func RegisterConverterServer(s grpc.ServiceRegistrar, srv ConverterServer) { + s.RegisterService(&Converter_ServiceDesc, srv) +} + +func _Converter_Convert_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(ConvertRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ConverterServer).Convert(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: Converter_Convert_FullMethodName, + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ConverterServer).Convert(ctx, req.(*ConvertRequest)) + } + return interceptor(ctx, in, info, handler) +} + +// Converter_ServiceDesc is the grpc.ServiceDesc for Converter service. +// It's only intended for direct use with grpc.RegisterService, +// and not to be introspected or modified (even as a copy) +var Converter_ServiceDesc = grpc.ServiceDesc{ + ServiceName: "cnvrt.Converter", + HandlerType: (*ConverterServer)(nil), + Methods: []grpc.MethodDesc{ + { + MethodName: "Convert", + Handler: _Converter_Convert_Handler, + }, + }, + Streams: []grpc.StreamDesc{}, + Metadata: "changeAPI/changeAPI.proto", +} diff --git a/go.mod b/go.mod new file mode 100644 index 0000000..eebd076 --- /dev/null +++ b/go.mod @@ -0,0 +1,15 @@ +module github.com/netscrawler/protoss + +go 1.22 + +require ( + google.golang.org/grpc v1.64.0 + google.golang.org/protobuf v1.34.2 +) + +require ( + golang.org/x/net v0.22.0 // indirect + golang.org/x/sys v0.18.0 // indirect + golang.org/x/text v0.14.0 // indirect + google.golang.org/genproto/googleapis/rpc v0.0.0-20240318140521-94a12d6c2237 // indirect +) diff --git a/go.sum b/go.sum new file mode 100644 index 0000000..9240e22 --- /dev/null +++ b/go.sum @@ -0,0 +1,14 @@ +github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= +github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= +golang.org/x/net v0.22.0 h1:9sGLhx7iRIHEiX0oAJ3MRZMUCElJgy7Br1nO+AMN3Tc= +golang.org/x/net v0.22.0/go.mod h1:JKghWKKOSdJwpW2GEx0Ja7fmaKnMsbu+MWVZTokSYmg= +golang.org/x/sys v0.18.0 h1:DBdB3niSjOA/O0blCZBqDefyWNYveAYMNF1Wum0DYQ4= +golang.org/x/sys v0.18.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/text v0.14.0 h1:ScX5w1eTa3QqT8oi6+ziP7dTV1S2+ALU0bI+0zXKWiQ= +golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= +google.golang.org/genproto/googleapis/rpc v0.0.0-20240318140521-94a12d6c2237 h1:NnYq6UN9ReLM9/Y01KWNOWyI5xQ9kbIms5GGJVwS/Yc= +google.golang.org/genproto/googleapis/rpc v0.0.0-20240318140521-94a12d6c2237/go.mod h1:WtryC6hu0hhx87FDGxWCDptyssuo68sk10vYjF+T9fY= +google.golang.org/grpc v1.64.0 h1:KH3VH9y/MgNQg1dE7b3XfVK0GsPSIzJwdF617gUSbvY= +google.golang.org/grpc v1.64.0/go.mod h1:oxjF8E3FBnjp+/gVFYdWacaLDx9na1aqy9oovLpxQYg= +google.golang.org/protobuf v1.34.2 h1:6xV6lTsCfpGD21XK49h7MhtcApnLqkfYgPcdHftf6hg= +google.golang.org/protobuf v1.34.2/go.mod h1:qYOHts0dSfpeUzUFpOMr/WGzszTmLH+DiWniOlNbLDw= diff --git a/proto/changeAPI/changeAPI.proto b/proto/changeAPI/changeAPI.proto new file mode 100644 index 0000000..509040b --- /dev/null +++ b/proto/changeAPI/changeAPI.proto @@ -0,0 +1,25 @@ +syntax = "proto3"; +package cnvrt; +option go_package = "netscrawler.cnvrt.v1;cnvrtv1"; + + + +message ConvertRequest { + uint32 amount = 1; + string target_currency = 2; +} + +message ConvertResponse { + uint32 base_amount = 1; + uint32 converted_amount = 2; + string converted_currency = 3; + float rate = 4; +} + +service Converter { + + rpc Convert(ConvertRequest) returns (ConvertResponse) { + + } +} +