status-go/protocol/migrations/sqlite/1632303896_modify_contacts_...

33 lines
1.3 KiB
MySQL
Raw Normal View History

2021-03-24 08:04:03 +00:00
ALTER TABLE contacts ADD COLUMN added BOOLEAN DEFAULT FALSE;
ALTER TABLE contacts ADD COLUMN blocked BOOLEAN DEFAULT FALSE;
CREATE INDEX tmp_contacts ON contacts(hex(system_tags));
UPDATE contacts SET added = 1 WHERE hex(system_tags) LIKE '%6164646564%';
UPDATE contacts SET blocked = 1 WHERE hex(system_tags) LIKE '%626c6f636b6564%';
CREATE INDEX contacts_added on contacts(added);
CREATE INDEX contacts_blocked on contacts(blocked);
CREATE INDEX contacts_local_nickname on contacts(local_nickname);
CREATE INDEX tmp_contacts_delete ON contacts(added, blocked, local_nickname);
DELETE FROM contacts
WHERE NOT(added) AND NOT(blocked) AND (local_nickname == "" OR local_nickname IS NULL)
AND NOT EXISTS (SELECT 1 FROM chat_identity_contacts i WHERE id = i.contact_id)
AND NOT EXISTS (SELECT 1 FROM ens_verification_records v WHERE id = v.public_key);
/*
would be cool to remove these columns
ALTER TABLE contacts DROP COLUMN name;
ALTER TABLE contacts DROP COLUMN ens_verified;
ALTER TABLE contacts DROP COLUMN ens_verified_at;
ALTER TABLE contacts DROP COLUMN device_info;
ALTER TABLE contacts DROP COLUMN system_tags;
ALTER TABLE contacts DROP COLUMN tribute_to_talk;
ALTER TABLE contacts DROP COLUMN last_ens_clock_value;
ALTER TABLE contacts DROP COLUMN photo;
*/
DROP INDEX tmp_contacts_delete;
DROP INDEX tmp_contacts;