wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 1 | CREATE TABLE IF NOT EXISTS `users` ( |
| 2 | user_id INT AUTO_INCREMENT PRIMARY KEY, |
| 3 | user_name VARCHAR(255) NOT NULL, |
| 4 | password VARCHAR(255) NOT NULL, |
wuchimedes | a0649c6 | 2025-04-05 15:53:39 +0800 | [diff] [blame] | 5 | email VARCHAR(255) NOT NULL UNIQUE, |
| 6 | passkey VARCHAR(255) NOT NULL UNIQUE |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 7 | ); |
| 8 | |
| 9 | CREATE TABLE IF NOT EXISTS `torrents` ( |
| 10 | torrent_id INT AUTO_INCREMENT PRIMARY KEY, |
| 11 | user_id INT NOT NULL, |
| 12 | torrent_name VARCHAR(255) NOT NULL, |
wuchimedes | 223bfab | 2025-04-04 17:16:05 +0800 | [diff] [blame] | 13 | info_hash BINARY(20) NOT NULL, |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 14 | file_size FLOAT NOT NULL, |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 15 | FOREIGN KEY (user_id) REFERENCES users(user_id) |
| 16 | ); |
| 17 | |
| 18 | CREATE TABLE IF NOT EXISTS `peers` ( |
wuchimedes | a0649c6 | 2025-04-05 15:53:39 +0800 | [diff] [blame] | 19 | passkey VARCHAR(255) NOT NULL, |
wuchimedes | 223bfab | 2025-04-04 17:16:05 +0800 | [diff] [blame] | 20 | info_hash BINARY(20) NOT NULL, |
| 21 | peer_id VARCHAR(20) NOT NULL, |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 22 | ip_address VARCHAR(128) NOT NULL, |
| 23 | port INT NOT NULL, |
| 24 | uploaded FLOAT NOT NULL, |
| 25 | downloaded FLOAT NOT NULL, |
wuchimedes | 223bfab | 2025-04-04 17:16:05 +0800 | [diff] [blame] | 26 | last_seen TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
wuchimedes | a0649c6 | 2025-04-05 15:53:39 +0800 | [diff] [blame] | 27 | FOREIGN KEY (passkey) REFERENCES users(passkey), |
| 28 | PRIMARY KEY (passkey, info_hash, peer_id) |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 29 | ); |