Revert non-trivial schema changes and move them to a new schema version.
							parent
							
								
									2ded344620
								
							
						
					
					
						commit
						a1665c5094
					
				|  | @ -14,7 +14,7 @@ | |||
|  */ | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS events( | ||||
|     stream_ordering BIGINT PRIMARY KEY, | ||||
|     stream_ordering BIGINT PRIMARY KEY AUTOINCREMENT, | ||||
|     topological_ordering BIGINT NOT NULL, | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     type VARCHAR(150) NOT NULL, | ||||
|  | @ -62,10 +62,10 @@ CREATE TABLE IF NOT EXISTS current_state_events( | |||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     type VARCHAR(150) NOT NULL, | ||||
|     state_key VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id), | ||||
|     UNIQUE (room_id, type, state_key) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS curr_events_event_id ON current_state_events (event_id); | ||||
| CREATE INDEX IF NOT EXISTS current_state_events_room_id ON current_state_events (room_id); | ||||
| CREATE INDEX IF NOT EXISTS current_state_events_type ON current_state_events (type); | ||||
| CREATE INDEX IF NOT EXISTS current_state_events_state_key ON current_state_events (state_key); | ||||
|  | @ -75,10 +75,10 @@ CREATE TABLE IF NOT EXISTS room_memberships( | |||
|     user_id VARCHAR(150) NOT NULL, | ||||
|     sender VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     membership VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id) | ||||
|     membership VARCHAR(150) NOT NULL | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS room_memberships_event_id ON room_memberships (event_id); | ||||
| CREATE INDEX IF NOT EXISTS room_memberships_room_id ON room_memberships (room_id); | ||||
| CREATE INDEX IF NOT EXISTS room_memberships_user_id ON room_memberships (user_id); | ||||
| 
 | ||||
|  | @ -87,26 +87,25 @@ CREATE TABLE IF NOT EXISTS feedback( | |||
|     feedback_type VARCHAR(150), | ||||
|     target_event_id VARCHAR(150), | ||||
|     sender VARCHAR(150), | ||||
|     room_id VARCHAR(150), | ||||
|     UNIQUE (event_id) | ||||
|     room_id VARCHAR(150) | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS topics( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     topic VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id) | ||||
|     topic VARCHAR(150) NOT NULL | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS topics_event_id ON topics(event_id); | ||||
| CREATE INDEX IF NOT EXISTS topics_room_id ON topics(room_id); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS room_names( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     name VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id) | ||||
|     name VARCHAR(150) NOT NULL | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS room_names_event_id ON room_names(event_id); | ||||
| CREATE INDEX IF NOT EXISTS room_names_room_id ON room_names(room_id); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS rooms( | ||||
|  |  | |||
|  | @ -63,6 +63,3 @@ CREATE TABLE IF NOT EXISTS remote_media_cache_thumbnails ( | |||
|         thumbnail_type | ||||
|      ) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS remote_media_cache_thumbnails_media_id | ||||
|     ON remote_media_cache_thumbnails (media_id); | ||||
|  |  | |||
|  | @ -16,16 +16,14 @@ CREATE TABLE IF NOT EXISTS presence( | |||
|   user_id VARCHAR(150) NOT NULL, | ||||
|   state VARCHAR(20), | ||||
|   status_msg VARCHAR(150), | ||||
|   mtime BIGINT, -- miliseconds since last state change | ||||
|   UNIQUE (user_id) | ||||
|   mtime BIGINT -- miliseconds since last state change | ||||
| ); | ||||
| 
 | ||||
| -- For each of /my/ users which possibly-remote users are allowed to see their | ||||
| -- presence state | ||||
| CREATE TABLE IF NOT EXISTS presence_allow_inbound( | ||||
|   observed_user_id VARCHAR(150) NOT NULL, | ||||
|   observer_user_id VARCHAR(150) NOT NULL, -- a UserID, | ||||
|   UNIQUE (observed_user_id, observer_user_id) | ||||
|   observer_user_id VARCHAR(150) NOT NULL -- a UserID, | ||||
| ); | ||||
| 
 | ||||
| -- For each of /my/ users (watcher), which possibly-remote users are they | ||||
|  | @ -33,6 +31,5 @@ CREATE TABLE IF NOT EXISTS presence_allow_inbound( | |||
| CREATE TABLE IF NOT EXISTS presence_list( | ||||
|   user_id VARCHAR(150) NOT NULL, | ||||
|   observed_user_id VARCHAR(150) NOT NULL, -- a UserID, | ||||
|   accepted BOOLEAN NOT NULL, | ||||
|   UNIQUE (user_id, observed_user_id) | ||||
|   accepted BOOLEAN NOT NULL | ||||
| ); | ||||
|  |  | |||
|  | @ -15,6 +15,5 @@ | |||
| CREATE TABLE IF NOT EXISTS profiles( | ||||
|     user_id VARCHAR(150) NOT NULL, | ||||
|     displayname VARCHAR(150), | ||||
|     avatar_url VARCHAR(150), | ||||
|     UNIQUE(user_id) | ||||
|     avatar_url VARCHAR(150) | ||||
| ); | ||||
|  |  | |||
|  | @ -15,8 +15,7 @@ | |||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS room_aliases( | ||||
|     room_alias VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (room_alias) | ||||
|     room_id VARCHAR(150) NOT NULL | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS room_alias_servers( | ||||
|  |  | |||
|  | @ -49,10 +49,10 @@ CREATE TABLE IF NOT EXISTS transaction_id_to_pdu( | |||
|     transaction_id INTEGER, | ||||
|     destination VARCHAR(150), | ||||
|     pdu_id VARCHAR(150), | ||||
|     pdu_origin VARCHAR(150), | ||||
|     UNIQUE (transaction_id, destination) | ||||
|     pdu_origin VARCHAR(150) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS transaction_id_to_pdu_tx ON transaction_id_to_pdu(transaction_id, destination) | ||||
| CREATE INDEX IF NOT EXISTS transaction_id_to_pdu_dest ON transaction_id_to_pdu(destination); | ||||
| 
 | ||||
| -- To track destination health | ||||
|  |  | |||
|  | @ -13,6 +13,7 @@ | |||
|  * limitations under the License. | ||||
|  */ | ||||
| CREATE TABLE IF NOT EXISTS users( | ||||
|     id BIGINT PRIMARY KEY AUTOINCREMENT, | ||||
|     name VARCHAR(150), | ||||
|     password_hash VARCHAR(150), | ||||
|     creation_ts BIGINT, | ||||
|  | @ -35,8 +36,8 @@ CREATE TABLE IF NOT EXISTS user_ips ( | |||
|     device_id VARCHAR(150), | ||||
|     ip VARCHAR(150) NOT NULL, | ||||
|     user_agent VARCHAR(150) NOT NULL, | ||||
|     last_seen BIGINT NOT NULL | ||||
|     last_seen BIGINT NOT NULL, | ||||
|     UNIQUE (user, access_token, ip, user_agent) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS user_ips_user ON user_ips(user); | ||||
| CREATE INDEX IF NOT EXISTS user_ips_user_ip ON user_ips(user, access_token, ip); | ||||
|  |  | |||
|  | @ -0,0 +1,89 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *     http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS event_forward_extremities( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id, room_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS ev_extrem_room ON event_forward_extremities(room_id); | ||||
| CREATE INDEX IF NOT EXISTS ev_extrem_id ON event_forward_extremities(event_id); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS event_backward_extremities( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id, room_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS ev_b_extrem_room ON event_backward_extremities(room_id); | ||||
| CREATE INDEX IF NOT EXISTS ev_b_extrem_id ON event_backward_extremities(event_id); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS event_edges( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     prev_event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     is_state BOOL NOT NULL, | ||||
|     UNIQUE (event_id, prev_event_id, room_id, is_state) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS ev_edges_id ON event_edges(event_id); | ||||
| CREATE INDEX IF NOT EXISTS ev_edges_prev_id ON event_edges(prev_event_id); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS room_depth( | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     min_depth INTEGER NOT NULL, | ||||
|     UNIQUE (room_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS room_depth_room ON room_depth(room_id); | ||||
| 
 | ||||
| 
 | ||||
| create TABLE IF NOT EXISTS event_destinations( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     destination VARCHAR(150) NOT NULL, | ||||
|     delivered_ts BIGINT DEFAULT 0, -- or 0 if not delivered | ||||
|     UNIQUE (event_id, destination) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS event_destinations_id ON event_destinations(event_id); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS state_forward_extremities( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     type VARCHAR(150) NOT NULL, | ||||
|     state_key VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id, room_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS st_extrem_keys ON state_forward_extremities( | ||||
|     room_id, type, state_key | ||||
| ); | ||||
| CREATE INDEX IF NOT EXISTS st_extrem_id ON state_forward_extremities(event_id); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS event_auth( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     auth_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id, auth_id, room_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS evauth_edges_id ON event_auth(event_id); | ||||
| CREATE INDEX IF NOT EXISTS evauth_edges_auth_id ON event_auth(auth_id); | ||||
|  | @ -0,0 +1,55 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *    http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS event_content_hashes ( | ||||
|     event_id VARCHAR(150), | ||||
|     algorithm VARCHAR(150), | ||||
|     hash BLOB, | ||||
|     UNIQUE (event_id, algorithm) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS event_content_hashes_id ON event_content_hashes(event_id); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS event_reference_hashes ( | ||||
|     event_id VARCHAR(150), | ||||
|     algorithm VARCHAR(150), | ||||
|     hash BLOB, | ||||
|     UNIQUE (event_id, algorithm) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS event_reference_hashes_id ON event_reference_hashes(event_id); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS event_signatures ( | ||||
|     event_id VARCHAR(150), | ||||
|     signature_name VARCHAR(150), | ||||
|     key_id VARCHAR(150), | ||||
|     signature BLOB, | ||||
|     UNIQUE (event_id, signature_name, key_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS event_signatures_id ON event_signatures(event_id); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS event_edge_hashes( | ||||
|     event_id VARCHAR(150), | ||||
|     prev_event_id VARCHAR(150), | ||||
|     algorithm VARCHAR(150), | ||||
|     hash BLOB, | ||||
|     UNIQUE (event_id, prev_event_id, algorithm) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS event_edge_hashes_id ON event_edge_hashes(event_id); | ||||
|  | @ -0,0 +1,124 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *    http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS events( | ||||
|     stream_ordering BIGINT PRIMARY KEY, | ||||
|     topological_ordering BIGINT NOT NULL, | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     type VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     content BLOB NOT NULL, | ||||
|     unrecognized_keys BLOB, | ||||
|     processed BOOL NOT NULL, | ||||
|     outlier BOOL NOT NULL, | ||||
|     depth BIGINT DEFAULT 0 NOT NULL, | ||||
|     UNIQUE (event_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS events_stream_ordering ON events (stream_ordering); | ||||
| CREATE INDEX IF NOT EXISTS events_topological_ordering ON events (topological_ordering); | ||||
| CREATE INDEX IF NOT EXISTS events_room_id ON events (room_id); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS event_json( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     internal_metadata BLOB NOT NULL, | ||||
|     json BLOB NOT NULL, | ||||
|     UNIQUE (event_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS event_json_room_id ON event_json(room_id); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS state_events( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     type VARCHAR(150) NOT NULL, | ||||
|     state_key VARCHAR(150) NOT NULL, | ||||
|     prev_state VARCHAR(150), | ||||
|     UNIQUE (event_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS state_events_room_id ON state_events (room_id); | ||||
| CREATE INDEX IF NOT EXISTS state_events_type ON state_events (type); | ||||
| CREATE INDEX IF NOT EXISTS state_events_state_key ON state_events (state_key); | ||||
| 
 | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS current_state_events( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     type VARCHAR(150) NOT NULL, | ||||
|     state_key VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id), | ||||
|     UNIQUE (room_id, type, state_key) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS current_state_events_room_id ON current_state_events (room_id); | ||||
| CREATE INDEX IF NOT EXISTS current_state_events_type ON current_state_events (type); | ||||
| CREATE INDEX IF NOT EXISTS current_state_events_state_key ON current_state_events (state_key); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS room_memberships( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     user_id VARCHAR(150) NOT NULL, | ||||
|     sender VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     membership VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS room_memberships_room_id ON room_memberships (room_id); | ||||
| CREATE INDEX IF NOT EXISTS room_memberships_user_id ON room_memberships (user_id); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS feedback( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     feedback_type VARCHAR(150), | ||||
|     target_event_id VARCHAR(150), | ||||
|     sender VARCHAR(150), | ||||
|     room_id VARCHAR(150), | ||||
|     UNIQUE (event_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS topics( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     topic VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS topics_room_id ON topics(room_id); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS room_names( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     name VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS room_names_room_id ON room_names(room_id); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS rooms( | ||||
|     room_id VARCHAR(150) PRIMARY KEY NOT NULL, | ||||
|     is_public BOOL, | ||||
|     creator VARCHAR(150) | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS room_hosts( | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     host VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (room_id, host) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS room_hosts_room_id ON room_hosts (room_id); | ||||
|  | @ -0,0 +1,31 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *    http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| CREATE TABLE IF NOT EXISTS server_tls_certificates( | ||||
|   server_name VARCHAR(150), -- Server name. | ||||
|   fingerprint VARCHAR(150), -- Certificate fingerprint. | ||||
|   from_server VARCHAR(150), -- Which key server the certificate was fetched from. | ||||
|   ts_added_ms BIGINT, -- When the certifcate was added. | ||||
|   tls_certificate BLOB, -- DER encoded x509 certificate. | ||||
|   UNIQUE (server_name, fingerprint) | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS server_signature_keys( | ||||
|   server_name VARCHAR(150), -- Server name. | ||||
|   key_id VARCHAR(150), -- Key version. | ||||
|   from_server VARCHAR(150), -- Which key server the key was fetched form. | ||||
|   ts_added_ms BIGINT, -- When the key was added. | ||||
|   verify_key BLOB, -- NACL verification key. | ||||
|   UNIQUE (server_name, key_id) | ||||
| ); | ||||
|  | @ -0,0 +1,68 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *    http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS local_media_repository ( | ||||
|     media_id VARCHAR(150), -- The id used to refer to the media. | ||||
|     media_type VARCHAR(150), -- The MIME-type of the media. | ||||
|     media_length INTEGER, -- Length of the media in bytes. | ||||
|     created_ts BIGINT, -- When the content was uploaded in ms. | ||||
|     upload_name VARCHAR(150), -- The name the media was uploaded with. | ||||
|     user_id VARCHAR(150), -- The user who uploaded the file. | ||||
|     UNIQUE (media_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS local_media_repository_thumbnails ( | ||||
|     media_id VARCHAR(150), -- The id used to refer to the media. | ||||
|     thumbnail_width INTEGER, -- The width of the thumbnail in pixels. | ||||
|     thumbnail_height INTEGER, -- The height of the thumbnail in pixels. | ||||
|     thumbnail_type VARCHAR(150), -- The MIME-type of the thumbnail. | ||||
|     thumbnail_method VARCHAR(150), -- The method used to make the thumbnail. | ||||
|     thumbnail_length INTEGER, -- The length of the thumbnail in bytes. | ||||
|     UNIQUE ( | ||||
|         media_id, thumbnail_width, thumbnail_height, thumbnail_type | ||||
|     ) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS local_media_repository_thumbnails_media_id | ||||
|     ON local_media_repository_thumbnails (media_id); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS remote_media_cache ( | ||||
|     media_origin VARCHAR(150), -- The remote HS the media came from. | ||||
|     media_id VARCHAR(150), -- The id used to refer to the media on that server. | ||||
|     media_type VARCHAR(150), -- The MIME-type of the media. | ||||
|     created_ts BIGINT, -- When the content was uploaded in ms. | ||||
|     upload_name VARCHAR(150), -- The name the media was uploaded with. | ||||
|     media_length INTEGER, -- Length of the media in bytes. | ||||
|     filesystem_id VARCHAR(150), -- The name used to store the media on disk. | ||||
|     UNIQUE (media_origin, media_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS remote_media_cache_thumbnails ( | ||||
|     media_origin VARCHAR(150), -- The remote HS the media came from. | ||||
|     media_id VARCHAR(150), -- The id used to refer to the media. | ||||
|     thumbnail_width INTEGER, -- The width of the thumbnail in pixels. | ||||
|     thumbnail_height INTEGER, -- The height of the thumbnail in pixels. | ||||
|     thumbnail_method VARCHAR(150), -- The method used to make the thumbnail | ||||
|     thumbnail_type VARCHAR(150), -- The MIME-type of the thumbnail. | ||||
|     thumbnail_length INTEGER, -- The length of the thumbnail in bytes. | ||||
|     filesystem_id VARCHAR(150), -- The name used to store the media on disk. | ||||
|     UNIQUE ( | ||||
|         media_origin, media_id, thumbnail_width, thumbnail_height, | ||||
|         thumbnail_type | ||||
|      ) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS remote_media_cache_thumbnails_media_id | ||||
|     ON remote_media_cache_thumbnails (media_id); | ||||
|  | @ -0,0 +1,38 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *    http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| CREATE TABLE IF NOT EXISTS presence( | ||||
|   user_id VARCHAR(150) NOT NULL, | ||||
|   state VARCHAR(20), | ||||
|   status_msg VARCHAR(150), | ||||
|   mtime BIGINT, -- miliseconds since last state change | ||||
|   UNIQUE (user_id) | ||||
| ); | ||||
| 
 | ||||
| -- For each of /my/ users which possibly-remote users are allowed to see their | ||||
| -- presence state | ||||
| CREATE TABLE IF NOT EXISTS presence_allow_inbound( | ||||
|   observed_user_id VARCHAR(150) NOT NULL, | ||||
|   observer_user_id VARCHAR(150) NOT NULL, -- a UserID, | ||||
|   UNIQUE (observed_user_id, observer_user_id) | ||||
| ); | ||||
| 
 | ||||
| -- For each of /my/ users (watcher), which possibly-remote users are they | ||||
| -- watching? | ||||
| CREATE TABLE IF NOT EXISTS presence_list( | ||||
|   user_id VARCHAR(150) NOT NULL, | ||||
|   observed_user_id VARCHAR(150) NOT NULL, -- a UserID, | ||||
|   accepted BOOLEAN NOT NULL, | ||||
|   UNIQUE (user_id, observed_user_id) | ||||
| ); | ||||
|  | @ -0,0 +1,20 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *    http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| CREATE TABLE IF NOT EXISTS profiles( | ||||
|     user_id VARCHAR(150) NOT NULL, | ||||
|     displayname VARCHAR(150), | ||||
|     avatar_url VARCHAR(150), | ||||
|     UNIQUE(user_id) | ||||
| ); | ||||
|  | @ -0,0 +1,22 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *     http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| CREATE TABLE IF NOT EXISTS redactions ( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     redacts VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS redactions_event_id ON redactions (event_id); | ||||
| CREATE INDEX IF NOT EXISTS redactions_redacts ON redactions (redacts); | ||||
|  | @ -0,0 +1,25 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *    http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS room_aliases( | ||||
|     room_alias VARCHAR(150) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (room_alias) | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS room_alias_servers( | ||||
|     room_alias VARCHAR(150) NOT NULL, | ||||
|     server VARCHAR(150) NOT NULL | ||||
| ); | ||||
|  | @ -0,0 +1,40 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *    http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS state_groups( | ||||
|     id VARCHAR(20) PRIMARY KEY, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     event_id VARCHAR(150) NOT NULL | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS state_groups_state( | ||||
|     state_group VARCHAR(20) NOT NULL, | ||||
|     room_id VARCHAR(150) NOT NULL, | ||||
|     type VARCHAR(150) NOT NULL, | ||||
|     state_key VARCHAR(150) NOT NULL, | ||||
|     event_id VARCHAR(150) NOT NULL | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS event_to_state_groups( | ||||
|     event_id VARCHAR(150) NOT NULL, | ||||
|     state_group VARCHAR(150) NOT NULL, | ||||
|     UNIQUE (event_id) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS state_groups_id ON state_groups(id); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS state_groups_state_id ON state_groups_state(state_group); | ||||
| CREATE INDEX IF NOT EXISTS state_groups_state_tuple ON state_groups_state(room_id, type, state_key); | ||||
| CREATE INDEX IF NOT EXISTS event_to_state_groups_id ON event_to_state_groups(event_id); | ||||
|  | @ -0,0 +1,63 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *    http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| -- Stores what transaction ids we have received and what our response was | ||||
| CREATE TABLE IF NOT EXISTS received_transactions( | ||||
|     transaction_id VARCHAR(150), | ||||
|     origin VARCHAR(150), | ||||
|     ts BIGINT, | ||||
|     response_code INTEGER, | ||||
|     response_json BLOB, | ||||
|     has_been_referenced BOOL default 0, -- Whether thishas been referenced by a prev_tx | ||||
|     UNIQUE (transaction_id, origin) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS transactions_have_ref ON received_transactions(origin, has_been_referenced);-- WHERE has_been_referenced = 0; | ||||
| 
 | ||||
| 
 | ||||
| -- Stores what transactions we've sent, what their response was (if we got one) and whether we have | ||||
| -- since referenced the transaction in another outgoing transaction | ||||
| CREATE TABLE IF NOT EXISTS sent_transactions( | ||||
|     id BIGINT PRIMARY KEY, -- This is used to apply insertion ordering | ||||
|     transaction_id VARCHAR(150), | ||||
|     destination VARCHAR(150), | ||||
|     response_code INTEGER DEFAULT 0, | ||||
|     response_json BLOB, | ||||
|     ts BIGINT | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS sent_transaction_dest ON sent_transactions(destination); | ||||
| CREATE INDEX IF NOT EXISTS sent_transaction_txn_id ON sent_transactions(transaction_id); | ||||
| -- So that we can do an efficient look up of all transactions that have yet to be successfully | ||||
| -- sent. | ||||
| CREATE INDEX IF NOT EXISTS sent_transaction_sent ON sent_transactions(response_code); | ||||
| 
 | ||||
| 
 | ||||
| -- For sent transactions only. | ||||
| CREATE TABLE IF NOT EXISTS transaction_id_to_pdu( | ||||
|     transaction_id INTEGER, | ||||
|     destination VARCHAR(150), | ||||
|     pdu_id VARCHAR(150), | ||||
|     pdu_origin VARCHAR(150), | ||||
|     UNIQUE (transaction_id, destination) | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS transaction_id_to_pdu_dest ON transaction_id_to_pdu(destination); | ||||
| 
 | ||||
| -- To track destination health | ||||
| CREATE TABLE IF NOT EXISTS destinations( | ||||
|     destination VARCHAR(150) PRIMARY KEY, | ||||
|     retry_last_ts BIGINT, | ||||
|     retry_interval INTEGER | ||||
| ); | ||||
|  | @ -0,0 +1,42 @@ | |||
| /* Copyright 2014, 2015 OpenMarket Ltd | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *    http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| CREATE TABLE IF NOT EXISTS users( | ||||
|     name VARCHAR(150), | ||||
|     password_hash VARCHAR(150), | ||||
|     creation_ts BIGINT, | ||||
|     admin BOOL DEFAULT 0 NOT NULL, | ||||
|     UNIQUE(name) | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS access_tokens( | ||||
|     id BIGINT PRIMARY KEY, | ||||
|     user_id VARCHAR(150) NOT NULL, | ||||
|     device_id VARCHAR(150), | ||||
|     token VARCHAR(150) NOT NULL, | ||||
|     last_used BIGINT, | ||||
|     UNIQUE(token) | ||||
| ); | ||||
| 
 | ||||
| CREATE TABLE IF NOT EXISTS user_ips ( | ||||
|     user VARCHAR(150) NOT NULL, | ||||
|     access_token VARCHAR(150) NOT NULL, | ||||
|     device_id VARCHAR(150), | ||||
|     ip VARCHAR(150) NOT NULL, | ||||
|     user_agent VARCHAR(150) NOT NULL, | ||||
|     last_seen BIGINT NOT NULL | ||||
| ); | ||||
| 
 | ||||
| CREATE INDEX IF NOT EXISTS user_ips_user ON user_ips(user); | ||||
| CREATE INDEX IF NOT EXISTS user_ips_user_ip ON user_ips(user, access_token, ip); | ||||
		Loading…
	
		Reference in New Issue
	
	 Erik Johnston
						Erik Johnston