// Generated by the gRPC C++ plugin.
// If you make any local change, they will be lost.
// source: keyapis/identity_b2b/v1/keyapis_identity_b2b_authorization_v1.proto

#include "keyapis/identity_b2b/v1/keyapis_identity_b2b_authorization_v1.pb.h"
#include "keyapis/identity_b2b/v1/keyapis_identity_b2b_authorization_v1.grpc.pb.h"

#include <functional>
#include <grpcpp/impl/codegen/async_stream.h>
#include <grpcpp/impl/codegen/async_unary_call.h>
#include <grpcpp/impl/codegen/channel_interface.h>
#include <grpcpp/impl/codegen/client_unary_call.h>
#include <grpcpp/impl/codegen/client_callback.h>
#include <grpcpp/impl/codegen/message_allocator.h>
#include <grpcpp/impl/codegen/method_handler.h>
#include <grpcpp/impl/codegen/rpc_service_method.h>
#include <grpcpp/impl/codegen/server_callback.h>
#include <grpcpp/impl/codegen/server_callback_handlers.h>
#include <grpcpp/impl/codegen/server_context.h>
#include <grpcpp/impl/codegen/service_type.h>
#include <grpcpp/impl/codegen/sync_stream.h>
namespace keyapis {
namespace identity_b2b {
namespace v1 {

static const char* AuthorizationB2bService_method_names[] = {
  "/keyapis.identity_b2b.v1.AuthorizationB2bService/PostAuthorizationLogin",
  "/keyapis.identity_b2b.v1.AuthorizationB2bService/PostAuthorizationSendCode",
  "/keyapis.identity_b2b.v1.AuthorizationB2bService/PostAuthorizationLoginByPassword",
  "/keyapis.identity_b2b.v1.AuthorizationB2bService/PostAuthorizationCheckCode",
};

std::unique_ptr< AuthorizationB2bService::Stub> AuthorizationB2bService::NewStub(const std::shared_ptr< ::grpc::ChannelInterface>& channel, const ::grpc::StubOptions& options) {
  (void)options;
  std::unique_ptr< AuthorizationB2bService::Stub> stub(new AuthorizationB2bService::Stub(channel, options));
  return stub;
}

AuthorizationB2bService::Stub::Stub(const std::shared_ptr< ::grpc::ChannelInterface>& channel, const ::grpc::StubOptions& options)
  : channel_(channel), rpcmethod_PostAuthorizationLogin_(AuthorizationB2bService_method_names[0], options.suffix_for_stats(),::grpc::internal::RpcMethod::NORMAL_RPC, channel)
  , rpcmethod_PostAuthorizationSendCode_(AuthorizationB2bService_method_names[1], options.suffix_for_stats(),::grpc::internal::RpcMethod::NORMAL_RPC, channel)
  , rpcmethod_PostAuthorizationLoginByPassword_(AuthorizationB2bService_method_names[2], options.suffix_for_stats(),::grpc::internal::RpcMethod::NORMAL_RPC, channel)
  , rpcmethod_PostAuthorizationCheckCode_(AuthorizationB2bService_method_names[3], options.suffix_for_stats(),::grpc::internal::RpcMethod::NORMAL_RPC, channel)
  {}

::grpc::Status AuthorizationB2bService::Stub::PostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response) {
  return ::grpc::internal::BlockingUnaryCall< ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), rpcmethod_PostAuthorizationLogin_, context, request, response);
}

void AuthorizationB2bService::Stub::async::PostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response, std::function<void(::grpc::Status)> f) {
  ::grpc::internal::CallbackUnaryCall< ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_PostAuthorizationLogin_, context, request, response, std::move(f));
}

void AuthorizationB2bService::Stub::async::PostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response, ::grpc::ClientUnaryReactor* reactor) {
  ::grpc::internal::ClientCallbackUnaryFactory::Create< ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_PostAuthorizationLogin_, context, request, response, reactor);
}

::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>* AuthorizationB2bService::Stub::PrepareAsyncPostAuthorizationLoginRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::grpc::CompletionQueue* cq) {
  return ::grpc::internal::ClientAsyncResponseReaderHelper::Create< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse, ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), cq, rpcmethod_PostAuthorizationLogin_, context, request);
}

::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>* AuthorizationB2bService::Stub::AsyncPostAuthorizationLoginRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::grpc::CompletionQueue* cq) {
  auto* result =
    this->PrepareAsyncPostAuthorizationLoginRaw(context, request, cq);
  result->StartCall();
  return result;
}

::grpc::Status AuthorizationB2bService::Stub::PostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response) {
  return ::grpc::internal::BlockingUnaryCall< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), rpcmethod_PostAuthorizationSendCode_, context, request, response);
}

void AuthorizationB2bService::Stub::async::PostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response, std::function<void(::grpc::Status)> f) {
  ::grpc::internal::CallbackUnaryCall< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_PostAuthorizationSendCode_, context, request, response, std::move(f));
}

void AuthorizationB2bService::Stub::async::PostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response, ::grpc::ClientUnaryReactor* reactor) {
  ::grpc::internal::ClientCallbackUnaryFactory::Create< ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_PostAuthorizationSendCode_, context, request, response, reactor);
}

::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>* AuthorizationB2bService::Stub::PrepareAsyncPostAuthorizationSendCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::grpc::CompletionQueue* cq) {
  return ::grpc::internal::ClientAsyncResponseReaderHelper::Create< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), cq, rpcmethod_PostAuthorizationSendCode_, context, request);
}

::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>* AuthorizationB2bService::Stub::AsyncPostAuthorizationSendCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::grpc::CompletionQueue* cq) {
  auto* result =
    this->PrepareAsyncPostAuthorizationSendCodeRaw(context, request, cq);
  result->StartCall();
  return result;
}

::grpc::Status AuthorizationB2bService::Stub::PostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response) {
  return ::grpc::internal::BlockingUnaryCall< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), rpcmethod_PostAuthorizationLoginByPassword_, context, request, response);
}

void AuthorizationB2bService::Stub::async::PostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response, std::function<void(::grpc::Status)> f) {
  ::grpc::internal::CallbackUnaryCall< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_PostAuthorizationLoginByPassword_, context, request, response, std::move(f));
}

void AuthorizationB2bService::Stub::async::PostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response, ::grpc::ClientUnaryReactor* reactor) {
  ::grpc::internal::ClientCallbackUnaryFactory::Create< ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_PostAuthorizationLoginByPassword_, context, request, response, reactor);
}

::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>* AuthorizationB2bService::Stub::PrepareAsyncPostAuthorizationLoginByPasswordRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::grpc::CompletionQueue* cq) {
  return ::grpc::internal::ClientAsyncResponseReaderHelper::Create< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), cq, rpcmethod_PostAuthorizationLoginByPassword_, context, request);
}

::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>* AuthorizationB2bService::Stub::AsyncPostAuthorizationLoginByPasswordRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::grpc::CompletionQueue* cq) {
  auto* result =
    this->PrepareAsyncPostAuthorizationLoginByPasswordRaw(context, request, cq);
  result->StartCall();
  return result;
}

::grpc::Status AuthorizationB2bService::Stub::PostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response) {
  return ::grpc::internal::BlockingUnaryCall< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), rpcmethod_PostAuthorizationCheckCode_, context, request, response);
}

void AuthorizationB2bService::Stub::async::PostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response, std::function<void(::grpc::Status)> f) {
  ::grpc::internal::CallbackUnaryCall< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_PostAuthorizationCheckCode_, context, request, response, std::move(f));
}

void AuthorizationB2bService::Stub::async::PostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response, ::grpc::ClientUnaryReactor* reactor) {
  ::grpc::internal::ClientCallbackUnaryFactory::Create< ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_PostAuthorizationCheckCode_, context, request, response, reactor);
}

::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>* AuthorizationB2bService::Stub::PrepareAsyncPostAuthorizationCheckCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::grpc::CompletionQueue* cq) {
  return ::grpc::internal::ClientAsyncResponseReaderHelper::Create< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), cq, rpcmethod_PostAuthorizationCheckCode_, context, request);
}

::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>* AuthorizationB2bService::Stub::AsyncPostAuthorizationCheckCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::grpc::CompletionQueue* cq) {
  auto* result =
    this->PrepareAsyncPostAuthorizationCheckCodeRaw(context, request, cq);
  result->StartCall();
  return result;
}

AuthorizationB2bService::Service::Service() {
  AddMethod(new ::grpc::internal::RpcServiceMethod(
      AuthorizationB2bService_method_names[0],
      ::grpc::internal::RpcMethod::NORMAL_RPC,
      new ::grpc::internal::RpcMethodHandler< AuthorizationB2bService::Service, ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(
          [](AuthorizationB2bService::Service* service,
             ::grpc::ServerContext* ctx,
             const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* req,
             ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* resp) {
               return service->PostAuthorizationLogin(ctx, req, resp);
             }, this)));
  AddMethod(new ::grpc::internal::RpcServiceMethod(
      AuthorizationB2bService_method_names[1],
      ::grpc::internal::RpcMethod::NORMAL_RPC,
      new ::grpc::internal::RpcMethodHandler< AuthorizationB2bService::Service, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(
          [](AuthorizationB2bService::Service* service,
             ::grpc::ServerContext* ctx,
             const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* req,
             ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* resp) {
               return service->PostAuthorizationSendCode(ctx, req, resp);
             }, this)));
  AddMethod(new ::grpc::internal::RpcServiceMethod(
      AuthorizationB2bService_method_names[2],
      ::grpc::internal::RpcMethod::NORMAL_RPC,
      new ::grpc::internal::RpcMethodHandler< AuthorizationB2bService::Service, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(
          [](AuthorizationB2bService::Service* service,
             ::grpc::ServerContext* ctx,
             const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* req,
             ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* resp) {
               return service->PostAuthorizationLoginByPassword(ctx, req, resp);
             }, this)));
  AddMethod(new ::grpc::internal::RpcServiceMethod(
      AuthorizationB2bService_method_names[3],
      ::grpc::internal::RpcMethod::NORMAL_RPC,
      new ::grpc::internal::RpcMethodHandler< AuthorizationB2bService::Service, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(
          [](AuthorizationB2bService::Service* service,
             ::grpc::ServerContext* ctx,
             const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* req,
             ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* resp) {
               return service->PostAuthorizationCheckCode(ctx, req, resp);
             }, this)));
}

AuthorizationB2bService::Service::~Service() {
}

::grpc::Status AuthorizationB2bService::Service::PostAuthorizationLogin(::grpc::ServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response) {
  (void) context;
  (void) request;
  (void) response;
  return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
}

::grpc::Status AuthorizationB2bService::Service::PostAuthorizationSendCode(::grpc::ServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response) {
  (void) context;
  (void) request;
  (void) response;
  return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
}

::grpc::Status AuthorizationB2bService::Service::PostAuthorizationLoginByPassword(::grpc::ServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response) {
  (void) context;
  (void) request;
  (void) response;
  return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
}

::grpc::Status AuthorizationB2bService::Service::PostAuthorizationCheckCode(::grpc::ServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response) {
  (void) context;
  (void) request;
  (void) response;
  return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
}


}  // namespace keyapis
}  // namespace identity_b2b
}  // namespace v1

