// 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
// Original file comments:
//
// Сервис предоставляет возможность авторизации для пользователей B2B
#ifndef GRPC_keyapis_2fidentity_5fb2b_2fv1_2fkeyapis_5fidentity_5fb2b_5fauthorization_5fv1_2eproto__INCLUDED
#define GRPC_keyapis_2fidentity_5fb2b_2fv1_2fkeyapis_5fidentity_5fb2b_5fauthorization_5fv1_2eproto__INCLUDED

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

#include <functional>
#include <grpcpp/impl/codegen/async_generic_service.h>
#include <grpcpp/impl/codegen/async_stream.h>
#include <grpcpp/impl/codegen/async_unary_call.h>
#include <grpcpp/impl/codegen/client_callback.h>
#include <grpcpp/impl/codegen/client_context.h>
#include <grpcpp/impl/codegen/completion_queue.h>
#include <grpcpp/impl/codegen/message_allocator.h>
#include <grpcpp/impl/codegen/method_handler.h>
#include <grpcpp/impl/codegen/proto_utils.h>
#include <grpcpp/impl/codegen/rpc_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/status.h>
#include <grpcpp/impl/codegen/stub_options.h>
#include <grpcpp/impl/codegen/sync_stream.h>

namespace keyapis {
namespace identity_b2b {
namespace v1 {

// Сервис авторизации пользователей B2B
class AuthorizationB2bService final {
 public:
  static constexpr char const* service_full_name() {
    return "keyapis.identity_b2b.v1.AuthorizationB2bService";
  }
  class StubInterface {
   public:
    virtual ~StubInterface() {}
    // Метод авторизации по ОТП-коду для B2B.
    // Не требует авторизации
    virtual ::grpc::Status PostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response) = 0;
    std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>> AsyncPostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>>(AsyncPostAuthorizationLoginRaw(context, request, cq));
    }
    std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>> PrepareAsyncPostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>>(PrepareAsyncPostAuthorizationLoginRaw(context, request, cq));
    }
    // Метод запроса ОТП-кода для B2B.
    // Не требует авторизации
    virtual ::grpc::Status PostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response) = 0;
    std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>> AsyncPostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>>(AsyncPostAuthorizationSendCodeRaw(context, request, cq));
    }
    std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>> PrepareAsyncPostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>>(PrepareAsyncPostAuthorizationSendCodeRaw(context, request, cq));
    }
    // Метод авторизации для B2B по паролю.
    // Не требует авторизации
    virtual ::grpc::Status PostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response) = 0;
    std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>> AsyncPostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>>(AsyncPostAuthorizationLoginByPasswordRaw(context, request, cq));
    }
    std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>> PrepareAsyncPostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>>(PrepareAsyncPostAuthorizationLoginByPasswordRaw(context, request, cq));
    }
    // Метод проверки кода двухфакторной авторизации и активация сессии.
    // Не требует авторизации
    virtual ::grpc::Status PostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response) = 0;
    std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>> AsyncPostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>>(AsyncPostAuthorizationCheckCodeRaw(context, request, cq));
    }
    std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>> PrepareAsyncPostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>>(PrepareAsyncPostAuthorizationCheckCodeRaw(context, request, cq));
    }
    class async_interface {
     public:
      virtual ~async_interface() {}
      // Метод авторизации по ОТП-коду для B2B.
      // Не требует авторизации
      virtual void PostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response, std::function<void(::grpc::Status)>) = 0;
      virtual void PostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response, ::grpc::ClientUnaryReactor* reactor) = 0;
      // Метод запроса ОТП-кода для B2B.
      // Не требует авторизации
      virtual void PostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response, std::function<void(::grpc::Status)>) = 0;
      virtual void PostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response, ::grpc::ClientUnaryReactor* reactor) = 0;
      // Метод авторизации для B2B по паролю.
      // Не требует авторизации
      virtual void PostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response, std::function<void(::grpc::Status)>) = 0;
      virtual void PostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response, ::grpc::ClientUnaryReactor* reactor) = 0;
      // Метод проверки кода двухфакторной авторизации и активация сессии.
      // Не требует авторизации
      virtual void PostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response, std::function<void(::grpc::Status)>) = 0;
      virtual void PostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response, ::grpc::ClientUnaryReactor* reactor) = 0;
    };
    typedef class async_interface experimental_async_interface;
    virtual class async_interface* async() { return nullptr; }
    class async_interface* experimental_async() { return async(); }
   private:
    virtual ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>* AsyncPostAuthorizationLoginRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::grpc::CompletionQueue* cq) = 0;
    virtual ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>* PrepareAsyncPostAuthorizationLoginRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::grpc::CompletionQueue* cq) = 0;
    virtual ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>* AsyncPostAuthorizationSendCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::grpc::CompletionQueue* cq) = 0;
    virtual ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>* PrepareAsyncPostAuthorizationSendCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::grpc::CompletionQueue* cq) = 0;
    virtual ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>* AsyncPostAuthorizationLoginByPasswordRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::grpc::CompletionQueue* cq) = 0;
    virtual ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>* PrepareAsyncPostAuthorizationLoginByPasswordRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::grpc::CompletionQueue* cq) = 0;
    virtual ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>* AsyncPostAuthorizationCheckCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::grpc::CompletionQueue* cq) = 0;
    virtual ::grpc::ClientAsyncResponseReaderInterface< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>* PrepareAsyncPostAuthorizationCheckCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::grpc::CompletionQueue* cq) = 0;
  };
  class Stub final : public StubInterface {
   public:
    Stub(const std::shared_ptr< ::grpc::ChannelInterface>& channel, const ::grpc::StubOptions& options = ::grpc::StubOptions());
    ::grpc::Status PostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response) override;
    std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>> AsyncPostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>>(AsyncPostAuthorizationLoginRaw(context, request, cq));
    }
    std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>> PrepareAsyncPostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>>(PrepareAsyncPostAuthorizationLoginRaw(context, request, cq));
    }
    ::grpc::Status PostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response) override;
    std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>> AsyncPostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>>(AsyncPostAuthorizationSendCodeRaw(context, request, cq));
    }
    std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>> PrepareAsyncPostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>>(PrepareAsyncPostAuthorizationSendCodeRaw(context, request, cq));
    }
    ::grpc::Status PostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response) override;
    std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>> AsyncPostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>>(AsyncPostAuthorizationLoginByPasswordRaw(context, request, cq));
    }
    std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>> PrepareAsyncPostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>>(PrepareAsyncPostAuthorizationLoginByPasswordRaw(context, request, cq));
    }
    ::grpc::Status PostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response) override;
    std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>> AsyncPostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>>(AsyncPostAuthorizationCheckCodeRaw(context, request, cq));
    }
    std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>> PrepareAsyncPostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::grpc::CompletionQueue* cq) {
      return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>>(PrepareAsyncPostAuthorizationCheckCodeRaw(context, request, cq));
    }
    class async final :
      public StubInterface::async_interface {
     public:
      void PostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response, std::function<void(::grpc::Status)>) override;
      void PostAuthorizationLogin(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response, ::grpc::ClientUnaryReactor* reactor) override;
      void PostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response, std::function<void(::grpc::Status)>) override;
      void PostAuthorizationSendCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response, ::grpc::ClientUnaryReactor* reactor) override;
      void PostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response, std::function<void(::grpc::Status)>) override;
      void PostAuthorizationLoginByPassword(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response, ::grpc::ClientUnaryReactor* reactor) override;
      void PostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response, std::function<void(::grpc::Status)>) override;
      void PostAuthorizationCheckCode(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response, ::grpc::ClientUnaryReactor* reactor) override;
     private:
      friend class Stub;
      explicit async(Stub* stub): stub_(stub) { }
      Stub* stub() { return stub_; }
      Stub* stub_;
    };
    class async* async() override { return &async_stub_; }

   private:
    std::shared_ptr< ::grpc::ChannelInterface> channel_;
    class async async_stub_{this};
    ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>* AsyncPostAuthorizationLoginRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::grpc::CompletionQueue* cq) override;
    ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>* PrepareAsyncPostAuthorizationLoginRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest& request, ::grpc::CompletionQueue* cq) override;
    ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>* AsyncPostAuthorizationSendCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::grpc::CompletionQueue* cq) override;
    ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>* PrepareAsyncPostAuthorizationSendCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest& request, ::grpc::CompletionQueue* cq) override;
    ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>* AsyncPostAuthorizationLoginByPasswordRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::grpc::CompletionQueue* cq) override;
    ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>* PrepareAsyncPostAuthorizationLoginByPasswordRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest& request, ::grpc::CompletionQueue* cq) override;
    ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>* AsyncPostAuthorizationCheckCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::grpc::CompletionQueue* cq) override;
    ::grpc::ClientAsyncResponseReader< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>* PrepareAsyncPostAuthorizationCheckCodeRaw(::grpc::ClientContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest& request, ::grpc::CompletionQueue* cq) override;
    const ::grpc::internal::RpcMethod rpcmethod_PostAuthorizationLogin_;
    const ::grpc::internal::RpcMethod rpcmethod_PostAuthorizationSendCode_;
    const ::grpc::internal::RpcMethod rpcmethod_PostAuthorizationLoginByPassword_;
    const ::grpc::internal::RpcMethod rpcmethod_PostAuthorizationCheckCode_;
  };
  static std::unique_ptr<Stub> NewStub(const std::shared_ptr< ::grpc::ChannelInterface>& channel, const ::grpc::StubOptions& options = ::grpc::StubOptions());

  class Service : public ::grpc::Service {
   public:
    Service();
    virtual ~Service();
    // Метод авторизации по ОТП-коду для B2B.
    // Не требует авторизации
    virtual ::grpc::Status PostAuthorizationLogin(::grpc::ServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response);
    // Метод запроса ОТП-кода для B2B.
    // Не требует авторизации
    virtual ::grpc::Status PostAuthorizationSendCode(::grpc::ServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response);
    // Метод авторизации для B2B по паролю.
    // Не требует авторизации
    virtual ::grpc::Status PostAuthorizationLoginByPassword(::grpc::ServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response);
    // Метод проверки кода двухфакторной авторизации и активация сессии.
    // Не требует авторизации
    virtual ::grpc::Status PostAuthorizationCheckCode(::grpc::ServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response);
  };
  template <class BaseClass>
  class WithAsyncMethod_PostAuthorizationLogin : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithAsyncMethod_PostAuthorizationLogin() {
      ::grpc::Service::MarkMethodAsync(0);
    }
    ~WithAsyncMethod_PostAuthorizationLogin() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationLogin(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    void RequestPostAuthorizationLogin(::grpc::ServerContext* context, ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* request, ::grpc::ServerAsyncResponseWriter< ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) {
      ::grpc::Service::RequestAsyncUnary(0, context, request, response, new_call_cq, notification_cq, tag);
    }
  };
  template <class BaseClass>
  class WithAsyncMethod_PostAuthorizationSendCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithAsyncMethod_PostAuthorizationSendCode() {
      ::grpc::Service::MarkMethodAsync(1);
    }
    ~WithAsyncMethod_PostAuthorizationSendCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationSendCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    void RequestPostAuthorizationSendCode(::grpc::ServerContext* context, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* request, ::grpc::ServerAsyncResponseWriter< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) {
      ::grpc::Service::RequestAsyncUnary(1, context, request, response, new_call_cq, notification_cq, tag);
    }
  };
  template <class BaseClass>
  class WithAsyncMethod_PostAuthorizationLoginByPassword : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithAsyncMethod_PostAuthorizationLoginByPassword() {
      ::grpc::Service::MarkMethodAsync(2);
    }
    ~WithAsyncMethod_PostAuthorizationLoginByPassword() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationLoginByPassword(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    void RequestPostAuthorizationLoginByPassword(::grpc::ServerContext* context, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* request, ::grpc::ServerAsyncResponseWriter< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) {
      ::grpc::Service::RequestAsyncUnary(2, context, request, response, new_call_cq, notification_cq, tag);
    }
  };
  template <class BaseClass>
  class WithAsyncMethod_PostAuthorizationCheckCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithAsyncMethod_PostAuthorizationCheckCode() {
      ::grpc::Service::MarkMethodAsync(3);
    }
    ~WithAsyncMethod_PostAuthorizationCheckCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationCheckCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    void RequestPostAuthorizationCheckCode(::grpc::ServerContext* context, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* request, ::grpc::ServerAsyncResponseWriter< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) {
      ::grpc::Service::RequestAsyncUnary(3, context, request, response, new_call_cq, notification_cq, tag);
    }
  };
  typedef WithAsyncMethod_PostAuthorizationLogin<WithAsyncMethod_PostAuthorizationSendCode<WithAsyncMethod_PostAuthorizationLoginByPassword<WithAsyncMethod_PostAuthorizationCheckCode<Service > > > > AsyncService;
  template <class BaseClass>
  class WithCallbackMethod_PostAuthorizationLogin : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithCallbackMethod_PostAuthorizationLogin() {
      ::grpc::Service::MarkMethodCallback(0,
          new ::grpc::internal::CallbackUnaryHandler< ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>(
            [this](
                   ::grpc::CallbackServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* response) { return this->PostAuthorizationLogin(context, request, response); }));}
    void SetMessageAllocatorFor_PostAuthorizationLogin(
        ::grpc::MessageAllocator< ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>* allocator) {
      ::grpc::internal::MethodHandler* const handler = ::grpc::Service::GetHandler(0);
      static_cast<::grpc::internal::CallbackUnaryHandler< ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>*>(handler)
              ->SetMessageAllocator(allocator);
    }
    ~WithCallbackMethod_PostAuthorizationLogin() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationLogin(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    virtual ::grpc::ServerUnaryReactor* PostAuthorizationLogin(
      ::grpc::CallbackServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* /*response*/)  { return nullptr; }
  };
  template <class BaseClass>
  class WithCallbackMethod_PostAuthorizationSendCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithCallbackMethod_PostAuthorizationSendCode() {
      ::grpc::Service::MarkMethodCallback(1,
          new ::grpc::internal::CallbackUnaryHandler< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>(
            [this](
                   ::grpc::CallbackServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* response) { return this->PostAuthorizationSendCode(context, request, response); }));}
    void SetMessageAllocatorFor_PostAuthorizationSendCode(
        ::grpc::MessageAllocator< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>* allocator) {
      ::grpc::internal::MethodHandler* const handler = ::grpc::Service::GetHandler(1);
      static_cast<::grpc::internal::CallbackUnaryHandler< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>*>(handler)
              ->SetMessageAllocator(allocator);
    }
    ~WithCallbackMethod_PostAuthorizationSendCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationSendCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    virtual ::grpc::ServerUnaryReactor* PostAuthorizationSendCode(
      ::grpc::CallbackServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* /*response*/)  { return nullptr; }
  };
  template <class BaseClass>
  class WithCallbackMethod_PostAuthorizationLoginByPassword : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithCallbackMethod_PostAuthorizationLoginByPassword() {
      ::grpc::Service::MarkMethodCallback(2,
          new ::grpc::internal::CallbackUnaryHandler< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>(
            [this](
                   ::grpc::CallbackServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* response) { return this->PostAuthorizationLoginByPassword(context, request, response); }));}
    void SetMessageAllocatorFor_PostAuthorizationLoginByPassword(
        ::grpc::MessageAllocator< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>* allocator) {
      ::grpc::internal::MethodHandler* const handler = ::grpc::Service::GetHandler(2);
      static_cast<::grpc::internal::CallbackUnaryHandler< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>*>(handler)
              ->SetMessageAllocator(allocator);
    }
    ~WithCallbackMethod_PostAuthorizationLoginByPassword() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationLoginByPassword(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    virtual ::grpc::ServerUnaryReactor* PostAuthorizationLoginByPassword(
      ::grpc::CallbackServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* /*response*/)  { return nullptr; }
  };
  template <class BaseClass>
  class WithCallbackMethod_PostAuthorizationCheckCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithCallbackMethod_PostAuthorizationCheckCode() {
      ::grpc::Service::MarkMethodCallback(3,
          new ::grpc::internal::CallbackUnaryHandler< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>(
            [this](
                   ::grpc::CallbackServerContext* context, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* request, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* response) { return this->PostAuthorizationCheckCode(context, request, response); }));}
    void SetMessageAllocatorFor_PostAuthorizationCheckCode(
        ::grpc::MessageAllocator< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>* allocator) {
      ::grpc::internal::MethodHandler* const handler = ::grpc::Service::GetHandler(3);
      static_cast<::grpc::internal::CallbackUnaryHandler< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>*>(handler)
              ->SetMessageAllocator(allocator);
    }
    ~WithCallbackMethod_PostAuthorizationCheckCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationCheckCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    virtual ::grpc::ServerUnaryReactor* PostAuthorizationCheckCode(
      ::grpc::CallbackServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* /*response*/)  { return nullptr; }
  };
  typedef WithCallbackMethod_PostAuthorizationLogin<WithCallbackMethod_PostAuthorizationSendCode<WithCallbackMethod_PostAuthorizationLoginByPassword<WithCallbackMethod_PostAuthorizationCheckCode<Service > > > > CallbackService;
  typedef CallbackService ExperimentalCallbackService;
  template <class BaseClass>
  class WithGenericMethod_PostAuthorizationLogin : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithGenericMethod_PostAuthorizationLogin() {
      ::grpc::Service::MarkMethodGeneric(0);
    }
    ~WithGenericMethod_PostAuthorizationLogin() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationLogin(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
  };
  template <class BaseClass>
  class WithGenericMethod_PostAuthorizationSendCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithGenericMethod_PostAuthorizationSendCode() {
      ::grpc::Service::MarkMethodGeneric(1);
    }
    ~WithGenericMethod_PostAuthorizationSendCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationSendCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
  };
  template <class BaseClass>
  class WithGenericMethod_PostAuthorizationLoginByPassword : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithGenericMethod_PostAuthorizationLoginByPassword() {
      ::grpc::Service::MarkMethodGeneric(2);
    }
    ~WithGenericMethod_PostAuthorizationLoginByPassword() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationLoginByPassword(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
  };
  template <class BaseClass>
  class WithGenericMethod_PostAuthorizationCheckCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithGenericMethod_PostAuthorizationCheckCode() {
      ::grpc::Service::MarkMethodGeneric(3);
    }
    ~WithGenericMethod_PostAuthorizationCheckCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationCheckCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
  };
  template <class BaseClass>
  class WithRawMethod_PostAuthorizationLogin : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithRawMethod_PostAuthorizationLogin() {
      ::grpc::Service::MarkMethodRaw(0);
    }
    ~WithRawMethod_PostAuthorizationLogin() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationLogin(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    void RequestPostAuthorizationLogin(::grpc::ServerContext* context, ::grpc::ByteBuffer* request, ::grpc::ServerAsyncResponseWriter< ::grpc::ByteBuffer>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) {
      ::grpc::Service::RequestAsyncUnary(0, context, request, response, new_call_cq, notification_cq, tag);
    }
  };
  template <class BaseClass>
  class WithRawMethod_PostAuthorizationSendCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithRawMethod_PostAuthorizationSendCode() {
      ::grpc::Service::MarkMethodRaw(1);
    }
    ~WithRawMethod_PostAuthorizationSendCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationSendCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    void RequestPostAuthorizationSendCode(::grpc::ServerContext* context, ::grpc::ByteBuffer* request, ::grpc::ServerAsyncResponseWriter< ::grpc::ByteBuffer>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) {
      ::grpc::Service::RequestAsyncUnary(1, context, request, response, new_call_cq, notification_cq, tag);
    }
  };
  template <class BaseClass>
  class WithRawMethod_PostAuthorizationLoginByPassword : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithRawMethod_PostAuthorizationLoginByPassword() {
      ::grpc::Service::MarkMethodRaw(2);
    }
    ~WithRawMethod_PostAuthorizationLoginByPassword() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationLoginByPassword(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    void RequestPostAuthorizationLoginByPassword(::grpc::ServerContext* context, ::grpc::ByteBuffer* request, ::grpc::ServerAsyncResponseWriter< ::grpc::ByteBuffer>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) {
      ::grpc::Service::RequestAsyncUnary(2, context, request, response, new_call_cq, notification_cq, tag);
    }
  };
  template <class BaseClass>
  class WithRawMethod_PostAuthorizationCheckCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithRawMethod_PostAuthorizationCheckCode() {
      ::grpc::Service::MarkMethodRaw(3);
    }
    ~WithRawMethod_PostAuthorizationCheckCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationCheckCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    void RequestPostAuthorizationCheckCode(::grpc::ServerContext* context, ::grpc::ByteBuffer* request, ::grpc::ServerAsyncResponseWriter< ::grpc::ByteBuffer>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) {
      ::grpc::Service::RequestAsyncUnary(3, context, request, response, new_call_cq, notification_cq, tag);
    }
  };
  template <class BaseClass>
  class WithRawCallbackMethod_PostAuthorizationLogin : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithRawCallbackMethod_PostAuthorizationLogin() {
      ::grpc::Service::MarkMethodRawCallback(0,
          new ::grpc::internal::CallbackUnaryHandler< ::grpc::ByteBuffer, ::grpc::ByteBuffer>(
            [this](
                   ::grpc::CallbackServerContext* context, const ::grpc::ByteBuffer* request, ::grpc::ByteBuffer* response) { return this->PostAuthorizationLogin(context, request, response); }));
    }
    ~WithRawCallbackMethod_PostAuthorizationLogin() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationLogin(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    virtual ::grpc::ServerUnaryReactor* PostAuthorizationLogin(
      ::grpc::CallbackServerContext* /*context*/, const ::grpc::ByteBuffer* /*request*/, ::grpc::ByteBuffer* /*response*/)  { return nullptr; }
  };
  template <class BaseClass>
  class WithRawCallbackMethod_PostAuthorizationSendCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithRawCallbackMethod_PostAuthorizationSendCode() {
      ::grpc::Service::MarkMethodRawCallback(1,
          new ::grpc::internal::CallbackUnaryHandler< ::grpc::ByteBuffer, ::grpc::ByteBuffer>(
            [this](
                   ::grpc::CallbackServerContext* context, const ::grpc::ByteBuffer* request, ::grpc::ByteBuffer* response) { return this->PostAuthorizationSendCode(context, request, response); }));
    }
    ~WithRawCallbackMethod_PostAuthorizationSendCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationSendCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    virtual ::grpc::ServerUnaryReactor* PostAuthorizationSendCode(
      ::grpc::CallbackServerContext* /*context*/, const ::grpc::ByteBuffer* /*request*/, ::grpc::ByteBuffer* /*response*/)  { return nullptr; }
  };
  template <class BaseClass>
  class WithRawCallbackMethod_PostAuthorizationLoginByPassword : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithRawCallbackMethod_PostAuthorizationLoginByPassword() {
      ::grpc::Service::MarkMethodRawCallback(2,
          new ::grpc::internal::CallbackUnaryHandler< ::grpc::ByteBuffer, ::grpc::ByteBuffer>(
            [this](
                   ::grpc::CallbackServerContext* context, const ::grpc::ByteBuffer* request, ::grpc::ByteBuffer* response) { return this->PostAuthorizationLoginByPassword(context, request, response); }));
    }
    ~WithRawCallbackMethod_PostAuthorizationLoginByPassword() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationLoginByPassword(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    virtual ::grpc::ServerUnaryReactor* PostAuthorizationLoginByPassword(
      ::grpc::CallbackServerContext* /*context*/, const ::grpc::ByteBuffer* /*request*/, ::grpc::ByteBuffer* /*response*/)  { return nullptr; }
  };
  template <class BaseClass>
  class WithRawCallbackMethod_PostAuthorizationCheckCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithRawCallbackMethod_PostAuthorizationCheckCode() {
      ::grpc::Service::MarkMethodRawCallback(3,
          new ::grpc::internal::CallbackUnaryHandler< ::grpc::ByteBuffer, ::grpc::ByteBuffer>(
            [this](
                   ::grpc::CallbackServerContext* context, const ::grpc::ByteBuffer* request, ::grpc::ByteBuffer* response) { return this->PostAuthorizationCheckCode(context, request, response); }));
    }
    ~WithRawCallbackMethod_PostAuthorizationCheckCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable synchronous version of this method
    ::grpc::Status PostAuthorizationCheckCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    virtual ::grpc::ServerUnaryReactor* PostAuthorizationCheckCode(
      ::grpc::CallbackServerContext* /*context*/, const ::grpc::ByteBuffer* /*request*/, ::grpc::ByteBuffer* /*response*/)  { return nullptr; }
  };
  template <class BaseClass>
  class WithStreamedUnaryMethod_PostAuthorizationLogin : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithStreamedUnaryMethod_PostAuthorizationLogin() {
      ::grpc::Service::MarkMethodStreamed(0,
        new ::grpc::internal::StreamedUnaryHandler<
          ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>(
            [this](::grpc::ServerContext* context,
                   ::grpc::ServerUnaryStreamer<
                     ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>* streamer) {
                       return this->StreamedPostAuthorizationLogin(context,
                         streamer);
                  }));
    }
    ~WithStreamedUnaryMethod_PostAuthorizationLogin() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable regular version of this method
    ::grpc::Status PostAuthorizationLogin(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    // replace default version of method with streamed unary
    virtual ::grpc::Status StreamedPostAuthorizationLogin(::grpc::ServerContext* context, ::grpc::ServerUnaryStreamer< ::keyapis::identity_b2b::v1::PostAuthorizationLoginRequest,::keyapis::identity_b2b::v1::PostAuthorizationLoginResponse>* server_unary_streamer) = 0;
  };
  template <class BaseClass>
  class WithStreamedUnaryMethod_PostAuthorizationSendCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithStreamedUnaryMethod_PostAuthorizationSendCode() {
      ::grpc::Service::MarkMethodStreamed(1,
        new ::grpc::internal::StreamedUnaryHandler<
          ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>(
            [this](::grpc::ServerContext* context,
                   ::grpc::ServerUnaryStreamer<
                     ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>* streamer) {
                       return this->StreamedPostAuthorizationSendCode(context,
                         streamer);
                  }));
    }
    ~WithStreamedUnaryMethod_PostAuthorizationSendCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable regular version of this method
    ::grpc::Status PostAuthorizationSendCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    // replace default version of method with streamed unary
    virtual ::grpc::Status StreamedPostAuthorizationSendCode(::grpc::ServerContext* context, ::grpc::ServerUnaryStreamer< ::keyapis::identity_b2b::v1::PostAuthorizationSendCodeRequest,::keyapis::identity_b2b::v1::PostAuthorizationSendCodeResponse>* server_unary_streamer) = 0;
  };
  template <class BaseClass>
  class WithStreamedUnaryMethod_PostAuthorizationLoginByPassword : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithStreamedUnaryMethod_PostAuthorizationLoginByPassword() {
      ::grpc::Service::MarkMethodStreamed(2,
        new ::grpc::internal::StreamedUnaryHandler<
          ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>(
            [this](::grpc::ServerContext* context,
                   ::grpc::ServerUnaryStreamer<
                     ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>* streamer) {
                       return this->StreamedPostAuthorizationLoginByPassword(context,
                         streamer);
                  }));
    }
    ~WithStreamedUnaryMethod_PostAuthorizationLoginByPassword() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable regular version of this method
    ::grpc::Status PostAuthorizationLoginByPassword(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    // replace default version of method with streamed unary
    virtual ::grpc::Status StreamedPostAuthorizationLoginByPassword(::grpc::ServerContext* context, ::grpc::ServerUnaryStreamer< ::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordRequest,::keyapis::identity_b2b::v1::PostAuthorizationLoginByPasswordResponse>* server_unary_streamer) = 0;
  };
  template <class BaseClass>
  class WithStreamedUnaryMethod_PostAuthorizationCheckCode : public BaseClass {
   private:
    void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
   public:
    WithStreamedUnaryMethod_PostAuthorizationCheckCode() {
      ::grpc::Service::MarkMethodStreamed(3,
        new ::grpc::internal::StreamedUnaryHandler<
          ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>(
            [this](::grpc::ServerContext* context,
                   ::grpc::ServerUnaryStreamer<
                     ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>* streamer) {
                       return this->StreamedPostAuthorizationCheckCode(context,
                         streamer);
                  }));
    }
    ~WithStreamedUnaryMethod_PostAuthorizationCheckCode() override {
      BaseClassMustBeDerivedFromService(this);
    }
    // disable regular version of this method
    ::grpc::Status PostAuthorizationCheckCode(::grpc::ServerContext* /*context*/, const ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest* /*request*/, ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse* /*response*/) override {
      abort();
      return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
    }
    // replace default version of method with streamed unary
    virtual ::grpc::Status StreamedPostAuthorizationCheckCode(::grpc::ServerContext* context, ::grpc::ServerUnaryStreamer< ::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeRequest,::keyapis::identity_b2b::v1::PostAuthorizationCheckCodeResponse>* server_unary_streamer) = 0;
  };
  typedef WithStreamedUnaryMethod_PostAuthorizationLogin<WithStreamedUnaryMethod_PostAuthorizationSendCode<WithStreamedUnaryMethod_PostAuthorizationLoginByPassword<WithStreamedUnaryMethod_PostAuthorizationCheckCode<Service > > > > StreamedUnaryService;
  typedef Service SplitStreamedService;
  typedef WithStreamedUnaryMethod_PostAuthorizationLogin<WithStreamedUnaryMethod_PostAuthorizationSendCode<WithStreamedUnaryMethod_PostAuthorizationLoginByPassword<WithStreamedUnaryMethod_PostAuthorizationCheckCode<Service > > > > StreamedService;
};

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


#endif  // GRPC_keyapis_2fidentity_5fb2b_2fv1_2fkeyapis_5fidentity_5fb2b_5fauthorization_5fv1_2eproto__INCLUDED
