update 2024-04-16 17:05:43
This commit is contained in:
parent
e328ad5ce3
commit
41aa3a166c
@ -28,6 +28,8 @@ class JoomlaPower << (F,LightGreen) >> #RoyalBlue {
|
|||||||
+ load(array $guids) : void
|
+ load(array $guids) : void
|
||||||
+ get(string $guid, int $build) : ?object
|
+ get(string $guid, int $build) : ?object
|
||||||
- set(string $guid) : bool
|
- set(string $guid) : bool
|
||||||
|
- extractLastNameFromNamespace(string $namespace) : ?string
|
||||||
|
- removeLastNameFromNamespace(string $namespace) : string
|
||||||
- isPowerSet(string $guid) : bool
|
- isPowerSet(string $guid) : bool
|
||||||
- isGuidValid(string $guid) : bool
|
- isGuidValid(string $guid) : bool
|
||||||
- getPowerData(string $guid) : ?object
|
- getPowerData(string $guid) : ?object
|
||||||
@ -39,7 +41,7 @@ class JoomlaPower << (F,LightGreen) >> #RoyalBlue {
|
|||||||
note right of JoomlaPower::__construct
|
note right of JoomlaPower::__construct
|
||||||
Constructor.
|
Constructor.
|
||||||
|
|
||||||
since: 3.2.0
|
since: 3.2.1
|
||||||
|
|
||||||
arguments:
|
arguments:
|
||||||
Config $config
|
Config $config
|
||||||
@ -52,63 +54,77 @@ end note
|
|||||||
note left of JoomlaPower::load
|
note left of JoomlaPower::load
|
||||||
load all the powers linked to this component
|
load all the powers linked to this component
|
||||||
|
|
||||||
since: 3.2.0
|
since: 3.2.1
|
||||||
return: void
|
return: void
|
||||||
end note
|
end note
|
||||||
|
|
||||||
note right of JoomlaPower::get
|
note right of JoomlaPower::get
|
||||||
Get a power
|
Get a power
|
||||||
|
|
||||||
since: 3.2.0
|
since: 3.2.1
|
||||||
return: ?object
|
return: ?object
|
||||||
end note
|
end note
|
||||||
|
|
||||||
note left of JoomlaPower::set
|
note left of JoomlaPower::set
|
||||||
Set a power
|
Set a power
|
||||||
|
|
||||||
since: 3.2.0
|
since: 3.2.1
|
||||||
return: bool
|
return: bool
|
||||||
end note
|
end note
|
||||||
|
|
||||||
|
note right of JoomlaPower::extractLastNameFromNamespace
|
||||||
|
Extracts the last part of a namespace string, which is typically the class name.
|
||||||
|
|
||||||
|
since: 3.2.1
|
||||||
|
return: ?string
|
||||||
|
end note
|
||||||
|
|
||||||
|
note left of JoomlaPower::removeLastNameFromNamespace
|
||||||
|
Removes the last name from the namespace.
|
||||||
|
|
||||||
|
since: 3.2.1
|
||||||
|
return: string
|
||||||
|
end note
|
||||||
|
|
||||||
note right of JoomlaPower::isPowerSet
|
note right of JoomlaPower::isPowerSet
|
||||||
Check if the power is already set
|
Check if the power is already set
|
||||||
|
|
||||||
since: 3.2.0
|
since: 3.2.1
|
||||||
return: bool
|
return: bool
|
||||||
end note
|
end note
|
||||||
|
|
||||||
note left of JoomlaPower::isGuidValid
|
note left of JoomlaPower::isGuidValid
|
||||||
Validate the GUID
|
Validate the GUID
|
||||||
|
|
||||||
since: 3.2.0
|
since: 3.2.1
|
||||||
return: bool
|
return: bool
|
||||||
end note
|
end note
|
||||||
|
|
||||||
note right of JoomlaPower::getPowerData
|
note right of JoomlaPower::getPowerData
|
||||||
Get the power data from the database
|
Get the power data from the database
|
||||||
|
|
||||||
since: 3.2.0
|
since: 3.2.1
|
||||||
return: ?object
|
return: ?object
|
||||||
end note
|
end note
|
||||||
|
|
||||||
note left of JoomlaPower::getCleanNamespace
|
note left of JoomlaPower::getCleanNamespace
|
||||||
Get Clean Namespace without use or ; as part of the name space
|
Get Clean Namespace without use or ; as part of the name space
|
||||||
|
|
||||||
since: 3.2.0
|
since: 3.2.1
|
||||||
return: string
|
return: string
|
||||||
end note
|
end note
|
||||||
|
|
||||||
note right of JoomlaPower::getUseNamespace
|
note right of JoomlaPower::getUseNamespace
|
||||||
Get [use Namespace\Class;]
|
Get [use Namespace\Class;]
|
||||||
|
|
||||||
since: 3.2.0
|
since: 3.2.1
|
||||||
return: string
|
return: string
|
||||||
end note
|
end note
|
||||||
|
|
||||||
note left of JoomlaPower::setSuperPowers
|
note left of JoomlaPower::setSuperPowers
|
||||||
Set the super powers of this power
|
Set the super powers of this power
|
||||||
|
|
||||||
since: 3.2.0
|
since: 3.2.1
|
||||||
return: void
|
return: void
|
||||||
end note
|
end note
|
||||||
|
|
||||||
|
@ -16,12 +16,9 @@ use Joomla\CMS\Factory;
|
|||||||
use Joomla\CMS\Application\CMSApplication;
|
use Joomla\CMS\Application\CMSApplication;
|
||||||
use Joomla\CMS\Language\Text;
|
use Joomla\CMS\Language\Text;
|
||||||
use VDM\Joomla\Utilities\ArrayHelper;
|
use VDM\Joomla\Utilities\ArrayHelper;
|
||||||
use VDM\Joomla\Utilities\StringHelper;
|
|
||||||
use VDM\Joomla\Utilities\JsonHelper;
|
use VDM\Joomla\Utilities\JsonHelper;
|
||||||
use VDM\Joomla\Utilities\GuidHelper;
|
use VDM\Joomla\Utilities\GuidHelper;
|
||||||
use VDM\Joomla\Utilities\String\ClassfunctionHelper;
|
|
||||||
use VDM\Joomla\Utilities\String\NamespaceHelper;
|
use VDM\Joomla\Utilities\String\NamespaceHelper;
|
||||||
use VDM\Joomla\Componentbuilder\Compiler\Factory as Compiler;
|
|
||||||
use VDM\Joomla\Componentbuilder\Compiler\Config;
|
use VDM\Joomla\Componentbuilder\Compiler\Config;
|
||||||
use VDM\Joomla\Componentbuilder\Compiler\Placeholder;
|
use VDM\Joomla\Componentbuilder\Compiler\Placeholder;
|
||||||
use VDM\Joomla\Componentbuilder\Compiler\Customcode;
|
use VDM\Joomla\Componentbuilder\Compiler\Customcode;
|
||||||
@ -31,7 +28,9 @@ use VDM\Joomla\Componentbuilder\Compiler\Interfaces\PowerInterface;
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Power
|
* Joomla Power
|
||||||
|
*
|
||||||
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
final class JoomlaPower implements PowerInterface
|
final class JoomlaPower implements PowerInterface
|
||||||
{
|
{
|
||||||
@ -39,7 +38,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* All loaded powers
|
* All loaded powers
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
public array $active = [];
|
public array $active = [];
|
||||||
|
|
||||||
@ -47,7 +46,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* All power namespaces
|
* All power namespaces
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
public array $namespace = [];
|
public array $namespace = [];
|
||||||
|
|
||||||
@ -55,7 +54,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* All super powers of this build
|
* All super powers of this build
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
public array $superpowers = [];
|
public array $superpowers = [];
|
||||||
|
|
||||||
@ -63,7 +62,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* Old super powers found in the local repos
|
* Old super powers found in the local repos
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
public array $old_superpowers = [];
|
public array $old_superpowers = [];
|
||||||
|
|
||||||
@ -71,7 +70,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* The url to the power, if there is an error.
|
* The url to the power, if there is an error.
|
||||||
*
|
*
|
||||||
* @var string
|
* @var string
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected string $fixUrl;
|
protected string $fixUrl;
|
||||||
|
|
||||||
@ -79,7 +78,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* The state of all loaded powers
|
* The state of all loaded powers
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected array $state = [];
|
protected array $state = [];
|
||||||
|
|
||||||
@ -87,7 +86,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* The state of retry to loaded powers
|
* The state of retry to loaded powers
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected array $retry = [];
|
protected array $retry = [];
|
||||||
|
|
||||||
@ -95,7 +94,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* Compiler Config
|
* Compiler Config
|
||||||
*
|
*
|
||||||
* @var Config
|
* @var Config
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected Config $config;
|
protected Config $config;
|
||||||
|
|
||||||
@ -103,7 +102,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* Compiler Placeholder
|
* Compiler Placeholder
|
||||||
*
|
*
|
||||||
* @var Placeholder
|
* @var Placeholder
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected Placeholder $placeholder;
|
protected Placeholder $placeholder;
|
||||||
|
|
||||||
@ -111,7 +110,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* Compiler Customcode
|
* Compiler Customcode
|
||||||
*
|
*
|
||||||
* @var Customcode
|
* @var Customcode
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected Customcode $customcode;
|
protected Customcode $customcode;
|
||||||
|
|
||||||
@ -119,7 +118,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* Compiler Customcode in Gui
|
* Compiler Customcode in Gui
|
||||||
*
|
*
|
||||||
* @var Gui
|
* @var Gui
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected Gui $gui;
|
protected Gui $gui;
|
||||||
|
|
||||||
@ -127,21 +126,21 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* The JCB Superpower class
|
* The JCB Superpower class
|
||||||
*
|
*
|
||||||
* @var Superpower
|
* @var Superpower
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected Superpower $superpower;
|
protected Superpower $superpower;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Database object to query local DB
|
* Database object to query local DB
|
||||||
*
|
*
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected $db;
|
protected $db;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Database object to query local DB
|
* Database object to query local DB
|
||||||
*
|
*
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected $app;
|
protected $app;
|
||||||
|
|
||||||
@ -155,7 +154,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* @param Superpower $superpower The JCB superpower object.
|
* @param Superpower $superpower The JCB superpower object.
|
||||||
*
|
*
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
public function __construct(Config $config, Placeholder $placeholder,
|
public function __construct(Config $config, Placeholder $placeholder,
|
||||||
Customcode $customcode, Gui $gui, Superpower $superpower)
|
Customcode $customcode, Gui $gui, Superpower $superpower)
|
||||||
@ -175,7 +174,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* @param array $guids The global unique ids of the linked powers
|
* @param array $guids The global unique ids of the linked powers
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
public function load(array $guids)
|
public function load(array $guids)
|
||||||
{
|
{
|
||||||
@ -195,7 +194,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* @param int $build Force build switch (to override global switch)
|
* @param int $build Force build switch (to override global switch)
|
||||||
*
|
*
|
||||||
* @return object|null
|
* @return object|null
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
public function get(string $guid, int $build = 0): ?object
|
public function get(string $guid, int $build = 0): ?object
|
||||||
{
|
{
|
||||||
@ -213,7 +212,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* @param string $guid The global unique id of the power
|
* @param string $guid The global unique id of the power
|
||||||
*
|
*
|
||||||
* @return bool true on successful setting of a power
|
* @return bool true on successful setting of a power
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function set(string $guid): bool
|
private function set(string $guid): bool
|
||||||
{
|
{
|
||||||
@ -235,9 +234,34 @@ final class JoomlaPower implements PowerInterface
|
|||||||
// all powers linked to it
|
// all powers linked to it
|
||||||
$this->state[$guid] = true;
|
$this->state[$guid] = true;
|
||||||
|
|
||||||
echo '<pre>';
|
// convert settings to an array
|
||||||
var_dump($this->active[$guid]);
|
if (JsonHelper::check($this->active[$guid]->settings))
|
||||||
exit;
|
{
|
||||||
|
$this->active[$guid]->settings = $settings
|
||||||
|
= json_decode($this->active[$guid]->settings, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
// set a target version
|
||||||
|
$joomla_version = $this->config->joomla_version;
|
||||||
|
|
||||||
|
if ($joomla_version && ArrayHelper::check($settings))
|
||||||
|
{
|
||||||
|
foreach ($settings as $namespace)
|
||||||
|
{
|
||||||
|
if ($joomla_version == $namespace['joomla_version'] ||
|
||||||
|
$namespace['joomla_version'] == 0)
|
||||||
|
{
|
||||||
|
$this->active[$guid]->namespace = $namespace['namespace'];
|
||||||
|
$this->active[$guid]->type = $namespace['type'] ?? 'class';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->active[$guid]->class_name =
|
||||||
|
$this->extractLastNameFromNamespace($this->active[$guid]->namespace);
|
||||||
|
|
||||||
|
$this->active[$guid]->_namespace =
|
||||||
|
$this->removeLastNameFromNamespace($this->active[$guid]->namespace);
|
||||||
|
|
||||||
// set the approved super power values
|
// set the approved super power values
|
||||||
$this->setSuperPowers($guid);
|
$this->setSuperPowers($guid);
|
||||||
@ -245,6 +269,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// we failed to get the power,
|
// we failed to get the power,
|
||||||
// so we raise an error message
|
// so we raise an error message
|
||||||
@ -277,13 +302,55 @@ final class JoomlaPower implements PowerInterface
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Extracts the last part of a namespace string, which is typically the class name.
|
||||||
|
*
|
||||||
|
* @param string $namespace The namespace string to extract from.
|
||||||
|
*
|
||||||
|
* @return string|null The extracted class name.
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
private function extractLastNameFromNamespace(string $namespace): ?string
|
||||||
|
{
|
||||||
|
$parts = explode('\\', $namespace);
|
||||||
|
$result = end($parts);
|
||||||
|
|
||||||
|
// Remove '\\' from the beginning and end of the resulting string
|
||||||
|
$result = trim($result, '\\');
|
||||||
|
|
||||||
|
// If the resulting string is empty, return null
|
||||||
|
return empty($result) ? null : $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes the last name from the namespace.
|
||||||
|
*
|
||||||
|
* @param string $namespace The namespace
|
||||||
|
*
|
||||||
|
* @return string The namespace shortened
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
private function removeLastNameFromNamespace(string $namespace): string
|
||||||
|
{
|
||||||
|
// Remove '\\' from the beginning and end of the resulting string
|
||||||
|
$namespace = trim($namespace, '\\');
|
||||||
|
|
||||||
|
$parts = explode('\\', $namespace);
|
||||||
|
|
||||||
|
// Remove the last part (the class name)
|
||||||
|
array_pop($parts);
|
||||||
|
|
||||||
|
// Reassemble the namespace without the class name
|
||||||
|
return implode('\\', $parts);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if the power is already set
|
* Check if the power is already set
|
||||||
*
|
*
|
||||||
* @param string $guid The global unique id of the power
|
* @param string $guid The global unique id of the power
|
||||||
*
|
*
|
||||||
* @return bool true if the power is already set
|
* @return bool true if the power is already set
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function isPowerSet(string $guid): bool
|
private function isPowerSet(string $guid): bool
|
||||||
{
|
{
|
||||||
@ -296,7 +363,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* @param string $guid The global unique id of the power
|
* @param string $guid The global unique id of the power
|
||||||
*
|
*
|
||||||
* @return bool true if the GUID is valid
|
* @return bool true if the GUID is valid
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function isGuidValid(string $guid): bool
|
private function isGuidValid(string $guid): bool
|
||||||
{
|
{
|
||||||
@ -309,7 +376,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* @param string $guid The global unique id of the power
|
* @param string $guid The global unique id of the power
|
||||||
*
|
*
|
||||||
* @return object|null The power data
|
* @return object|null The power data
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function getPowerData(string $guid): ?object
|
private function getPowerData(string $guid): ?object
|
||||||
{
|
{
|
||||||
@ -336,7 +403,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* @param bool $removeNumbers The switch to remove numbers
|
* @param bool $removeNumbers The switch to remove numbers
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function getCleanNamespace(string $namespace): string
|
private function getCleanNamespace(string $namespace): string
|
||||||
{
|
{
|
||||||
@ -351,7 +418,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* @param string $as The use as name (default is none)
|
* @param string $as The use as name (default is none)
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function getUseNamespace(string $namespace, string $as = 'default'): string
|
private function getUseNamespace(string $namespace, string $as = 'default'): string
|
||||||
{
|
{
|
||||||
@ -369,7 +436,7 @@ final class JoomlaPower implements PowerInterface
|
|||||||
* @param string $guid The global unique id of the power
|
* @param string $guid The global unique id of the power
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function setSuperPowers(string $guid): void
|
private function setSuperPowers(string $guid): void
|
||||||
{
|
{
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* All loaded powers
|
* All loaded powers
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
public array $active = [];
|
public array $active = [];
|
||||||
|
|
||||||
@ -10,7 +10,7 @@
|
|||||||
* All power namespaces
|
* All power namespaces
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
public array $namespace = [];
|
public array $namespace = [];
|
||||||
|
|
||||||
@ -18,7 +18,7 @@
|
|||||||
* All super powers of this build
|
* All super powers of this build
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
public array $superpowers = [];
|
public array $superpowers = [];
|
||||||
|
|
||||||
@ -26,7 +26,7 @@
|
|||||||
* Old super powers found in the local repos
|
* Old super powers found in the local repos
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
public array $old_superpowers = [];
|
public array $old_superpowers = [];
|
||||||
|
|
||||||
@ -34,7 +34,7 @@
|
|||||||
* The url to the power, if there is an error.
|
* The url to the power, if there is an error.
|
||||||
*
|
*
|
||||||
* @var string
|
* @var string
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected string $fixUrl;
|
protected string $fixUrl;
|
||||||
|
|
||||||
@ -42,7 +42,7 @@
|
|||||||
* The state of all loaded powers
|
* The state of all loaded powers
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected array $state = [];
|
protected array $state = [];
|
||||||
|
|
||||||
@ -50,7 +50,7 @@
|
|||||||
* The state of retry to loaded powers
|
* The state of retry to loaded powers
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected array $retry = [];
|
protected array $retry = [];
|
||||||
|
|
||||||
@ -58,7 +58,7 @@
|
|||||||
* Compiler Config
|
* Compiler Config
|
||||||
*
|
*
|
||||||
* @var Config
|
* @var Config
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected Config $config;
|
protected Config $config;
|
||||||
|
|
||||||
@ -66,7 +66,7 @@
|
|||||||
* Compiler Placeholder
|
* Compiler Placeholder
|
||||||
*
|
*
|
||||||
* @var Placeholder
|
* @var Placeholder
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected Placeholder $placeholder;
|
protected Placeholder $placeholder;
|
||||||
|
|
||||||
@ -74,7 +74,7 @@
|
|||||||
* Compiler Customcode
|
* Compiler Customcode
|
||||||
*
|
*
|
||||||
* @var Customcode
|
* @var Customcode
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected Customcode $customcode;
|
protected Customcode $customcode;
|
||||||
|
|
||||||
@ -82,7 +82,7 @@
|
|||||||
* Compiler Customcode in Gui
|
* Compiler Customcode in Gui
|
||||||
*
|
*
|
||||||
* @var Gui
|
* @var Gui
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected Gui $gui;
|
protected Gui $gui;
|
||||||
|
|
||||||
@ -90,21 +90,21 @@
|
|||||||
* The JCB Superpower class
|
* The JCB Superpower class
|
||||||
*
|
*
|
||||||
* @var Superpower
|
* @var Superpower
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected Superpower $superpower;
|
protected Superpower $superpower;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Database object to query local DB
|
* Database object to query local DB
|
||||||
*
|
*
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected $db;
|
protected $db;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Database object to query local DB
|
* Database object to query local DB
|
||||||
*
|
*
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected $app;
|
protected $app;
|
||||||
|
|
||||||
@ -118,7 +118,7 @@
|
|||||||
* @param Superpower $superpower The JCB superpower object.
|
* @param Superpower $superpower The JCB superpower object.
|
||||||
*
|
*
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
public function __construct(Config $config, Placeholder $placeholder,
|
public function __construct(Config $config, Placeholder $placeholder,
|
||||||
Customcode $customcode, Gui $gui, Superpower $superpower)
|
Customcode $customcode, Gui $gui, Superpower $superpower)
|
||||||
@ -138,7 +138,7 @@
|
|||||||
* @param array $guids The global unique ids of the linked powers
|
* @param array $guids The global unique ids of the linked powers
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
public function load(array $guids)
|
public function load(array $guids)
|
||||||
{
|
{
|
||||||
@ -158,7 +158,7 @@
|
|||||||
* @param int $build Force build switch (to override global switch)
|
* @param int $build Force build switch (to override global switch)
|
||||||
*
|
*
|
||||||
* @return object|null
|
* @return object|null
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
public function get(string $guid, int $build = 0): ?object
|
public function get(string $guid, int $build = 0): ?object
|
||||||
{
|
{
|
||||||
@ -176,7 +176,7 @@
|
|||||||
* @param string $guid The global unique id of the power
|
* @param string $guid The global unique id of the power
|
||||||
*
|
*
|
||||||
* @return bool true on successful setting of a power
|
* @return bool true on successful setting of a power
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function set(string $guid): bool
|
private function set(string $guid): bool
|
||||||
{
|
{
|
||||||
@ -198,9 +198,34 @@
|
|||||||
// all powers linked to it
|
// all powers linked to it
|
||||||
$this->state[$guid] = true;
|
$this->state[$guid] = true;
|
||||||
|
|
||||||
echo '<pre>';
|
// convert settings to an array
|
||||||
var_dump($this->active[$guid]);
|
if (JsonHelper::check($this->active[$guid]->settings))
|
||||||
exit;
|
{
|
||||||
|
$this->active[$guid]->settings = $settings
|
||||||
|
= json_decode($this->active[$guid]->settings, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
// set a target version
|
||||||
|
$joomla_version = $this->config->joomla_version;
|
||||||
|
|
||||||
|
if ($joomla_version && ArrayHelper::check($settings))
|
||||||
|
{
|
||||||
|
foreach ($settings as $namespace)
|
||||||
|
{
|
||||||
|
if ($joomla_version == $namespace['joomla_version'] ||
|
||||||
|
$namespace['joomla_version'] == 0)
|
||||||
|
{
|
||||||
|
$this->active[$guid]->namespace = $namespace['namespace'];
|
||||||
|
$this->active[$guid]->type = $namespace['type'] ?? 'class';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->active[$guid]->class_name =
|
||||||
|
$this->extractLastNameFromNamespace($this->active[$guid]->namespace);
|
||||||
|
|
||||||
|
$this->active[$guid]->_namespace =
|
||||||
|
$this->removeLastNameFromNamespace($this->active[$guid]->namespace);
|
||||||
|
|
||||||
// set the approved super power values
|
// set the approved super power values
|
||||||
$this->setSuperPowers($guid);
|
$this->setSuperPowers($guid);
|
||||||
@ -208,6 +233,7 @@
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// we failed to get the power,
|
// we failed to get the power,
|
||||||
// so we raise an error message
|
// so we raise an error message
|
||||||
@ -240,13 +266,55 @@
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Extracts the last part of a namespace string, which is typically the class name.
|
||||||
|
*
|
||||||
|
* @param string $namespace The namespace string to extract from.
|
||||||
|
*
|
||||||
|
* @return string|null The extracted class name.
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
private function extractLastNameFromNamespace(string $namespace): ?string
|
||||||
|
{
|
||||||
|
$parts = explode('\\', $namespace);
|
||||||
|
$result = end($parts);
|
||||||
|
|
||||||
|
// Remove '\\' from the beginning and end of the resulting string
|
||||||
|
$result = trim($result, '\\');
|
||||||
|
|
||||||
|
// If the resulting string is empty, return null
|
||||||
|
return empty($result) ? null : $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes the last name from the namespace.
|
||||||
|
*
|
||||||
|
* @param string $namespace The namespace
|
||||||
|
*
|
||||||
|
* @return string The namespace shortened
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
private function removeLastNameFromNamespace(string $namespace): string
|
||||||
|
{
|
||||||
|
// Remove '\\' from the beginning and end of the resulting string
|
||||||
|
$namespace = trim($namespace, '\\');
|
||||||
|
|
||||||
|
$parts = explode('\\', $namespace);
|
||||||
|
|
||||||
|
// Remove the last part (the class name)
|
||||||
|
array_pop($parts);
|
||||||
|
|
||||||
|
// Reassemble the namespace without the class name
|
||||||
|
return implode('\\', $parts);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if the power is already set
|
* Check if the power is already set
|
||||||
*
|
*
|
||||||
* @param string $guid The global unique id of the power
|
* @param string $guid The global unique id of the power
|
||||||
*
|
*
|
||||||
* @return bool true if the power is already set
|
* @return bool true if the power is already set
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function isPowerSet(string $guid): bool
|
private function isPowerSet(string $guid): bool
|
||||||
{
|
{
|
||||||
@ -259,7 +327,7 @@
|
|||||||
* @param string $guid The global unique id of the power
|
* @param string $guid The global unique id of the power
|
||||||
*
|
*
|
||||||
* @return bool true if the GUID is valid
|
* @return bool true if the GUID is valid
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function isGuidValid(string $guid): bool
|
private function isGuidValid(string $guid): bool
|
||||||
{
|
{
|
||||||
@ -272,7 +340,7 @@
|
|||||||
* @param string $guid The global unique id of the power
|
* @param string $guid The global unique id of the power
|
||||||
*
|
*
|
||||||
* @return object|null The power data
|
* @return object|null The power data
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function getPowerData(string $guid): ?object
|
private function getPowerData(string $guid): ?object
|
||||||
{
|
{
|
||||||
@ -299,7 +367,7 @@
|
|||||||
* @param bool $removeNumbers The switch to remove numbers
|
* @param bool $removeNumbers The switch to remove numbers
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function getCleanNamespace(string $namespace): string
|
private function getCleanNamespace(string $namespace): string
|
||||||
{
|
{
|
||||||
@ -314,7 +382,7 @@
|
|||||||
* @param string $as The use as name (default is none)
|
* @param string $as The use as name (default is none)
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function getUseNamespace(string $namespace, string $as = 'default'): string
|
private function getUseNamespace(string $namespace, string $as = 'default'): string
|
||||||
{
|
{
|
||||||
@ -332,7 +400,7 @@
|
|||||||
* @param string $guid The global unique id of the power
|
* @param string $guid The global unique id of the power
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
private function setSuperPowers(string $guid): void
|
private function setSuperPowers(string $guid): void
|
||||||
{
|
{
|
||||||
|
@ -16,10 +16,6 @@
|
|||||||
"use": "0a59c65c-9daf-4bc9-baf4-e063ff9e6a8a",
|
"use": "0a59c65c-9daf-4bc9-baf4-e063ff9e6a8a",
|
||||||
"as": "default"
|
"as": "default"
|
||||||
},
|
},
|
||||||
"use_selection1": {
|
|
||||||
"use": "1f28cb53-60d9-4db1-b517-3c7dc6b429ef",
|
|
||||||
"as": "default"
|
|
||||||
},
|
|
||||||
"use_selection2": {
|
"use_selection2": {
|
||||||
"use": "4b225c51-d293-48e4-b3f6-5136cf5c3f18",
|
"use": "4b225c51-d293-48e4-b3f6-5136cf5c3f18",
|
||||||
"as": "default"
|
"as": "default"
|
||||||
@ -28,18 +24,10 @@
|
|||||||
"use": "9c513baf-b279-43fd-ae29-a585c8cbc4f0",
|
"use": "9c513baf-b279-43fd-ae29-a585c8cbc4f0",
|
||||||
"as": "default"
|
"as": "default"
|
||||||
},
|
},
|
||||||
"use_selection4": {
|
|
||||||
"use": "30c5b4c2-f75f-4d15-869a-f8bfedd87358",
|
|
||||||
"as": "default"
|
|
||||||
},
|
|
||||||
"use_selection5": {
|
"use_selection5": {
|
||||||
"use": "ce8cf834-6bac-44fb-941c-861f7e046cc0",
|
"use": "ce8cf834-6bac-44fb-941c-861f7e046cc0",
|
||||||
"as": "default"
|
"as": "default"
|
||||||
},
|
},
|
||||||
"use_selection6": {
|
|
||||||
"use": "d910d8b8-4c23-4f3e-8cda-438f2d2bd7ac",
|
|
||||||
"as": "Compiler"
|
|
||||||
},
|
|
||||||
"use_selection7": {
|
"use_selection7": {
|
||||||
"use": "fa4bf18e-301e-42e3-91fb-6e0096c07adc",
|
"use": "fa4bf18e-301e-42e3-91fb-6e0096c07adc",
|
||||||
"as": "default"
|
"as": "default"
|
||||||
@ -62,7 +50,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"namespace": "VDM\\Joomla\\Componentbuilder.Compiler.JoomlaPower",
|
"namespace": "VDM\\Joomla\\Componentbuilder.Compiler.JoomlaPower",
|
||||||
"description": "Power",
|
"description": "Joomla Power\r\n\r\n@since 3.2.1",
|
||||||
"licensing_template": "\/**\r\n * @package Joomla.Component.Builder\r\n *\r\n * @created 4th September, 2022\r\n * @author Llewellyn van der Merwe <https:\/\/dev.vdm.io>\r\n * @git Joomla Component Builder <https:\/\/git.vdm.dev\/joomla\/Component-Builder>\r\n * @copyright Copyright (C) 2015 Vast Development Method. All rights reserved.\r\n * @license GNU General Public License version 2 or later; see LICENSE.txt\r\n *\/\r\n",
|
"licensing_template": "\/**\r\n * @package Joomla.Component.Builder\r\n *\r\n * @created 4th September, 2022\r\n * @author Llewellyn van der Merwe <https:\/\/dev.vdm.io>\r\n * @git Joomla Component Builder <https:\/\/git.vdm.dev\/joomla\/Component-Builder>\r\n * @copyright Copyright (C) 2015 Vast Development Method. All rights reserved.\r\n * @license GNU General Public License version 2 or later; see LICENSE.txt\r\n *\/\r\n",
|
||||||
"head": "use Joomla\\CMS\\Factory;\r\nuse Joomla\\CMS\\Application\\CMSApplication;\r\nuse Joomla\\CMS\\Language\\Text;",
|
"head": "use Joomla\\CMS\\Factory;\r\nuse Joomla\\CMS\\Application\\CMSApplication;\r\nuse Joomla\\CMS\\Language\\Text;",
|
||||||
"composer": ""
|
"composer": ""
|
||||||
|
Loading…
x
Reference in New Issue
Block a user