|  | @@ -29,7 +29,7 @@ function init_db_schema() {
 | 
											
												
													
														|  |        SELECT logged_in_as, IFNULL(GROUP_CONCAT(send_as SEPARATOR ' '), '') AS send_as_acl FROM sender_acl
 |  |        SELECT logged_in_as, IFNULL(GROUP_CONCAT(send_as SEPARATOR ' '), '') AS send_as_acl FROM sender_acl
 | 
											
												
													
														|  |        WHERE send_as NOT LIKE '@%'
 |  |        WHERE send_as NOT LIKE '@%'
 | 
											
												
													
														|  |        GROUP BY logged_in_as;",
 |  |        GROUP BY logged_in_as;",
 | 
											
												
													
														|  | -    // END
 |  | 
 | 
											
												
													
														|  | 
 |  | +    // END 
 | 
											
												
													
														|  |      "grouped_sender_acl_external" => "CREATE VIEW grouped_sender_acl_external (username, send_as_acl) AS
 |  |      "grouped_sender_acl_external" => "CREATE VIEW grouped_sender_acl_external (username, send_as_acl) AS
 | 
											
												
													
														|  |        SELECT logged_in_as, IFNULL(GROUP_CONCAT(send_as SEPARATOR ' '), '') AS send_as_acl FROM sender_acl
 |  |        SELECT logged_in_as, IFNULL(GROUP_CONCAT(send_as SEPARATOR ' '), '') AS send_as_acl FROM sender_acl
 | 
											
												
													
														|  |        WHERE send_as NOT LIKE '@%' AND external = '1'
 |  |        WHERE send_as NOT LIKE '@%' AND external = '1'
 | 
											
										
											
												
													
														|  | @@ -872,7 +872,7 @@ function init_db_schema() {
 | 
											
												
													
														|  |          $stmt = $pdo->query("SHOW TABLES LIKE 'mailbox'");
 |  |          $stmt = $pdo->query("SHOW TABLES LIKE 'mailbox'");
 | 
											
												
													
														|  |          $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 |  |          $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
											
												
													
														|  |          if ($num_results != 0) {
 |  |          if ($num_results != 0) {
 | 
											
												
													
														|  | -          $stmt = $pdo->query("SHOW COLUMNS FROM `mailbox` LIKE '%tls_enforce%'");
 |  | 
 | 
											
												
													
														|  | 
 |  | +          $stmt = $pdo->query("SHOW COLUMNS FROM `mailbox` LIKE '%tls_enforce%'"); 
 | 
											
												
													
														|  |            $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 |  |            $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
											
												
													
														|  |            if ($num_results != 0) {
 |  |            if ($num_results != 0) {
 | 
											
												
													
														|  |              $stmt = $pdo->query("SELECT `username`, `tls_enforce_in`, `tls_enforce_out` FROM `mailbox`");
 |  |              $stmt = $pdo->query("SELECT `username`, `tls_enforce_in`, `tls_enforce_out` FROM `mailbox`");
 | 
											
										
											
												
													
														|  | @@ -883,7 +883,7 @@ function init_db_schema() {
 | 
											
												
													
														|  |            }
 |  |            }
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  | -      $stmt = $pdo->query("SHOW TABLES LIKE '" . $table . "'");
 |  | 
 | 
											
												
													
														|  | 
 |  | +      $stmt = $pdo->query("SHOW TABLES LIKE '" . $table . "'"); 
 | 
											
												
													
														|  |        $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 |  |        $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
											
												
													
														|  |        if ($num_results != 0) {
 |  |        if ($num_results != 0) {
 | 
											
												
													
														|  |          $stmt = $pdo->prepare("SELECT CONCAT('ALTER TABLE ', `table_schema`, '.', `table_name`, ' DROP FOREIGN KEY ', `constraint_name`, ';') AS `FKEY_DROP` FROM `information_schema`.`table_constraints`
 |  |          $stmt = $pdo->prepare("SELECT CONCAT('ALTER TABLE ', `table_schema`, '.', `table_name`, ' DROP FOREIGN KEY ', `constraint_name`, ';') AS `FKEY_DROP` FROM `information_schema`.`table_constraints`
 | 
											
										
											
												
													
														|  | @@ -894,7 +894,7 @@ function init_db_schema() {
 | 
											
												
													
														|  |            $pdo->query($row['FKEY_DROP']);
 |  |            $pdo->query($row['FKEY_DROP']);
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |          foreach($properties['cols'] as $column => $type) {
 |  |          foreach($properties['cols'] as $column => $type) {
 | 
											
												
													
														|  | -          $stmt = $pdo->query("SHOW COLUMNS FROM `" . $table . "` LIKE '" . $column . "'");
 |  | 
 | 
											
												
													
														|  | 
 |  | +          $stmt = $pdo->query("SHOW COLUMNS FROM `" . $table . "` LIKE '" . $column . "'"); 
 | 
											
												
													
														|  |            $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 |  |            $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
											
												
													
														|  |            if ($num_results == 0) {
 |  |            if ($num_results == 0) {
 | 
											
												
													
														|  |              if (strpos($type, 'AUTO_INCREMENT') !== false) {
 |  |              if (strpos($type, 'AUTO_INCREMENT') !== false) {
 | 
											
										
											
												
													
														|  | @@ -916,7 +916,7 @@ function init_db_schema() {
 | 
											
												
													
														|  |            if (strtolower($key_type) == 'primary') {
 |  |            if (strtolower($key_type) == 'primary') {
 | 
											
												
													
														|  |              foreach ($key_content as $key_values) {
 |  |              foreach ($key_content as $key_values) {
 | 
											
												
													
														|  |                $fields = "`" . implode("`, `", $key_values) . "`";
 |  |                $fields = "`" . implode("`, `", $key_values) . "`";
 | 
											
												
													
														|  | -              $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE Key_name = 'PRIMARY'");
 |  | 
 | 
											
												
													
														|  | 
 |  | +              $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE Key_name = 'PRIMARY'"); 
 | 
											
												
													
														|  |                $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 |  |                $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
											
												
													
														|  |                $is_drop = ($num_results != 0) ? "DROP PRIMARY KEY, " : "";
 |  |                $is_drop = ($num_results != 0) ? "DROP PRIMARY KEY, " : "";
 | 
											
												
													
														|  |                $pdo->query("ALTER TABLE `" . $table . "` " . $is_drop . "ADD PRIMARY KEY (" . $fields . ")");
 |  |                $pdo->query("ALTER TABLE `" . $table . "` " . $is_drop . "ADD PRIMARY KEY (" . $fields . ")");
 | 
											
										
											
												
													
														|  | @@ -925,7 +925,7 @@ function init_db_schema() {
 | 
											
												
													
														|  |            if (strtolower($key_type) == 'key') {
 |  |            if (strtolower($key_type) == 'key') {
 | 
											
												
													
														|  |              foreach ($key_content as $key_name => $key_values) {
 |  |              foreach ($key_content as $key_name => $key_values) {
 | 
											
												
													
														|  |                $fields = "`" . implode("`, `", $key_values) . "`";
 |  |                $fields = "`" . implode("`, `", $key_values) . "`";
 | 
											
												
													
														|  | -              $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE Key_name = '" . $key_name . "'");
 |  | 
 | 
											
												
													
														|  | 
 |  | +              $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE Key_name = '" . $key_name . "'"); 
 | 
											
												
													
														|  |                $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 |  |                $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
											
												
													
														|  |                $is_drop = ($num_results != 0) ? "DROP INDEX `" . $key_name . "`, " : "";
 |  |                $is_drop = ($num_results != 0) ? "DROP INDEX `" . $key_name . "`, " : "";
 | 
											
												
													
														|  |                $pdo->query("ALTER TABLE `" . $table . "` " . $is_drop . "ADD KEY `" . $key_name . "` (" . $fields . ")");
 |  |                $pdo->query("ALTER TABLE `" . $table . "` " . $is_drop . "ADD KEY `" . $key_name . "` (" . $fields . ")");
 | 
											
										
											
												
													
														|  | @@ -933,7 +933,7 @@ function init_db_schema() {
 | 
											
												
													
														|  |            }
 |  |            }
 | 
											
												
													
														|  |            if (strtolower($key_type) == 'unique') {
 |  |            if (strtolower($key_type) == 'unique') {
 | 
											
												
													
														|  |              foreach ($key_content as $key_name => $key_values) {
 |  |              foreach ($key_content as $key_name => $key_values) {
 | 
											
												
													
														|  | -              $fields = "`" . implode("`, `", $key_values) . "`";
 |  | 
 | 
											
												
													
														|  | 
 |  | +              $fields = "`" . implode("`, `", $key_values) . "`"; 
 | 
											
												
													
														|  |                $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE Key_name = '" . $key_name . "'");
 |  |                $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE Key_name = '" . $key_name . "'");
 | 
											
												
													
														|  |                $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 |  |                $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
											
												
													
														|  |                $is_drop = ($num_results != 0) ? "DROP INDEX `" . $key_name . "`, " : "";
 |  |                $is_drop = ($num_results != 0) ? "DROP INDEX `" . $key_name . "`, " : "";
 | 
											
										
											
												
													
														|  | @@ -942,7 +942,7 @@ function init_db_schema() {
 | 
											
												
													
														|  |            }
 |  |            }
 | 
											
												
													
														|  |            if (strtolower($key_type) == 'fkey') {
 |  |            if (strtolower($key_type) == 'fkey') {
 | 
											
												
													
														|  |              foreach ($key_content as $key_name => $key_values) {
 |  |              foreach ($key_content as $key_name => $key_values) {
 | 
											
												
													
														|  | -              $fields = "`" . implode("`, `", $key_values) . "`";
 |  | 
 | 
											
												
													
														|  | 
 |  | +              $fields = "`" . implode("`, `", $key_values) . "`"; 
 | 
											
												
													
														|  |                $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE Key_name = '" . $key_name . "'");
 |  |                $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE Key_name = '" . $key_name . "'");
 | 
											
												
													
														|  |                $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 |  |                $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
											
												
													
														|  |                if ($num_results != 0) {
 |  |                if ($num_results != 0) {
 | 
											
										
											
												
													
														|  | @@ -955,8 +955,8 @@ function init_db_schema() {
 | 
											
												
													
														|  |            }
 |  |            }
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |          // Drop all vanished columns
 |  |          // Drop all vanished columns
 | 
											
												
													
														|  | -        $stmt = $pdo->query("SHOW COLUMNS FROM `" . $table . "`");
 |  | 
 | 
											
												
													
														|  | -        $cols_in_table = $stmt->fetchAll(PDO::FETCH_ASSOC);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        $stmt = $pdo->query("SHOW COLUMNS FROM `" . $table . "`"); 
 | 
											
												
													
														|  | 
 |  | +        $cols_in_table = $stmt->fetchAll(PDO::FETCH_ASSOC); 
 | 
											
												
													
														|  |          while ($row = array_shift($cols_in_table)) {
 |  |          while ($row = array_shift($cols_in_table)) {
 | 
											
												
													
														|  |            if (!array_key_exists($row['Field'], $properties['cols'])) {
 |  |            if (!array_key_exists($row['Field'], $properties['cols'])) {
 | 
											
												
													
														|  |              $pdo->query("ALTER TABLE `" . $table . "` DROP COLUMN `" . $row['Field'] . "`;");
 |  |              $pdo->query("ALTER TABLE `" . $table . "` DROP COLUMN `" . $row['Field'] . "`;");
 | 
											
										
											
												
													
														|  | @@ -964,8 +964,8 @@ function init_db_schema() {
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // Step 1: Get all non-primary keys, that currently exist and those that should exist
 |  |          // Step 1: Get all non-primary keys, that currently exist and those that should exist
 | 
											
												
													
														|  | -        $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE `Key_name` != 'PRIMARY'");
 |  | 
 | 
											
												
													
														|  | -        $keys_in_table = $stmt->fetchAll(PDO::FETCH_ASSOC);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE `Key_name` != 'PRIMARY'"); 
 | 
											
												
													
														|  | 
 |  | +        $keys_in_table = $stmt->fetchAll(PDO::FETCH_ASSOC); 
 | 
											
												
													
														|  |          $keys_to_exist = array();
 |  |          $keys_to_exist = array();
 | 
											
												
													
														|  |          if (isset($properties['keys']['unique']) && is_array($properties['keys']['unique'])) {
 |  |          if (isset($properties['keys']['unique']) && is_array($properties['keys']['unique'])) {
 | 
											
												
													
														|  |            foreach ($properties['keys']['unique'] as $key_name => $key_values) {
 |  |            foreach ($properties['keys']['unique'] as $key_name => $key_values) {
 | 
											
										
											
												
													
														|  | @@ -991,7 +991,7 @@ function init_db_schema() {
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |          // Step 3: Drop all vanished primary keys
 |  |          // Step 3: Drop all vanished primary keys
 | 
											
												
													
														|  |          if (!isset($properties['keys']['primary'])) {
 |  |          if (!isset($properties['keys']['primary'])) {
 | 
											
												
													
														|  | -          $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE Key_name = 'PRIMARY'");
 |  | 
 | 
											
												
													
														|  | 
 |  | +          $stmt = $pdo->query("SHOW KEYS FROM `" . $table . "` WHERE Key_name = 'PRIMARY'"); 
 | 
											
												
													
														|  |            $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 |  |            $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
											
												
													
														|  |            if ($num_results != 0) {
 |  |            if ($num_results != 0) {
 | 
											
												
													
														|  |              $pdo->query("ALTER TABLE `" . $table . "` DROP PRIMARY KEY");
 |  |              $pdo->query("ALTER TABLE `" . $table . "` DROP PRIMARY KEY");
 | 
											
										
											
												
													
														|  | @@ -1050,8 +1050,8 @@ function init_db_schema() {
 | 
											
												
													
														|  |      // Create events to clean database
 |  |      // Create events to clean database
 | 
											
												
													
														|  |      $events[] = 'DROP EVENT IF EXISTS clean_spamalias;
 |  |      $events[] = 'DROP EVENT IF EXISTS clean_spamalias;
 | 
											
												
													
														|  |  DELIMITER //
 |  |  DELIMITER //
 | 
											
												
													
														|  | -CREATE EVENT clean_spamalias
 |  | 
 | 
											
												
													
														|  | -ON SCHEDULE EVERY 1 DAY DO
 |  | 
 | 
											
												
													
														|  | 
 |  | +CREATE EVENT clean_spamalias 
 | 
											
												
													
														|  | 
 |  | +ON SCHEDULE EVERY 1 DAY DO 
 | 
											
												
													
														|  |  BEGIN
 |  |  BEGIN
 | 
											
												
													
														|  |    DELETE FROM spamalias WHERE validity < UNIX_TIMESTAMP();
 |  |    DELETE FROM spamalias WHERE validity < UNIX_TIMESTAMP();
 | 
											
												
													
														|  |  END;
 |  |  END;
 | 
											
										
											
												
													
														|  | @@ -1059,8 +1059,8 @@ END;
 | 
											
												
													
														|  |  DELIMITER ;';
 |  |  DELIMITER ;';
 | 
											
												
													
														|  |      $events[] = 'DROP EVENT IF EXISTS clean_oauth2;
 |  |      $events[] = 'DROP EVENT IF EXISTS clean_oauth2;
 | 
											
												
													
														|  |  DELIMITER //
 |  |  DELIMITER //
 | 
											
												
													
														|  | -CREATE EVENT clean_oauth2
 |  | 
 | 
											
												
													
														|  | -ON SCHEDULE EVERY 1 DAY DO
 |  | 
 | 
											
												
													
														|  | 
 |  | +CREATE EVENT clean_oauth2 
 | 
											
												
													
														|  | 
 |  | +ON SCHEDULE EVERY 1 DAY DO 
 | 
											
												
													
														|  |  BEGIN
 |  |  BEGIN
 | 
											
												
													
														|  |    DELETE FROM oauth_refresh_tokens WHERE expires < NOW();
 |  |    DELETE FROM oauth_refresh_tokens WHERE expires < NOW();
 | 
											
												
													
														|  |    DELETE FROM oauth_access_tokens WHERE expires < NOW();
 |  |    DELETE FROM oauth_access_tokens WHERE expires < NOW();
 | 
											
										
											
												
													
														|  | @@ -1073,7 +1073,7 @@ DELIMITER ;';
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      // Inject admin if not exists
 |  |      // Inject admin if not exists
 | 
											
												
													
														|  | -    $stmt = $pdo->query("SELECT NULL FROM `admin`");
 |  | 
 | 
											
												
													
														|  | 
 |  | +    $stmt = $pdo->query("SELECT NULL FROM `admin`"); 
 | 
											
												
													
														|  |      $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 |  |      $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
											
												
													
														|  |      if ($num_results == 0) {
 |  |      if ($num_results == 0) {
 | 
											
												
													
														|  |      $stmt = $pdo->query("INSERT INTO `admin` (`username`, `password`, `superadmin`, `created`, `modified`, `active`)
 |  |      $stmt = $pdo->query("INSERT INTO `admin` (`username`, `password`, `superadmin`, `created`, `modified`, `active`)
 | 
											
										
											
												
													
														|  | @@ -1084,7 +1084,7 @@ DELIMITER ;';
 | 
											
												
													
														|  |      $stmt = $pdo->query("DELETE FROM `admin` WHERE `username` NOT IN  (SELECT `username` FROM `domain_admins`);");
 |  |      $stmt = $pdo->query("DELETE FROM `admin` WHERE `username` NOT IN  (SELECT `username` FROM `domain_admins`);");
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |      // Insert new DB schema version
 |  |      // Insert new DB schema version
 | 
											
												
													
														|  | -    $stmt = $pdo->query("REPLACE INTO `versions` (`application`, `version`) VALUES ('db_schema', '" . $db_version . "');");
 |  | 
 | 
											
												
													
														|  | 
 |  | +    $stmt = $pdo->query("REPLACE INTO `versions` (`application`, `version`) VALUES ('db_schema', '" . $db_version . "');"); 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      // Migrate attributes
 |  |      // Migrate attributes
 | 
											
												
													
														|  |      $stmt = $pdo->query("UPDATE `mailbox` SET `attributes` = '{}' WHERE `attributes` = '' OR `attributes` IS NULL;");
 |  |      $stmt = $pdo->query("UPDATE `mailbox` SET `attributes` = '{}' WHERE `attributes` = '' OR `attributes` IS NULL;");
 |