// Code generated by protoc-gen-go-grpc. DO NOT EDIT. package main import ( context "context" grpc "google.golang.org/grpc" codes "google.golang.org/grpc/codes" status "google.golang.org/grpc/status" emptypb "google.golang.org/protobuf/types/known/emptypb" ) // 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.32.0 or later. const _ = grpc.SupportPackageIsVersion7 // BankClient is the client API for Bank 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 BankClient interface { // OpenAccount creates an account with the type and given initial deposit // as its balance. OpenAccount(ctx context.Context, in *OpenAccountRequest, opts ...grpc.CallOption) (*Account, error) // CloseAccount closes the indicated account. An account can only be // closed if its balance is zero. CloseAccount(ctx context.Context, in *CloseAccountRequest, opts ...grpc.CallOption) (*emptypb.Empty, error) // GetAccounts lists all accounts for the current customer. GetAccounts(ctx context.Context, in *emptypb.Empty, opts ...grpc.CallOption) (*GetAccountsResponse, error) // GetTransactions streams all transactions that match the given criteria. // If the given start date is not specified, transactions since beginning // of time are included. Similarly, if the given end date is not specified, // transactions all the way to the presnet are included. GetTransactions(ctx context.Context, in *GetTransactionsRequest, opts ...grpc.CallOption) (Bank_GetTransactionsClient, error) // Deposit increases the balance of an account by depositing funds into it. Deposit(ctx context.Context, in *DepositRequest, opts ...grpc.CallOption) (*BalanceResponse, error) // Withdraw decreases the balance of an account by withdrawing funds from it. Withdraw(ctx context.Context, in *WithdrawRequest, opts ...grpc.CallOption) (*BalanceResponse, error) // Transfer moves money from one account to another. The source and destination // accounts can be with this bank (e.g. "local" account numbers) or can be // external accounts, identified by their ACH routing and account numbers. Transfer(ctx context.Context, in *TransferRequest, opts ...grpc.CallOption) (*TransferResponse, error) } type bankClient struct { cc grpc.ClientConnInterface } func NewBankClient(cc grpc.ClientConnInterface) BankClient { return &bankClient{cc} } func (c *bankClient) OpenAccount(ctx context.Context, in *OpenAccountRequest, opts ...grpc.CallOption) (*Account, error) { out := new(Account) err := c.cc.Invoke(ctx, "/Bank/OpenAccount", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *bankClient) CloseAccount(ctx context.Context, in *CloseAccountRequest, opts ...grpc.CallOption) (*emptypb.Empty, error) { out := new(emptypb.Empty) err := c.cc.Invoke(ctx, "/Bank/CloseAccount", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *bankClient) GetAccounts(ctx context.Context, in *emptypb.Empty, opts ...grpc.CallOption) (*GetAccountsResponse, error) { out := new(GetAccountsResponse) err := c.cc.Invoke(ctx, "/Bank/GetAccounts", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *bankClient) GetTransactions(ctx context.Context, in *GetTransactionsRequest, opts ...grpc.CallOption) (Bank_GetTransactionsClient, error) { stream, err := c.cc.NewStream(ctx, &Bank_ServiceDesc.Streams[0], "/Bank/GetTransactions", opts...) if err != nil { return nil, err } x := &bankGetTransactionsClient{stream} if err := x.ClientStream.SendMsg(in); err != nil { return nil, err } if err := x.ClientStream.CloseSend(); err != nil { return nil, err } return x, nil } type Bank_GetTransactionsClient interface { Recv() (*Transaction, error) grpc.ClientStream } type bankGetTransactionsClient struct { grpc.ClientStream } func (x *bankGetTransactionsClient) Recv() (*Transaction, error) { m := new(Transaction) if err := x.ClientStream.RecvMsg(m); err != nil { return nil, err } return m, nil } func (c *bankClient) Deposit(ctx context.Context, in *DepositRequest, opts ...grpc.CallOption) (*BalanceResponse, error) { out := new(BalanceResponse) err := c.cc.Invoke(ctx, "/Bank/Deposit", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *bankClient) Withdraw(ctx context.Context, in *WithdrawRequest, opts ...grpc.CallOption) (*BalanceResponse, error) { out := new(BalanceResponse) err := c.cc.Invoke(ctx, "/Bank/Withdraw", in, out, opts...) if err != nil { return nil, err } return out, nil } func (c *bankClient) Transfer(ctx context.Context, in *TransferRequest, opts ...grpc.CallOption) (*TransferResponse, error) { out := new(TransferResponse) err := c.cc.Invoke(ctx, "/Bank/Transfer", in, out, opts...) if err != nil { return nil, err } return out, nil } // BankServer is the server API for Bank service. // All implementations must embed UnimplementedBankServer // for forward compatibility type BankServer interface { // OpenAccount creates an account with the type and given initial deposit // as its balance. OpenAccount(context.Context, *OpenAccountRequest) (*Account, error) // CloseAccount closes the indicated account. An account can only be // closed if its balance is zero. CloseAccount(context.Context, *CloseAccountRequest) (*emptypb.Empty, error) // GetAccounts lists all accounts for the current customer. GetAccounts(context.Context, *emptypb.Empty) (*GetAccountsResponse, error) // GetTransactions streams all transactions that match the given criteria. // If the given start date is not specified, transactions since beginning // of time are included. Similarly, if the given end date is not specified, // transactions all the way to the presnet are included. GetTransactions(*GetTransactionsRequest, Bank_GetTransactionsServer) error // Deposit increases the balance of an account by depositing funds into it. Deposit(context.Context, *DepositRequest) (*BalanceResponse, error) // Withdraw decreases the balance of an account by withdrawing funds from it. Withdraw(context.Context, *WithdrawRequest) (*BalanceResponse, error) // Transfer moves money from one account to another. The source and destination // accounts can be with this bank (e.g. "local" account numbers) or can be // external accounts, identified by their ACH routing and account numbers. Transfer(context.Context, *TransferRequest) (*TransferResponse, error) mustEmbedUnimplementedBankServer() } // UnimplementedBankServer must be embedded to have forward compatible implementations. type UnimplementedBankServer struct { } func (UnimplementedBankServer) OpenAccount(context.Context, *OpenAccountRequest) (*Account, error) { return nil, status.Errorf(codes.Unimplemented, "method OpenAccount not implemented") } func (UnimplementedBankServer) CloseAccount(context.Context, *CloseAccountRequest) (*emptypb.Empty, error) { return nil, status.Errorf(codes.Unimplemented, "method CloseAccount not implemented") } func (UnimplementedBankServer) GetAccounts(context.Context, *emptypb.Empty) (*GetAccountsResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method GetAccounts not implemented") } func (UnimplementedBankServer) GetTransactions(*GetTransactionsRequest, Bank_GetTransactionsServer) error { return status.Errorf(codes.Unimplemented, "method GetTransactions not implemented") } func (UnimplementedBankServer) Deposit(context.Context, *DepositRequest) (*BalanceResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method Deposit not implemented") } func (UnimplementedBankServer) Withdraw(context.Context, *WithdrawRequest) (*BalanceResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method Withdraw not implemented") } func (UnimplementedBankServer) Transfer(context.Context, *TransferRequest) (*TransferResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method Transfer not implemented") } func (UnimplementedBankServer) mustEmbedUnimplementedBankServer() {} // UnsafeBankServer may be embedded to opt out of forward compatibility for this service. // Use of this interface is not recommended, as added methods to BankServer will // result in compilation errors. type UnsafeBankServer interface { mustEmbedUnimplementedBankServer() } func RegisterBankServer(s grpc.ServiceRegistrar, srv BankServer) { s.RegisterService(&Bank_ServiceDesc, srv) } func _Bank_OpenAccount_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(OpenAccountRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(BankServer).OpenAccount(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/Bank/OpenAccount", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(BankServer).OpenAccount(ctx, req.(*OpenAccountRequest)) } return interceptor(ctx, in, info, handler) } func _Bank_CloseAccount_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(CloseAccountRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(BankServer).CloseAccount(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/Bank/CloseAccount", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(BankServer).CloseAccount(ctx, req.(*CloseAccountRequest)) } return interceptor(ctx, in, info, handler) } func _Bank_GetAccounts_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(emptypb.Empty) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(BankServer).GetAccounts(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/Bank/GetAccounts", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(BankServer).GetAccounts(ctx, req.(*emptypb.Empty)) } return interceptor(ctx, in, info, handler) } func _Bank_GetTransactions_Handler(srv interface{}, stream grpc.ServerStream) error { m := new(GetTransactionsRequest) if err := stream.RecvMsg(m); err != nil { return err } return srv.(BankServer).GetTransactions(m, &bankGetTransactionsServer{stream}) } type Bank_GetTransactionsServer interface { Send(*Transaction) error grpc.ServerStream } type bankGetTransactionsServer struct { grpc.ServerStream } func (x *bankGetTransactionsServer) Send(m *Transaction) error { return x.ServerStream.SendMsg(m) } func _Bank_Deposit_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(DepositRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(BankServer).Deposit(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/Bank/Deposit", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(BankServer).Deposit(ctx, req.(*DepositRequest)) } return interceptor(ctx, in, info, handler) } func _Bank_Withdraw_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(WithdrawRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(BankServer).Withdraw(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/Bank/Withdraw", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(BankServer).Withdraw(ctx, req.(*WithdrawRequest)) } return interceptor(ctx, in, info, handler) } func _Bank_Transfer_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(TransferRequest) if err := dec(in); err != nil { return nil, err } if interceptor == nil { return srv.(BankServer).Transfer(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, FullMethod: "/Bank/Transfer", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(BankServer).Transfer(ctx, req.(*TransferRequest)) } return interceptor(ctx, in, info, handler) } // Bank_ServiceDesc is the grpc.ServiceDesc for Bank service. // It's only intended for direct use with grpc.RegisterService, // and not to be introspected or modified (even as a copy) var Bank_ServiceDesc = grpc.ServiceDesc{ ServiceName: "Bank", HandlerType: (*BankServer)(nil), Methods: []grpc.MethodDesc{ { MethodName: "OpenAccount", Handler: _Bank_OpenAccount_Handler, }, { MethodName: "CloseAccount", Handler: _Bank_CloseAccount_Handler, }, { MethodName: "GetAccounts", Handler: _Bank_GetAccounts_Handler, }, { MethodName: "Deposit", Handler: _Bank_Deposit_Handler, }, { MethodName: "Withdraw", Handler: _Bank_Withdraw_Handler, }, { MethodName: "Transfer", Handler: _Bank_Transfer_Handler, }, }, Streams: []grpc.StreamDesc{ { StreamName: "GetTransactions", Handler: _Bank_GetTransactions_Handler, ServerStreams: true, }, }, Metadata: "bank.proto", }