status-im/status-go

View on GitHub
protocol/migrations/sqlite/1632303896_modify_contacts_table.up.sql

Summary

Maintainability
Test Coverage
ALTER TABLE contacts ADD COLUMN added BOOLEAN DEFAULT FALSE;
ALTER TABLE contacts ADD COLUMN has_added_us 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 has_added_us = 1 WHERE hex(system_tags) LIKE '%72656365%';
UPDATE contacts SET blocked = 1 WHERE hex(system_tags) LIKE '%626c6f636b6564%';
CREATE INDEX contacts_added on contacts(added);
CREATE INDEX contacts_has_added_us on contacts(has_added_us);
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 NOT(has_added_us) 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;