Zum Ende der Metadaten springen
Zum Anfang der Metadaten

Sie zeigen eine alte Version dieser Seite an. Zeigen Sie die aktuelle Version an.

Unterschiede anzeigen Seitenhistorie anzeigen

« Vorherige Version anzeigen Version 2 Nächste Version anzeigen »

Dieses Paket regelt den Zugriff auf Dateien. Die Dateien können dabei auf verschiedene Arten gespeichert werden (lokal, S3-Speicher, SFTP). Dieses Paket arbeitet eng mit dem Paket League\Flysystem zusammen.

Einrichtung

Das Paket verfügt über zwei Tabellen, welche die Speichertypen der verschiedenen Verzeichnisse definieren. Dabei werden von brandbox vordefinierte Volumen an Adapter verknüpft. Ein Adapter gibt vor, welches Unterverzeichnis welchem Speichertyp zugewiesen ist. Diese Verknüpfung von Volumen und Adaptern kann von der Volumenkonfiguration übersteuert werden. In manchen Fällen (bspw. Temporärverzeichnissen) ist es nicht sinnvoll sie anders als lokal zu speichern. Standardmäßig stehen zwei Speichertypen zur Verfügung: lokal und S3.

So kann bspw. für das Volumen share ein Adapter für das Verzeichnis public erstellt werden, welcher den Speichertyp S3 definiert.

S3

Um einen S3-Speicher nutzen zu können, müssen diverse Informationen bereitgestellt werden. Diese Informationen werden nicht in der Datenbank abgelegt oder über die UI konfiguriert. Sie müssen wie folgt in der config.php definiert werden.

S3 Konfiguration
's3' => [
	'bucket' => 'brandbox-test',
	'endpoint' => 'endpointWithoutProtocol',
	'key' => 'EXAMPLEKEY',
	'secret' => 'EXAMPLESECRET',
	'isSecure' => true
]

Struktur und Funktionsweise

Wie beschrieben arbeitet das Paket mit League\Flysystem zusammen und abstrahiert den Funktionsumfang davon. Neben einer regulären Manager-Klasse bietet das Paket zwei weitere Manager an, die den Umfang mit Dateien (\Brandbox\FrameworkStorage\Framework\Storage\FileManager) und Ordnern (\Brandbox\FrameworkStorage\Framework\Storage\DirectoryManager) vereinfachen sollen. Es wird empfohlen möglichst mit diesen zwei Manager-Klassen zu arbeiten. Die veralteten Funktionen von Brandbox/Filesystem sollten durch die neuen Funktionen der Directory- und FileManager ersetzt werden.

Events

Um in das Vorgehen von framework-storage einzugreifen, stehen folgende Events zur Verfügung.

EventBeschreibung
\Brandbox\FrameworkStorage\Framework\Storage\Lib\Event\OnPrefixPathDieses Event bietet die Möglichkeit einem Pfad ein Präfix zu verabreichen. Neben dem Pfad wird der ermittelte Speichertyp bereitgestellt.
\Brandbox\FrameworkStorage\Framework\Storage\Lib\Event\OnPopulateMounts

Dieses Event ermöglicht es weitere Mounts hinzuzufügen. Das dafür vorgesehene Array ist assoziativ. Jeder neue Eintrag muss den Speichertyp als key erhalten. Der value entspricht der bereitzustellenden \League\Flysystem\FilesystemOperator -Instanz.

Das Array wird im Anschluss dem MountManager von Flysystem übergeben.



  • Keine Stichwörter