1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
/*
* Copyright (c) 2008, 2014, Oracle and/or its affiliates. All rights reserved.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; version 2 of the
* License.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA
*/
#ifndef _WB_TUNNEL_H_
#define _WB_TUNNEL_H_
#include "python_context.h"
#include "cppdbc.h"
#include "wb_backend_public_interface.h"
class SSHTunnel;
namespace wb
{
class WBContext;
class TunnelManager
{
wb::WBContext *_wb;
grt::AutoPyObject _tunnel;
friend class ::SSHTunnel;
int lookup_tunnel(const char *server, const char *username, const char *target);
int open_tunnel(const char *server, const char *username, const char *password,
const char *keyfile, const char *target);
void wait_tunnel(int port);
void set_keepalive(int port, int keepalive);
public:
TunnelManager(wb::WBContext *wb);
~TunnelManager();
wb::WBContext *wb() { return _wb; }
void start();
void shutdown();
boost::shared_ptr<sql::TunnelConnection> create_tunnel(db_mgmt_ConnectionRef connectionProperties);
bool get_message_for(int port, std::string &type, std::string &message);
};
};
#endif
|