0
0
mirror of https://github.com/zeromq/libzmq.git synced 2025-01-22 07:29:31 +08:00
libzmq/src/gssapi_client.hpp

84 lines
2.2 KiB
C++
Raw Normal View History

2013-09-24 22:20:01 -05:00
/*
2014-04-24 14:39:29 -07:00
Copyright (c) 2007-2014 Contributors as noted in the AUTHORS file
2013-09-24 22:20:01 -05:00
This file is part of 0MQ.
0MQ is free software; you can redistribute it and/or modify it under
the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
0MQ is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef __ZMQ_GSSAPI_CLIENT_HPP_INCLUDED__
#define __ZMQ_GSSAPI_CLIENT_HPP_INCLUDED__
2013-09-24 22:20:01 -05:00
2014-04-25 13:47:07 +09:30
#ifdef HAVE_LIBGSSAPI_KRB5
#include "gssapi_mechanism_base.hpp"
2013-09-24 22:20:01 -05:00
namespace zmq
{
class msg_t;
class gssapi_client_t :
public gssapi_mechanism_base_t
2013-09-24 22:20:01 -05:00
{
public:
gssapi_client_t (const options_t &options_);
virtual ~gssapi_client_t ();
2013-09-24 22:20:01 -05:00
// mechanism implementation
virtual int next_handshake_command (msg_t *msg_);
virtual int process_handshake_command (msg_t *msg_);
virtual int encode (msg_t *msg_);
virtual int decode (msg_t *msg_);
2014-05-06 17:49:26 +02:00
virtual status_t status () const;
2013-09-24 22:20:01 -05:00
private:
2014-04-25 13:47:07 +09:30
2013-09-24 22:20:01 -05:00
enum state_t {
call_next_init,
send_next_token,
recv_next_token,
send_ready,
recv_ready,
connected
2013-09-24 22:20:01 -05:00
};
2014-04-23 10:20:22 -07:00
// Human-readable principal name of the service we are connecting to
char * service_name;
// Current FSM state
2013-09-24 22:20:01 -05:00
state_t state;
// Points to either send_tok or recv_tok
// during context initialization
gss_buffer_desc *token_ptr;
// The desired underlying mechanism
gss_OID_set_desc mechs;
// True iff client considers the server authenticated
bool security_context_established;
2013-09-24 22:20:01 -05:00
int initialize_context ();
int produce_next_token (msg_t *msg_);
int process_next_token (msg_t *msg_);
2013-09-24 22:20:01 -05:00
};
}
#endif
2014-04-25 13:47:07 +09:30
#endif