|  | @@ -3,7 +3,7 @@ function init_db_schema() {
 | 
	
		
			
				|  |  |    try {
 | 
	
		
			
				|  |  |      global $pdo;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    $db_version = "16092020_1200";
 | 
	
		
			
				|  |  | +    $db_version = "20092020_2000";
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      $stmt = $pdo->query("SHOW TABLES LIKE 'versions'");
 | 
	
		
			
				|  |  |      $num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
 | 
	
	
		
			
				|  | @@ -1149,17 +1149,17 @@ function init_db_schema() {
 | 
	
		
			
				|  |  |      // Migrate attributes
 | 
	
		
			
				|  |  |      // pushover
 | 
	
		
			
				|  |  |      $pdo->query("UPDATE `pushover` SET `attributes` = '{}' WHERE `attributes` = '' OR `attributes` IS NULL;");
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `pushover` SET `attributes` =  JSON_SET(`attributes`, '$.evaluate_x_prio', \"0\") WHERE JSON_EXTRACT(`attributes`, '$.evaluate_x_prio') IS NULL;");
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `pushover` SET `attributes` =  JSON_SET(`attributes`, '$.only_x_prio', \"0\") WHERE JSON_EXTRACT(`attributes`, '$.only_x_prio') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `pushover` SET `attributes` =  JSON_SET(`attributes`, '$.evaluate_x_prio', \"0\") WHERE JSON_VALUE(`attributes`, '$.evaluate_x_prio') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `pushover` SET `attributes` =  JSON_SET(`attributes`, '$.only_x_prio', \"0\") WHERE JSON_VALUE(`attributes`, '$.only_x_prio') IS NULL;");
 | 
	
		
			
				|  |  |      // mailbox
 | 
	
		
			
				|  |  |      $pdo->query("UPDATE `mailbox` SET `attributes` = '{}' WHERE `attributes` = '' OR `attributes` IS NULL;");
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.force_pw_update', \"0\") WHERE JSON_EXTRACT(`attributes`, '$.force_pw_update') IS NULL;");
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.sogo_access', \"1\") WHERE JSON_EXTRACT(`attributes`, '$.sogo_access') IS NULL;");
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.imap_access', \"1\") WHERE JSON_EXTRACT(`attributes`, '$.imap_access') IS NULL;");
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.pop3_access', \"1\") WHERE JSON_EXTRACT(`attributes`, '$.pop3_access') IS NULL;");
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.smtp_access', \"1\") WHERE JSON_EXTRACT(`attributes`, '$.smtp_access') IS NULL;");
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.mailbox_format', \"maildir:\") WHERE JSON_EXTRACT(`attributes`, '$.mailbox_format') IS NULL;");
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.quarantine_notification', \"never\") WHERE JSON_EXTRACT(`attributes`, '$.quarantine_notification') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.force_pw_update', \"0\") WHERE JSON_VALUE(`attributes`, '$.force_pw_update') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.sogo_access', \"1\") WHERE JSON_VALUE(`attributes`, '$.sogo_access') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.imap_access', \"1\") WHERE JSON_VALUE(`attributes`, '$.imap_access') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.pop3_access', \"1\") WHERE JSON_VALUE(`attributes`, '$.pop3_access') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.smtp_access', \"1\") WHERE JSON_VALUE(`attributes`, '$.smtp_access') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.mailbox_format', \"maildir:\") WHERE JSON_VALUE(`attributes`, '$.mailbox_format') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.quarantine_notification', \"never\") WHERE JSON_VALUE(`attributes`, '$.quarantine_notification') IS NULL;");
 | 
	
		
			
				|  |  |      foreach($tls_options as $tls_user => $tls_options) {
 | 
	
		
			
				|  |  |        $stmt = $pdo->prepare("UPDATE `mailbox` SET `attributes` = JSON_SET(`attributes`, '$.tls_enforce_in', :tls_enforce_in),
 | 
	
		
			
				|  |  |          `attributes` = JSON_SET(`attributes`, '$.tls_enforce_out', :tls_enforce_out)
 | 
	
	
		
			
				|  | @@ -1167,8 +1167,8 @@ function init_db_schema() {
 | 
	
		
			
				|  |  |        $stmt->execute(array(':tls_enforce_in' => $tls_options['tls_enforce_in'], ':tls_enforce_out' => $tls_options['tls_enforce_out'], ':username' => $tls_user));
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |      // Set tls_enforce_* if still missing (due to deleted attrs for example)
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.tls_enforce_out', \"1\") WHERE JSON_EXTRACT(`attributes`, '$.tls_enforce_out') IS NULL;");
 | 
	
		
			
				|  |  | -    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.tls_enforce_in', \"1\") WHERE JSON_EXTRACT(`attributes`, '$.tls_enforce_in') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.tls_enforce_out', \"1\") WHERE JSON_VALUE(`attributes`, '$.tls_enforce_out') IS NULL;");
 | 
	
		
			
				|  |  | +    $pdo->query("UPDATE `mailbox` SET `attributes` =  JSON_SET(`attributes`, '$.tls_enforce_in', \"1\") WHERE JSON_VALUE(`attributes`, '$.tls_enforce_in') IS NULL;");
 | 
	
		
			
				|  |  |      // Fix ACL
 | 
	
		
			
				|  |  |      $pdo->query("INSERT INTO `user_acl` (`username`) SELECT `username` FROM `mailbox` WHERE `kind` = '' AND NOT EXISTS (SELECT `username` FROM `user_acl`);");
 | 
	
		
			
				|  |  |      $pdo->query("INSERT INTO `da_acl` (`username`) SELECT DISTINCT `username` FROM `domain_admins` WHERE `username` != 'admin' AND NOT EXISTS (SELECT `username` FROM `da_acl`);");
 |