mirror of
https://github.com/status-im/realm-js.git
synced 2025-01-15 09:04:25 +00:00
remove duplicte code and privitize methods
This commit is contained in:
parent
a54d2216f9
commit
6e9d9bb793
@ -35,7 +35,7 @@ ObjectSchema::ObjectSchema(realm::Group *group, std::string name) : name(name) {
|
|||||||
if (property.type == PropertyTypeObject || property.type == PropertyTypeArray) {
|
if (property.type == PropertyTypeObject || property.type == PropertyTypeArray) {
|
||||||
// set link type for objects and arrays
|
// set link type for objects and arrays
|
||||||
realm::TableRef linkTable = table->get_link_target(col);
|
realm::TableRef linkTable = table->get_link_target(col);
|
||||||
property.object_type = ObjectStore::class_for_table_name(linkTable->get_name().data());
|
property.object_type = ObjectStore::object_type_for_table_name(linkTable->get_name().data());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
property.object_type = "";
|
property.object_type = "";
|
||||||
@ -72,7 +72,7 @@ std::vector<ObjectSchema> ObjectSchema::object_schema_from_group(realm::Group *g
|
|||||||
vector<ObjectSchema> object_schema;
|
vector<ObjectSchema> object_schema;
|
||||||
|
|
||||||
for (unsigned long i = 0; i < numTables; i++) {
|
for (unsigned long i = 0; i < numTables; i++) {
|
||||||
std::string name = ObjectStore::class_for_table_name(group->get_table_name(i).data());
|
std::string name = ObjectStore::object_type_for_table_name(group->get_table_name(i).data());
|
||||||
if (name.length()) {
|
if (name.length()) {
|
||||||
object_schema.push_back(ObjectSchema(group, name));
|
object_schema.push_back(ObjectSchema(group, name));
|
||||||
}
|
}
|
||||||
|
@ -105,26 +105,26 @@ void ObjectStore::set_primary_key_for_object(realm::Group *group, StringData obj
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
string ObjectStore::class_for_table_name(string table_name) {
|
string ObjectStore::object_type_for_table_name(string table_name) {
|
||||||
if (table_name.compare(0, 6, c_object_table_name_prefix) == 0) {
|
if (table_name.compare(0, 6, c_object_table_name_prefix) == 0) {
|
||||||
return table_name.substr(6, table_name.length()-6);
|
return table_name.substr(6, table_name.length()-6);
|
||||||
}
|
}
|
||||||
return string();
|
return string();
|
||||||
}
|
}
|
||||||
|
|
||||||
string ObjectStore::table_name_for_class(string class_name) {
|
string ObjectStore::table_name_for_object_type(string object_type) {
|
||||||
return c_object_table_name_prefix + class_name;
|
return c_object_table_name_prefix + object_type;
|
||||||
}
|
}
|
||||||
|
|
||||||
realm::TableRef ObjectStore::table_for_object_type(realm::Group *group, StringData object_type) {
|
realm::TableRef ObjectStore::table_for_object_type(realm::Group *group, StringData object_type) {
|
||||||
return group->get_table(table_name_for_class(object_type));
|
return group->get_table(table_name_for_object_type(object_type));
|
||||||
}
|
}
|
||||||
|
|
||||||
realm::TableRef ObjectStore::table_for_object_type_create_if_needed(realm::Group *group, StringData object_type, bool &created) {
|
realm::TableRef ObjectStore::table_for_object_type_create_if_needed(realm::Group *group, StringData object_type, bool &created) {
|
||||||
return group->get_or_add_table(table_name_for_class(object_type), &created);
|
return group->get_or_add_table(table_name_for_object_type(object_type), &created);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::string> ObjectStore::validate_and_update_column_mapping(realm::Group *group, ObjectSchema &target_schema) {
|
std::vector<std::string> ObjectStore::validate_schema_and_update_column_mapping(realm::Group *group, ObjectSchema &target_schema) {
|
||||||
vector<string> validation_errors;
|
vector<string> validation_errors;
|
||||||
ObjectSchema table_schema(group, target_schema.name);
|
ObjectSchema table_schema(group, target_schema.name);
|
||||||
|
|
||||||
@ -180,9 +180,8 @@ static inline bool property_has_changed(Property &p1, Property &p2) {
|
|||||||
// set references to tables on targetSchema and create/update any missing or out-of-date tables
|
// set references to tables on targetSchema and create/update any missing or out-of-date tables
|
||||||
// if update existing is true, updates existing tables, otherwise validates existing tables
|
// if update existing is true, updates existing tables, otherwise validates existing tables
|
||||||
// NOTE: must be called from within write transaction
|
// NOTE: must be called from within write transaction
|
||||||
static inline bool create_tables(realm::Group *group, ObjectStore::Schema target_schema, bool update_existing) {
|
bool ObjectStore::create_tables(realm::Group *group, ObjectStore::Schema target_schema, bool update_existing) {
|
||||||
// create metadata tables if neded
|
bool changed = false;
|
||||||
bool changed = realm::ObjectStore::create_metadata_tables(group);
|
|
||||||
|
|
||||||
// first pass to create missing tables
|
// first pass to create missing tables
|
||||||
vector<ObjectSchema *> to_update;
|
vector<ObjectSchema *> to_update;
|
||||||
@ -276,14 +275,14 @@ bool ObjectStore::update_realm_with_schema(realm::Group *group,
|
|||||||
bool migrating = is_migration_required(group, version);
|
bool migrating = is_migration_required(group, version);
|
||||||
|
|
||||||
// create tables
|
// create tables
|
||||||
bool changed = create_tables(group, schema, migrating);
|
bool changed = create_metadata_tables(group) | create_tables(group, schema, migrating);
|
||||||
for (size_t i = 0; i < schema.size(); i++) {
|
for (size_t i = 0; i < schema.size(); i++) {
|
||||||
ObjectSchema *target_schema = schema[i].get();
|
ObjectSchema *target_schema = schema[i].get();
|
||||||
TableRef table = table_for_object_type(group, target_schema->name);
|
TableRef table = table_for_object_type(group, target_schema->name);
|
||||||
|
|
||||||
// read-only realms may be missing tables entirely
|
// read-only realms may be missing tables entirely
|
||||||
if (table) {
|
if (table) {
|
||||||
auto errors = validate_and_update_column_mapping(group, *target_schema);
|
auto errors = validate_schema_and_update_column_mapping(group, *target_schema);
|
||||||
if (errors.size()) {
|
if (errors.size()) {
|
||||||
throw ObjectStoreValidationException(errors, target_schema->name);
|
throw ObjectStoreValidationException(errors, target_schema->name);
|
||||||
}
|
}
|
||||||
|
@ -28,38 +28,18 @@ namespace realm {
|
|||||||
// Schema version used for uninitialized Realms
|
// Schema version used for uninitialized Realms
|
||||||
static const uint64_t NotVersioned;
|
static const uint64_t NotVersioned;
|
||||||
|
|
||||||
// check if the realm already has all metadata tables
|
|
||||||
static bool has_metadata_tables(Group *group);
|
|
||||||
|
|
||||||
// create any metadata tables that don't already exist
|
|
||||||
// must be in write transaction to set
|
|
||||||
// returns true if it actually did anything
|
|
||||||
static bool create_metadata_tables(Group *group);
|
|
||||||
|
|
||||||
// get the last set schema version
|
// get the last set schema version
|
||||||
static uint64_t get_schema_version(Group *group);
|
static uint64_t get_schema_version(Group *group);
|
||||||
|
|
||||||
// set a new schema version
|
// set a new schema version
|
||||||
static void set_schema_version(Group *group, uint64_t version);
|
static void set_schema_version(Group *group, uint64_t version);
|
||||||
|
|
||||||
// get primary key property name for object type
|
// checks if a migration is required for a given schema version
|
||||||
static StringData get_primary_key_for_object(Group *group, StringData object_type);
|
static bool is_migration_required(realm::Group *group, uint64_t new_version);
|
||||||
|
|
||||||
// sets primary key property for object type
|
|
||||||
// must be in write transaction to set
|
|
||||||
static void set_primary_key_for_object(Group *group, StringData object_type, StringData primary_key);
|
|
||||||
|
|
||||||
// verify a target schema against its table, setting the table_column property on each schema object
|
// verify a target schema against its table, setting the table_column property on each schema object
|
||||||
// returns array of validation errors
|
// returns array of validation errors
|
||||||
static std::vector<std::string> validate_and_update_column_mapping(Group *group, ObjectSchema &target_schema);
|
static std::vector<std::string> validate_schema_and_update_column_mapping(Group *group, ObjectSchema &target_schema);
|
||||||
|
|
||||||
// get the table used to store object of objectClass
|
|
||||||
static std::string table_name_for_class(std::string class_name);
|
|
||||||
static std::string class_for_table_name(std::string table_name);
|
|
||||||
static realm::TableRef table_for_object_type(Group *group, StringData object_type);
|
|
||||||
static realm::TableRef table_for_object_type_create_if_needed(Group *group, StringData object_type, bool &created);
|
|
||||||
|
|
||||||
static bool is_migration_required(realm::Group *group, uint64_t new_version);
|
|
||||||
|
|
||||||
// updates a Realm to a given target schema/version creating tables as necessary
|
// updates a Realm to a given target schema/version creating tables as necessary
|
||||||
// returns if any changes were made
|
// returns if any changes were made
|
||||||
@ -72,6 +52,35 @@ namespace realm {
|
|||||||
uint64_t version,
|
uint64_t version,
|
||||||
Schema schema,
|
Schema schema,
|
||||||
MigrationFunction migration);
|
MigrationFunction migration);
|
||||||
|
|
||||||
|
// get a table for an object type
|
||||||
|
static realm::TableRef table_for_object_type(Group *group, StringData object_type);
|
||||||
|
|
||||||
|
private:
|
||||||
|
// check if the realm already has all metadata tables
|
||||||
|
static bool has_metadata_tables(Group *group);
|
||||||
|
|
||||||
|
// create any metadata tables that don't already exist
|
||||||
|
// must be in write transaction to set
|
||||||
|
// returns true if it actually did anything
|
||||||
|
static bool create_metadata_tables(Group *group);
|
||||||
|
|
||||||
|
// set references to tables on targetSchema and create/update any missing or out-of-date tables
|
||||||
|
// if update existing is true, updates existing tables, otherwise validates existing tables
|
||||||
|
static bool create_tables(realm::Group *group, ObjectStore::Schema target_schema, bool update_existing);
|
||||||
|
|
||||||
|
// get primary key property name for object type
|
||||||
|
static StringData get_primary_key_for_object(Group *group, StringData object_type);
|
||||||
|
|
||||||
|
// sets primary key property for object type
|
||||||
|
// must be in write transaction to set
|
||||||
|
static void set_primary_key_for_object(Group *group, StringData object_type, StringData primary_key);
|
||||||
|
|
||||||
|
static realm::TableRef table_for_object_type_create_if_needed(Group *group, StringData object_type, bool &created);
|
||||||
|
static std::string table_name_for_object_type(std::string class_name);
|
||||||
|
static std::string object_type_for_table_name(std::string table_name);
|
||||||
|
|
||||||
|
friend ObjectSchema;
|
||||||
};
|
};
|
||||||
|
|
||||||
class ObjectStoreException : public std::exception {
|
class ObjectStoreException : public std::exception {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user