mirror of
				https://github.com/avecms/AVE.cms.git
				synced 2025-11-04 06:56:38 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			129 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
<?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();
 | 
						|
 |