1
0
mirror of https://github.com/codership/wsrep-lib.git synced 2025-04-19 21:02:17 +03:00
wsrep-lib/dbsim/db_client_service.hpp
Teemu Ollakka a7ce22ac91 Fix crash close_orphaned_sr_transactions() BF abort
Some implementations of provider `bf_abort()` require `victim_ctx`
to point to application side victim context. However, when
total order BF abort was done from `close_orphaned_sr_transactions()`,
the application side context was not available.

To fix this, added an interface method `call_in_operation_context()`
which allows invoking a function object with a reference to
application side operation context passed in as a parameter.
This method is used in `close_orphaned_sr_transactions()`
to call `client_state::total_order_bf_abort()` with appropriate
victim operation context.
2024-03-09 12:16:42 +02:00

112 lines
3.1 KiB
C++

/*
* Copyright (C) 2018 Codership Oy <info@codership.com>
*
* This file is part of wsrep-lib.
*
* Wsrep-lib 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, either version 2 of the License, or
* (at your option) any later version.
*
* Wsrep-lib 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 wsrep-lib. If not, see <https://www.gnu.org/licenses/>.
*/
#ifndef WSREP_DB_CLIENT_SERVICE_HPP
#define WSREP_DB_CLIENT_SERVICE_HPP
#include "wsrep/client_service.hpp"
#include "wsrep/transaction.hpp"
namespace db
{
class client;
class client_state;
class client_service : public wsrep::client_service
{
public:
client_service(db::client& client);
bool interrupted(wsrep::unique_lock<wsrep::mutex>&)
const override
{ return false; }
void reset_globals() override { }
void store_globals() override { }
int prepare_data_for_replication() override
{
return 0;
}
void cleanup_transaction() override { }
size_t bytes_generated() const override
{
return 0;
}
bool statement_allowed_for_streaming() const override
{
return true;
}
int prepare_fragment_for_replication(wsrep::mutable_buffer&,
size_t& position) override
{
position = 0;
return 0;
}
int remove_fragments() override { return 0; }
int bf_rollback() override;
void will_replay() override { }
void signal_replayed() override { }
void wait_for_replayers(wsrep::unique_lock<wsrep::mutex>&) override { }
enum wsrep::provider::status replay()
override;
enum wsrep::provider::status replay_unordered() override
{
return wsrep::provider::success;
}
void emergency_shutdown() override { ::abort(); }
enum wsrep::provider::status commit_by_xid() override
{
return wsrep::provider::success;
}
bool is_explicit_xa() override
{
return false;
}
bool is_prepared_xa() override
{
return false;
}
bool is_xa_rollback() override
{
return false;
}
void call_in_operation_context(
const std::function<void(wsrep::operation_context&)>& fn)
const override
{
wsrep::null_operation_context op;
fn(op);
}
void debug_sync(const char*) override { }
void debug_crash(const char*) override { }
private:
db::client& client_;
wsrep::client_state& client_state_;
};
}
#endif // WSREP_DB_CLIENT_SERVICE_HPP