Upgrades
5 years ago
AudioPresets.php
2 years ago
EmailCollection.php
5 years ago
Migrations.php
3 years ago
Presets.php
2 years ago
Table.php
4 years ago
Videos.php
4 years ago
Visits.php
4 years ago
Webhooks.php
3 years ago
Visits.php
64 lines
| 1 | <?php |
| 2 | |
| 3 | namespace PrestoPlayer\Database; |
| 4 | |
| 5 | use PrestoPlayer\Database\Table; |
| 6 | |
| 7 | class Visits |
| 8 | { |
| 9 | protected $table; |
| 10 | protected $version = 1; |
| 11 | protected $name = 'presto_player_visits'; |
| 12 | |
| 13 | public function __construct(Table $table) |
| 14 | { |
| 15 | $this->table = $table; |
| 16 | } |
| 17 | |
| 18 | public function getName() |
| 19 | { |
| 20 | global $wpdb; |
| 21 | return $wpdb->prefix . $this->name; |
| 22 | } |
| 23 | |
| 24 | /** |
| 25 | * Add relationships custom table |
| 26 | * This allows for simple, efficient queries |
| 27 | * |
| 28 | * @return void |
| 29 | */ |
| 30 | public function install() |
| 31 | { |
| 32 | return $this->table->create($this->name, " |
| 33 | id bigint(20) unsigned NOT NULL auto_increment, |
| 34 | user_id bigint(20) unsigned NULL, |
| 35 | duration bigint(20) unsigned NOT NULL, |
| 36 | video_id bigint(20) unsigned NOT NULL, |
| 37 | ip_address varchar(39) DEFAULT '' NULL, |
| 38 | created_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP(), |
| 39 | updated_at TIMESTAMP NOT NULL, |
| 40 | deleted_at TIMESTAMP NULL, |
| 41 | PRIMARY KEY (id), |
| 42 | KEY user_id (user_id), |
| 43 | KEY video_id (video_id), |
| 44 | KEY ip_address (ip_address), |
| 45 | KEY created_at (created_at), |
| 46 | KEY updated_at (updated_at) |
| 47 | ", $this->version); |
| 48 | } |
| 49 | |
| 50 | /** |
| 51 | * Uninstall tables |
| 52 | * |
| 53 | * @return void |
| 54 | */ |
| 55 | public function uninstall() |
| 56 | { |
| 57 | $this->table->drop($this->getName()); |
| 58 | } |
| 59 | |
| 60 | public function exists(){ |
| 61 | return $this->table->exists($this->name ); |
| 62 | } |
| 63 | } |
| 64 |