modifs.mineures sans commentaires

This commit is contained in:
Jephté Clain 2024-09-24 22:15:15 +04:00
parent 15f81c8ecf
commit ccb81d35a6
2 changed files with 204 additions and 28 deletions

127
tests/wip/app/app2Test.php Normal file
View File

@ -0,0 +1,127 @@
<?php
namespace nur\sery\wip\app {
use nulib\tests\TestCase;
use nur\sery\wip\app\impl\config;
use nur\sery\wip\app\impl\myapp2;
use nur\sery\wip\app\impl\MyApplication1;
use nur\sery\wip\app\impl\MyApplication2;
class app2Test extends TestCase {
function testWith() {
$projdir = config::get_projdir();
$cwd = getcwd();
myapp2::reset();
$app1 = myapp2::with(MyApplication1::class);
self::assertSame([
"projdir" => $projdir,
"vendor" => [
"bindir" => "$projdir/vendor/bin",
"autoload" => "$projdir/vendor/autoload.php",
],
"appcode" => "nur-sery",
"cwd" => $cwd,
"datadir" => "$projdir/devel",
"etcdir" => "$projdir/devel/etc",
"vardir" => "$projdir/devel/var",
"logdir" => "$projdir/devel/log",
"profile" => "devel",
"name" => "my-application1",
"title" => null,
], $app1->getParams());
$app2 = myapp2::with(MyApplication2::class, $app1);
self::assertSame([
"projdir" => $projdir,
"vendor" => [
"bindir" => "$projdir/vendor/bin",
"autoload" => "$projdir/vendor/autoload.php",
],
"appcode" => "nur-sery",
"cwd" => $cwd,
"datadir" => "$projdir/devel",
"etcdir" => "$projdir/devel/etc",
"vardir" => "$projdir/devel/var",
"logdir" => "$projdir/devel/log",
"profile" => "devel",
"name" => "my-application2",
"title" => null,
], $app2->getParams());
}
function testInit() {
$projdir = config::get_projdir();
$cwd = getcwd();
myapp2::reset();
myapp2::init(MyApplication1::class);
self::assertSame([
"projdir" => $projdir,
"vendor" => [
"bindir" => "$projdir/vendor/bin",
"autoload" => "$projdir/vendor/autoload.php",
],
"appcode" => "nur-sery",
"cwd" => $cwd,
"datadir" => "$projdir/devel",
"etcdir" => "$projdir/devel/etc",
"vardir" => "$projdir/devel/var",
"logdir" => "$projdir/devel/log",
"profile" => "devel",
"name" => "my-application1",
"title" => null,
], myapp2::get()->getParams());
myapp2::init(MyApplication2::class);
self::assertSame([
"projdir" => $projdir,
"vendor" => [
"bindir" => "$projdir/vendor/bin",
"autoload" => "$projdir/vendor/autoload.php",
],
"appcode" => "nur-sery",
"cwd" => $cwd,
"datadir" => "$projdir/devel",
"etcdir" => "$projdir/devel/etc",
"vardir" => "$projdir/devel/var",
"logdir" => "$projdir/devel/log",
"profile" => "devel",
"name" => "my-application2",
"title" => null,
], myapp2::get()->getParams());
}
}
}
namespace nur\sery\wip\app\impl {
use nur\cli\Application2;
use nur\sery\os\path;
use nur\sery\wip\app\app2;
class config {
const PROJDIR = __DIR__.'/../../..';
static function get_projdir(): string {
return path::abspath(self::PROJDIR);
}
}
class myapp2 extends app2 {
static function reset(): void {
self::$app = null;
}
}
class MyApplication1 extends Application2 {
const PROJDIR = config::PROJDIR;
function main() {
}
}
class MyApplication2 extends Application2 {
const PROJDIR = null;
function main() {
}
}
}

View File

@ -16,14 +16,25 @@ use nur\sery\str;
use nur\sery\ValueException; use nur\sery\ValueException;
class app2 { class app2 {
static ?func $is_bgapplication_enabled = null; static ?func $bgapplication_enabled = null;
/** /**
* spécifier la fonction permettant de vérifier si l'exécution de tâches * spécifier la fonction permettant de vérifier si l'exécution de tâches
* planifiées est autorisé. Par défaut, les tâches planifiées sont autorisées * de fond est autorisée. Si cette méthode n'est pas utilisée, par défaut,
* les tâches planifiées sont autorisées
*
* si $func===true, spécifier une fonction qui retourne toujours vrai
* si $func===false, spécifiée une fonction qui retourne toujours faux
* sinon, $func doit être une fonction valide
*/ */
static function set_bgapplication_enabled_checker($func): void { static function set_bgapplication_enabled($func): void {
self::$is_bgapplication_enabled = func::with($func); if (is_bool($func)) {
$enabled = $func;
$func = function () use ($enabled) {
return $enabled;
};
}
self::$bgapplication_enabled = func::with($func);
} }
/** /**
@ -31,10 +42,10 @@ class app2 {
* afficher une erreur et quitter l'application * afficher une erreur et quitter l'application
*/ */
static function check_bgapplication_enabled(bool $forceEnabled=false): void { static function check_bgapplication_enabled(bool $forceEnabled=false): void {
if (self::$is_bgapplication_enabled === null) return; if (self::$bgapplication_enabled === null) return;
$enabled = boolval(self::$is_bgapplication_enabled->invoke()); $enabled = boolval(self::$bgapplication_enabled->invoke());
if (!$forceEnabled && !$enabled) { if (!$forceEnabled && !$enabled) {
msg::debug("Planifications désactivées. L'application n'a pas été lancée"); msg::debug("Planifications désactivées. La tâche n'a pas été lancée");
throw new ExitError(); throw new ExitError();
} }
} }
@ -51,7 +62,9 @@ class app2 {
if ($app instanceof self) { if ($app instanceof self) {
$params = $app->getParams(); $params = $app->getParams();
} elseif ($app instanceof Application || $app instanceof Application2) { } elseif ($app instanceof Application || $app instanceof Application2) {
$class = get_class($app);
$params = [ $params = [
"class" => $class,
"projdir" => $app::PROJDIR, "projdir" => $app::PROJDIR,
"vendor" => $app::VENDOR, "vendor" => $app::VENDOR,
"appcode" => $app::APPCODE, "appcode" => $app::APPCODE,
@ -59,12 +72,14 @@ class app2 {
"etcdir" => $app::ETCDIR, "etcdir" => $app::ETCDIR,
"vardir" => $app::VARDIR, "vardir" => $app::VARDIR,
"logdir" => $app::LOGDIR, "logdir" => $app::LOGDIR,
"apptype" => "cli", "appgroup" => $app::APPGROUP,
"name" => $app::NAME, "name" => $app::NAME,
"title" => $app::TITLE, "title" => $app::TITLE,
]; ];
} elseif (self::isa_Application($app)) { } elseif (self::isa_Application($app)) {
$class = $app;
$params = [ $params = [
"class" => $class,
"projdir" => constant("$app::PROJDIR"), "projdir" => constant("$app::PROJDIR"),
"vendor" => constant("$app::VENDOR"), "vendor" => constant("$app::VENDOR"),
"appcode" => constant("$app::APPCODE"), "appcode" => constant("$app::APPCODE"),
@ -72,7 +87,7 @@ class app2 {
"etcdir" => constant("$app::ETCDIR"), "etcdir" => constant("$app::ETCDIR"),
"vardir" => constant("$app::VARDIR"), "vardir" => constant("$app::VARDIR"),
"logdir" => constant("$app::LOGDIR"), "logdir" => constant("$app::LOGDIR"),
"apptype" => "cli", "appgroup" => constant("$app::APPGROUP"),
"name" => constant("$app::NAME"), "name" => constant("$app::NAME"),
"title" => constant("$app::TITLE"), "title" => constant("$app::TITLE"),
]; ];
@ -84,29 +99,32 @@ class app2 {
return $params; return $params;
} }
protected static ?self $app = null;
/** /**
* @param Application|string $app * @param Application|string|array $app
* @param Application|string $proj * @param Application|string|array|null $proj
*/ */
static function with($app, $proj=null): self { static function with($app, $proj=null): self {
$params = self::get_params($app); $params = self::get_params($app);
$proj ??= self::$app;
$proj_params = $proj !== null? self::get_params($proj): null; $proj_params = $proj !== null? self::get_params($proj): null;
if ($proj_params !== null) { if ($proj_params !== null) {
A::merge($params, cl::select($proj_params, [ A::merge($params, cl::select($proj_params, [
"projdir", "projdir",
"vendor", "vendor",
"appcode", "appcode",
"cwd",
"datadir", "datadir",
"etcdir", "etcdir",
"vardir", "vardir",
"logdir", "logdir",
"profile",
])); ]));
} }
return new static($params, $proj_params !== null); return new static($params, $proj_params !== null);
} }
protected static ?self $app = null;
static function init($app, $proj=null): void { static function init($app, $proj=null): void {
self::$app = static::with($app, $proj); self::$app = static::with($app, $proj);
} }
@ -129,27 +147,50 @@ class app2 {
"projdir" => $projdir, "projdir" => $projdir,
"vendor" => $vendor, "vendor" => $vendor,
"appcode" => $appcode, "appcode" => $appcode,
"cwd" => $cwd,
"datadir" => $datadir, "datadir" => $datadir,
"etcdir" => $etcdir, "etcdir" => $etcdir,
"vardir" => $vardir, "vardir" => $vardir,
"logdir" => $logdir, "logdir" => $logdir,
"profile" => $profile,
] = $params; ] = $params;
$cwd = $params["cwd"] ?? null;
$datadirIsDefined = true;
$profile = $params["profile"] ?? null;
} else { } else {
$projdir = path::abspath($params["projdir"] ?? "."); # projdir
$projdir = $params["projdir"] ?? null;
if ($projdir === null) {
global $_composer_autoload_path, $_composer_bin_dir;
$autoload = $_composer_autoload_path ?? null;
$bindir = $_composer_bin_dir ?? null;
if ($autoload !== null) {
$vendor = preg_replace('/\/[^\/]+\.php$/', "", $autoload);
$bindir ??= "$vendor/bin";
$projdir = preg_replace('/\/[^\/]+$/', "", $vendor);
$params["vendor"] = [
"autoload" => $autoload,
"bindir" => $bindir,
];
}
}
if ($projdir === null) $projdir = ".";
$projdir = path::abspath($projdir);
# vendor
$vendor = $params["vendor"] ?? self::DEFAULT_VENDOR; $vendor = $params["vendor"] ?? self::DEFAULT_VENDOR;
$vendor["bindir"] = path::reljoin($projdir, $vendor["bindir"]); $vendor["bindir"] = path::reljoin($projdir, $vendor["bindir"]);
$vendor["autoload"] = path::reljoin($projdir, $vendor["autoload"]); $vendor["autoload"] = path::reljoin($projdir, $vendor["autoload"]);
$appcode = $params["appcode"] ?? "app"; # appcode
$appcode = $params["appcode"] ?? null;
if ($appcode === null) {
$appcode = str::without_suffix("-app", path::basename($projdir));
}
$APPCODE = str_replace("-", "_", strtoupper($appcode)); $APPCODE = str_replace("-", "_", strtoupper($appcode));
# cwd # cwd
$cwd = getcwd(); $cwd = $params["cwd"] ?? null;
# datadir # datadir
$datadir = getenv("${APPCODE}_DATADIR"); $datadir = getenv("${APPCODE}_DATADIR");
$datadirIsDefined = $datadir !== false; $datadirIsDefined = $datadir !== false;
if ($datadir === false) $datadir = $params["datadir"] ?? null; if ($datadir === false) $datadir = $params["datadir"] ?? null;
if ($datadir === null) $datadir = "devel/data"; if ($datadir === null) $datadir = "devel";
$datadir = path::reljoin($projdir, $datadir); $datadir = path::reljoin($projdir, $datadir);
# etcdir # etcdir
$etcdir = getenv("${APPCODE}_ETCDIR"); $etcdir = getenv("${APPCODE}_ETCDIR");
@ -170,8 +211,12 @@ class app2 {
$profile = getenv("${APPCODE}_PROFILE"); $profile = getenv("${APPCODE}_PROFILE");
if ($profile === false) $profile = getenv("APP_PROFILE"); if ($profile === false) $profile = getenv("APP_PROFILE");
if ($profile === false) $profile = $params["profile"] ?? null; if ($profile === false) $profile = $params["profile"] ?? null;
if ($profile === null) $profile = $datadirIsDefined? "prod": "devel";
} }
# cwd
$cwd ??= getcwd();
# profile
$profile ??= $datadirIsDefined? "prod": "devel";
$this->projdir = $projdir; $this->projdir = $projdir;
$this->vendor = $vendor; $this->vendor = $vendor;
$this->appcode = $appcode; $this->appcode = $appcode;
@ -182,17 +227,18 @@ class app2 {
$this->logdir = $logdir; $this->logdir = $logdir;
$this->profile = $profile; $this->profile = $profile;
# apptype, name, title # name, title
$this->apptype = $params["apptype"] ?? "cli"; $appgroup = $params["appgroup"] ?? null;
$name = $params["name"] ?? null; $name = $params["name"] ?? $params["class"] ?? null;
if ($name === null) { if ($name === null) {
$name = $appcode; $name = $appcode;
} else { } else {
# si $name est une classe, enlever le package et normaliser i.e # si $name est une classe, enlever le package et normaliser i.e
# my\package\MyApplication --> my-application # my\package\MyApplication --> my-application
$name = preg_replace('/.*\\\\/', "", $name); $name = preg_replace('/.*\\\\/', "", $name);
$name = str::without_suffix("-app", str::camel2us($name, false, "-")); $name = str::camel2us($name, false, "-");
} }
$this->appgroup = $appgroup;
$this->name = $name; $this->name = $name;
$this->title = $params["title"] ?? null; $this->title = $params["title"] ?? null;
} }
@ -261,6 +307,9 @@ class app2 {
/** /**
* @param ?string|false $profile * @param ?string|false $profile
*
* false === pas de profil
* null === profil par défaut
*/ */
function withProfile(string $file, $profile): string { function withProfile(string $file, $profile): string {
if ($profile !== false) { if ($profile !== false) {
@ -306,10 +355,10 @@ class app2 {
############################################################################# #############################################################################
# Paramètres spécifiques à cette application # Paramètres spécifiques à cette application
protected string $apptype; protected string $appgroup;
function getApptype(): string { function getAppgroup(): ?string {
return $this->apptype; return $this->appgroup;
} }
protected string $name; protected string $name;
@ -339,7 +388,7 @@ class app2 {
"vardir" => $this->vardir, "vardir" => $this->vardir,
"logdir" => $this->logdir, "logdir" => $this->logdir,
"profile" => $this->profile, "profile" => $this->profile,
"apptype" => $this->apptype, "appgroup" => $this->appgroup,
"name" => $this->name, "name" => $this->name,
"title" => $this->title, "title" => $this->title,
]; ];