codekanzlei / cake-attachments
File Attachments plugin for CakePHP
Installs: 47 882
Dependents: 3
Suggesters: 0
Security: 0
Stars: 4
Watchers: 3
Forks: 6
Open Issues: 2
Type:cakephp-plugin
Requires
- php: >=7.3.0
- ext-imagick: *
- cakephp/cakephp: >= 4.0
- codekanzlei/cake-frontend-bridge: ^4.0.0-RC2
Requires (Dev)
- phpstan/phpstan: ^0.11
- scherersoftware/coding-standard: ^4.0.0
This package is auto-updated.
Last update: 2024-12-07 14:56:07 UTC
README
Requirements
You can find the requirements in composer.json
.
- ImageMagick for resizing images
- cake-frontend-bridge for easy access to the current controller and action derived from the URL
- ghostscript for pdf previews. On Mac OS X, you can install ghostscript via homebrew:
`brew install ghostscript`
CakePHP 3 File Attachments Handling
Note: This Plugin depends on the codekanzlei/cake-frontend-bridge Plugin.
Installation
1. require the plugin in your composer.json
"require": {
...
"codekanzlei/cake-attachments": "dev-master",
...
}
2. Include the plugin using composer
Open a terminal in your project directory and run the following command:
$ composer update
Setup & Configuration
1. Load the plugin in your config/bootstrap.php
Plugin::load('Attachments', ['bootstrap' => false, 'routes' => true]);
Also be sure to add the cake-frontend-bridge since it is required for this plugin to work properly.
Plugin::load('FrontendBridge', ['bootstrap' => false, 'routes' => true, 'autoload' => true]);
2. Create a table attachments
in your project database
Run the following sql-query on your project database. You can find it in the Plugin's config/schema.sql
file.
CREATE TABLE `attachments` (
`id` char(36) NOT NULL,
`filepath` varchar(255) NOT NULL,
`filename` varchar(255) NOT NULL,
`filetype` varchar(45) NOT NULL,
`filesize` int(10) NOT NULL,
`model` varchar(255) NOT NULL,
`foreign_key` char(36) NOT NULL,
`tags` text,
`created` datetime DEFAULT NULL,
`modified` datetime DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
3. Create additional folders in your project folder
Open a terminal in your project directory and run these commands:
$ mkdir -p tmp/uploads
$ mkdir -p app_data/attachments
You might have to change the folder permissions for these folders depending on your environment. The application must have permissions to read and write data into them.
4. Adding JavaScript files to your project
In your webroot/js/app/app_controller.js
, add the following key to the baseComponents
Array:
'Attachments'
This grants the project permission to use the plugin's .js files
5. Adding Attachments to your project
In your config/app.php
, add the following key:
'Attachments' => [
'tmpUploadsPath' => ROOT . '/tmp/uploads/',
'path' => ROOT . '/app_data/attachments/',
'acceptedFileTypes' => '/\.(jpe?g|png)$/i',
'autorotate' => false
],
Further possible filetypes you want to allow can be specified in the 'acceptedFileTypes' filed, such as gif|jpe?g|png|pdf|docx|doc|xls|xlsx|tif|tiff|zip
When setting autorotate to true, views and previews of picture attachments will be rotated depending on their EXIF data.
6. Adding AttachmentHelper to your project
In your /serc/Controller/AppController.php
, add the following keys to the public $helpers
Array:
'Attachments.Attachments',
As the cake-frontend-bridge Plugin is required for the Attachments Plugin to work properly, some further configuarion is needed. Add the following key to the $helpers
Array:
'FrontendBridge' => ['className' => 'FrontendBridge.FrontendBridge'],
Use the FrontendBridge in your AppController extends Controller
:
use \FrontendBridge\Lib\FrontendBridgeTrait;
Lastly, add the FrontendBridge-key to public $components
'FrontendBridge.FrontendBridge',
7. Include Attachments in your default layout
In your src/Template/Layout/default.ctp
, you need to create a new div element that contains the UI-elements of the Attachments Plugin.
<div class="<?php echo $this->FrontendBridge->getMainContentClasses() ?>">
</div>
Note: Make sure that the line containing <?= $this->fetch('content') ?>
is a child-element of this <div>
-Element.
Usage
1. Setting up a Model
Go to the table you want use the Attachments plugin in. For example, if you want to be able to attach files to your Users, go to /Model/Table/UsersTable.php
and add the following line to its initialize()
callback method:
$this->addBehavior('Attachments.Attachments');
2. Setting up an Entity
In your Entity (if we stick to the Users-example above this would be Model/Entity/User.php
), make sure you add attachments
and attachment_uploads
to your $_accessible
property like so:
protected $_accessible = [
'attachments' => true,
'attachment_uploads' => true
];
attachment_uploads
is the default form field name, which you can change via the Helper's and Behavior's options.
3. Setting up a Controller
Be sure to contain Attachments stored with this plugin in your Controllers.
If we stick to the Users-example above, your Controller/UsersController.php
might look something like this:
public function edit($id = null)
{
$user = $this->Users->get($id, [
'contain' => ['Attachments']
])
4. Setting up a view
In your Forms, use the AttachmentsHelper to create an attachments area:
echo $this->Attachments->attachmentsArea($entity, [
'label' => 'File Attachments',
'formFieldName' => 'attachment_uploads'
]);
The Helper will automatically add CSS and JS dependencies to your script
and css
view blocks. If you don't
want that, you can disable this behavior by setting includeDependencies
to false
in the Helper's config.
See AttachmentsHelper::addDependencies()
for the JS/CSS dependencies you need to include.
Authorization
If you would like to restrict access to Attachments based on custom logic, you can pass a callback function to the Behavior config.
$this->addBehavior('Attachments.Attachments', [
'downloadAuthorizeCallback' => function (Attachment $attachment, EntityInterface $relatedEntity, Request $request) {
return false;
}
]);
This callback prevents previewing, viewing, downloading, deleting and manipulating attachments.