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 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167
|
/*
* Copyright (c) 2009, 2018, 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, version 2.0, as
* published by the Free Software Foundation.
*
* This program is also distributed with certain software (including
* but not limited to OpenSSL) that is licensed under separate terms,
* as designated in a particular file or component or in included license
* documentation. The authors of MySQL hereby grant you an
* additional permission to link the program and your derivative works
* with the separately licensed software that they have included with
* MySQL.
*
* Without limiting anything contained in the foregoing, this file,
* which is part of MySQL Connector/C++, is also subject to the
* Universal FOSS Exception, version 1.0, a copy of which can be found at
* http://oss.oracle.com/licenses/universal-foss-exception.
*
* 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, version 2.0, 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 _NATIVE_CONNECTION_WRAPPER_H_
#define _NATIVE_CONNECTION_WRAPPER_H_
#include <boost/noncopyable.hpp>
#include <config.h>
#ifdef HAVE_STDINT_H
#include <stdint.h>
#endif
#include "../mysql_connection_options.h"
namespace sql
{
class SQLString;
namespace mysql
{
namespace NativeAPI
{
class NativeResultsetWrapper;
class NativeStatementWrapper;
enum Protocol_Type
{
PROTOCOL_TCP,
PROTOCOL_SOCKET,
PROTOCOL_PIPE,
/* Total number of supported protocol types */
PROTOCOL_COUNT
};
class NativeConnectionWrapper : public boost::noncopyable
{
public:
virtual ~NativeConnectionWrapper() {}
virtual uint64_t affected_rows() = 0;
virtual bool autocommit(bool) = 0;
virtual bool connect(const ::sql::SQLString & host,
const ::sql::SQLString & user,
const ::sql::SQLString & passwd,
const ::sql::SQLString & db,
unsigned int port,
const ::sql::SQLString & socket_or_pipe,
unsigned long client_flag) = 0;
virtual bool commit() = 0;
virtual void debug(const ::sql::SQLString &) = 0;
virtual unsigned int errNo() = 0;
virtual ::sql::SQLString error() = 0;
virtual ::sql::SQLString escapeString(const ::sql::SQLString &) = 0;
virtual unsigned int field_count() = 0;
virtual unsigned long get_client_version() = 0;
virtual const ::sql::SQLString & get_server_info() = 0;
virtual unsigned long get_server_version() = 0;
virtual void get_character_set_info(void *cs) = 0;
virtual bool more_results() = 0;
virtual int next_result() = 0;
virtual int options(::sql::mysql::MySQL_Connection_Options, const void *) = 0;
virtual int options(::sql::mysql::MySQL_Connection_Options,
const ::sql::SQLString &) = 0;
virtual int options(::sql::mysql::MySQL_Connection_Options,
const bool &) = 0;
virtual int options(::sql::mysql::MySQL_Connection_Options,
const int &) = 0;
virtual int options(::sql::mysql::MySQL_Connection_Options,
const ::sql::SQLString &,
const ::sql::SQLString &) = 0;
virtual int get_option(::sql::mysql::MySQL_Connection_Options, const void *) = 0;
virtual int get_option(::sql::mysql::MySQL_Connection_Options,
const ::sql::SQLString &) = 0;
virtual int get_option(::sql::mysql::MySQL_Connection_Options,
const bool &) = 0;
virtual int get_option(::sql::mysql::MySQL_Connection_Options,
const int &) = 0;
virtual int query(const SQLString &) = 0;
virtual int ping() = 0;
/* virtual int real_query(const SQLString &, uint64_t) = 0;*/
virtual bool rollback() = 0;
virtual ::sql::SQLString sqlstate() = 0;
virtual ::sql::SQLString info() = 0;
virtual bool ssl_set(const ::sql::SQLString & key,
const ::sql::SQLString & cert,
const ::sql::SQLString & ca,
const ::sql::SQLString & capath,
const ::sql::SQLString & cipher) = 0;
virtual NativeResultsetWrapper * store_result() = 0;
virtual int use_protocol(Protocol_Type) = 0;
virtual NativeResultsetWrapper * use_result() = 0;
virtual NativeStatementWrapper & stmt_init() = 0;
virtual unsigned int warning_count() = 0;
};
} /* namespace NativeAPI */
} /* namespace mysql */
} /* namespace sql */
#endif /* _NATIVE_CONNECTION_WRAPPER_H_ */
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* End:
* vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4
*/
|