libzmq/src/gssapi_client.hpp

84 lines
2.2 KiB
C++
Raw Normal View History

2013-09-25 05:20:01 +02:00
/*
Copyright (c) 2007-2015 Contributors as noted in the AUTHORS file
2013-09-25 05:20:01 +02: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-25 05:20:01 +02:00
2014-04-25 06:17:07 +02:00
#ifdef HAVE_LIBGSSAPI_KRB5
#include "gssapi_mechanism_base.hpp"
2013-09-25 05:20:01 +02:00
namespace zmq
{
class msg_t;
class gssapi_client_t :
public gssapi_mechanism_base_t
2013-09-25 05:20:01 +02:00
{
public:
gssapi_client_t (const options_t &options_);
virtual ~gssapi_client_t ();
2013-09-25 05:20:01 +02: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-25 05:20:01 +02:00
private:
2014-04-25 06:17:07 +02:00
2013-09-25 05:20:01 +02:00
enum state_t {
call_next_init,
send_next_token,
recv_next_token,
send_ready,
recv_ready,
connected
2013-09-25 05:20:01 +02:00
};
2014-04-23 19:20:22 +02:00
// Human-readable principal name of the service we are connecting to
char * service_name;
// Current FSM state
2013-09-25 05:20:01 +02: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-25 05:20:01 +02:00
int initialize_context ();
int produce_next_token (msg_t *msg_);
int process_next_token (msg_t *msg_);
2013-09-25 05:20:01 +02:00
};
}
#endif
2014-04-25 06:17:07 +02:00
#endif