From 85e7dc4403c176bb268648c66b03c4120f16a5fc Mon Sep 17 00:00:00 2001 From: Arthur Schiwon Date: Thu, 3 Mar 2022 21:19:11 +0100 Subject: be conservative when reading from fresh created column Signed-off-by: Arthur Schiwon --- .../lib/Migration/Version1130Date20211102154716.php | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/apps/user_ldap/lib/Migration/Version1130Date20211102154716.php b/apps/user_ldap/lib/Migration/Version1130Date20211102154716.php index 27f5f5ce504..03106b635bb 100644 --- a/apps/user_ldap/lib/Migration/Version1130Date20211102154716.php +++ b/apps/user_ldap/lib/Migration/Version1130Date20211102154716.php @@ -43,6 +43,8 @@ class Version1130Date20211102154716 extends SimpleMigrationStep { private $dbc; /** @var LoggerInterface */ private $logger; + /** @var string[] */ + private $hashColumnAddedToTables = []; public function __construct(IDBConnection $dbc, LoggerInterface $logger) { $this->dbc = $dbc; @@ -89,6 +91,7 @@ class Version1130Date20211102154716 extends SimpleMigrationStep { 'length' => 64, ]); $changeSchema = true; + $this->hashColumnAddedToTables[] = $tableName; } $column = $table->getColumn('ldap_dn'); if ($tableName === 'ldap_user_mapping') { @@ -177,9 +180,16 @@ class Version1130Date20211102154716 extends SimpleMigrationStep { protected function getSelectQuery(string $table): IQueryBuilder { $qb = $this->dbc->getQueryBuilder(); - $qb->select('owncloud_name', 'ldap_dn', 'ldap_dn_hash') - ->from($table) - ->where($qb->expr()->isNull('ldap_dn_hash')); + $qb->select('owncloud_name', 'ldap_dn') + ->from($table); + + // when added we may run into risk that it's read from a DB node + // where the column is not present. Then the where clause is also + // not necessary since all rows qualify. + if (!in_array($table, $this->hashColumnAddedToTables, true)) { + $qb->where($qb->expr()->isNull('ldap_dn_hash')); + } + return $qb; } -- cgit v1.2.3