forked from ZwiiCMS-Team/ZwiiCMS
Gestion des fichiers par certains membres
This commit is contained in:
parent
5d09fb6146
commit
ff93b545b9
@ -2683,6 +2683,7 @@ class layout extends common {
|
||||
$items .= '<span id="footerDisplayMemberAccount"';
|
||||
$items .= $this->getData(['theme','footer','displaymemberAccount']) === false ? ' class="displayNone"' : '';
|
||||
$items .= '><wbr> | <a href="' . helper::baseUrl() . 'user/edit/' . $this->getUser('id'). '/' . $_SESSION['csrf'] . '" data-tippy-content="Gérer mon compte" >' . template::ico('user', 'all') . '</a>';
|
||||
if( $this->getData(['user', $this->getUser('id') , 'files']) === true) $items .= '<wbr><a href="' . helper::baseUrl(false) . 'core/vendor/filemanager/dialog.php?type=0&akey=' . md5_file(self::DATA_DIR.'core.json') .'" data-tippy-content="Gérer les fichiers" data-lity>' . template::ico('folder') . '</a>';
|
||||
$items .= '<wbr><a id="barLogout" href="' . helper::baseUrl() . 'user/logout" data-tippy-content="Me déconnecter">' . template::ico('logout','left') . '</a>';
|
||||
$items .= '</span>';
|
||||
}
|
||||
@ -2914,6 +2915,7 @@ class layout extends common {
|
||||
|| $this->getData(['theme','footer','displayMemberBar']) === false
|
||||
)
|
||||
) {
|
||||
if( $this->getData(['user', $this->getUser('id') , 'files']) === true) $itemsRight .= '<li><a href="' . helper::baseUrl(false) . 'core/vendor/filemanager/dialog.php?type=0&akey=' . md5_file(self::DATA_DIR.'core.json') .'" data-tippy-content="Gérer les fichiers" data-lity>' . template::ico('folder') . '</a></li>';
|
||||
$itemsRight .= '<li><a href="' . helper::baseUrl() . 'user/edit/' . $this->getUser('id'). '/' . $_SESSION['csrf'] . '" data-tippy-content="Gérer mon compte">' . template::ico('user', 'right') . '</a></li>';
|
||||
$itemsRight .= '<li><a id="barLogout" href="' . helper::baseUrl() . 'user/logout" data-tippy-content="Me déconnecter">' . template::ico('logout') . '</a></li>';
|
||||
}
|
||||
|
@ -87,7 +87,8 @@ class user extends common {
|
||||
"connectTimeout" => null,
|
||||
"accessUrl" => null,
|
||||
"accessTimer" => null,
|
||||
"accessCsrf" => null
|
||||
"accessCsrf" => null,
|
||||
"files" => $this->getInput('userAddFiles', helper::FILTER_BOOLEAN)
|
||||
]
|
||||
]);
|
||||
|
||||
@ -256,7 +257,8 @@ class user extends common {
|
||||
'connectTimeout' => $this->getData(['user',$this->getUrl(2),'connectTimeout']),
|
||||
'accessUrl' => $this->getData(['user',$this->getUrl(2),'accessUrl']),
|
||||
'accessTimer' => $this->getData(['user',$this->getUrl(2),'accessTimer']),
|
||||
'accessCsrf' => $this->getData(['user',$this->getUrl(2),'accessCsrf'])
|
||||
'accessCsrf' => $this->getData(['user',$this->getUrl(2),'accessCsrf']),
|
||||
'files' => $this->getInput('userEditFiles', helper::FILTER_BOOLEAN)
|
||||
]
|
||||
]);
|
||||
// Redirection spécifique si l'utilisateur change son mot de passe
|
||||
|
@ -43,3 +43,28 @@ $("#userAddGroup").on("change", function() {
|
||||
$(".userAddGroupDescription").hide();
|
||||
$("#userAddGroupDescription" + $(this).val()).show();
|
||||
}).trigger("change");
|
||||
|
||||
/**
|
||||
* Autorisation d'upload et de download pour un membre
|
||||
*/
|
||||
$(document).ready(function(){
|
||||
if($("#userAddGroup").val() === '1') {
|
||||
$("#userAddMemberFiles").slideDown();
|
||||
}
|
||||
else {
|
||||
$("#userAddMemberFiles").slideUp(function() {
|
||||
$("#userAddtFiles").prop("checked", false).trigger("change");
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
$("#userAddGroup").on("change", function() {
|
||||
if($("#userAddGroup").val() === '1') {
|
||||
$("#userAddMemberFiles").slideDown();
|
||||
}
|
||||
else {
|
||||
$("#userAddMemberFiles").slideUp(function() {
|
||||
$("#userAddFiles").prop("checked", false).trigger("change");
|
||||
});
|
||||
}
|
||||
}).trigger("change");
|
||||
|
@ -46,6 +46,11 @@
|
||||
'label' => 'Groupe',
|
||||
'selected' => self::GROUP_MEMBER
|
||||
]); ?>
|
||||
<div id="userAddMemberFiles" class="displayNone">
|
||||
<?php echo template::checkbox('userAddFiles', true, 'Updown et download autorisés', [
|
||||
'checked' => false
|
||||
]); ?>
|
||||
</div>
|
||||
Autorisations :
|
||||
<ul id="userAddGroupDescription<?php echo self::GROUP_MEMBER; ?>" class="userAddGroupDescription displayNone">
|
||||
<li>Accès aux pages privées membres</li>
|
||||
|
@ -23,3 +23,27 @@ $("#userEditGroup").on("change", function() {
|
||||
$("#userEditLabelAuth").css("display","inline-block");
|
||||
}
|
||||
}).trigger("change");
|
||||
|
||||
$(document).ready(function(){
|
||||
// Membre avec ou sans gestion de fichiers
|
||||
if($("#userEditGroup").val() === '1') {
|
||||
$("#userEditMemberFiles").slideDown();
|
||||
}
|
||||
else {
|
||||
$("#userEditMemberFiles").slideUp(function() {
|
||||
$("#userEditFiles").prop("checked", false).trigger("change");
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
$("#userEditGroup").on("change", function() {
|
||||
// Membre avec ou sans gestion de fichiers
|
||||
if($("#userEditGroup").val() === '1') {
|
||||
$("#userEditMemberFiles").slideDown();
|
||||
}
|
||||
else {
|
||||
$("#userEditMemberFiles").slideUp(function() {
|
||||
$("#userEditFiles").prop("checked", false).trigger("change");
|
||||
});
|
||||
}
|
||||
}).trigger("change");
|
||||
|
@ -64,7 +64,13 @@
|
||||
'label' => 'Groupe',
|
||||
'selected' => $this->getData(['user', $this->getUrl(2), 'group'])
|
||||
]); ?>
|
||||
<div id="userEditLabelAuth">Autorisations :</div>
|
||||
<div id="userEditMemberFiles" class="displayNone">
|
||||
<?php echo template::checkbox('userEditFiles', true, 'Updown et download autorisés', [
|
||||
'checked' => $this->getData(['user', $this->getUrl(2), 'files']),
|
||||
'help' => 'Ce membre pourra déposer ou télécharger des fichiers dans le dossier \'updown\' et ses sous-dossiers'
|
||||
]); ?>
|
||||
</div>
|
||||
<div id="userEditLabelAuth">Autorisations :</div>
|
||||
<ul id="userEditGroupDescription<?php echo self::GROUP_MEMBER; ?>" class="userEditGroupDescription displayNone">
|
||||
<li>Accès aux pages privées membres</li>
|
||||
</ul>
|
||||
|
106
core/vendor/filemanager/config/config.php
vendored
106
core/vendor/filemanager/config/config.php
vendored
@ -13,6 +13,75 @@ ob_start('mb_output_handler');
|
||||
date_default_timezone_set('Europe/Paris');
|
||||
setlocale(LC_CTYPE, 'fr_FR'); //correct transliteration
|
||||
|
||||
/* Lecture du groupe de l'utilisateur connecté pour attribuer les droits et les dossiers */
|
||||
$userId = $_COOKIE['ZWII_USER_ID'];
|
||||
$json = file_get_contents('../../../site/data/user.json');
|
||||
$tab = json_decode($json, true);
|
||||
$group = $tab['user'][$userId]['group'];
|
||||
$uploadDir = '/site/file/source/';
|
||||
$currentPath = '../../../site/file/source/';
|
||||
if( $group === 3){
|
||||
// Administrateur, droits maximum
|
||||
$deleteFiles = true;
|
||||
$createFolders = true;
|
||||
$deleteFolders = true;
|
||||
$uploadFiles = true;
|
||||
$renameFiles = true;
|
||||
$renameFolders = true;
|
||||
$duplicateFiles = true;
|
||||
$extractFiles = true;
|
||||
$copycutFiles = true;
|
||||
$copycutDirs = true;
|
||||
$chmodFiles = true;
|
||||
$chmodDirs = true;
|
||||
$previewtextFiles = true;
|
||||
$edittextFiles = true;
|
||||
$createtextFiles = true;
|
||||
$downloadFiles = true;
|
||||
}
|
||||
elseif( $group === 2){
|
||||
// Modérateur éditeur
|
||||
$deleteFiles = false;
|
||||
$createFolders = true;
|
||||
$deleteFolders = false;
|
||||
$uploadFiles = true;
|
||||
$renameFiles = true;
|
||||
$renameFolders = false;
|
||||
$duplicateFiles = true;
|
||||
$extractFiles = true;
|
||||
$copycutFiles = true;
|
||||
$copycutDirs = false;
|
||||
$chmodFiles = false;
|
||||
$chmodDirs = false;
|
||||
$previewtextFiles = true;
|
||||
$edittextFiles = true;
|
||||
$createtextFiles = true;
|
||||
$downloadFiles = true;
|
||||
}
|
||||
else{
|
||||
// Membre avec droits d'upload / download
|
||||
$uploadDir = '/site/file/source/updown/';
|
||||
$currentPath = '../../../site/file/source/updown/';
|
||||
if(!is_dir('../../../site/file/source/updown')) mkdir ('../../../site/file/source/updown');
|
||||
$deleteFiles = false;
|
||||
$createFolders = false;
|
||||
$deleteFolders = false;
|
||||
$uploadFiles = true;
|
||||
$renameFiles = false;
|
||||
$renameFolders = false;
|
||||
$duplicateFiles = false;
|
||||
$extractFiles = false;
|
||||
$copycutFiles = true;
|
||||
$copycutDirs = false;
|
||||
$chmodFiles = false;
|
||||
$chmodDirs = false;
|
||||
$previewtextFiles = false;
|
||||
$edittextFiles = false;
|
||||
$createtextFiles = false;
|
||||
$downloadFiles = true;
|
||||
}
|
||||
/* Fin lecture du groupe de l'utilisateur connecté pour attribuer les droits et les dossiers */
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Optional security
|
||||
@ -77,7 +146,7 @@ $config = array(
|
||||
| with start and final /
|
||||
|
|
||||
*/
|
||||
'upload_dir' => '/site/file/source/',
|
||||
'upload_dir' => $uploadDir,
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| relative path from filemanager folder to upload folder
|
||||
@ -86,7 +155,7 @@ $config = array(
|
||||
| with final /
|
||||
|
|
||||
*/
|
||||
'current_path' => '../../../site/file/source/',
|
||||
'current_path' => $currentPath,
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
@ -336,22 +405,23 @@ $config = array(
|
||||
//*************************
|
||||
//Permissions configuration
|
||||
//******************
|
||||
'delete_files' => true,
|
||||
'create_folders' => true,
|
||||
'delete_folders' => true,
|
||||
'upload_files' => true,
|
||||
'rename_files' => true,
|
||||
'rename_folders' => true,
|
||||
'duplicate_files' => true,
|
||||
'extract_files' => true,
|
||||
'copy_cut_files' => true, // for copy/cut files
|
||||
'copy_cut_dirs' => true, // for copy/cut directories
|
||||
'chmod_files' => true, // change file permissions
|
||||
'chmod_dirs' => true, // change folder permissions
|
||||
'preview_text_files' => true, // eg.: txt, log etc.
|
||||
'edit_text_files' => true, // eg.: txt, log etc.
|
||||
'create_text_files' => true, // only create files with exts. defined in $config['editable_text_file_exts']
|
||||
'download_files' => true, // allow download files or just preview
|
||||
|
||||
'delete_files' => $deleteFiles,
|
||||
'create_folders' => $createFolders,
|
||||
'delete_folders' => $deleteFolders,
|
||||
'upload_files' => $uploadFiles,
|
||||
'rename_files' => $renameFiles,
|
||||
'rename_folders' => $renameFolders,
|
||||
'duplicate_files' => $duplicateFiles,
|
||||
'extract_files' => $extractFiles,
|
||||
'copy_cut_files' => $copycutFiles, // for copy/cut files
|
||||
'copy_cut_dirs' => $copycutDirs, // for copy/cut directories
|
||||
'chmod_files' => $chmodFiles, // change file permissions
|
||||
'chmod_dirs' => $chmodDirs, // change folder permissions
|
||||
'preview_text_files' => $previewtextFiles, // eg.: txt, log etc.
|
||||
'edit_text_files' => $edittextFiles, // eg.: txt, log etc.
|
||||
'create_text_files' => $createtextFiles, // only create files with exts. defined in $config['editable_text_file_exts']
|
||||
'download_files' => $downloadFiles, // allow download files or just preview
|
||||
|
||||
// you can preview these type of files if $preview_text_files is true
|
||||
'previewable_text_file_exts' => array( "bsh", "c","css", "cc", "cpp", "cs", "csh", "cyc", "cv", "htm", "html", "java", "js", "m", "mxml", "perl", "pl", "pm", "py", "rb", "sh", "xhtml", "xml","xsl",'txt', 'log', 'gpx', 'kml', '' ),
|
||||
|
Loading…
x
Reference in New Issue
Block a user