/* * Copyright 2015-present ScyllaDB */ /* * SPDX-License-Identifier: LicenseRef-ScyllaDB-Source-Available-1.0 */ #include "frozen_schema.hh" #include "db/schema_tables.hh" #include "db/view/view.hh" #include "view_info.hh" #include "mutation/canonical_mutation.hh" #include "schema_mutations.hh" #include "idl/frozen_schema.dist.hh" #include "idl/frozen_schema.dist.impl.hh" frozen_schema::frozen_schema(const schema_ptr& s) : _data([&s] { schema_mutations sm = db::schema_tables::make_schema_mutations(s, api::new_timestamp(), true); bytes_ostream out; ser::writer_of_schema wr(out); std::move(wr).write_version(s->version()) .write_mutations(sm) .end_schema(); return out; }()) { } schema_ptr frozen_schema::unfreeze(const db::schema_ctxt& ctxt, schema_ptr cdc_schema, std::optional base_info) const { auto in = ser::as_input_stream(_data); auto sv = ser::deserialize(in, std::type_identity()); auto sm = sv.mutations(); if (sm.is_view()) { return db::schema_tables::create_view_from_mutations(ctxt, std::move(sm), ctxt.user_types(), std::move(base_info), sv.version()); } else { if (base_info) { throw std::runtime_error("Trying to unfreeze regular table schema with base info"); } return db::schema_tables::create_table_from_mutations(ctxt, std::move(sm), ctxt.user_types(), std::move(cdc_schema), sv.version()); } } frozen_schema::frozen_schema(bytes_ostream b) : _data(std::move(b)) { } const bytes_ostream& frozen_schema::representation() const { return _data; } extended_frozen_schema::extended_frozen_schema(const schema_ptr& c) : fs(c), base_info([&c] -> std::optional { if (c->is_view()) { return c->view_info()->base_info(); } return std::nullopt; }()), frozen_cdc_schema([&c] -> std::optional { if (c->cdc_schema()) { return frozen_schema(c->cdc_schema()); } return std::nullopt; }()) { } schema_ptr extended_frozen_schema::unfreeze(const db::schema_ctxt& ctxt) const { auto cdc_schema = frozen_cdc_schema ? frozen_cdc_schema->unfreeze(ctxt, nullptr, {}) : nullptr; return fs.unfreeze(ctxt, std::move(cdc_schema), base_info); }