diff --git a/composer.json b/composer.json index 3b3b0e64..5b01747a 100644 --- a/composer.json +++ b/composer.json @@ -24,9 +24,9 @@ "silverstripe/template-engine": "^1", "silverstripe/vendor-plugin": "^2", "symfony/filesystem": "^7.0", - "intervention/image": "^3.7", - "league/flysystem": "^3.22", - "league/flysystem-local": "^3.22" + "intervention/image": "^3.9", + "league/flysystem": "^3.29", + "league/flysystem-local": "^3.29" }, "require-dev": { "silverstripe/recipe-testing": "^4", diff --git a/src/File.php b/src/File.php index f899aee1..1d14ea23 100644 --- a/src/File.php +++ b/src/File.php @@ -31,6 +31,7 @@ use SilverStripe\Security\InheritedPermissionsExtension; use SilverStripe\Security\Member; use SilverStripe\Security\Permission; +use SilverStripe\Security\PermissionCheckable; use SilverStripe\Security\PermissionChecker; use SilverStripe\Security\PermissionProvider; use SilverStripe\Security\Security; @@ -99,7 +100,7 @@ * @method Member Owner() * @method File Parent() */ -class File extends DataObject implements AssetContainer, Thumbnail, CMSPreviewable, PermissionProvider, Resettable +class File extends DataObject implements AssetContainer, Thumbnail, CMSPreviewable, PermissionProvider, Resettable, PermissionCheckable { use ImageManipulation; @@ -351,14 +352,6 @@ public function AbsoluteLink() return $this->getAbsoluteURL(); } - /** - * @return string - */ - public function getTreeTitle() - { - return Convert::raw2xml($this->Title); - } - /** * @param Member $member * @return bool @@ -1435,10 +1428,7 @@ public function PreviewLink($action = null) return $link; } - /** - * @return PermissionChecker - */ - public function getPermissionChecker() + public function getPermissionChecker(): PermissionChecker { return Injector::inst()->get(PermissionChecker::class.'.file'); } @@ -1518,13 +1508,12 @@ protected function filterFilename($name) }, $parts ?? [])); } - public function flushCache($persistent = true): static + public function flushCache(bool $persistent = true): static { - parent::flushCache($persistent); static::reset(); ImageShortcodeProvider::flush(); FileShortcodeProvider::flush(); - return $this; + return parent::flushCache($persistent); } public static function reset()