open-keychain/OpenKeychain/src/main/sqldelight/org/sufficientlysecure/keychain/KeyMetadata.sq
Vincent Breitmoser e3e5f7feec use explicit order for insert operations
This prevents a problem from different column orders in database tables.
In particular, this occurred with the user_packets table, where the `rank` column moved up in order.
2018-07-14 13:05:08 +02:00

27 lines
792 B
Plaintext

import java.lang.Boolean;
import java.util.Date;
CREATE TABLE IF NOT EXISTS key_metadata (
master_key_id INTEGER PRIMARY KEY,
last_updated INTEGER AS Date,
seen_on_keyservers INTEGER AS Boolean,
FOREIGN KEY(master_key_id) REFERENCES keyrings_public(master_key_id) ON DELETE CASCADE
);
selectByMasterKeyId:
SELECT *
FROM key_metadata
WHERE master_key_id = ?;
deleteAllLastUpdatedTimes:
UPDATE key_metadata
SET last_updated = null, seen_on_keyservers = null;
replaceKeyMetadata:
REPLACE INTO key_metadata (master_key_id, last_updated, seen_on_keyservers) VALUES (?, ?, ?);
selectFingerprintsForKeysOlderThan:
SELECT fingerprint
FROM keys
LEFT JOIN key_metadata USING (master_key_id)
WHERE rank = 0 AND (last_updated IS NULL OR last_updated < ?);