use new Zip Helper (and various fix)
This commit is contained in:
parent
e9886ee444
commit
4046c9e2e7
2 changed files with 41 additions and 41 deletions
|
@ -1,11 +1,10 @@
|
|||
<?php
|
||||
// Language: Français
|
||||
// Module: tinyPacker -
|
||||
// Date: 2023-01-30 18:50:34
|
||||
// Author: Pierre Van Glabeke
|
||||
// Translated with dcTranslater - 2022.12.26
|
||||
|
||||
|
||||
/**
|
||||
* @package Dotclear
|
||||
*
|
||||
* @copyright Olivier Meunier & Association Dotclear
|
||||
* @copyright GPL-2.0-only
|
||||
*/
|
||||
#
|
||||
# DOT NOT MODIFY THIS FILE !
|
||||
#
|
||||
|
|
125
src/Backend.php
125
src/Backend.php
|
@ -15,13 +15,14 @@ declare(strict_types=1);
|
|||
namespace Dotclear\Plugin\tinyPacker;
|
||||
|
||||
/* dotclear */
|
||||
use adminModulesList;
|
||||
use dcCore;
|
||||
use dcNsProcess;
|
||||
use dcPage;
|
||||
use Dotclear\Helper\File\Zip\Zip;
|
||||
|
||||
/* clearbricks */
|
||||
use files;
|
||||
use fileZip;
|
||||
use html;
|
||||
use http;
|
||||
use path;
|
||||
|
@ -36,61 +37,11 @@ use Exception;
|
|||
*/
|
||||
class Backend extends dcNsProcess
|
||||
{
|
||||
public static function init(): bool
|
||||
{
|
||||
static::$init = defined('DC_CONTEXT_ADMIN') && dcCOre::app()->auth->isSuperAdmin();
|
||||
/** @var string Public packages folder */
|
||||
public const TINYPACKER_DIR = 'packages';
|
||||
|
||||
return static::$init;
|
||||
}
|
||||
|
||||
public static function process(): bool
|
||||
{
|
||||
if (!static::$init) {
|
||||
return false;
|
||||
}
|
||||
|
||||
dcCore::app()->addBehaviors([
|
||||
'adminModulesListGetActions' => function ($list, $id, $_) {
|
||||
return in_array($list->getList(), [
|
||||
'plugin-activate',
|
||||
'theme-activate',
|
||||
]) ? sprintf(
|
||||
'<input type="submit" name="%s[%s]" value="Pack" />',
|
||||
self::id(),
|
||||
html::escapeHTML($id)
|
||||
) : null;
|
||||
},
|
||||
'adminModulesListDoActions' => function ($list, $modules, $type) {
|
||||
# Pack action
|
||||
if (empty($_POST[self::id()])
|
||||
|| !is_array($_POST[self::id()])) {
|
||||
return null;
|
||||
}
|
||||
|
||||
# Repository directory
|
||||
$dir = path::real(
|
||||
dcCore::app()->blog->public_path . '/packages',
|
||||
false
|
||||
);
|
||||
|
||||
if (!is_dir($dir)) {
|
||||
files::makeDir($dir, true);
|
||||
}
|
||||
if (!is_writable($dir)) {
|
||||
throw new Exception(__('Destination directory is not writable.'));
|
||||
}
|
||||
|
||||
# Module to pack
|
||||
$modules = array_keys($_POST[self::id()]);
|
||||
$id = $modules[0];
|
||||
|
||||
if (!$list->modules->moduleExists($id)) {
|
||||
throw new Exception(__('No such module.'));
|
||||
}
|
||||
$module = $list->modules->getModules($id);
|
||||
|
||||
# Excluded files and dirs
|
||||
$exclude = [
|
||||
/** @var array Excluded files and dirs */
|
||||
public const TINYPACKER_EXCLUDE = [
|
||||
'\.',
|
||||
'\.\.',
|
||||
'__MACOSX',
|
||||
|
@ -104,6 +55,58 @@ class Backend extends dcNsProcess
|
|||
'_disabled',
|
||||
];
|
||||
|
||||
public static function init(): bool
|
||||
{
|
||||
static::$init = defined('DC_CONTEXT_ADMIN') && dcCore::app()->auth->isSuperAdmin();
|
||||
|
||||
return static::$init;
|
||||
}
|
||||
|
||||
public static function process(): bool
|
||||
{
|
||||
if (!static::$init) {
|
||||
return false;
|
||||
}
|
||||
|
||||
dcCore::app()->addBehaviors([
|
||||
'adminModulesListGetActions' => function (adminModulesList $list, string $id, array $_): string {
|
||||
return in_array($list->getList(), [
|
||||
'plugin-activate',
|
||||
'theme-activate',
|
||||
]) ? sprintf(
|
||||
'<input type="submit" name="%s[%s]" value="Pack" />',
|
||||
self::id(),
|
||||
html::escapeHTML($id)
|
||||
) : '';
|
||||
},
|
||||
'adminModulesListDoActions' => function (adminModulesList $list, array $modules, string $type): void {
|
||||
# Pack action
|
||||
if (empty($_POST[self::id()])
|
||||
|| !is_array($_POST[self::id()])) {
|
||||
return;
|
||||
}
|
||||
|
||||
# Repository directory
|
||||
$dir = (string) path::real(
|
||||
dcCore::app()->blog->public_path . DIRECTORY_SEPARATOR . self::TINYPACKER_DIR,
|
||||
false
|
||||
);
|
||||
if (!empty($dir) && !is_dir($dir)) {
|
||||
files::makeDir($dir, true);
|
||||
}
|
||||
if (empty($dir) || !is_writable($dir)) {
|
||||
throw new Exception(__('Destination directory is not writable.'));
|
||||
}
|
||||
|
||||
# Module to pack
|
||||
$modules = array_keys($_POST[self::id()]);
|
||||
$id = $modules[0];
|
||||
|
||||
if (!$list->modules->moduleExists($id)) {
|
||||
throw new Exception(__('No such module.'));
|
||||
}
|
||||
$module = $list->modules->getModules($id);
|
||||
|
||||
# Packages names
|
||||
$files = [
|
||||
$type . '-' . $id . '.zip',
|
||||
|
@ -111,21 +114,19 @@ class Backend extends dcNsProcess
|
|||
];
|
||||
|
||||
# Create zip
|
||||
foreach ($files as $f) {
|
||||
foreach ($files as $file) {
|
||||
@set_time_limit(300);
|
||||
$fp = fopen($dir . '/' . $f, 'wb');
|
||||
|
||||
$zip = new fileZip($fp);
|
||||
$zip = new Zip($dir . '/' . $file);
|
||||
|
||||
foreach ($exclude as $e) {
|
||||
foreach (self::TINYPACKER_EXCLUDE as $e) {
|
||||
$zip->addExclusion(sprintf(
|
||||
'#(^|/)(%s)(/|$)#',
|
||||
$e
|
||||
));
|
||||
}
|
||||
|
||||
$zip->addDirectory($module['root'], $id, true);
|
||||
$zip->write();
|
||||
$zip->addDirectory((string) path::real($module['root']), $id, true);
|
||||
$zip->close();
|
||||
unset($zip);
|
||||
}
|
||||
|
@ -140,7 +141,7 @@ class Backend extends dcNsProcess
|
|||
return true;
|
||||
}
|
||||
|
||||
private function id()
|
||||
private static function id(): string
|
||||
{
|
||||
return basename(dirname(__DIR__));
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue