mirror of https://github.com/avecms/AVE.cms.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
128 lines
6.0 KiB
128 lines
6.0 KiB
<?php |
|
|
|
error_reporting(0); // Set E_ALL for debuging |
|
|
|
// load composer autoload before load elFinder autoload If you need composer |
|
//require './vendor/autoload.php'; |
|
|
|
// elFinder autoload |
|
require './autoload.php'; |
|
// =============================================== |
|
|
|
// Enable FTP connector netmount |
|
elFinder::$netDrivers['ftp'] = 'FTP'; |
|
// =============================================== |
|
|
|
// // Required for Dropbox network mount |
|
// // Installation by composer |
|
// // `composer require kunalvarma05/dropbox-php-sdk` |
|
// // Enable network mount |
|
// elFinder::$netDrivers['dropbox2'] = 'Dropbox2'; |
|
// // Dropbox2 Netmount driver need next two settings. You can get at https://www.dropbox.com/developers/apps |
|
// // AND reuire regist redirect url to "YOUR_CONNECTOR_URL?cmd=netmount&protocol=dropbox2&host=1" |
|
// define('ELFINDER_DROPBOX_APPKEY', ''); |
|
// define('ELFINDER_DROPBOX_APPSECRET', ''); |
|
// =============================================== |
|
|
|
// // Required for Google Drive network mount |
|
// // Installation by composer |
|
// // `composer require google/apiclient:^2.0` |
|
// // Enable network mount |
|
// elFinder::$netDrivers['googledrive'] = 'GoogleDrive'; |
|
// // GoogleDrive Netmount driver need next two settings. You can get at https://console.developers.google.com |
|
// // AND reuire regist redirect url to "YOUR_CONNECTOR_URL?cmd=netmount&protocol=googledrive&host=1" |
|
// define('ELFINDER_GOOGLEDRIVE_CLIENTID', ''); |
|
// define('ELFINDER_GOOGLEDRIVE_CLIENTSECRET', ''); |
|
// // Required case of without composer |
|
// define('ELFINDER_GOOGLEDRIVE_GOOGLEAPICLIENT', '/path/to/google-api-php-client/vendor/autoload.php'); |
|
// =============================================== |
|
|
|
// // Required for Google Drive network mount with Flysystem |
|
// // Installation by composer |
|
// // `composer require nao-pon/flysystem-google-drive:~1.1 nao-pon/elfinder-flysystem-driver-ext` |
|
// // Enable network mount |
|
// elFinder::$netDrivers['googledrive'] = 'FlysystemGoogleDriveNetmount'; |
|
// // GoogleDrive Netmount driver need next two settings. You can get at https://console.developers.google.com |
|
// // AND reuire regist redirect url to "YOUR_CONNECTOR_URL?cmd=netmount&protocol=googledrive&host=1" |
|
// define('ELFINDER_GOOGLEDRIVE_CLIENTID', ''); |
|
// define('ELFINDER_GOOGLEDRIVE_CLIENTSECRET', ''); |
|
// =============================================== |
|
|
|
// // Required for One Drive network mount |
|
// // * cURL PHP extension required |
|
// // * HTTP server PATH_INFO supports required |
|
// // Enable network mount |
|
// elFinder::$netDrivers['onedrive'] = 'OneDrive'; |
|
// // GoogleDrive Netmount driver need next two settings. You can get at https://dev.onedrive.com |
|
// // AND reuire regist redirect url to "YOUR_CONNECTOR_URL/netmount/onedrive/1" |
|
// define('ELFINDER_ONEDRIVE_CLIENTID', ''); |
|
// define('ELFINDER_ONEDRIVE_CLIENTSECRET', ''); |
|
// =============================================== |
|
|
|
// // Required for Box network mount |
|
// // * cURL PHP extension required |
|
// // Enable network mount |
|
// elFinder::$netDrivers['box'] = 'Box'; |
|
// // Box Netmount driver need next two settings. You can get at https://developer.box.com |
|
// // AND reuire regist redirect url to "YOUR_CONNECTOR_URL" |
|
// define('ELFINDER_BOX_CLIENTID', ''); |
|
// define('ELFINDER_BOX_CLIENTSECRET', ''); |
|
// =============================================== |
|
|
|
/** |
|
* Simple function to demonstrate how to control file access using "accessControl" callback. |
|
* This method will disable accessing files/folders starting from '.' (dot) |
|
* |
|
* @param string $attr attribute name (read|write|locked|hidden) |
|
* @param string $path absolute file path |
|
* @param string $data value of volume option `accessControlData` |
|
* @param object $volume elFinder volume driver object |
|
* @param bool|null $isDir path is directory (true: directory, false: file, null: unknown) |
|
* @param string $relpath file path relative to volume root directory started with directory separator |
|
* @return bool|null |
|
**/ |
|
function access($attr, $path, $data, $volume, $isDir, $relpath) { |
|
$basename = basename($path); |
|
return $basename[0] === '.' // if file/folder begins with '.' (dot) |
|
&& strlen($relpath) !== 1 // but with out volume root |
|
? !($attr == 'read' || $attr == 'write') // set read+write to false, other (locked+hidden) set to true |
|
: null; // else elFinder decide it itself |
|
} |
|
|
|
|
|
// Documentation for connector options: |
|
// https://github.com/Studio-42/elFinder/wiki/Connector-configuration-options |
|
$opts = array( |
|
// 'debug' => true, |
|
'roots' => array( |
|
// Items volume |
|
array( |
|
'driver' => 'LocalFileSystem', // driver for accessing file system (REQUIRED) |
|
'path' => '../files/', // path to files (REQUIRED) |
|
'URL' => dirname($_SERVER['PHP_SELF']) . '/../files/', // URL to files (REQUIRED) |
|
'trashHash' => 't1_Lw', // elFinder's hash of trash folder |
|
'winHashFix' => DIRECTORY_SEPARATOR !== '/', // to make hash same to Linux one on windows too |
|
'uploadDeny' => array('all'), // All Mimetypes not allowed to upload |
|
'uploadAllow' => array('image', 'text/plain'),// Mimetype `image` and `text/plain` allowed to upload |
|
'uploadOrder' => array('deny', 'allow'), // allowed Mimetype `image` and `text/plain` only |
|
'accessControl' => 'access' // disable and hide dot starting files (OPTIONAL) |
|
), |
|
// Trash volume |
|
array( |
|
'id' => '1', |
|
'driver' => 'Trash', |
|
'path' => '../files/.trash/', |
|
'tmbURL' => dirname($_SERVER['PHP_SELF']) . '/../files/.trash/.tmb/', |
|
'winHashFix' => DIRECTORY_SEPARATOR !== '/', // to make hash same to Linux one on windows too |
|
'uploadDeny' => array('all'), // Recomend the same settings as the original volume that uses the trash |
|
'uploadAllow' => array('image', 'text/plain'),// Same as above |
|
'uploadOrder' => array('deny', 'allow'), // Same as above |
|
'accessControl' => 'access', // Same as above |
|
) |
|
) |
|
); |
|
|
|
// run elFinder |
|
$connector = new elFinderConnector(new elFinder($opts)); |
|
$connector->run(); |
|
|
|
|