whc-projects/flysystem-pdo-adapter

PDO adapter for Flysystem file abstraction layer

1.0.5 2017-12-24 08:40 UTC

This package is not auto-updated.

Last update: 2024-05-09 15:09:16 UTC


README

Build Status License

PDO database adapter for Flysystem filesystem abstraction. No additional dependencies, only PDO extension required.

Installation

composer require integral/flysystem-pdo-adapter

Database Configuration

At the beginning you have to create a table that will be used to store files.

SQL table schema examples for MySQL and SQLite are presented below.

MySQL

CREATE TABLE files (
  id int(11) NOT NULL AUTO_INCREMENT,
  path varchar(255) NOT NULL,
  type enum('file','dir') NOT NULL,
  contents longblob,
  size int(11) NOT NULL DEFAULT 0,
  mimetype varchar(127),
  timestamp int(11) NOT NULL DEFAULT 0,
  PRIMARY KEY (id),
  UNIQUE KEY path_unique (path)
);

Usage

Create an adapter by passing a valid PDO object and table name as constructor arguments:

MySQL

// http://php.net/manual/pl/ref.pdo-mysql.connection.php
$pdo = new PDO('mysql:host=hostname;dbname=database_name', 'username', 'password');
$adapter = new PDOAdapter($pdo, 'files');

SQLite

// http://php.net/manual/pl/ref.pdo-sqlite.connection.php
$pdo = new PDO('sqlite:/absolute/path/to/database.sqlite');
$adapter = new PDOAdapter($pdo, 'files');

PostgreSQL

// http://php.net/manual/pl/ref.pdo-pgsql.php
$pdo = new PDO('pgsql:host=localhost;port=5432;dbname=testdb;user=bruce;password=mypass');
$adapter = new PDOAdapter($pdo, 'public.files');

Then simply pass the created adapter to \League\Flysystem\Filesystem:

$filesystem = new Filesystem($adapter);

Done! At this point the $filesystem is ready to use.

Note

This implementation emulates a tree structured filesystem, therefore some of the operations (like renaming or deleting a folder) produce quite a lot of database queries, which may result in a poor performance for some scenarios.