summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjld3103 <jld3103yt@gmail.com>2023-07-03 10:05:53 +0200
committerjld3103 <jld3103yt@gmail.com>2023-07-03 18:09:27 +0200
commitcd91b771934c81c8cf0a4ed8724b8584f8593e31 (patch)
tree2a518a3a9e21584fceeb04b2d5b656ed1d13f0d3
parent646dfd2a40aa79b8fed8be314070bb8f629a6edc (diff)
downloadnextcloud-server-cd91b771934c81c8cf0a4ed8724b8584f8593e31.tar.gz
nextcloud-server-cd91b771934c81c8cf0a4ed8724b8584f8593e31.zip
psalm: Enable more/less specific errors
Signed-off-by: jld3103 <jld3103yt@gmail.com>
-rw-r--r--build/psalm-baseline.xml558
-rw-r--r--psalm.xml4
2 files changed, 478 insertions, 84 deletions
diff --git a/build/psalm-baseline.xml b/build/psalm-baseline.xml
index 59132110977..eddbeed05d5 100644
--- a/build/psalm-baseline.xml
+++ b/build/psalm-baseline.xml
@@ -63,6 +63,14 @@
<code>IEventListener</code>
</MissingTemplateParam>
</file>
+ <file src="apps/comments/lib/Notification/Listener.php">
+ <LessSpecificReturnStatement>
+ <code>$uids</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code><![CDATA[list<string>]]></code>
+ </MoreSpecificReturnType>
+ </file>
<file src="apps/contactsinteraction/lib/Listeners/ContactInteractionListener.php">
<MissingTemplateParam>
<code>IEventListener</code>
@@ -89,7 +97,7 @@
</file>
<file src="apps/dav/appinfo/v1/webdav.php">
<InvalidArgument>
- <code>'OCA\DAV\Connector\Sabre::addPlugin'</code>
+ <code><![CDATA['OCA\DAV\Connector\Sabre::addPlugin']]></code>
</InvalidArgument>
<TooManyArguments>
<code>dispatch</code>
@@ -144,11 +152,17 @@
<code>array</code>
<code>array</code>
</InvalidNullableReturnType>
+ <LessSpecificReturnStatement>
+ <code>Reader::read($objectData)</code>
+ </LessSpecificReturnStatement>
<MoreSpecificImplementedParamType>
<code>$objectData</code>
<code>$uris</code>
<code>$uris</code>
</MoreSpecificImplementedParamType>
+ <MoreSpecificReturnType>
+ <code>VCalendar</code>
+ </MoreSpecificReturnType>
<NullableReturnStatement>
<code><![CDATA[$this->atomic(function () use ($calendarId, $syncToken, $syncLevel, $limit, $calendarType) {
// Current synctoken
@@ -268,6 +282,9 @@
</MoreSpecificImplementedParamType>
</file>
<file src="apps/dav/lib/CalDAV/Reminder/NotificationProvider/AbstractProvider.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$vevent->DTEND]]></code>
+ </LessSpecificReturnStatement>
<UndefinedMethod>
<code>hasTime</code>
<code>isFloating</code>
@@ -275,6 +292,12 @@
</UndefinedMethod>
</file>
<file src="apps/dav/lib/CalDAV/Reminder/NotificationProvider/EmailProvider.php">
+ <LessSpecificReturnStatement>
+ <code>$emailAddresses</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code><![CDATA[array<string, array{LANG?: string}>]]></code>
+ </MoreSpecificReturnType>
<UndefinedMethod>
<code>getDateTime</code>
<code>getDateTime</code>
@@ -292,6 +315,15 @@
</TypeDoesNotContainType>
</file>
<file src="apps/dav/lib/CalDAV/Reminder/ReminderService.php">
+ <LessSpecificReturnStatement>
+ <code>$vevents</code>
+ <code>VObject\Reader::read($calendarData,
+ VObject\Reader::OPTION_FORGIVING)</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>VObject\Component\VCalendar|null</code>
+ <code>VObject\Component\VEvent[]</code>
+ </MoreSpecificReturnType>
<UndefinedMethod>
<code>getDateTime</code>
<code>getDateTime</code>
@@ -321,7 +353,7 @@
</RedundantCast>
<RedundantCondition>
<code><![CDATA[!empty($modified['old']) && is_array($modified['old'])]]></code>
- <code>is_array($modified['old'])</code>
+ <code><![CDATA[is_array($modified['old'])]]></code>
</RedundantCondition>
</file>
<file src="apps/dav/lib/CalDAV/Schedule/IMipService.php">
@@ -332,9 +364,12 @@
</file>
<file src="apps/dav/lib/CalDAV/Schedule/Plugin.php">
<InvalidArgument>
- <code>[$aclPlugin, 'propFind']</code>
- <code>[$aclPlugin, 'propFind']</code>
+ <code><![CDATA[[$aclPlugin, 'propFind']]]></code>
+ <code><![CDATA[[$aclPlugin, 'propFind']]]></code>
</InvalidArgument>
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$vevent->DTEND]]></code>
+ </LessSpecificReturnStatement>
<UndefinedInterfaceMethod>
<code>get</code>
<code>getChildren</code>
@@ -365,12 +400,12 @@
</file>
<file src="apps/dav/lib/CalDAV/Search/Xml/Request/CalendarSearchReport.php">
<TypeDoesNotContainType>
- <code>!is_array($newProps['filters']['comps'])</code>
- <code>!is_array($newProps['filters']['params'])</code>
- <code>!is_array($newProps['filters']['props'])</code>
- <code>!isset($newProps['filters']['comps']) || !is_array($newProps['filters']['comps'])</code>
- <code>!isset($newProps['filters']['params']) || !is_array($newProps['filters']['params'])</code>
- <code>!isset($newProps['filters']['props']) || !is_array($newProps['filters']['props'])</code>
+ <code><![CDATA[!is_array($newProps['filters']['comps'])]]></code>
+ <code><![CDATA[!is_array($newProps['filters']['params'])]]></code>
+ <code><![CDATA[!is_array($newProps['filters']['props'])]]></code>
+ <code><![CDATA[!isset($newProps['filters']['comps']) || !is_array($newProps['filters']['comps'])]]></code>
+ <code><![CDATA[!isset($newProps['filters']['params']) || !is_array($newProps['filters']['params'])]]></code>
+ <code><![CDATA[!isset($newProps['filters']['props']) || !is_array($newProps['filters']['props'])]]></code>
</TypeDoesNotContainType>
</file>
<file src="apps/dav/lib/CalDAV/WebcalCaching/RefreshWebcalService.php">
@@ -383,6 +418,12 @@
<code><![CDATA[$this->getKey()]]></code>
<code><![CDATA[$this->getKey()]]></code>
</InvalidArgument>
+ <LessSpecificReturnStatement>
+ <code>Reader::read($cardData)</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>VCard</code>
+ </MoreSpecificReturnType>
</file>
<file src="apps/dav/lib/CardDAV/AddressBookRoot.php">
<ParamNameMismatch>
@@ -393,8 +434,14 @@
<FalsableReturnStatement>
<code>false</code>
</FalsableReturnStatement>
+ <LessSpecificReturnStatement>
+ <code>Reader::read($cardData)</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>VCard</code>
+ </MoreSpecificReturnType>
<TypeDoesNotContainType>
- <code>$addressBooks[$row['id']][$readOnlyPropertyName] === 0</code>
+ <code><![CDATA[$addressBooks[$row['id']][$readOnlyPropertyName] === 0]]></code>
</TypeDoesNotContainType>
</file>
<file src="apps/dav/lib/CardDAV/MultiGetExportPlugin.php">
@@ -406,6 +453,15 @@
<InvalidNullableReturnType>
<code>string</code>
</InvalidNullableReturnType>
+ <LessSpecificReturnStatement>
+ <code><![CDATA[[
+ 'Content-Type' => $type,
+ 'body' => $val
+ ]]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>false|array{body: string, Content-Type: string}</code>
+ </MoreSpecificReturnType>
<NullableReturnStatement>
<code>$type</code>
</NullableReturnStatement>
@@ -452,6 +508,14 @@
<code>bool</code>
</InvalidNullableReturnType>
</file>
+ <file src="apps/dav/lib/Connector/Sabre/Auth.php">
+ <LessSpecificReturnStatement>
+ <code>$data</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>array{bool, string}</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="apps/dav/lib/Connector/Sabre/BearerAuth.php">
<UndefinedInterfaceMethod>
<code>tryTokenLogin</code>
@@ -467,6 +531,12 @@
<InvalidReturnType>
<code>\Sabre\DAV\INode[]</code>
</InvalidReturnType>
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->node]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>Folder</code>
+ </MoreSpecificReturnType>
<NullArgument>
<code>null</code>
<code>null</code>
@@ -477,9 +547,15 @@
</ParamNameMismatch>
</file>
<file src="apps/dav/lib/Connector/Sabre/File.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->node]]></code>
+ </LessSpecificReturnStatement>
<MoreSpecificImplementedParamType>
<code>$data</code>
</MoreSpecificImplementedParamType>
+ <MoreSpecificReturnType>
+ <code>\OCP\Files\File</code>
+ </MoreSpecificReturnType>
</file>
<file src="apps/dav/lib/Connector/Sabre/FilesReportPlugin.php">
<InvalidArgument>
@@ -490,7 +566,7 @@
<code>bool</code>
</InvalidNullableReturnType>
<TooManyArguments>
- <code>new PreconditionFailed('Cannot filter by non-existing tag', 0, $e)</code>
+ <code><![CDATA[new PreconditionFailed('Cannot filter by non-existing tag', 0, $e)]]></code>
</TooManyArguments>
<UndefinedClass>
<code>\OCA\Circles\Api\v1\Circles</code>
@@ -761,8 +837,8 @@
</file>
<file src="apps/dav/lib/Server.php">
<InvalidArgument>
- <code>'OCA\DAV\Connector\Sabre::addPlugin'</code>
- <code>'OCA\DAV\Connector\Sabre::authInit'</code>
+ <code><![CDATA['OCA\DAV\Connector\Sabre::addPlugin']]></code>
+ <code><![CDATA['OCA\DAV\Connector\Sabre::authInit']]></code>
</InvalidArgument>
<TooManyArguments>
<code>dispatch</code>
@@ -820,12 +896,30 @@
<code>getSize</code>
</UndefinedInterfaceMethod>
</file>
+ <file src="apps/dav/lib/UserMigration/ContactsMigrator.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[[
+ 'name' => $addressBookNode->getName(),
+ 'displayName' => $addressBookInfo['{DAV:}displayname'],
+ 'description' => $addressBookInfo['{' . CardDAVPlugin::NS_CARDDAV . '}addressbook-description'],
+ 'vCards' => $vCards,
+ ]]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>array{name: string, displayName: string, description: ?string, vCards: VCard[]}</code>
+ </MoreSpecificReturnType>
+ </file>
+ <file src="apps/encryption/lib/Command/FixKeyLocation.php">
+ <MoreSpecificReturnType>
+ <code><![CDATA[\Generator<File>]]></code>
+ </MoreSpecificReturnType>
+ </file>
<file src="apps/encryption/lib/Crypto/Crypt.php">
<RedundantCondition>
<code>$userSession</code>
</RedundantCondition>
<TypeDoesNotContainType>
- <code>get_class($res) === 'OpenSSLAsymmetricKey'</code>
+ <code><![CDATA[get_class($res) === 'OpenSSLAsymmetricKey']]></code>
</TypeDoesNotContainType>
</file>
<file src="apps/encryption/lib/Crypto/Encryption.php">
@@ -845,10 +939,16 @@
</file>
<file src="apps/encryption/lib/Session.php">
<TooManyArguments>
- <code>new Exceptions\PrivateKeyMissingException('please try to log-out and log-in again', 0)</code>
+ <code><![CDATA[new Exceptions\PrivateKeyMissingException('please try to log-out and log-in again', 0)]]></code>
</TooManyArguments>
</file>
<file src="apps/encryption/lib/Util.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->files->getMount($path)->getStorage()]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>\OC\Files\Storage\Storage|null</code>
+ </MoreSpecificReturnType>
<RedundantCondition>
<code>$userSession</code>
</RedundantCondition>
@@ -870,8 +970,14 @@
<code>$shareId</code>
<code>$shareId</code>
<code>$shareId</code>
- <code>(int)$data['id']</code>
+ <code><![CDATA[(int)$data['id']]]></code>
</InvalidArgument>
+ <LessSpecificReturnStatement>
+ <code>$nodes[0]</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>\OCP\Files\File|\OCP\Files\Folder</code>
+ </MoreSpecificReturnType>
</file>
<file src="apps/federatedfilesharing/lib/Listeners/LoadAdditionalScriptsListener.php">
<MissingTemplateParam>
@@ -899,14 +1005,30 @@
<code>string</code>
</InvalidReturnType>
<InvalidScalarArgument>
- <code>(int)$share['id']</code>
+ <code><![CDATA[(int)$share['id']]]></code>
</InvalidScalarArgument>
</file>
+ <file src="apps/federation/lib/DbHandler.php">
+ <LessSpecificReturnStatement>
+ <code>$result</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code><![CDATA[list<array{id: int, url: string, url_hash: string, shared_secret: ?string, status: int, sync_token: ?string}>]]></code>
+ </MoreSpecificReturnType>
+ </file>
<file src="apps/federation/lib/Listener/SabrePluginAuthInitListener.php">
<MissingTemplateParam>
<code>IEventListener</code>
</MissingTemplateParam>
</file>
+ <file src="apps/federation/lib/TrustedServers.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->dbHandler->getAllServer()]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code><![CDATA[list<array{id: int, url: string, url_hash: string, shared_secret: string, status: int, sync_token: string}>]]></code>
+ </MoreSpecificReturnType>
+ </file>
<file src="apps/files/ajax/download.php">
<InvalidArgument>
<code>$files_list</code>
@@ -916,6 +1038,13 @@
<FalsableReturnStatement>
<code><![CDATA[$this->fileEncrypted[$fileId]]]></code>
</FalsableReturnStatement>
+ <LessSpecificReturnStatement>
+ <code>$folder</code>
+ <code><![CDATA[$this->fileEncrypted[$fileId]]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>Folder</code>
+ </MoreSpecificReturnType>
<TypeDoesNotContainType>
<code><![CDATA[$this->fileIsEncrypted]]></code>
<code><![CDATA[$this->fileIsEncrypted]]></code>
@@ -934,6 +1063,12 @@
</TypeDoesNotContainType>
</file>
<file src="apps/files/lib/Command/ScanAppData.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->root->get('appdata_'.$instanceId)]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>\OCP\Files\Folder</code>
+ </MoreSpecificReturnType>
<NullArgument>
<code>null</code>
<code>null</code>
@@ -1003,7 +1138,7 @@
</file>
<file src="apps/files/lib/Service/TagService.php">
<InvalidArgument>
- <code>self::class . '::' . $eventName</code>
+ <code><![CDATA[self::class . '::' . $eventName]]></code>
</InvalidArgument>
<TooManyArguments>
<code>dispatch</code>
@@ -1025,6 +1160,14 @@
<code>getUniqueStorages</code>
</UndefinedMethod>
</file>
+ <file src="apps/files_external/lib/Lib/Backend/Backend.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->storageClass]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code><![CDATA[class-string<IStorage>]]></code>
+ </MoreSpecificReturnType>
+ </file>
<file src="apps/files_external/lib/Lib/Storage/SFTP.php">
<InternalMethod>
<code>put</code>
@@ -1083,7 +1226,7 @@
</file>
<file src="apps/files_external/lib/Service/BackendService.php">
<InvalidArgument>
- <code>'OCA\\Files_External::loadAdditionalBackends'</code>
+ <code><![CDATA['OCA\\Files_External::loadAdditionalBackends']]></code>
</InvalidArgument>
<TooManyArguments>
<code>dispatch</code>
@@ -1110,6 +1253,14 @@
<code>$files_list</code>
</InvalidArgument>
</file>
+ <file src="apps/files_sharing/lib/External/Manager.php">
+ <LessSpecificReturnStatement>
+ <code>$mount</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>Mount</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="apps/files_sharing/lib/External/Scanner.php">
<MoreSpecificImplementedParamType>
<code>$cacheData</code>
@@ -1198,7 +1349,7 @@
</file>
<file src="apps/files_sharing/templates/public.php">
<RedundantCondition>
- <code>$_['hideFileList'] !== true</code>
+ <code><![CDATA[$_['hideFileList'] !== true]]></code>
<code><![CDATA[isset($_['hideFileList']) && $_['hideFileList'] !== true]]></code>
</RedundantCondition>
</file>
@@ -1246,7 +1397,7 @@
</file>
<file src="apps/files_trashbin/lib/Storage.php">
<InvalidArgument>
- <code>'OCA\Files_Trashbin::moveToTrash'</code>
+ <code><![CDATA['OCA\Files_Trashbin::moveToTrash']]></code>
</InvalidArgument>
<InvalidOperand>
<code><![CDATA[$this->mountPoint]]></code>
@@ -1401,8 +1552,14 @@
<file src="apps/sharebymail/lib/ShareByMailProvider.php">
<InvalidArgument>
<code><![CDATA[$share->getId()]]></code>
- <code>(int)$data['id']</code>
+ <code><![CDATA[(int)$data['id']]]></code>
</InvalidArgument>
+ <LessSpecificReturnStatement>
+ <code>$nodes[0]</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>\OCP\Files\File|\OCP\Files\Folder</code>
+ </MoreSpecificReturnType>
</file>
<file src="apps/systemtags/lib/Activity/Listener.php">
<InvalidArgument>
@@ -1495,7 +1652,7 @@
</file>
<file src="apps/user_ldap/lib/AppInfo/Application.php">
<InvalidArgument>
- <code>'OCA\\User_LDAP\\User\\User::postLDAPBackendAdded'</code>
+ <code><![CDATA['OCA\\User_LDAP\\User\\User::postLDAPBackendAdded']]></code>
</InvalidArgument>
<TooManyArguments>
<code>dispatch</code>
@@ -1802,6 +1959,16 @@
<code>getAllAliases</code>
</UndefinedInterfaceMethod>
</file>
+ <file src="core/Command/Maintenance/RepairShareOwnership.php">
+ <LessSpecificReturnStatement>
+ <code>$found</code>
+ <code>$found</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>array{shareId: int, fileTarget: string, initiator: string, receiver: string, owner: string, mountOwner: string}[]</code>
+ <code>array{shareId: int, fileTarget: string, initiator: string, receiver: string, owner: string, mountOwner: string}[]</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="core/Command/Preview/Repair.php">
<UndefinedInterfaceMethod>
<code>section</code>
@@ -1867,7 +2034,7 @@
</file>
<file src="lib/private/Accounts/AccountManager.php">
<InvalidArgument>
- <code>'OC\AccountManager::userUpdated'</code>
+ <code><![CDATA['OC\AccountManager::userUpdated']]></code>
</InvalidArgument>
<TooManyArguments>
<code>dispatch</code>
@@ -1884,6 +2051,12 @@
<code><![CDATA[$this->providerClasses]]></code>
<code><![CDATA[$this->settingsClasses]]></code>
</InvalidPropertyAssignmentValue>
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->settings]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>ActivitySettings[]</code>
+ </MoreSpecificReturnType>
<TypeDoesNotContainType>
<code><![CDATA[!is_string($currentUserId) && $currentUserId !== null]]></code>
</TypeDoesNotContainType>
@@ -2045,7 +2218,7 @@
</file>
<file src="lib/private/AppFramework/Routing/RouteConfig.php">
<InvalidArrayOffset>
- <code>$action['url-postfix']</code>
+ <code><![CDATA[$action['url-postfix']]]></code>
</InvalidArrayOffset>
</file>
<file src="lib/private/AppFramework/Services/AppConfig.php">
@@ -2054,9 +2227,48 @@
</MoreSpecificImplementedParamType>
</file>
<file src="lib/private/AppFramework/Utility/SimpleContainer.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$class->newInstance()]]></code>
+ <code><![CDATA[$class->newInstanceArgs(array_map(function (ReflectionParameter $parameter) {
+ $parameterType = $parameter->getType();
+
+ $resolveName = $parameter->getName();
+
+ // try to find out if it is a class or a simple parameter
+ if ($parameterType !== null && ($parameterType instanceof ReflectionNamedType) && !$parameterType->isBuiltin()) {
+ $resolveName = $parameterType->getName();
+ }
+
+ try {
+ $builtIn = $parameter->hasType() && ($parameter->getType() instanceof ReflectionNamedType)
+ && $parameter->getType()->isBuiltin();
+ return $this->query($resolveName, !$builtIn);
+ } catch (QueryException $e) {
+ // Service not found, use the default value when available
+ if ($parameter->isDefaultValueAvailable()) {
+ return $parameter->getDefaultValue();
+ }
+
+ if ($parameterType !== null && ($parameterType instanceof ReflectionNamedType) && !$parameterType->isBuiltin()) {
+ $resolveName = $parameter->getName();
+ try {
+ return $this->query($resolveName);
+ } catch (QueryException $e2) {
+ // don't lose the error we got while trying to query by type
+ throw new QueryException($e->getMessage(), (int) $e->getCode(), $e);
+ }
+ }
+
+ throw $e;
+ }
+ }, $constructor->getParameters()))]]></code>
+ </LessSpecificReturnStatement>
<MissingTemplateParam>
<code>ArrayAccess</code>
</MissingTemplateParam>
+ <MoreSpecificReturnType>
+ <code>\stdClass</code>
+ </MoreSpecificReturnType>
<RedundantCast>
<code><![CDATA[(int) $e->getCode()]]></code>
</RedundantCast>
@@ -2111,7 +2323,7 @@
</UndefinedMagicMethod>
</file>
<file src="lib/private/Authentication/TwoFactorAuth/Db/ProviderUserAssignmentDao.php">
- <InvalidReturnStatement>
+ <LessSpecificReturnStatement>
<code><![CDATA[array_map(function (array $row) {
return [
'provider_id' => $row['provider_id'],
@@ -2119,10 +2331,10 @@
'enabled' => 1 === (int) $row['enabled'],
];
}, $rows)]]></code>
- </InvalidReturnStatement>
- <InvalidReturnType>
- <code>int[]</code>
- </InvalidReturnType>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code><![CDATA[list<array{provider_id: string, uid: string, enabled: bool}>]]></code>
+ </MoreSpecificReturnType>
</file>
<file src="lib/private/Authentication/TwoFactorAuth/Manager.php">
<InvalidArgument>
@@ -2152,11 +2364,6 @@
<code><![CDATA[$this->providers]]></code>
</UndefinedInterfaceMethod>
</file>
- <file src="lib/private/Authentication/TwoFactorAuth/Registry.php">
- <InvalidArrayAccess>
- <code>$provider['provider_id']</code>
- </InvalidArrayAccess>
- </file>
<file src="lib/private/BackgroundJob/QueuedJob.php">
<MoreSpecificImplementedParamType>
<code>$jobList</code>
@@ -2175,6 +2382,26 @@
</LessSpecificImplementedReturnType>
</file>
<file src="lib/private/Calendar/Manager.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[array_merge(
+ ...array_map(function ($registration) use ($principalUri, $calendarUris) {
+ try {
+ /** @var ICalendarProvider $provider */
+ $provider = $this->container->get($registration->getService());
+ } catch (Throwable $e) {
+ $this->logger->error('Could not load calendar provider ' . $registration->getService() . ': ' . $e->getMessage(), [
+ 'exception' => $e,
+ ]);
+ return [];
+ }
+
+ return $provider->getCalendars($principalUri, $calendarUris);
+ }, $context->getCalendarProviders())
+ )]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>ICreateFromString[]</code>
+ </MoreSpecificReturnType>
<NamedArgumentNotAllowed>
<code><![CDATA[array_map(function ($registration) use ($principalUri, $calendarUris) {
try {
@@ -2269,7 +2496,7 @@
<code>getParams</code>
</InternalMethod>
<InvalidArrayOffset>
- <code>$params['collation']</code>
+ <code><![CDATA[$params['collation']]]></code>
</InvalidArrayOffset>
</file>
<file src="lib/private/DB/Connection.php">
@@ -2280,8 +2507,8 @@
<code>$params</code>
</InvalidArgument>
<InvalidArrayOffset>
- <code>$params['adapter']</code>
- <code>$params['tablePrefix']</code>
+ <code><![CDATA[$params['adapter']]]></code>
+ <code><![CDATA[$params['tablePrefix']]]></code>
</InvalidArrayOffset>
<InvalidReturnStatement>
<code><![CDATA[$this->adapter->lastInsertId($seqName)]]></code>
@@ -2307,6 +2534,12 @@
<code>$offset</code>
<code>$offset</code>
</InvalidOperand>
+ <LessSpecificReturnStatement>
+ <code>$s</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>IMigrationStep</code>
+ </MoreSpecificReturnType>
</file>
<file src="lib/private/DB/OracleConnection.php">
<InvalidArrayAccess>
@@ -2327,7 +2560,7 @@
<code>getParams</code>
</InternalMethod>
<InvalidArrayOffset>
- <code>$params['collation']</code>
+ <code><![CDATA[$params['collation']]]></code>
</InvalidArrayOffset>
</file>
<file src="lib/private/DB/QueryBuilder/QueryBuilder.php">
@@ -2403,10 +2636,21 @@
</UndefinedMethod>
</file>
<file src="lib/private/DirectEditing/Token.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->manager->getFileForToken($this->data['user_id'], $this->data['file_id'], $this->data['file_path'])]]></code>
+ </LessSpecificReturnStatement>
<UndefinedMethod>
<code>getShareForToken</code>
</UndefinedMethod>
</file>
+ <file src="lib/private/Encryption/File.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[['users' => $uniqueUserIds, 'public' => $public]]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>array{users: string[], public: bool}</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="lib/private/Encryption/Keys/Storage.php">
<InvalidNullableReturnType>
<code>deleteUserKey</code>
@@ -2427,6 +2671,16 @@
<code>dispatch</code>
</TooManyArguments>
</file>
+ <file src="lib/private/EventDispatcher/GenericEventWrapper.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->event->setArgument($key, $value)]]></code>
+ <code><![CDATA[$this->event->setArguments($args)]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>setArgument</code>
+ <code>setArguments</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="lib/private/EventDispatcher/SymfonyAdapter.php">
<ImplementedParamTypeMismatch>
<code>$eventName</code>
@@ -2446,6 +2700,14 @@
<code>$providerId</code>
</ParamNameMismatch>
</file>
+ <file src="lib/private/Files/AppData/AppData.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->folder]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>Folder</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="lib/private/Files/Cache/Cache.php">
<InvalidArgument>
<code>$parentData</code>
@@ -2522,10 +2784,10 @@
<code>$user</code>
</InvalidOperand>
<RedundantCondition>
- <code>get_class($provider) !== 'OCA\Files_Sharing\MountProvider'</code>
+ <code><![CDATA[get_class($provider) !== 'OCA\Files_Sharing\MountProvider']]></code>
</RedundantCondition>
<TypeDoesNotContainType>
- <code>get_class($provider) === 'OCA\Files_Sharing\MountProvider'</code>
+ <code><![CDATA[get_class($provider) === 'OCA\Files_Sharing\MountProvider']]></code>
</TypeDoesNotContainType>
</file>
<file src="lib/private/Files/Config/UserMountCache.php">
@@ -2536,6 +2798,12 @@
<LessSpecificImplementedReturnType>
<code>array</code>
</LessSpecificImplementedReturnType>
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->cacheInfoCache[$fileId]]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>array{int, string, int}</code>
+ </MoreSpecificReturnType>
</file>
<file src="lib/private/Files/FileInfo.php">
<MissingTemplateParam>
@@ -2543,6 +2811,16 @@
</MissingTemplateParam>
</file>
<file src="lib/private/Files/Filesystem.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$mount->getStorage()]]></code>
+ <code><![CDATA[self::getMountManager()->findByNumericId($id)]]></code>
+ <code><![CDATA[self::getMountManager()->findByStorageId($id)]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>Mount\MountPoint[]</code>
+ <code>Mount\MountPoint[]</code>
+ <code>\OC\Files\Storage\Storage|null</code>
+ </MoreSpecificReturnType>
<TooManyArguments>
<code>addStorageWrapper</code>
</TooManyArguments>
@@ -2569,25 +2847,37 @@
</InvalidReturnType>
</file>
<file src="lib/private/Files/Node/Folder.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->root->get($this->getFullPath($path))]]></code>
+ <code><![CDATA[$this->root->getByIdInPath((int)$id, $this->getPath())]]></code>
+ <code><![CDATA[array_map(function (FileInfo $file) {
+ return $this->createNode($file->getPath(), $file);
+ }, $files)]]></code>
+ </LessSpecificReturnStatement>
<MoreSpecificImplementedParamType>
<code>$node</code>
</MoreSpecificImplementedParamType>
+ <MoreSpecificReturnType>
+ <code>\OC\Files\Node\Node</code>
+ <code>\OC\Files\Node\Node[]</code>
+ <code>\OC\Files\Node\Node[]</code>
+ </MoreSpecificReturnType>
</file>
<file src="lib/private/Files/Node/HookConnector.php">
<InvalidArgument>
- <code>'\OCP\Files::postCopy'</code>
- <code>'\OCP\Files::postCreate'</code>
- <code>'\OCP\Files::postDelete'</code>
- <code>'\OCP\Files::postRename'</code>
- <code>'\OCP\Files::postTouch'</code>
- <code>'\OCP\Files::postWrite'</code>
- <code>'\OCP\Files::preCopy'</code>
- <code>'\OCP\Files::preCreate'</code>
- <code>'\OCP\Files::preDelete'</code>
- <code>'\OCP\Files::preRename'</code>
- <code>'\OCP\Files::preTouch'</code>
- <code>'\OCP\Files::preWrite'</code>
- <code>'\OCP\Files::read'</code>
+ <code><![CDATA['\OCP\Files::postCopy']]></code>
+ <code><![CDATA['\OCP\Files::postCreate']]></code>
+ <code><![CDATA['\OCP\Files::postDelete']]></code>
+ <code><![CDATA['\OCP\Files::postRename']]></code>
+ <code><![CDATA['\OCP\Files::postTouch']]></code>
+ <code><![CDATA['\OCP\Files::postWrite']]></code>
+ <code><![CDATA['\OCP\Files::preCopy']]></code>
+ <code><![CDATA['\OCP\Files::preCreate']]></code>
+ <code><![CDATA['\OCP\Files::preDelete']]></code>
+ <code><![CDATA['\OCP\Files::preRename']]></code>
+ <code><![CDATA['\OCP\Files::preTouch']]></code>
+ <code><![CDATA['\OCP\Files::preWrite']]></code>
+ <code><![CDATA['\OCP\Files::read']]></code>
</InvalidArgument>
<TooManyArguments>
<code>dispatch</code>
@@ -2625,9 +2915,17 @@
<code><![CDATA[$this->__call(__FUNCTION__, func_get_args())]]></code>
</InvalidReturnStatement>
</file>
+ <file src="lib/private/Files/Node/LazyUserFolder.php">
+ <LessSpecificReturnStatement>
+ <code>$node</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>Folder</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="lib/private/Files/Node/Node.php">
<InvalidArgument>
- <code>'\OCP\Files::' . $hook</code>
+ <code><![CDATA['\OCP\Files::' . $hook]]></code>
</InvalidArgument>
<InvalidNullableReturnType>
<code>FileInfo</code>
@@ -2635,6 +2933,12 @@
<InvalidReturnType>
<code>getChecksum</code>
</InvalidReturnType>
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->parent]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>INode|IRootFolder</code>
+ </MoreSpecificReturnType>
<NullableReturnStatement>
<code><![CDATA[$this->fileInfo]]></code>
</NullableReturnStatement>
@@ -2650,9 +2954,21 @@
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/Files/Node/Root.php">
- <InvalidNullableReturnType>
+ <LessSpecificReturnStatement>
+ <code>$folders</code>
+ <code><![CDATA[$this->createNode($fullPath, $fileInfo, false)]]></code>
+ <code><![CDATA[$this->mountManager->findByNumericId($numericId)]]></code>
+ <code><![CDATA[$this->mountManager->findByStorageId($storageId)]]></code>
+ <code><![CDATA[$this->mountManager->findIn($mountPoint)]]></code>
+ <code><![CDATA[$this->user]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>MountPoint[]</code>
+ <code>Node</code>
+ <code>\OC\Files\Mount\MountPoint[]</code>
+ <code>\OC\Files\Mount\MountPoint[]</code>
<code>\OC\User\User</code>
- </InvalidNullableReturnType>
+ </MoreSpecificReturnType>
<NullableReturnStatement>
<code><![CDATA[$this->user]]></code>
</NullableReturnStatement>
@@ -2682,7 +2998,7 @@
<code>Promise\promise_for(
new Credentials($key, $secret)
)</code>
- <code>\Aws\or_chain([self::class, 'legacySignatureProvider'], ClientResolver::_default_signature_provider())</code>
+ <code><![CDATA[\Aws\or_chain([self::class, 'legacySignatureProvider'], ClientResolver::_default_signature_provider())]]></code>
</UndefinedFunction>
</file>
<file src="lib/private/Files/ObjectStore/S3ObjectTrait.php">
@@ -2859,6 +3175,14 @@
<code>int</code>
</InvalidReturnType>
</file>
+ <file src="lib/private/Files/Utils/Scanner.php">
+ <LessSpecificReturnStatement>
+ <code>$mounts</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>\OC\Files\Mount\MountPoint[]</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="lib/private/Files/View.php">
<InvalidScalarArgument>
<code>$mtime</code>
@@ -2891,20 +3215,26 @@
</file>
<file src="lib/private/Group/Group.php">
<InvalidArgument>
- <code>IGroup::class . '::postAddUser'</code>
- <code>IGroup::class . '::postDelete'</code>
- <code>IGroup::class . '::postRemoveUser'</code>
- <code>IGroup::class . '::preAddUser'</code>
- <code>IGroup::class . '::preDelete'</code>
- <code>IGroup::class . '::preRemoveUser'</code>
+ <code><![CDATA[IGroup::class . '::postAddUser']]></code>
+ <code><![CDATA[IGroup::class . '::postDelete']]></code>
+ <code><![CDATA[IGroup::class . '::postRemoveUser']]></code>
+ <code><![CDATA[IGroup::class . '::preAddUser']]></code>
+ <code><![CDATA[IGroup::class . '::preDelete']]></code>
+ <code><![CDATA[IGroup::class . '::preRemoveUser']]></code>
<code>bool</code>
</InvalidArgument>
<InvalidOperand>
<code>$hide</code>
</InvalidOperand>
+ <LessSpecificReturnStatement>
+ <code>$users</code>
+ </LessSpecificReturnStatement>
<MoreSpecificImplementedParamType>
<code>$user</code>
</MoreSpecificImplementedParamType>
+ <MoreSpecificReturnType>
+ <code>\OC\User\User[]</code>
+ </MoreSpecificReturnType>
<RedundantCondition>
<code><![CDATA[$this->emitter]]></code>
<code><![CDATA[$this->emitter]]></code>
@@ -2926,6 +3256,15 @@
</UndefinedMethod>
</file>
<file src="lib/private/Group/Manager.php">
+ <LessSpecificReturnStatement>
+ <code>$groups</code>
+ <code>array_values($groups)</code>
+ <code>array_values($groups)</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>\OC\Group\Group[]</code>
+ <code>\OC\Group\Group[]</code>
+ </MoreSpecificReturnType>
<UndefinedInterfaceMethod>
<code>createGroup</code>
<code>getGroupDetails</code>
@@ -2951,8 +3290,8 @@
<code>false</code>
</InvalidArgument>
<InvalidArrayOffset>
- <code>$app['path']</code>
- <code>$app['path']</code>
+ <code><![CDATA[$app['path']]]></code>
+ <code><![CDATA[$app['path']]]></code>
</InvalidArrayOffset>
<NullArgument>
<code>null</code>
@@ -3121,6 +3460,9 @@
<InvalidReturnType>
<code>false|resource</code>
</InvalidReturnType>
+ <LessSpecificReturnType>
+ <code>null|string</code>
+ </LessSpecificReturnType>
<MismatchingDocblockParamType>
<code>ISimpleFile</code>
</MismatchingDocblockParamType>
@@ -3272,6 +3614,22 @@
<InvalidArgument>
<code>new GenericEvent($user)</code>
</InvalidArgument>
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->get(IFile::class)]]></code>
+ <code><![CDATA[$this->get(IGroupManager::class)]]></code>
+ <code><![CDATA[$this->get(INavigationManager::class)]]></code>
+ <code><![CDATA[$this->get(IUserManager::class)]]></code>
+ <code><![CDATA[$this->get(IUserSession::class)]]></code>
+ <code><![CDATA[$this->get(\OCP\Encryption\IManager::class)]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>\OC\Encryption\File</code>
+ <code>\OC\Encryption\Manager</code>
+ <code>\OC\Group\Manager</code>
+ <code>\OC\NavigationManager</code>
+ <code>\OC\User\Manager</code>
+ <code>\OC\User\Session</code>
+ </MoreSpecificReturnType>
<UndefinedDocblockClass>
<code>\OC\OCSClient</code>
</UndefinedDocblockClass>
@@ -3306,8 +3664,8 @@
</file>
<file src="lib/private/Setup.php">
<RedundantCondition>
- <code>$content !== ''</code>
- <code>$type === 'pdo'</code>
+ <code><![CDATA[$content !== '']]></code>
+ <code><![CDATA[$type === 'pdo']]></code>
</RedundantCondition>
<UndefinedVariable>
<code>$vendor</code>
@@ -3337,7 +3695,7 @@
<InvalidArgument>
<code><![CDATA[$share->getId()]]></code>
<code><![CDATA[$share->getId()]]></code>
- <code>(int)$data['id']</code>
+ <code><![CDATA[(int)$data['id']]]></code>
</InvalidArgument>
<TooManyArguments>
<code>set</code>
@@ -3349,12 +3707,12 @@
<file src="lib/private/Share20/Manager.php">
<InvalidArgument>
<code>$id</code>
- <code>'OCP\Share::postAcceptShare'</code>
- <code>'OCP\Share::postShare'</code>
- <code>'OCP\Share::postUnshare'</code>
- <code>'OCP\Share::postUnshareFromSelf'</code>
- <code>'OCP\Share::preShare'</code>
- <code>'OCP\Share::preUnshare'</code>
+ <code><![CDATA['OCP\Share::postAcceptShare']]></code>
+ <code><![CDATA['OCP\Share::postShare']]></code>
+ <code><![CDATA['OCP\Share::postUnshare']]></code>
+ <code><![CDATA['OCP\Share::postUnshareFromSelf']]></code>
+ <code><![CDATA['OCP\Share::preShare']]></code>
+ <code><![CDATA['OCP\Share::preUnshare']]></code>
</InvalidArgument>
<TooManyArguments>
<code>dispatch</code>
@@ -3413,6 +3771,14 @@
<code>getLazyRootFolder</code>
</UndefinedInterfaceMethod>
</file>
+ <file src="lib/private/Share20/Share.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->node]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>getNode</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="lib/private/Streamer.php">
<InvalidArgument>
<code>$stream</code>
@@ -3543,7 +3909,7 @@
<code>boolean|null</code>
</ImplementedReturnTypeMismatch>
<InvalidArgument>
- <code>IUser::class . '::firstLogin'</code>
+ <code><![CDATA[IUser::class . '::firstLogin']]></code>
</InvalidArgument>
<NoInterfaceProperties>
<code><![CDATA[$request->server]]></code>
@@ -3555,11 +3921,11 @@
</file>
<file src="lib/private/User/User.php">
<InvalidArgument>
- <code>IUser::class . '::changeUser'</code>
- <code>IUser::class . '::postDelete'</code>
- <code>IUser::class . '::postSetPassword'</code>
- <code>IUser::class . '::preDelete'</code>
- <code>IUser::class . '::preSetPassword'</code>
+ <code><![CDATA[IUser::class . '::changeUser']]></code>
+ <code><![CDATA[IUser::class . '::postDelete']]></code>
+ <code><![CDATA[IUser::class . '::postSetPassword']]></code>
+ <code><![CDATA[IUser::class . '::preDelete']]></code>
+ <code><![CDATA[IUser::class . '::preSetPassword']]></code>
</InvalidArgument>
<TooManyArguments>
<code>dispatch</code>
@@ -3590,8 +3956,8 @@
<code>ManagerEvent::EVENT_APP_UPDATE</code>
</InvalidArgument>
<InvalidArrayOffset>
- <code>$dir['path']</code>
- <code>$dir['url']</code>
+ <code><![CDATA[$dir['path']]]></code>
+ <code><![CDATA[$dir['url']]]></code>
</InvalidArrayOffset>
<NullArgument>
<code>null</code>
@@ -3667,6 +4033,14 @@
<code>$column</code>
</NullableReturnStatement>
</file>
+ <file src="lib/public/AppFramework/Http/Response.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[array_merge($mergeWith, $this->headers)]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>array{X-Request-Id: string, Cache-Control: string, Content-Security-Policy: string, Feature-Policy: string, X-Robots-Tag: string, Last-Modified?: string, ETag?: string, ...H}</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="lib/public/Authentication/TwoFactorAuth/IProvider.php">
<AmbiguousConstantInheritance>
<code>EVENT_FAILED</code>
@@ -3678,6 +4052,14 @@
<code>\ArrayAccess</code>
</MissingTemplateParam>
</file>
+ <file src="lib/public/Color.php">
+ <LessSpecificReturnStatement>
+ <code>$step</code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>array{0: int, 1: int, 2: int}</code>
+ </MoreSpecificReturnType>
+ </file>
<file src="lib/public/Diagnostics/IQueryLogger.php">
<LessSpecificImplementedReturnType>
<code>mixed</code>
@@ -3709,4 +4091,12 @@
<code>\Iterator</code>
</MissingTemplateParam>
</file>
+ <file src="lib/public/Preview/BeforePreviewFetchedEvent.php">
+ <LessSpecificReturnStatement>
+ <code><![CDATA[$this->mode]]></code>
+ </LessSpecificReturnStatement>
+ <MoreSpecificReturnType>
+ <code>null|IPreview::MODE_FILL|IPreview::MODE_COVER</code>
+ </MoreSpecificReturnType>
+ </file>
</files>
diff --git a/psalm.xml b/psalm.xml
index 831b875d5a0..87cecf3e2d2 100644
--- a/psalm.xml
+++ b/psalm.xml
@@ -83,6 +83,10 @@
<file name="3rdparty/sabre/uri/lib/functions.php" />
</stubs>
<issueHandlers>
+ <LessSpecificReturnStatement errorLevel="error"/>
+ <LessSpecificReturnType errorLevel="error"/>
+ <LessSpecificImplementedReturnType errorLevel="error"/>
+ <MoreSpecificReturnType errorLevel="error"/>
<UndefinedClass>
<errorLevel type="suppress">
<referencedClass name="OCA\GroupFolders\Mount\GroupFolderStorage"/>