status-go/protocol/migrations/sqlite/1699041816_profile_showcase_contacts.up.sql
Mikhail Rogachev 03c32f620f
feat: Profile showcase data sharing (#4209)
* feat: Add profile showcase messaging part with ecrypted data

* feat: Separate profile showcase categories to provide ablity to store custom data

* fix: review fixes

* feat: move profile showcase out of contact data

* fix: create index on contact id for profile tables

* chore: remove logger from link preview
2023-11-09 22:59:01 +04:00

67 lines
2.2 KiB
SQL

DROP TABLE profile_showcase_preferences;
DROP TABLE profile_showcase_contacts;
-- Four tables for storing own profile showcase preferences
CREATE TABLE profile_showcase_communities_preferences (
community_id TEXT PRIMARY KEY ON CONFLICT REPLACE,
visibility INT NOT NULL DEFAULT 0,
sort_order INT DEFAULT 0
);
CREATE TABLE profile_showcase_accounts_preferences (
address TEXT PRIMARY KEY ON CONFLICT REPLACE,
name TEXT DEFAULT "",
color_id DEFAULT "",
emoji VARCHAR DEFAULT "",
visibility INT NOT NULL DEFAULT 0,
sort_order INT DEFAULT 0
);
CREATE TABLE profile_showcase_collectibles_preferences (
uid TEXT PRIMARY KEY ON CONFLICT REPLACE,
visibility INT NOT NULL DEFAULT 0,
sort_order INT DEFAULT 0
);
CREATE TABLE profile_showcase_assets_preferences (
symbol TEXT PRIMARY KEY ON CONFLICT REPLACE,
visibility INT NOT NULL DEFAULT 0,
sort_order INT DEFAULT 0
);
-- Four tables for storing profile showcase for each contact
CREATE TABLE profile_showcase_communities_contacts (
community_id TEXT NOT NULL,
sort_order INT DEFAULT 0,
contact_id TEXT NOT NULL,
PRIMARY KEY (contact_id, community_id)
);
CREATE INDEX profile_showcase_communities_contact_id ON profile_showcase_communities_contacts (contact_id);
CREATE TABLE profile_showcase_accounts_contacts (
address TEXT NOT NULL,
name TEXT DEFAULT "",
color_id DEFAULT "",
emoji VARCHAR DEFAULT "",
sort_order INT DEFAULT 0,
contact_id TEXT NOT NULL,
PRIMARY KEY (contact_id, address)
);
CREATE INDEX profile_showcase_accounts_contact_id ON profile_showcase_accounts_contacts (contact_id);
CREATE TABLE profile_showcase_collectibles_contacts (
uid TEXT NOT NULL,
sort_order INT DEFAULT 0,
contact_id TEXT NOT NULL,
PRIMARY KEY (contact_id, uid)
);
CREATE INDEX profile_showcase_collectibles_contact_id ON profile_showcase_collectibles_contacts (contact_id);
CREATE TABLE profile_showcase_assets_contacts (
symbol TEXT NOT NULL,
sort_order INT DEFAULT 0,
contact_id TEXT NOT NULL,
PRIMARY KEY (contact_id, symbol)
);
CREATE INDEX profile_showcase_assets_contact_id ON profile_showcase_assets_contacts (contact_id);