Skip to content

Commit

Permalink
Merge branch '4.4-dev' into 5.0/upmerge/300923
Browse files Browse the repository at this point in the history
# Conflicts:
#	administrator/components/com_joomlaupdate/src/Model/UpdateModel.php
#	administrator/language/en-GB/com_joomlaupdate.ini
#	administrator/manifests/files/joomla.xml
#	composer.json
#	composer.lock
#	libraries/src/Event/MultiFactor/BeforeDisplayMethods.php
#	libraries/src/Event/MultiFactor/Callback.php
#	libraries/src/Event/MultiFactor/Captive.php
#	libraries/src/Event/MultiFactor/GetSetup.php
#	libraries/src/Event/MultiFactor/SaveSetup.php
#	libraries/src/Event/MultiFactor/Validate.php
#	libraries/src/Event/QuickIcon/GetIconEvent.php
#	libraries/src/Event/Result/ResultAware.php
#	libraries/src/Event/Table/AbstractEvent.php
#	libraries/src/Event/Table/AfterLoadEvent.php
#	libraries/src/Event/Table/AfterMoveEvent.php
#	libraries/src/Event/Table/AfterReorderEvent.php
#	libraries/src/Event/Table/AfterStoreEvent.php
#	libraries/src/Event/Table/BeforeBindEvent.php
#	libraries/src/Event/Table/BeforeCheckoutEvent.php
#	libraries/src/Event/Table/BeforeLoadEvent.php
#	libraries/src/Event/Table/BeforeMoveEvent.php
#	libraries/src/Event/Table/BeforePublishEvent.php
#	libraries/src/Event/Table/BeforeReorderEvent.php
#	libraries/src/Event/Table/BeforeStoreEvent.php
#	libraries/src/Event/Table/SetNewTagsEvent.php
#	libraries/src/Event/WebAsset/WebAssetRegistryAssetChanged.php
#	libraries/src/Helper/TagsHelper.php
#	libraries/src/MVC/Model/Exception/ModelExceptionInterface.php
#	libraries/src/Version.php
#	plugins/system/debug/src/DataCollector/SessionCollector.php
#	tests/System/integration/administrator/components/com_privacy/Consent.cy.js
#	tests/System/integration/administrator/components/com_users/Groups.cy.js
#	tests/System/integration/administrator/components/com_users/Levels.cy.js
#	tests/System/integration/api/com_config/Application.cy.js
  • Loading branch information
HLeithner committed Sep 30, 2023
2 parents c55a187 + 8871a7b commit 0719930
Show file tree
Hide file tree
Showing 32 changed files with 178 additions and 118 deletions.
59 changes: 31 additions & 28 deletions administrator/components/com_joomlaupdate/src/Model/UpdateModel.php
Original file line number Diff line number Diff line change
Expand Up @@ -968,9 +968,9 @@ public function upload()

// Check the uploaded file (throws RuntimeException when a check failed)
if (\extension_loaded('zip')) {
$this->checkPackageFileZip($userfile['tmp_name']);
$this->checkPackageFileZip($userfile['tmp_name'], $userfile['name']);
} else {
$this->checkPackageFileNoZip($userfile['tmp_name']);
$this->checkPackageFileNoZip($userfile['tmp_name'], $userfile['name']);
}

// Build the appropriate paths.
Expand Down Expand Up @@ -1790,64 +1790,66 @@ public function collectError(string $context, \Throwable $error)
/**
* Check the update package with ZipArchive class from zip PHP extension
*
* @param string $filePath Full path to the update package to test
* @param string $filePath Full path to the uploaded update package (temporary file) to test
* @param string $packageName Name of the selected update package
*
* @return void
*
* @since 5.0.0
* @since 4.4.0
* @throws \RuntimeException
*/
private function checkPackageFileZip(string $filePath)
private function checkPackageFileZip(string $filePath, $packageName)
{
$zipArchive = new \ZipArchive();

if ($zipArchive->open($filePath) !== true) {
throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN', $packageName), 500);
}

if ($zipArchive->locateName('installation/index.php') !== false) {
throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_INSTALL_PACKAGE'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_INSTALL_PACKAGE', $packageName), 500);
}

$manifestFile = $zipArchive->getFromName('administrator/manifests/files/joomla.xml');

if ($manifestFile === false) {
throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_MANIFEST_FILE'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_MANIFEST_FILE', $packageName), 500);
}

$this->checkManifestXML($manifestFile);
$this->checkManifestXML($manifestFile, $packageName);
}

/**
* Check the update package without using the ZipArchive class from zip PHP extension
*
* @param string $filePath Full path to the update package to test
* @param string $filePath Full path to the uploaded update package (temporary file) to test
* @param string $packageName Name of the selected update package
*
* @return void
*
* @see https://pkware.cachefly.net/webdocs/casestudies/APPNOTE.TXT
* @since 5.0.0
* @since 4.4.0
* @throws \RuntimeException
*/
private function checkPackageFileNoZip(string $filePath)
private function checkPackageFileNoZip(string $filePath, $packageName)
{
// The file must exist and be readable
if (!file_exists($filePath) || !is_readable($filePath)) {
throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN', $packageName), 500);
}

// The file must be at least 1KiB (anything less is not even a real file!)
$filesize = filesize($filePath);

if ($filesize < 1024) {
throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN', $packageName), 500);
}

// Open the file
$fp = @fopen($filePath, 'rb');

if ($fp === false) {
throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN', $packageName), 500);
}

// Read chunks of max. 1MiB size
Expand All @@ -1874,7 +1876,7 @@ private function checkPackageFileNoZip(string $filePath)
if ($fileChunk === false || strlen($fileChunk) !== $readsize) {
@fclose($fp);

throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN', $packageName), 500);
}

$posFirstHeader = strpos($fileChunk, $headerSignature);
Expand All @@ -1893,7 +1895,7 @@ private function checkPackageFileNoZip(string $filePath)
if (substr($fileChunk, $pos - 46, 4) == $headerSignature && substr($fileChunk, $pos - 18, 2) == $sizeSignatureIndexPhp) {
@fclose($fp);

throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_INSTALL_PACKAGE'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_INSTALL_PACKAGE', $packageName), 500);
}

$offset = $pos + 22;
Expand Down Expand Up @@ -1928,14 +1930,14 @@ private function checkPackageFileNoZip(string $filePath)
if (!$headerFound) {
@fclose($fp);

throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN', $packageName), 500);
}

// If no central directory file header found for the manifest XML file it's not a valid Joomla package
if (!$headerInfo) {
@fclose($fp);

throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_MANIFEST_FILE'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_MANIFEST_FILE', $packageName), 500);
}

// Read the local file header of the manifest XML file
Expand All @@ -1948,7 +1950,7 @@ private function checkPackageFileNoZip(string $filePath)
if (!$localHeaderInfo['Compressed']) {
@fclose($fp);

throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_MANIFEST_FILE'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_MANIFEST_FILE', $packageName), 500);
}

// Read the compressed manifest XML file content
Expand Down Expand Up @@ -1978,34 +1980,35 @@ private function checkPackageFileNoZip(string $filePath)
}

if (!$manifestFile) {
throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_MANIFEST_FILE'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_MANIFEST_FILE', $packageName), 500);
}

$this->checkManifestXML($manifestFile);
$this->checkManifestXML($manifestFile, $packageName);
}

/**
* Check content of manifest XML file in update package
*
* @param string $manifest Content of the manifest XML file
* @param string $manifest Content of the manifest XML file
* @param string $packageName Name of the selected update package
*
* @return void
*
* @since 5.0.0
* @since 4.4.0
* @throws \RuntimeException
*/
private function checkManifestXML(string $manifest)
private function checkManifestXML(string $manifest, $packageName)
{
$manifestXml = simplexml_load_string($manifest);

if (!$manifestXml) {
throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_VERSION_FOUND'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_VERSION_FOUND', $packageName), 500);
}

$versionPackage = (string) $manifestXml->version ?: '';

if (!$versionPackage) {
throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_VERSION_FOUND'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_VERSION_FOUND', $packageName), 500);
}

$currentVersion = JVERSION;
Expand All @@ -2016,7 +2019,7 @@ private function checkManifestXML(string $manifest)
}

if (version_compare($versionPackage, $currentVersion, 'lt')) {
throw new \RuntimeException(Text::_('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_DOWNGRADE'), 500);
throw new \RuntimeException(Text::sprintf('COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_DOWNGRADE', $packageName, $versionPackage, $currentVersion), 500);
}
}
}
16 changes: 9 additions & 7 deletions administrator/components/com_users/src/Model/UsersModel.php
Original file line number Diff line number Diff line change
Expand Up @@ -365,10 +365,7 @@ protected function getListQuery()
$groups = $this->getState('filter.groups');

if ($groupId || isset($groups)) {
$query->join('LEFT', '#__user_usergroup_map AS map2 ON map2.user_id = a.id')
->group(
$db->quoteName(
[
$group_by = [
'a.id',
'a.name',
'a.username',
Expand All @@ -385,9 +382,14 @@ protected function getListQuery()
'a.otpKey',
'a.otep',
'a.requireReset',
]
)
);
];

if (PluginHelper::isEnabled('multifactorauth')) {
$group_by[] = 'mfa.mfaRecords';
}

$query->join('LEFT', '#__user_usergroup_map AS map2 ON map2.user_id = a.id')
->group($db->quoteName($group_by));

if ($groupId) {
$groupId = (int) $groupId;
Expand Down
10 changes: 5 additions & 5 deletions administrator/language/en-GB/com_joomlaupdate.ini
Original file line number Diff line number Diff line change
Expand Up @@ -179,11 +179,11 @@ COM_JOOMLAUPDATE_VIEW_UPDATE_FINALISE_HEAD_DESC="To complete the update Process
COM_JOOMLAUPDATE_VIEW_UPDATE_PERCENT="Percent complete"
COM_JOOMLAUPDATE_VIEW_UPLOAD_CAPTIVE_INTRO_BODY="Make sure that the update file you have uploaded comes from the official Joomla download page. Afterwards, please confirm that you want to install it by re-entering the login information for your site &quot;%s&quot; below."
COM_JOOMLAUPDATE_VIEW_UPLOAD_CAPTIVE_INTRO_HEAD="Are you sure you want to install the file you uploaded?"
COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_DOWNGRADE="The update package file has a lower version than the current Joomla version. You cannot downgrade a Joomla site."
COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_INSTALL_PACKAGE="The uploaded package file looks like it is a full installation package of Joomla which can only be used for creating new sites. You can only use the \"Upgrade Package (.zip)\" to update your site."
COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_MANIFEST_FILE="The uploaded package file is not a Joomla update package. It does not contain the \"administrator/manifests/files/joomla.xml\" file."
COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_VERSION_FOUND="The uploaded package file is not a Joomla update package. It does not contain valid version information."
COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN="The uploaded package file is either not a ZIP file or is corrupted."
COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_DOWNGRADE="The uploaded package file \"%1$s\" has a lower version \"%2$s\" than the installed version \"%3$s\". You cannot downgrade a Joomla site.<br>Check <a class=\"alert-link\" href=\"https://downloads.joomla.org/latest\" target=\"_blank\" rel=\"noopener noreferrer\">the official Joomla download page</a> for the Joomla Upgrade Package of a <em><strong>newer version</strong></em>."
COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_INSTALL_PACKAGE="The uploaded package file \"%s\" looks like it is a full installation package of Joomla which can only be used for creating new sites. You can only use the <em><strong>Upgrade Package</strong></em> to update your site.<br>Check <a class=\"alert-link\" href=\"https://downloads.joomla.org/latest\" target=\"_blank\" rel=\"noopener noreferrer\">the official Joomla download page</a> for the Joomla <em><strong>Upgrade Package</strong></em> of the right version."
COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_MANIFEST_FILE="The uploaded package file \"%s\" is not a Joomla update package. It does not contain the \"administrator/manifests/files/joomla.xml\" file.<br>Check <a class=\"alert-link\" href=\"https://downloads.joomla.org/latest\" target=\"_blank\" rel=\"noopener noreferrer\">the official Joomla download page</a> for the right Joomla <em><strong>Upgrade Package</strong></em>."
COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_NO_VERSION_FOUND="The uploaded package file \"%s\" is not a Joomla update package. It does not contain valid version information.<br>Check <a class=\"alert-link\" href=\"https://downloads.joomla.org/latest\" target=\"_blank\" rel=\"noopener noreferrer\">the official Joomla download page</a> for the right Joomla <em><strong>Upgrade Package</strong></em>."
COM_JOOMLAUPDATE_VIEW_UPLOAD_ERROR_PACKAGE_OPEN="The uploaded package file \"%s\" is either not a ZIP file or is corrupted.<br>Check <a class=\"alert-link\" href=\"https://downloads.joomla.org/latest\" target=\"_blank\" rel=\"noopener noreferrer\">the official Joomla download page</a> for the desired Joomla <em><strong>Upgrade Package in ZIP format</strong></em>."
COM_JOOMLAUPDATE_VIEW_UPLOAD_PACKAGE_FILE="Joomla package file"
COM_JOOMLAUPDATE_XML_DESCRIPTION="Updates Joomla to the latest version with one click."

Expand Down
4 changes: 2 additions & 2 deletions libraries/src/Event/MultiFactor/BeforeDisplayMethods.php
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ public function __construct(User $user)
* @return User
* @since 4.2.0
*
* @deprecated 5.0.0 will be removed in 6.0
* @deprecated 4.4.0 will be removed in 6.0
* Use counterpart with onSet prefix
*/
public function setUser(User $value): User
Expand All @@ -64,7 +64,7 @@ public function setUser(User $value): User
* @param User $value The value to validate
*
* @return User
* @since 5.0.0
* @since 4.4.0
*/
protected function onSetUser(User $value): User
{
Expand Down
4 changes: 2 additions & 2 deletions libraries/src/Event/MultiFactor/Callback.php
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ public function __construct(string $method)
* @throws \DomainException
* @since 4.2.0
*
* @deprecated 5.0.0 will be removed in 6.0
* @deprecated 4.4.0 will be removed in 6.0
* Use counterpart with onSet prefix
*/
public function setMethod(string $value): string
Expand All @@ -62,7 +62,7 @@ public function setMethod(string $value): string
*
* @return string
* @throws \DomainException
* @since 5.0.0
* @since 4.4.0
*/
protected function onSetMethod(string $value): string
{
Expand Down
4 changes: 2 additions & 2 deletions libraries/src/Event/MultiFactor/Captive.php
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ public function __construct(MfaTable $record)
* @return MfaTable
* @since 4.2.0
*
* @deprecated 5.0.0 will be removed in 6.0
* @deprecated 4.4.0 will be removed in 6.0
* Use counterpart with onSet prefix
*/
public function setRecord(MfaTable $value): MfaTable
Expand All @@ -73,7 +73,7 @@ public function setRecord(MfaTable $value): MfaTable
* @param MfaTable $value The value to validate
*
* @return MfaTable
* @since 5.0.0
* @since 4.4.0
*/
protected function onSetRecord(MfaTable $value): MfaTable
{
Expand Down
4 changes: 2 additions & 2 deletions libraries/src/Event/MultiFactor/GetSetup.php
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ public function __construct(MfaTable $record)
* @return MfaTable
* @since 4.2.0
*
* @deprecated 5.0.0 will be removed in 6.0
* @deprecated 4.4.0 will be removed in 6.0
* Use counterpart with onSet prefix
*/
public function setRecord(MfaTable $value): MfaTable
Expand All @@ -73,7 +73,7 @@ public function setRecord(MfaTable $value): MfaTable
* @param MfaTable $value The value to validate
*
* @return MfaTable
* @since 5.0.0
* @since 4.4.0
*/
protected function onSetRecord(MfaTable $value): MfaTable
{
Expand Down
8 changes: 4 additions & 4 deletions libraries/src/Event/MultiFactor/SaveSetup.php
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ public function __construct(MfaTable $record, Input $input)
* @return MfaTable
* @since 4.2.0
*
* @deprecated 5.0.0 will be removed in 6.0
* @deprecated 4.4.0 will be removed in 6.0
* Use counterpart with onSet prefix
*/
public function setRecord(MfaTable $value): MfaTable
Expand All @@ -79,7 +79,7 @@ public function setRecord(MfaTable $value): MfaTable
* @return Input
* @since 4.2.0
*
* @deprecated 5.0.0 will be removed in 6.0
* @deprecated 4.4.0 will be removed in 6.0
* Use counterpart with onSet prefix
*/
public function setInput(Input $value): Input
Expand All @@ -97,7 +97,7 @@ public function setInput(Input $value): Input
* @param MfaTable $value The value to validate
*
* @return MfaTable
* @since 5.0.0
* @since 4.4.0
*/
protected function onSetRecord(MfaTable $value): MfaTable
{
Expand All @@ -110,7 +110,7 @@ protected function onSetRecord(MfaTable $value): MfaTable
* @param Input $value The value to validate
*
* @return Input
* @since 5.0.0
* @since 4.4.0
*/
protected function onSetInput(Input $value): Input
{
Expand Down
12 changes: 6 additions & 6 deletions libraries/src/Event/MultiFactor/Validate.php
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ public function __construct(MfaTable $record, User $user, string $code)
* @return MfaTable
* @since 4.2.0
*
* @deprecated 5.0.0 will be removed in 6.0
* @deprecated 4.4.0 will be removed in 6.0
* Use counterpart with onSet prefix
*/
public function setRecord(MfaTable $value): MfaTable
Expand All @@ -79,7 +79,7 @@ public function setRecord(MfaTable $value): MfaTable
* @return User
* @since 4.2.0
*
* @deprecated 5.0.0 will be removed in 6.0
* @deprecated 4.4.0 will be removed in 6.0
* Use counterpart with onSet prefix
*/
public function setUser(User $value): User
Expand All @@ -99,7 +99,7 @@ public function setUser(User $value): User
* @return string|null
* @since 4.2.0
*
* @deprecated 5.0.0 will be removed in 6.0
* @deprecated 4.4.0 will be removed in 6.0
* Use counterpart with onSet prefix
*/
public function setCode(?string $value): ?string
Expand All @@ -114,7 +114,7 @@ public function setCode(?string $value): ?string
* @param MfaTable $value The value to validate
*
* @return MfaTable
* @since 5.0.0
* @since 4.4.0
*/
protected function onSetRecord(MfaTable $value): MfaTable
{
Expand All @@ -127,7 +127,7 @@ protected function onSetRecord(MfaTable $value): MfaTable
* @param User $value The value to validate
*
* @return User
* @since 5.0.0
* @since 4.4.0
*/
protected function onSetUser(User $value): User
{
Expand All @@ -140,7 +140,7 @@ protected function onSetUser(User $value): User
* @param string|null $value The value to validate
*
* @return string|null
* @since 5.0.0
* @since 4.4.0
*/
protected function onSetCode(?string $value): ?string
{
Expand Down
Loading

0 comments on commit 0719930

Please sign in to comment.