|
| 1 | +<?php |
| 2 | + |
| 3 | +use wcf\system\condition\ConditionHandler; |
| 4 | +use wcf\system\WCF; |
| 5 | +use wcf\util\JSON; |
| 6 | + |
| 7 | +$exportedConditions = ConditionHandler::getInstance()->exportConditions("com.woltlab.wcf.condition.userGroupAssignment"); |
| 8 | +if ($exportedConditions === []) { |
| 9 | + return; |
| 10 | +} |
| 11 | + |
| 12 | +$sql = "UPDATE wcf1_user_group_assignment |
| 13 | + SET conditions = ?, |
| 14 | + isLegacy = ? |
| 15 | + WHERE assignmentID = ?"; |
| 16 | +$statement = WCF::getDB()->prepare($sql); |
| 17 | +foreach ($exportedConditions as $assignmentID => $conditionData) { |
| 18 | + renameObjectTypes($conditionData); |
| 19 | + |
| 20 | + $statement->execute([ |
| 21 | + JSON::encode($conditionData), |
| 22 | + 1, |
| 23 | + $assignmentID, |
| 24 | + ]); |
| 25 | +} |
| 26 | + |
| 27 | +/** |
| 28 | + * Rename the object types so that the migration functions can handle them. |
| 29 | + * @see \wcf\system\condition\provider\UserConditionProvider |
| 30 | + * |
| 31 | + * @param array<string, mixed> $conditionData |
| 32 | + */ |
| 33 | +function renameObjectTypes(array &$conditionData): void |
| 34 | +{ |
| 35 | + $objectTypeMap = [ |
| 36 | + 'com.woltlab.wcf.username' => 'com.woltlab.wcf.user.username', |
| 37 | + 'com.woltlab.wcf.email' => 'com.woltlab.wcf.user.email', |
| 38 | + 'com.woltlab.wcf.userGroup' => 'com.woltlab.wcf.user.userGroup', |
| 39 | + 'com.woltlab.wcf.languages' => 'com.woltlab.wcf.user.languages', |
| 40 | + 'com.woltlab.wcf.registrationDate' => 'com.woltlab.wcf.user.registrationDate', |
| 41 | + 'com.woltlab.wcf.registrationDateInterval' => 'com.woltlab.wcf.user.registrationDateInterval', |
| 42 | + 'com.woltlab.wcf.avatar' => 'com.woltlab.wcf.user.avatar', |
| 43 | + 'com.woltlab.wcf.signature' => 'com.woltlab.wcf.user.signature', |
| 44 | + 'com.woltlab.wcf.coverPhoto' => 'com.woltlab.wcf.user.coverPhoto', |
| 45 | + 'com.woltlab.wcf.state' => 'com.woltlab.wcf.user.state', |
| 46 | + 'com.woltlab.wcf.activityPoints' => 'com.woltlab.wcf.user.activityPoints', |
| 47 | + 'com.woltlab.wcf.likesReceived' => 'com.woltlab.wcf.user.likesReceived', |
| 48 | + // TODO 'com.woltlab.wcf.userOptions' |
| 49 | + 'com.woltlab.wcf.userTrophyCondition' => 'com.woltlab.wcf.user.trophyCondition', |
| 50 | + 'com.woltlab.wcf.trophyPoints' => 'com.woltlab.wcf.user.trophyPoints', |
| 51 | + ]; |
| 52 | + |
| 53 | + foreach ($objectTypeMap as $currentName => $newName) { |
| 54 | + if (isset($conditionData[$currentName])) { |
| 55 | + $conditionData[$newName] = $conditionData[$currentName]; |
| 56 | + unset($conditionData[$currentName]); |
| 57 | + } |
| 58 | + } |
| 59 | +} |
0 commit comments