101 lines
3.3 KiB
C

/* Copyright (c) 2015, 2017, 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,
51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA */
#ifndef READ_MODE_HANDLER_INCLUDE
#define READ_MODE_HANDLER_INCLUDE
#include "sql_service_command.h"
/**
This method creates a server session and connects to the server
to enable the read mode
@param session_isolation session creation requirements: use current thread,
use thread but initialize it or create it in a
dedicated thread
@return the operation status
@retval 0 OK
@retval !=0 Error
*/
int enable_server_read_mode(enum_plugin_con_isolation session_isolation);
/**
This method creates a server session and connects to the server
to disable the read mode
@param session_isolation session creation requirements: use current thread,
use thread but initialize it or create it in a
dedicated thread
@return the operation status
@retval 0 OK
@retval !=0 Error
*/
int disable_server_read_mode(enum_plugin_con_isolation session_isolation);
/**
Enable the super read only mode in the server.
@param sql_service_command Command interface given to execute the command
@return the operation status
@retval 0 OK
@retval !=0 Error
*/
long enable_super_read_only_mode(Sql_service_command_interface *sql_service_command);
/**
Disable the read only mode in the server.
@param sql_service_command Command interface given to execute the command
@return the operation status
@retval 0 OK
@retval !=0 Error
*/
long disable_super_read_only_mode(Sql_service_command_interface *sql_service_command);
/**
Get read mode status from server.
@param sql_service_command Command interface given to execute the command
@param read_only_enabled Update with value of read only mode
@param super_read_only_enabled Update with value of super read only mode
@return the operation status
@retval 0 OK
@retval !=0 Error
*/
long get_read_mode_state(Sql_service_command_interface *sql_service_command,
bool *read_only_enabled, bool *super_read_only_enabled);
/**
Set read mode status from server.
@param sql_service_command Command interface given to execute the command
@param read_only_enabled Value to set on read only mode
@param super_read_only_enabled Value to set on super read only mode
@return the operation status
@retval 0 OK
@retval !=0 Error
*/
long set_read_mode_state(Sql_service_command_interface *sql_service_command,
bool read_only_enabled, bool super_read_only_enabled);
#endif /* READ_MODE_HANDLER_INCLUDE */