Code Coverage |
||||||||||
Lines |
Functions and Methods |
Classes and Traits |
||||||||
| Total | |
77.59% |
45 / 58 |
|
50.00% |
3 / 6 |
CRAP | |
0.00% |
0 / 1 |
| add_webpush | |
77.59% |
45 / 58 |
|
50.00% |
3 / 6 |
6.41 | |
0.00% |
0 / 1 |
| depends_on | |
100.00% |
3 / 3 |
|
100.00% |
1 / 1 |
1 | |||
| effectively_installed | |
0.00% |
0 / 1 |
|
0.00% |
0 / 1 |
2 | |||
| update_schema | |
100.00% |
26 / 26 |
|
100.00% |
1 / 1 |
1 | |||
| revert_schema | |
0.00% |
0 / 6 |
|
0.00% |
0 / 1 |
2 | |||
| update_data | |
100.00% |
16 / 16 |
|
100.00% |
1 / 1 |
1 | |||
| revert_data | |
0.00% |
0 / 6 |
|
0.00% |
0 / 1 |
2 | |||
| 1 | <?php |
| 2 | /** |
| 3 | * |
| 4 | * This file is part of the phpBB Forum Software package. |
| 5 | * |
| 6 | * @copyright (c) phpBB Limited <https://www.phpbb.com> |
| 7 | * @license GNU General Public License, version 2 (GPL-2.0) |
| 8 | * |
| 9 | * For full copyright and license information, please see |
| 10 | * the docs/CREDITS.txt file. |
| 11 | * |
| 12 | */ |
| 13 | |
| 14 | namespace phpbb\db\migration\data\v400; |
| 15 | |
| 16 | use phpbb\db\migration\migration; |
| 17 | |
| 18 | class add_webpush extends migration |
| 19 | { |
| 20 | public static function depends_on(): array |
| 21 | { |
| 22 | return [ |
| 23 | '\phpbb\db\migration\data\v400\dev', |
| 24 | ]; |
| 25 | } |
| 26 | |
| 27 | public function effectively_installed(): bool |
| 28 | { |
| 29 | return $this->db_tools->sql_table_exists($this->table_prefix . 'notification_push'); |
| 30 | } |
| 31 | |
| 32 | public function update_schema(): array |
| 33 | { |
| 34 | return [ |
| 35 | 'add_tables' => [ |
| 36 | $this->table_prefix . 'notification_push' => [ |
| 37 | 'COLUMNS' => [ |
| 38 | 'notification_type_id' => ['USINT', 0], |
| 39 | 'item_id' => ['ULINT', 0], |
| 40 | 'item_parent_id' => ['ULINT', 0], |
| 41 | 'user_id' => ['ULINT', 0], |
| 42 | 'push_data' => ['MTEXT', ''], |
| 43 | 'notification_time' => ['TIMESTAMP', 0] |
| 44 | ], |
| 45 | 'PRIMARY_KEY' => ['notification_type_id', 'item_id', 'item_parent_id', 'user_id'], |
| 46 | ], |
| 47 | $this->table_prefix . 'push_subscriptions' => [ |
| 48 | 'COLUMNS' => [ |
| 49 | 'subscription_id' => ['ULINT', null, 'auto_increment'], |
| 50 | 'user_id' => ['ULINT', 0], |
| 51 | 'endpoint' => ['TEXT', ''], |
| 52 | 'expiration_time' => ['TIMESTAMP', 0], |
| 53 | 'p256dh' => ['VCHAR', ''], |
| 54 | 'auth' => ['VCHAR', ''], |
| 55 | ], |
| 56 | 'PRIMARY_KEY' => ['subscription_id', 'user_id'], |
| 57 | ] |
| 58 | ], |
| 59 | ]; |
| 60 | } |
| 61 | |
| 62 | public function revert_schema(): array |
| 63 | { |
| 64 | return [ |
| 65 | 'drop_tables' => [ |
| 66 | $this->table_prefix . 'notification_push', |
| 67 | $this->table_prefix . 'push_subscriptions', |
| 68 | ], |
| 69 | ]; |
| 70 | } |
| 71 | |
| 72 | public function update_data(): array |
| 73 | { |
| 74 | return [ |
| 75 | ['config.add', ['webpush_enable', false]], |
| 76 | ['config.add', ['webpush_vapid_public', '']], |
| 77 | ['config.add', ['webpush_vapid_private', '']], |
| 78 | ['module.add', [ |
| 79 | 'acp', |
| 80 | 'ACP_CLIENT_COMMUNICATION', |
| 81 | [ |
| 82 | 'module_basename' => 'acp_board', |
| 83 | 'module_langname' => 'ACP_WEBPUSH_SETTINGS', |
| 84 | 'module_mode' => 'webpush', |
| 85 | 'module_auth' => 'acl_a_board', |
| 86 | 'after' => ['settings', 'ACP_JABBER_SETTINGS'], |
| 87 | ], |
| 88 | ]], |
| 89 | ]; |
| 90 | } |
| 91 | |
| 92 | public function revert_data(): array |
| 93 | { |
| 94 | return [ |
| 95 | ['config.remove', ['webpush_enable']], |
| 96 | ['config.remove', ['webpush_vapid_public']], |
| 97 | ['config.remove', ['webpush_vapid_private']], |
| 98 | ['module.remove', ['acp', 'ACP_CLIENT_COMMUNICATION', 'ACP_WEBPUSH_SETTINGS']] |
| 99 | ]; |
| 100 | } |
| 101 | } |