e3e5f7feec
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.
27 lines
792 B
Plaintext
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 < ?); |