/* * Copyright (C) 2015-present ScyllaDB * * Modified by ScyllaDB */ /* * SPDX-License-Identifier: (LicenseRef-ScyllaDB-Source-Available-1.0 and Apache-2.0) */ #include #include "cql3/statements/drop_table_statement.hh" #include "cql3/statements/prepared_statement.hh" #include "cql3/query_processor.hh" #include "service/migration_manager.hh" #include "service/storage_proxy.hh" #include "mutation/mutation.hh" #include "cdc/log.hh" namespace cql3 { namespace statements { drop_table_statement::drop_table_statement(cf_name cf_name, bool if_exists) : schema_altering_statement{std::move(cf_name), &timeout_config::truncate_timeout} , _if_exists{if_exists} { } future<> drop_table_statement::check_access(query_processor& qp, const service::client_state& state) const { return state.has_column_family_access(keyspace(), column_family(), auth::permission::DROP); } future, cql3::cql_warnings_vec>> drop_table_statement::prepare_schema_mutations(query_processor& qp, service::query_state& state, const query_options& options, service::group0_batch& mc) const { ::shared_ptr ret; if (cdc::is_log_for_some_table(qp.db().real_database(), keyspace(), column_family())) { // we should really throw invalid_request_exception but for legacy reasons // with throw unauthorized_exception here co_return coroutine::exception(std::make_exception_ptr(exceptions::unauthorized_exception( format("Cannot DROP cdc log table {}", column_family())))); } try { auto muts = co_await service::prepare_column_family_drop_announcement(qp.proxy(), keyspace(), column_family(), mc.write_timestamp()); mc.add_mutations(std::move(muts)); using namespace cql_transport; ret = ::make_shared( event::schema_change::change_type::DROPPED, event::schema_change::target_type::TABLE, this->keyspace(), this->column_family()); } catch (const exceptions::configuration_exception& e) { if (!_if_exists) { co_return coroutine::exception(std::make_exception_ptr(exceptions::invalid_request_exception(e.get_message()))); } } { const auto& as = *state.get_client_state().get_auth_service(); co_await auth::revoke_all(as, auth::make_data_resource(keyspace(), column_family()), mc); } co_return std::make_tuple(std::move(ret), std::vector()); } std::unique_ptr drop_table_statement::prepare(data_dictionary::database db, cql_stats& stats) { return std::make_unique(audit_info(), make_shared(*this)); } } }