Release of v3.0.9
Add PHP check on installation. Add Database check on installation.
This commit is contained in:
parent
20bd3dfb8b
commit
d9a6c983bc
@ -1,3 +1,8 @@
|
|||||||
|
# v3.0.9
|
||||||
|
|
||||||
|
- Add PHP check on installation.
|
||||||
|
- Add Database check on installation.
|
||||||
|
|
||||||
# v3.0.8
|
# v3.0.8
|
||||||
|
|
||||||
- Moved all library classes away from default Namespace and Folder path to avoid collusion on outdated classes.
|
- Moved all library classes away from default Namespace and Folder path to avoid collusion on outdated classes.
|
||||||
|
26
README.md
26
README.md
@ -1,4 +1,4 @@
|
|||||||
# Get Bible (3.0.8)
|
# Get Bible (3.0.9)
|
||||||
|
|
||||||
![Get Bible image](https://git.vdm.dev/getBible/joomla-component/raw/branch/master/admin/assets/images/vdm-component.jpg "GetBible")
|
![Get Bible image](https://git.vdm.dev/getBible/joomla-component/raw/branch/master/admin/assets/images/vdm-component.jpg "GetBible")
|
||||||
|
|
||||||
@ -18,38 +18,38 @@ In essence, The Bible for Joomla is designed to transform how the Word of God is
|
|||||||
+ *Author*: [Llewellyn van der Merwe](mailto:joomla@vdm.io)
|
+ *Author*: [Llewellyn van der Merwe](mailto:joomla@vdm.io)
|
||||||
+ *Name*: [Get Bible](https://getbible.net)
|
+ *Name*: [Get Bible](https://getbible.net)
|
||||||
+ *First Build*: 3rd December, 2015
|
+ *First Build*: 3rd December, 2015
|
||||||
+ *Last Build*: 6th April, 2024
|
+ *Last Build*: 27th April, 2024
|
||||||
+ *Version*: 3.0.8
|
+ *Version*: 3.0.9
|
||||||
+ *Copyright*: Copyright (C) 2015. All Rights Reserved
|
+ *Copyright*: Copyright (C) 2015. All Rights Reserved
|
||||||
+ *License*: GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
+ *License*: GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
|
||||||
## Build Time
|
## Build Time
|
||||||
|
|
||||||
**563 Hours** or **70 Eight Hour Days** (actual time the author saved -
|
**578 Hours** or **72 Eight Hour Days** (actual time the author saved -
|
||||||
due to [Automated Component Builder](https://www.joomlacomponentbuilder.com))
|
due to [Automated Component Builder](https://www.joomlacomponentbuilder.com))
|
||||||
|
|
||||||
> (if creating a folder and file took **5 seconds** and writing one line of code took **10 seconds**,
|
> (if creating a folder and file took **5 seconds** and writing one line of code took **10 seconds**,
|
||||||
> never making one mistake or taking any coffee break.)
|
> never making one mistake or taking any coffee break.)
|
||||||
|
|
||||||
+ *Line count*: **201873**
|
+ *Line count*: **207156**
|
||||||
+ *File count*: **1720**
|
+ *File count*: **1738**
|
||||||
+ *Folder count*: **150**
|
+ *Folder count*: **150**
|
||||||
|
|
||||||
**372 Hours** or **47 Eight Hour Days** (the actual time the author spent)
|
**381 Hours** or **48 Eight Hour Days** (the actual time the author spent)
|
||||||
|
|
||||||
> (with the following break down:
|
> (with the following break down:
|
||||||
> **debugging @141hours** = codingtime / 4;
|
> **debugging @145hours** = codingtime / 4;
|
||||||
> **planning @80hours** = codingtime / 7;
|
> **planning @83hours** = codingtime / 7;
|
||||||
> **mapping @56hours** = codingtime / 10;
|
> **mapping @58hours** = codingtime / 10;
|
||||||
> **office @94hours** = codingtime / 6;)
|
> **office @96hours** = codingtime / 6;)
|
||||||
|
|
||||||
**935 Hours** or **117 Eight Hour Days**
|
**959 Hours** or **120 Eight Hour Days**
|
||||||
(a total of the realistic time frame for this project)
|
(a total of the realistic time frame for this project)
|
||||||
|
|
||||||
> (if creating a folder and file took **5 seconds** and writing one line of code took **10 seconds**,
|
> (if creating a folder and file took **5 seconds** and writing one line of code took **10 seconds**,
|
||||||
> with the normal everyday realities at the office, that includes the component planning, mapping & debugging.)
|
> with the normal everyday realities at the office, that includes the component planning, mapping & debugging.)
|
||||||
|
|
||||||
Project duration: **23.4 weeks** or **4.9 months**
|
Project duration: **24 weeks** or **5 months**
|
||||||
|
|
||||||
> This **component** was build with a Joomla [Automated Component Builder](https://www.joomlacomponentbuilder.com).
|
> This **component** was build with a Joomla [Automated Component Builder](https://www.joomlacomponentbuilder.com).
|
||||||
> Developed by [Llewellyn van der Merwe](mailto:joomla@vdm.io)
|
> Developed by [Llewellyn van der Merwe](mailto:joomla@vdm.io)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# Get Bible (3.0.8)
|
# Get Bible (3.0.9)
|
||||||
|
|
||||||
![Get Bible image](https://git.vdm.dev/getBible/joomla-component/raw/branch/master/admin/assets/images/vdm-component.jpg "GetBible")
|
![Get Bible image](https://git.vdm.dev/getBible/joomla-component/raw/branch/master/admin/assets/images/vdm-component.jpg "GetBible")
|
||||||
|
|
||||||
@ -18,38 +18,38 @@ In essence, The Bible for Joomla is designed to transform how the Word of God is
|
|||||||
+ *Author*: [Llewellyn van der Merwe](mailto:joomla@vdm.io)
|
+ *Author*: [Llewellyn van der Merwe](mailto:joomla@vdm.io)
|
||||||
+ *Name*: [Get Bible](https://getbible.net)
|
+ *Name*: [Get Bible](https://getbible.net)
|
||||||
+ *First Build*: 3rd December, 2015
|
+ *First Build*: 3rd December, 2015
|
||||||
+ *Last Build*: 6th April, 2024
|
+ *Last Build*: 27th April, 2024
|
||||||
+ *Version*: 3.0.8
|
+ *Version*: 3.0.9
|
||||||
+ *Copyright*: Copyright (C) 2015. All Rights Reserved
|
+ *Copyright*: Copyright (C) 2015. All Rights Reserved
|
||||||
+ *License*: GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
+ *License*: GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
|
||||||
## Build Time
|
## Build Time
|
||||||
|
|
||||||
**563 Hours** or **70 Eight Hour Days** (actual time the author saved -
|
**578 Hours** or **72 Eight Hour Days** (actual time the author saved -
|
||||||
due to [Automated Component Builder](https://www.joomlacomponentbuilder.com))
|
due to [Automated Component Builder](https://www.joomlacomponentbuilder.com))
|
||||||
|
|
||||||
> (if creating a folder and file took **5 seconds** and writing one line of code took **10 seconds**,
|
> (if creating a folder and file took **5 seconds** and writing one line of code took **10 seconds**,
|
||||||
> never making one mistake or taking any coffee break.)
|
> never making one mistake or taking any coffee break.)
|
||||||
|
|
||||||
+ *Line count*: **201873**
|
+ *Line count*: **207156**
|
||||||
+ *File count*: **1720**
|
+ *File count*: **1738**
|
||||||
+ *Folder count*: **150**
|
+ *Folder count*: **150**
|
||||||
|
|
||||||
**372 Hours** or **47 Eight Hour Days** (the actual time the author spent)
|
**381 Hours** or **48 Eight Hour Days** (the actual time the author spent)
|
||||||
|
|
||||||
> (with the following break down:
|
> (with the following break down:
|
||||||
> **debugging @141hours** = codingtime / 4;
|
> **debugging @145hours** = codingtime / 4;
|
||||||
> **planning @80hours** = codingtime / 7;
|
> **planning @83hours** = codingtime / 7;
|
||||||
> **mapping @56hours** = codingtime / 10;
|
> **mapping @58hours** = codingtime / 10;
|
||||||
> **office @94hours** = codingtime / 6;)
|
> **office @96hours** = codingtime / 6;)
|
||||||
|
|
||||||
**935 Hours** or **117 Eight Hour Days**
|
**959 Hours** or **120 Eight Hour Days**
|
||||||
(a total of the realistic time frame for this project)
|
(a total of the realistic time frame for this project)
|
||||||
|
|
||||||
> (if creating a folder and file took **5 seconds** and writing one line of code took **10 seconds**,
|
> (if creating a folder and file took **5 seconds** and writing one line of code took **10 seconds**,
|
||||||
> with the normal everyday realities at the office, that includes the component planning, mapping & debugging.)
|
> with the normal everyday realities at the office, that includes the component planning, mapping & debugging.)
|
||||||
|
|
||||||
Project duration: **23.4 weeks** or **4.9 months**
|
Project duration: **24 weeks** or **5 months**
|
||||||
|
|
||||||
> This **component** was build with a Joomla [Automated Component Builder](https://www.joomlacomponentbuilder.com).
|
> This **component** was build with a Joomla [Automated Component Builder](https://www.joomlacomponentbuilder.com).
|
||||||
> Developed by [Llewellyn van der Merwe](mailto:joomla@vdm.io)
|
> Developed by [Llewellyn van der Merwe](mailto:joomla@vdm.io)
|
||||||
|
@ -79,7 +79,7 @@ class GetbibleControllerTranslations extends AdminController
|
|||||||
{
|
{
|
||||||
// Redirect to the list screen with error.
|
// Redirect to the list screen with error.
|
||||||
$message = Text::_('COM_GETBIBLE_YOU_DO_NOT_HAVE_PERMISSION_TO_UPDATE_THE_BOOK_NAMES_PLEASE_CONTACT_YOUR_SYSTEM_ADMINISTRATOR_FOR_MORE_HELP');
|
$message = Text::_('COM_GETBIBLE_YOU_DO_NOT_HAVE_PERMISSION_TO_UPDATE_THE_BOOK_NAMES_PLEASE_CONTACT_YOUR_SYSTEM_ADMINISTRATOR_FOR_MORE_HELP');
|
||||||
$this->setRedirect(\JRoute::_('index.php?option=com_getbible&view=translations', false), $message, 'error');
|
$this->setRedirect(Route::_('index.php?option=com_getbible&view=translations', false), $message, 'error');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// Redirect to the list screen with error.
|
// Redirect to the list screen with error.
|
||||||
|
@ -18,51 +18,12 @@
|
|||||||
// No direct access to this file
|
// No direct access to this file
|
||||||
defined('_JEXEC') or die('Restricted access');
|
defined('_JEXEC') or die('Restricted access');
|
||||||
|
|
||||||
// register additional namespace
|
// The power autoloader for this project (JPATH_ADMINISTRATOR) area.
|
||||||
\spl_autoload_register(function ($class) {
|
$power_autoloader = JPATH_ADMINISTRATOR . '/components/com_getbible/helpers/powerloader.php';
|
||||||
// project-specific base directories and namespace prefix
|
if (file_exists($power_autoloader))
|
||||||
$search = [
|
{
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.GetBible' => 'TrueChristianChurch\\Joomla\\GetBible',
|
require_once $power_autoloader;
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Openai' => 'TrueChristianChurch\\Joomla\\Openai',
|
}
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Gitea' => 'TrueChristianChurch\\Joomla\\Gitea',
|
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla' => 'TrueChristianChurch\\Joomla'
|
|
||||||
];
|
|
||||||
// Start the search and load if found
|
|
||||||
$found = false;
|
|
||||||
$found_base_dir = "";
|
|
||||||
$found_len = 0;
|
|
||||||
foreach ($search as $base_dir => $prefix)
|
|
||||||
{
|
|
||||||
// does the class use the namespace prefix?
|
|
||||||
$len = strlen($prefix);
|
|
||||||
if (strncmp($prefix, $class, $len) === 0)
|
|
||||||
{
|
|
||||||
// we have a match so load the values
|
|
||||||
$found = true;
|
|
||||||
$found_base_dir = $base_dir;
|
|
||||||
$found_len = $len;
|
|
||||||
// done here
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// check if we found a match
|
|
||||||
if (!$found)
|
|
||||||
{
|
|
||||||
// not found so move to the next registered autoloader
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// get the relative class name
|
|
||||||
$relative_class = substr($class, $found_len);
|
|
||||||
// replace the namespace prefix with the base directory, replace namespace
|
|
||||||
// separators with directory separators in the relative class name, append
|
|
||||||
// with .php
|
|
||||||
$file = JPATH_ROOT . '/' . $found_base_dir . '/src' . str_replace('\\', '/', $relative_class) . '.php';
|
|
||||||
// if the file exists, require it
|
|
||||||
if (file_exists($file))
|
|
||||||
{
|
|
||||||
require $file;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
use Joomla\CMS\Factory;
|
use Joomla\CMS\Factory;
|
||||||
use Joomla\CMS\Language\Text;
|
use Joomla\CMS\Language\Text;
|
||||||
|
@ -18,51 +18,12 @@
|
|||||||
// No direct access to this file
|
// No direct access to this file
|
||||||
defined('_JEXEC') or die('Restricted access');
|
defined('_JEXEC') or die('Restricted access');
|
||||||
|
|
||||||
// register additional namespace
|
// The power autoloader for this project (JPATH_ADMINISTRATOR) area.
|
||||||
\spl_autoload_register(function ($class) {
|
$power_autoloader = JPATH_ADMINISTRATOR . '/components/com_getbible/helpers/powerloader.php';
|
||||||
// project-specific base directories and namespace prefix
|
if (file_exists($power_autoloader))
|
||||||
$search = [
|
{
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.GetBible' => 'TrueChristianChurch\\Joomla\\GetBible',
|
require_once $power_autoloader;
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Openai' => 'TrueChristianChurch\\Joomla\\Openai',
|
}
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Gitea' => 'TrueChristianChurch\\Joomla\\Gitea',
|
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla' => 'TrueChristianChurch\\Joomla'
|
|
||||||
];
|
|
||||||
// Start the search and load if found
|
|
||||||
$found = false;
|
|
||||||
$found_base_dir = "";
|
|
||||||
$found_len = 0;
|
|
||||||
foreach ($search as $base_dir => $prefix)
|
|
||||||
{
|
|
||||||
// does the class use the namespace prefix?
|
|
||||||
$len = strlen($prefix);
|
|
||||||
if (strncmp($prefix, $class, $len) === 0)
|
|
||||||
{
|
|
||||||
// we have a match so load the values
|
|
||||||
$found = true;
|
|
||||||
$found_base_dir = $base_dir;
|
|
||||||
$found_len = $len;
|
|
||||||
// done here
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// check if we found a match
|
|
||||||
if (!$found)
|
|
||||||
{
|
|
||||||
// not found so move to the next registered autoloader
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// get the relative class name
|
|
||||||
$relative_class = substr($class, $found_len);
|
|
||||||
// replace the namespace prefix with the base directory, replace namespace
|
|
||||||
// separators with directory separators in the relative class name, append
|
|
||||||
// with .php
|
|
||||||
$file = JPATH_ROOT . '/' . $found_base_dir . '/src' . str_replace('\\', '/', $relative_class) . '.php';
|
|
||||||
// if the file exists, require it
|
|
||||||
if (file_exists($file))
|
|
||||||
{
|
|
||||||
require $file;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
use Joomla\CMS\Factory;
|
use Joomla\CMS\Factory;
|
||||||
use Joomla\CMS\Language\Text;
|
use Joomla\CMS\Language\Text;
|
||||||
@ -80,6 +41,7 @@ use Joomla\Registry\Registry;
|
|||||||
use Joomla\String\StringHelper;
|
use Joomla\String\StringHelper;
|
||||||
use Joomla\Utilities\ArrayHelper;
|
use Joomla\Utilities\ArrayHelper;
|
||||||
use TrueChristianChurch\Joomla\GetBible\Factory as GetBibleFactory;
|
use TrueChristianChurch\Joomla\GetBible\Factory as GetBibleFactory;
|
||||||
|
use TrueChristianChurch\Joomla\Gitea\Factory as GiteaFactory;
|
||||||
use TrueChristianChurch\Joomla\Utilities\StringHelper as UtilitiesStringHelper;
|
use TrueChristianChurch\Joomla\Utilities\StringHelper as UtilitiesStringHelper;
|
||||||
use TrueChristianChurch\Joomla\Utilities\ObjectHelper;
|
use TrueChristianChurch\Joomla\Utilities\ObjectHelper;
|
||||||
use TrueChristianChurch\Joomla\Utilities\GetHelper;
|
use TrueChristianChurch\Joomla\Utilities\GetHelper;
|
||||||
|
65
admin/helpers/powerloader.php
Normal file
65
admin/helpers/powerloader.php
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
<?php
|
||||||
|
/*----------------------------------------------------------------------------------| io.vdm.dev |----/
|
||||||
|
Vast Development Method
|
||||||
|
/-------------------------------------------------------------------------------------------------------/
|
||||||
|
|
||||||
|
@package getBible.net
|
||||||
|
|
||||||
|
@created 3rd December, 2015
|
||||||
|
@author Llewellyn van der Merwe <https://getbible.net>
|
||||||
|
@git Get Bible <https://git.vdm.dev/getBible>
|
||||||
|
@github Get Bible <https://github.com/getBible>
|
||||||
|
@support Get Bible <https://git.vdm.dev/getBible/support>
|
||||||
|
@copyright Copyright (C) 2015. All Rights Reserved
|
||||||
|
@license GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
|
||||||
|
/------------------------------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
// No direct access to this file
|
||||||
|
defined('_JEXEC') or die;
|
||||||
|
|
||||||
|
// register additional namespace
|
||||||
|
spl_autoload_register(function ($class) {
|
||||||
|
// project-specific base directories and namespace prefix
|
||||||
|
$search = [
|
||||||
|
'libraries/vendor_getbible/TrueChristianChurch.Joomla.GetBible' => 'TrueChristianChurch\\Joomla\\GetBible',
|
||||||
|
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Openai' => 'TrueChristianChurch\\Joomla\\Openai',
|
||||||
|
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Gitea' => 'TrueChristianChurch\\Joomla\\Gitea',
|
||||||
|
'libraries/vendor_getbible/TrueChristianChurch.Joomla' => 'TrueChristianChurch\\Joomla'
|
||||||
|
];
|
||||||
|
// Start the search and load if found
|
||||||
|
$found = false;
|
||||||
|
$found_base_dir = "";
|
||||||
|
$found_len = 0;
|
||||||
|
foreach ($search as $base_dir => $prefix)
|
||||||
|
{
|
||||||
|
// does the class use the namespace prefix?
|
||||||
|
$len = strlen($prefix);
|
||||||
|
if (strncmp($prefix, $class, $len) === 0)
|
||||||
|
{
|
||||||
|
// we have a match so load the values
|
||||||
|
$found = true;
|
||||||
|
$found_base_dir = $base_dir;
|
||||||
|
$found_len = $len;
|
||||||
|
// done here
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// check if we found a match
|
||||||
|
if (!$found)
|
||||||
|
{
|
||||||
|
// not found so move to the next registered autoloader
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// get the relative class name
|
||||||
|
$relative_class = substr($class, $found_len);
|
||||||
|
// replace the namespace prefix with the base directory, replace namespace
|
||||||
|
// separators with directory separators in the relative class name, append
|
||||||
|
// with .php
|
||||||
|
$file = JPATH_ROOT . '/' . $found_base_dir . '/src' . str_replace('\\', '/', $relative_class) . '.php';
|
||||||
|
// if the file exists, require it
|
||||||
|
if (file_exists($file))
|
||||||
|
{
|
||||||
|
require $file;
|
||||||
|
}
|
||||||
|
});
|
@ -1655,7 +1655,7 @@ COM_GETBIBLE_THE_TAG_WAS_SUCCESSFULLY_REACTIVATED="The tag was successfully reac
|
|||||||
COM_GETBIBLE_THE_TAG_WAS_SUCCESSFULLY_REMOVED_FROM_THE_VERSE="The tag was successfully removed from the verse."
|
COM_GETBIBLE_THE_TAG_WAS_SUCCESSFULLY_REMOVED_FROM_THE_VERSE="The tag was successfully removed from the verse."
|
||||||
COM_GETBIBLE_THE_TAG_WAS_SUCCESSFULLY_UPDATED="The tag was successfully updated."
|
COM_GETBIBLE_THE_TAG_WAS_SUCCESSFULLY_UPDATED="The tag was successfully updated."
|
||||||
COM_GETBIBLE_THE_VERSE_WAS_SUCCESSFULLY_TAGGED="The verse was successfully tagged."
|
COM_GETBIBLE_THE_VERSE_WAS_SUCCESSFULLY_TAGGED="The verse was successfully tagged."
|
||||||
COM_GETBIBLE_THE_WIKI_CAN_ONLY_BE_LOADED_WHEN_YOUR_JCB_SYSTEM_HAS_INTERNET_CONNECTION="The wiki can only be loaded when your JCB system has internet connection."
|
COM_GETBIBLE_THE_WIKI_CAN_ONLY_BE_LOADED_WHEN_YOUR_GETBIBLE_SYSTEM_HAS_INTERNET_CONNECTION="The wiki can only be loaded when your getBible system has internet connection."
|
||||||
COM_GETBIBLE_THE_WIKI_IS_LOADING="The wiki is loading"
|
COM_GETBIBLE_THE_WIKI_IS_LOADING="The wiki is loading"
|
||||||
COM_GETBIBLE_THIS_IS_A_GLOBAL_TAG_SET_BY_US_AT_BSB_FOR_YOUR_CONVENIENCE_WE_HOLD_THE_PRIVILEGE_TO_MODIFY_THESE_TAGS_IF_YOU_BELIEVE_ITS_SET_IN_ERROR_KINDLY_INFORM_US="This is a global tag, set by us at <b>%s</b> for your convenience. We hold the privilege to modify these tags. If you believe it's set in error, kindly inform us."
|
COM_GETBIBLE_THIS_IS_A_GLOBAL_TAG_SET_BY_US_AT_BSB_FOR_YOUR_CONVENIENCE_WE_HOLD_THE_PRIVILEGE_TO_MODIFY_THESE_TAGS_IF_YOU_BELIEVE_ITS_SET_IN_ERROR_KINDLY_INFORM_US="This is a global tag, set by us at <b>%s</b> for your convenience. We hold the privilege to modify these tags. If you believe it's set in error, kindly inform us."
|
||||||
COM_GETBIBLE_THIS_TAG_COULD_NOT_BE_REMOVED="This tag could not be removed."
|
COM_GETBIBLE_THIS_TAG_COULD_NOT_BE_REMOVED="This tag could not be removed."
|
||||||
|
@ -124,34 +124,47 @@ class GetbibleModelAjax extends ListModel
|
|||||||
// do we have tags returned
|
// do we have tags returned
|
||||||
if (isset($tags[0]) && isset($tags[0]->name))
|
if (isset($tags[0]) && isset($tags[0]->name))
|
||||||
{
|
{
|
||||||
// get the version
|
// get the local version
|
||||||
$manifest = GetbibleHelper::manifest();
|
$manifest = GetbibleHelper::manifest();
|
||||||
$local_version = (string) $manifest->version;
|
$local_version = (string) $manifest->version;
|
||||||
$current_version = trim($tags[0]->name, 'vV');
|
$latest_version = '1.0.0';
|
||||||
|
$download_link = "https://git.vdm.dev/api/v1/getBible/joomla-component";
|
||||||
|
|
||||||
|
// Filter tags by major version matching the local version's major number
|
||||||
|
$major_version = explode('.', $local_version)[0];
|
||||||
|
$filtered_tags = array_filter($tags, function($tag) use ($major_version) {
|
||||||
|
return strpos($tag->name, "v$major_version") === 0;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!empty($filtered_tags))
|
||||||
|
{
|
||||||
|
// Sort versions to find the latest one
|
||||||
|
usort($filtered_tags, function($a, $b) {
|
||||||
|
return \version_compare($b->name, $a->name);
|
||||||
|
});
|
||||||
|
|
||||||
|
$latest_version = trim($filtered_tags[0]->name, 'vV');
|
||||||
|
|
||||||
|
// download link of the latest version
|
||||||
|
$download_link = $filtered_tags[0]->zipball_url;
|
||||||
|
}
|
||||||
|
|
||||||
// now check if this version is out dated
|
// now check if this version is out dated
|
||||||
if ($current_version === $local_version)
|
if (\version_compare($local_version, $latest_version) === 0)
|
||||||
{
|
{
|
||||||
return ['notice' => '<small><span style="color:green;"><span class="icon-shield"></span> ' . Text::_('COM_GETBIBLE_UP_TO_DATE') . '</span></small>'];
|
return ['notice' => '<small><span style="color:green;"><span class="icon-shield"></span> ' . Text::_('COM_GETBIBLE_UP_TO_DATE') . '</span></small>'];
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// check if this is beta version
|
// check if this is beta version
|
||||||
$current_array = array_map(function ($v) { return (int) $v; }, (array) explode('.', $current_version));
|
if (\version_compare($local_version, $latest_version) > 0)
|
||||||
$local_array = array_map(function ($v) { return (int) $v; }, (array) explode('.', $local_version));
|
|
||||||
if (($local_array[0] > $current_array[0]) ||
|
|
||||||
($local_array[0] == $current_array[0] && $local_array[1] > $current_array[1]) ||
|
|
||||||
($local_array[0] == $current_array[0] && $local_array[1] == $current_array[1] && $local_array[2] > $current_array[2]))
|
|
||||||
{
|
{
|
||||||
return ['notice' => '<small><span style="color:#F7B033;"><span class="icon-wrench"></span> ' . Text::_('COM_GETBIBLE_PRE_RELEASE') . '</span></small>'];
|
return ['notice' => '<small><span style="color:#F7B033;"><span class="icon-wrench"></span> ' . Text::_('COM_GETBIBLE_PRE_RELEASE') . '</span></small>'];
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// download link of the latest version
|
|
||||||
$download = "https://git.vdm.dev/api/v1/repos/getBible/joomla-component/archive/" . $tags[0]->name . ".zip";
|
|
||||||
|
|
||||||
return ['notice' => '<small><span style="color:red;"><span class="icon-warning-circle"></span> ' . Text::_('COM_GETBIBLE_OUT_OF_DATE') . '!</span> <a style="color:green;" href="' .
|
return ['notice' => '<small><span style="color:red;"><span class="icon-warning-circle"></span> ' . Text::_('COM_GETBIBLE_OUT_OF_DATE') . '!</span> <a style="color:green;" href="' .
|
||||||
$download . '" title="' . Text::_('COM_GETBIBLE_YOU_CAN_DIRECTLY_DOWNLOAD_THE_LATEST_UPDATE_OR_USE_THE_JOOMLA_UPDATE_AREA') . '">' . Text::_('COM_GETBIBLE_DOWNLOAD_UPDATE') . '!</a></small>'];
|
$download_link . '" title="' . Text::_('COM_GETBIBLE_YOU_CAN_DIRECTLY_DOWNLOAD_THE_LATEST_UPDATE_OR_USE_THE_JOOMLA_UPDATE_AREA') . '">' . Text::_('COM_GETBIBLE_DOWNLOAD_UPDATE') . '!</a></small>'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -240,6 +253,6 @@ class GetbibleModelAjax extends ListModel
|
|||||||
return ['error' => $message];
|
return ['error' => $message];
|
||||||
}
|
}
|
||||||
|
|
||||||
return ['error' => Text::_('COM_GETBIBLE_THE_WIKI_CAN_ONLY_BE_LOADED_WHEN_YOUR_JCB_SYSTEM_HAS_INTERNET_CONNECTION')];
|
return ['error' => Text::_('COM_GETBIBLE_THE_WIKI_CAN_ONLY_BE_LOADED_WHEN_YOUR_GETBIBLE_SYSTEM_HAS_INTERNET_CONNECTION')];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_linker` (
|
|||||||
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`public_notes` TINYINT(1) NOT NULL DEFAULT 0,
|
`public_notes` TINYINT(1) NOT NULL DEFAULT 0,
|
||||||
`public_tagged_verses` TINYINT(1) NOT NULL DEFAULT 0,
|
`public_tagged_verses` TINYINT(1) NOT NULL DEFAULT 0,
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -39,7 +39,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_note` (
|
|||||||
`linker` VARCHAR(36) NOT NULL DEFAULT '',
|
`linker` VARCHAR(36) NOT NULL DEFAULT '',
|
||||||
`note` TEXT NOT NULL,
|
`note` TEXT NOT NULL,
|
||||||
`verse` INT(7) NOT NULL DEFAULT 0,
|
`verse` INT(7) NOT NULL DEFAULT 0,
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -74,7 +74,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_tagged_verse` (
|
|||||||
`linker` VARCHAR(36) NOT NULL DEFAULT '',
|
`linker` VARCHAR(36) NOT NULL DEFAULT '',
|
||||||
`tag` VARCHAR(36) NOT NULL DEFAULT '',
|
`tag` VARCHAR(36) NOT NULL DEFAULT '',
|
||||||
`verse` INT(7) NOT NULL DEFAULT 0,
|
`verse` INT(7) NOT NULL DEFAULT 0,
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -103,7 +103,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_tagged_verse` (
|
|||||||
CREATE TABLE IF NOT EXISTS `#__getbible_prompt` (
|
CREATE TABLE IF NOT EXISTS `#__getbible_prompt` (
|
||||||
`id` INT(11) NOT NULL AUTO_INCREMENT,
|
`id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
|
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
|
||||||
`abbreviation` VARCHAR(100) NOT NULL DEFAULT '',
|
`abbreviation` VARCHAR(100) NOT NULL,
|
||||||
`ai_org_token_override` TINYINT(1) NOT NULL DEFAULT 0,
|
`ai_org_token_override` TINYINT(1) NOT NULL DEFAULT 0,
|
||||||
`cache_behaviour` TINYINT(1) NOT NULL DEFAULT 0,
|
`cache_behaviour` TINYINT(1) NOT NULL DEFAULT 0,
|
||||||
`cache_capacity` INT(11) NOT NULL DEFAULT 0,
|
`cache_capacity` INT(11) NOT NULL DEFAULT 0,
|
||||||
@ -128,7 +128,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_prompt` (
|
|||||||
`token_override` TINYINT(1) NOT NULL DEFAULT 0,
|
`token_override` TINYINT(1) NOT NULL DEFAULT 0,
|
||||||
`top_p` FLOAT(11) NOT NULL DEFAULT 0,
|
`top_p` FLOAT(11) NOT NULL DEFAULT 0,
|
||||||
`top_p_override` TINYINT(1) NOT NULL DEFAULT 0,
|
`top_p_override` TINYINT(1) NOT NULL DEFAULT 0,
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -157,30 +157,30 @@ CREATE TABLE IF NOT EXISTS `#__getbible_prompt` (
|
|||||||
CREATE TABLE IF NOT EXISTS `#__getbible_open_ai_response` (
|
CREATE TABLE IF NOT EXISTS `#__getbible_open_ai_response` (
|
||||||
`id` INT(11) NOT NULL AUTO_INCREMENT,
|
`id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
|
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
|
||||||
`abbreviation` VARCHAR(100) NOT NULL DEFAULT '',
|
`abbreviation` VARCHAR(100) NOT NULL,
|
||||||
`book` INT(11) NOT NULL DEFAULT 0,
|
`book` INT(11) NOT NULL DEFAULT 0,
|
||||||
`chapter` INT(11) NOT NULL DEFAULT 0,
|
`chapter` INT(11) NOT NULL DEFAULT 0,
|
||||||
`completion_tokens` INT(11) NOT NULL DEFAULT 0,
|
`completion_tokens` INT(11) NOT NULL DEFAULT 0,
|
||||||
`frequency_penalty` FLOAT(11) NOT NULL DEFAULT 0,
|
`frequency_penalty` FLOAT(11) NOT NULL DEFAULT 0,
|
||||||
`language` VARCHAR(255) NOT NULL DEFAULT '',
|
`language` VARCHAR(255) NOT NULL,
|
||||||
`lcsh` VARCHAR(255) NOT NULL DEFAULT '',
|
`lcsh` VARCHAR(255) NOT NULL,
|
||||||
`max_tokens` INT(11) NOT NULL DEFAULT 0,
|
`max_tokens` INT(11) NOT NULL DEFAULT 0,
|
||||||
`model` VARCHAR(50) NOT NULL DEFAULT '',
|
`model` VARCHAR(50) NOT NULL DEFAULT '',
|
||||||
`n` INT(7) NOT NULL DEFAULT 0,
|
`n` INT(7) NOT NULL DEFAULT 0,
|
||||||
`presence_penalty` FLOAT(11) NOT NULL DEFAULT 0,
|
`presence_penalty` FLOAT(11) NOT NULL DEFAULT 0,
|
||||||
`prompt` VARCHAR(36) NOT NULL DEFAULT '',
|
`prompt` VARCHAR(36) NOT NULL,
|
||||||
`prompt_tokens` INT(11) NOT NULL DEFAULT 0,
|
`prompt_tokens` INT(11) NOT NULL DEFAULT 0,
|
||||||
`response_created` VARCHAR(255) NOT NULL DEFAULT '',
|
`response_created` VARCHAR(255) NOT NULL,
|
||||||
`response_id` VARCHAR(255) NOT NULL DEFAULT '',
|
`response_id` VARCHAR(255) NOT NULL,
|
||||||
`response_model` VARCHAR(255) NOT NULL DEFAULT '',
|
`response_model` VARCHAR(255) NOT NULL,
|
||||||
`response_object` VARCHAR(255) NOT NULL DEFAULT '',
|
`response_object` VARCHAR(255) NOT NULL,
|
||||||
`selected_word` TEXT NOT NULL,
|
`selected_word` TEXT NOT NULL,
|
||||||
`temperature` FLOAT(11) NOT NULL DEFAULT 0,
|
`temperature` FLOAT(11) NOT NULL DEFAULT 0,
|
||||||
`top_p` FLOAT(11) NOT NULL DEFAULT 0,
|
`top_p` FLOAT(11) NOT NULL DEFAULT 0,
|
||||||
`total_tokens` INT(11) NOT NULL DEFAULT 0,
|
`total_tokens` INT(11) NOT NULL DEFAULT 0,
|
||||||
`verse` VARCHAR(255) NOT NULL DEFAULT '',
|
`verse` VARCHAR(255) NOT NULL,
|
||||||
`word` VARCHAR(255) NOT NULL DEFAULT '',
|
`word` VARCHAR(255) NOT NULL,
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -223,10 +223,10 @@ CREATE TABLE IF NOT EXISTS `#__getbible_open_ai_message` (
|
|||||||
`index` INT(11) NOT NULL DEFAULT 0,
|
`index` INT(11) NOT NULL DEFAULT 0,
|
||||||
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`open_ai_response` VARCHAR(255) NOT NULL DEFAULT '',
|
`open_ai_response` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`prompt` VARCHAR(36) NOT NULL DEFAULT '',
|
`prompt` VARCHAR(36) NOT NULL,
|
||||||
`role` VARCHAR(255) NOT NULL DEFAULT '',
|
`role` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`source` TINYINT(1) NOT NULL DEFAULT 0,
|
`source` TINYINT(1) NOT NULL DEFAULT 0,
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -257,7 +257,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_password` (
|
|||||||
`linker` VARCHAR(36) NOT NULL DEFAULT '',
|
`linker` VARCHAR(36) NOT NULL DEFAULT '',
|
||||||
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`password` VARCHAR(100) NOT NULL DEFAULT '',
|
`password` VARCHAR(100) NOT NULL DEFAULT '',
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -288,7 +288,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_tag` (
|
|||||||
`guid` VARCHAR(36) NOT NULL DEFAULT '',
|
`guid` VARCHAR(36) NOT NULL DEFAULT '',
|
||||||
`linker` VARCHAR(36) NOT NULL DEFAULT '',
|
`linker` VARCHAR(36) NOT NULL DEFAULT '',
|
||||||
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -330,7 +330,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_translation` (
|
|||||||
`language` VARCHAR(100) NOT NULL DEFAULT '',
|
`language` VARCHAR(100) NOT NULL DEFAULT '',
|
||||||
`sha` VARCHAR(64) NOT NULL DEFAULT '',
|
`sha` VARCHAR(64) NOT NULL DEFAULT '',
|
||||||
`translation` VARCHAR(255) NOT NULL DEFAULT '',
|
`translation` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -358,7 +358,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_book` (
|
|||||||
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`nr` INT(7) NOT NULL DEFAULT 0,
|
`nr` INT(7) NOT NULL DEFAULT 0,
|
||||||
`sha` VARCHAR(64) NOT NULL DEFAULT '',
|
`sha` VARCHAR(64) NOT NULL DEFAULT '',
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -389,7 +389,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_chapter` (
|
|||||||
`chapter` INT(7) NOT NULL DEFAULT 0,
|
`chapter` INT(7) NOT NULL DEFAULT 0,
|
||||||
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`sha` VARCHAR(64) NOT NULL DEFAULT '',
|
`sha` VARCHAR(64) NOT NULL DEFAULT '',
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
@ -422,7 +422,7 @@ CREATE TABLE IF NOT EXISTS `#__getbible_verse` (
|
|||||||
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
`name` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`text` TEXT NOT NULL,
|
`text` TEXT NOT NULL,
|
||||||
`verse` INT(7) NOT NULL DEFAULT 0,
|
`verse` INT(7) NOT NULL DEFAULT 0,
|
||||||
`params` text NULL,
|
`params` TEXT NULL,
|
||||||
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
`published` TINYINT(3) NOT NULL DEFAULT 1,
|
||||||
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`created_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
`modified_by` INT(10) unsigned NOT NULL DEFAULT 0,
|
||||||
|
1
admin/sql/updates/mysql/3.0.8.sql
Normal file
1
admin/sql/updates/mysql/3.0.8.sql
Normal file
@ -0,0 +1 @@
|
|||||||
|
|
@ -1,15 +1,15 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<extension type="component" version="3.10" method="upgrade">
|
<extension type="component" version="3.10" method="upgrade">
|
||||||
<name>COM_GETBIBLE</name>
|
<name>COM_GETBIBLE</name>
|
||||||
<creationDate>6th April, 2024</creationDate>
|
<creationDate>27th April, 2024</creationDate>
|
||||||
<author>Llewellyn van der Merwe</author>
|
<author>Llewellyn van der Merwe</author>
|
||||||
<authorEmail>joomla@vdm.io</authorEmail>
|
<authorEmail>joomla@vdm.io</authorEmail>
|
||||||
<authorUrl>https://getbible.net</authorUrl>
|
<authorUrl>https://getbible.net</authorUrl>
|
||||||
<copyright>Copyright (C) 2015. All Rights Reserved</copyright>
|
<copyright>Copyright (C) 2015. All Rights Reserved</copyright>
|
||||||
<license>GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html</license>
|
<license>GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html</license>
|
||||||
<version>3.0.8</version>
|
<version>3.0.9</version>
|
||||||
<description><![CDATA[
|
<description><![CDATA[
|
||||||
<h1>Get Bible (v.3.0.8)</h1>
|
<h1>Get Bible (v.3.0.9)</h1>
|
||||||
<div style="clear: both;"></div>
|
<div style="clear: both;"></div>
|
||||||
<p>Welcome to the next level of scripture engagement - The Bible for Joomla! Our purpose is to bring the Word of God to every person, in their native language, entirely free. This isn't just a typical extension; it's a groundbreaking tool developed to span language divides and deliver a rich, customizable Bible study experience to users worldwide.
|
<p>Welcome to the next level of scripture engagement - The Bible for Joomla! Our purpose is to bring the Word of God to every person, in their native language, entirely free. This isn't just a typical extension; it's a groundbreaking tool developed to span language divides and deliver a rich, customizable Bible study experience to users worldwide.
|
||||||
|
|
||||||
|
@ -179,7 +179,7 @@ final class Engineer
|
|||||||
$data->top_p = $this->prompt->getTopP();
|
$data->top_p = $this->prompt->getTopP();
|
||||||
$data->presence_penalty = $this->prompt->getPresencePenalty();
|
$data->presence_penalty = $this->prompt->getPresencePenalty();
|
||||||
$data->frequency_penalty = $this->prompt->getFrequencyPenalty();
|
$data->frequency_penalty = $this->prompt->getFrequencyPenalty();
|
||||||
$data->n = '';
|
$data->n = 0;
|
||||||
// Response data
|
// Response data
|
||||||
$data->response_id = $this->response->id ?? '';
|
$data->response_id = $this->response->id ?? '';
|
||||||
$data->response_object = $this->response->object ?? '';
|
$data->response_object = $this->response->object ?? '';
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,52 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @package GetBible
|
||||||
|
*
|
||||||
|
* @created 30th May, 2023
|
||||||
|
* @author Llewellyn van der Merwe <https://dev.vdm.io>
|
||||||
|
* @git GetBible <https://git.vdm.dev/getBible>
|
||||||
|
* @copyright Copyright (C) 2015 Vast Development Method. All rights reserved.
|
||||||
|
* @license GNU General Public License version 2 or later; see LICENSE.txt
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace TrueChristianChurch\Joomla\GetBible\Table;
|
||||||
|
|
||||||
|
|
||||||
|
use TrueChristianChurch\Joomla\GetBible\Table;
|
||||||
|
use TrueChristianChurch\Joomla\Interfaces\SchemaInterface;
|
||||||
|
use TrueChristianChurch\Joomla\Abstraction\Schema as ExtendingSchema;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GetBible Tables Schema
|
||||||
|
*
|
||||||
|
* @since 3.0.8
|
||||||
|
*/
|
||||||
|
final class Schema extends ExtendingSchema implements SchemaInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*
|
||||||
|
* @param Table $table The Table Class.
|
||||||
|
*
|
||||||
|
* @since 3.0.8
|
||||||
|
*/
|
||||||
|
public function __construct(?Table $table = null)
|
||||||
|
{
|
||||||
|
$table ??= new Table;
|
||||||
|
|
||||||
|
parent::__construct($table);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the targeted component code
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
* @since 3.0.8
|
||||||
|
*/
|
||||||
|
protected function getCode(): string
|
||||||
|
{
|
||||||
|
return 'getbible';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -34,7 +34,7 @@ abstract class BaseTable implements Tableinterface
|
|||||||
* All default fields
|
* All default fields
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
**/
|
**/
|
||||||
protected array $defaults = [
|
protected array $defaults = [
|
||||||
'id' => [
|
'id' => [
|
||||||
@ -45,7 +45,29 @@ abstract class BaseTable implements Tableinterface
|
|||||||
'title' => false,
|
'title' => false,
|
||||||
'list' => NULL,
|
'list' => NULL,
|
||||||
'store' => NULL,
|
'store' => NULL,
|
||||||
'tab_name' => NULL
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'INT(11)',
|
||||||
|
'default' => 'EMPTY',
|
||||||
|
'auto_increment' => true,
|
||||||
|
'primary_key' => true,
|
||||||
|
'null_switch' => 'NOT NULL'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
'asset_id' => [
|
||||||
|
'name' => 'asset_id',
|
||||||
|
'label' => NULL,
|
||||||
|
'type' => NULL,
|
||||||
|
'title' => false,
|
||||||
|
'list' => NULL,
|
||||||
|
'store' => NULL,
|
||||||
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'INT(10) unsigned',
|
||||||
|
'default' => '0',
|
||||||
|
'null_switch' => 'NOT NULL',
|
||||||
|
'comment' => 'FK to the #__assets table.'
|
||||||
|
]
|
||||||
],
|
],
|
||||||
'ordering' => [
|
'ordering' => [
|
||||||
'name' => 'ordering',
|
'name' => 'ordering',
|
||||||
@ -54,7 +76,12 @@ abstract class BaseTable implements Tableinterface
|
|||||||
'title' => false,
|
'title' => false,
|
||||||
'list' => NULL,
|
'list' => NULL,
|
||||||
'store' => NULL,
|
'store' => NULL,
|
||||||
'tab_name' => NULL
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'INT(11)',
|
||||||
|
'default' => '0',
|
||||||
|
'null_switch' => 'NOT NULL'
|
||||||
|
]
|
||||||
],
|
],
|
||||||
'published' => [
|
'published' => [
|
||||||
'name' => 'published',
|
'name' => 'published',
|
||||||
@ -63,7 +90,14 @@ abstract class BaseTable implements Tableinterface
|
|||||||
'title' => false,
|
'title' => false,
|
||||||
'list' => NULL,
|
'list' => NULL,
|
||||||
'store' => NULL,
|
'store' => NULL,
|
||||||
'tab_name' => NULL
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'TINYINT(3)',
|
||||||
|
'default' => '1',
|
||||||
|
'null_switch' => 'NOT NULL',
|
||||||
|
'key' => true,
|
||||||
|
'key_name' => 'state'
|
||||||
|
]
|
||||||
],
|
],
|
||||||
'modified_by' => [
|
'modified_by' => [
|
||||||
'name' => 'modified_by',
|
'name' => 'modified_by',
|
||||||
@ -72,7 +106,14 @@ abstract class BaseTable implements Tableinterface
|
|||||||
'title' => false,
|
'title' => false,
|
||||||
'list' => NULL,
|
'list' => NULL,
|
||||||
'store' => NULL,
|
'store' => NULL,
|
||||||
'tab_name' => NULL
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'INT(10) unsigned',
|
||||||
|
'default' => '0',
|
||||||
|
'null_switch' => 'NOT NULL',
|
||||||
|
'key' => true,
|
||||||
|
'key_name' => 'modifiedby'
|
||||||
|
]
|
||||||
],
|
],
|
||||||
'modified' => [
|
'modified' => [
|
||||||
'name' => 'modified',
|
'name' => 'modified',
|
||||||
@ -81,7 +122,12 @@ abstract class BaseTable implements Tableinterface
|
|||||||
'title' => false,
|
'title' => false,
|
||||||
'list' => NULL,
|
'list' => NULL,
|
||||||
'store' => NULL,
|
'store' => NULL,
|
||||||
'tab_name' => NULL
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'DATETIME',
|
||||||
|
'default' => '0000-00-00 00:00:00',
|
||||||
|
'null_switch' => 'NOT NULL'
|
||||||
|
]
|
||||||
],
|
],
|
||||||
'created_by' => [
|
'created_by' => [
|
||||||
'name' => 'created_by',
|
'name' => 'created_by',
|
||||||
@ -90,7 +136,14 @@ abstract class BaseTable implements Tableinterface
|
|||||||
'title' => false,
|
'title' => false,
|
||||||
'list' => NULL,
|
'list' => NULL,
|
||||||
'store' => NULL,
|
'store' => NULL,
|
||||||
'tab_name' => NULL
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'INT(10) unsigned',
|
||||||
|
'default' => '0',
|
||||||
|
'null_switch' => 'NOT NULL',
|
||||||
|
'key' => true,
|
||||||
|
'key_name' => 'createdby'
|
||||||
|
]
|
||||||
],
|
],
|
||||||
'created' => [
|
'created' => [
|
||||||
'name' => 'created',
|
'name' => 'created',
|
||||||
@ -99,7 +152,42 @@ abstract class BaseTable implements Tableinterface
|
|||||||
'title' => false,
|
'title' => false,
|
||||||
'list' => NULL,
|
'list' => NULL,
|
||||||
'store' => NULL,
|
'store' => NULL,
|
||||||
'tab_name' => NULL
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'DATETIME',
|
||||||
|
'default' => '0000-00-00 00:00:00',
|
||||||
|
'null_switch' => 'NOT NULL'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
'checked_out' => [
|
||||||
|
'name' => 'checked_out',
|
||||||
|
'label' => NULL,
|
||||||
|
'type' => NULL,
|
||||||
|
'title' => false,
|
||||||
|
'list' => NULL,
|
||||||
|
'store' => NULL,
|
||||||
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'INT(10) unsigned',
|
||||||
|
'default' => '0',
|
||||||
|
'null_switch' => 'NOT NULL',
|
||||||
|
'key' => true,
|
||||||
|
'key_name' => 'checkout'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
'checked_out_time' => [
|
||||||
|
'name' => 'checked_out_time',
|
||||||
|
'label' => NULL,
|
||||||
|
'type' => NULL,
|
||||||
|
'title' => false,
|
||||||
|
'list' => NULL,
|
||||||
|
'store' => NULL,
|
||||||
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'DATETIME',
|
||||||
|
'default' => '0000-00-00 00:00:00',
|
||||||
|
'null_switch' => 'NOT NULL'
|
||||||
|
]
|
||||||
],
|
],
|
||||||
'hits' => [
|
'hits' => [
|
||||||
'name' => 'hits',
|
'name' => 'hits',
|
||||||
@ -108,7 +196,12 @@ abstract class BaseTable implements Tableinterface
|
|||||||
'title' => false,
|
'title' => false,
|
||||||
'list' => NULL,
|
'list' => NULL,
|
||||||
'store' => NULL,
|
'store' => NULL,
|
||||||
'tab_name' => NULL
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'INT(10) unsigned',
|
||||||
|
'default' => '0',
|
||||||
|
'null_switch' => 'NOT NULL'
|
||||||
|
]
|
||||||
],
|
],
|
||||||
'version' => [
|
'version' => [
|
||||||
'name' => 'version',
|
'name' => 'version',
|
||||||
@ -117,7 +210,26 @@ abstract class BaseTable implements Tableinterface
|
|||||||
'title' => false,
|
'title' => false,
|
||||||
'list' => NULL,
|
'list' => NULL,
|
||||||
'store' => NULL,
|
'store' => NULL,
|
||||||
'tab_name' => NULL
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'INT(10) unsigned',
|
||||||
|
'default' => '1',
|
||||||
|
'null_switch' => 'NOT NULL'
|
||||||
|
]
|
||||||
|
],
|
||||||
|
'params' => [
|
||||||
|
'name' => 'params',
|
||||||
|
'label' => NULL,
|
||||||
|
'type' => NULL,
|
||||||
|
'title' => false,
|
||||||
|
'list' => NULL,
|
||||||
|
'store' => 'json',
|
||||||
|
'tab_name' => NULL,
|
||||||
|
'db' => [
|
||||||
|
'type' => 'TEXT',
|
||||||
|
'default' => 'EMPTY',
|
||||||
|
'null_switch' => 'NULL'
|
||||||
|
]
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
|
|
||||||
@ -130,48 +242,41 @@ abstract class BaseTable implements Tableinterface
|
|||||||
* Example: $this->get('table_name');
|
* Example: $this->get('table_name');
|
||||||
* Get all areas/views/tables with all their item/field/column details
|
* Get all areas/views/tables with all their item/field/column details
|
||||||
* Example: $this->get('All');
|
* Example: $this->get('All');
|
||||||
|
* Example: $this->get();
|
||||||
*
|
*
|
||||||
* @param string $table The table
|
* @param string|null $table The table
|
||||||
* @param string|null $field The field
|
* @param string|null $field The field
|
||||||
* @param string|null $key The value key
|
* @param string|null $key The value key
|
||||||
*
|
*
|
||||||
* @return mixed
|
* @return mixed
|
||||||
* @since 3.2.0
|
* @since 3.2.1
|
||||||
*/
|
*/
|
||||||
public function get(string $table, ?string $field = null, ?string $key = null)
|
public function get(?string $table = null, ?string $field = null, ?string $key = null)
|
||||||
{
|
{
|
||||||
// return the item/field/column of an area/view/table
|
// Return specific value
|
||||||
if (is_string($field) && is_string($key))
|
if ($table && $field && $key)
|
||||||
{
|
{
|
||||||
// return the value of a item/field/column of an area/view/table
|
return $this->tables[$table][$field][$key] ?? $this->getDefaultKey($field, $key);
|
||||||
if (isset($this->tables[$table][$field][$key]))
|
|
||||||
{
|
|
||||||
return $this->tables[$table][$field][$key];
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->getDefaultKey($field, $key);
|
|
||||||
}
|
|
||||||
// return the item/field/column of an area/view/table
|
|
||||||
elseif (is_string($field))
|
|
||||||
{
|
|
||||||
if (isset($this->tables[$table][$field]))
|
|
||||||
{
|
|
||||||
return $this->tables[$table][$field];
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->getDefault($field);
|
|
||||||
}
|
|
||||||
// return an area/view/table
|
|
||||||
elseif ($table !== 'All')
|
|
||||||
{
|
|
||||||
if (isset($this->tables[$table]))
|
|
||||||
{
|
|
||||||
return $this->tables[$table];
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// return all
|
// Return field within table
|
||||||
|
if ($table && $field)
|
||||||
|
{
|
||||||
|
return $this->tables[$table][$field] ?? $this->getDefault($field);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return all fields in a table or all tables if 'All' is passed
|
||||||
|
if ($table)
|
||||||
|
{
|
||||||
|
if (strtoupper($table) === 'ALL')
|
||||||
|
{
|
||||||
|
return $this->tables;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->tables[$table] ?? null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return all tables
|
||||||
return $this->tables;
|
return $this->tables;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -268,27 +373,30 @@ abstract class BaseTable implements Tableinterface
|
|||||||
*
|
*
|
||||||
* @param string $table The area
|
* @param string $table The area
|
||||||
* @param bool $default Add the default fields
|
* @param bool $default Add the default fields
|
||||||
|
* @param bool $details Add/Leave fields the details
|
||||||
*
|
*
|
||||||
* @return array|null On success an array of fields
|
* @return array|null On success an array of fields
|
||||||
* @since 3.2.0
|
* @since 3.2.0
|
||||||
*/
|
*/
|
||||||
public function fields(string $table, bool $default = false): ?array
|
public function fields(string $table, bool $default = false, bool $details = false): ?array
|
||||||
{
|
{
|
||||||
// return all fields of an area/view/table
|
// Retrieve fields from the specified table
|
||||||
if (($table = $this->get($table)) !== null)
|
$fields = $this->get($table);
|
||||||
|
|
||||||
|
if ($fields === null)
|
||||||
{
|
{
|
||||||
if ($default)
|
return null;
|
||||||
{
|
|
||||||
return $this->addDefault(array_keys($table));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return array_keys($table);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// none found
|
// Determine the fields output based on the $default and $details flags
|
||||||
return null;
|
if ($details)
|
||||||
|
{
|
||||||
|
return $default ? $this->addDefaultDetails($fields) : $fields;
|
||||||
|
}
|
||||||
|
|
||||||
|
$fieldKeys = array_keys($fields);
|
||||||
|
|
||||||
|
return $default ? $this->addDefault($fieldKeys) : $fieldKeys;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -304,6 +412,11 @@ abstract class BaseTable implements Tableinterface
|
|||||||
// add default fields
|
// add default fields
|
||||||
foreach ($this->defaults as $default)
|
foreach ($this->defaults as $default)
|
||||||
{
|
{
|
||||||
|
if (in_array($default['name'], $fields))
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
// used just for loading the fields
|
// used just for loading the fields
|
||||||
$order = $default['order'] ?? 1;
|
$order = $default['order'] ?? 1;
|
||||||
unset($default['order']);
|
unset($default['order']);
|
||||||
@ -321,6 +434,31 @@ abstract class BaseTable implements Tableinterface
|
|||||||
return $fields;
|
return $fields;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add the default fields
|
||||||
|
*
|
||||||
|
* @param array $fields The table dynamic fields
|
||||||
|
*
|
||||||
|
* @return array Fields (with defaults details added)
|
||||||
|
* @since 3.2.0
|
||||||
|
*/
|
||||||
|
protected function addDefaultDetails(array $fields): array
|
||||||
|
{
|
||||||
|
// add default fields
|
||||||
|
foreach ($this->defaults as $default)
|
||||||
|
{
|
||||||
|
// remove ordering for now
|
||||||
|
unset($default['order']);
|
||||||
|
|
||||||
|
if (!isset($fields[$default['name']]))
|
||||||
|
{
|
||||||
|
$fields[$default['name']] = $default;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $fields;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if the field is a default field
|
* Check if the field is a default field
|
||||||
*
|
*
|
||||||
@ -353,10 +491,10 @@ abstract class BaseTable implements Tableinterface
|
|||||||
* @param string $field The field to check
|
* @param string $field The field to check
|
||||||
* @param string $key The field key/property to check
|
* @param string $key The field key/property to check
|
||||||
*
|
*
|
||||||
* @return string|null String value if a default field property exist
|
* @return mixed String value if a default field property exist
|
||||||
* @since 3.2.0
|
* @since 3.2.0
|
||||||
*/
|
*/
|
||||||
protected function getDefaultKey(string $field, string $key): ?string
|
protected function getDefaultKey(string $field, string $key)
|
||||||
{
|
{
|
||||||
return $this->defaults[$field][$key] ?? null;
|
return $this->defaults[$field][$key] ?? null;
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,698 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @package Joomla.Component.Builder
|
||||||
|
*
|
||||||
|
* @created 4th September, 2022
|
||||||
|
* @author Llewellyn van der Merwe <https://dev.vdm.io>
|
||||||
|
* @git Joomla Component Builder <https://git.vdm.dev/joomla/Component-Builder>
|
||||||
|
* @copyright Copyright (C) 2015 Vast Development Method. All rights reserved.
|
||||||
|
* @license GNU General Public License version 2 or later; see LICENSE.txt
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace TrueChristianChurch\Joomla\Abstraction;
|
||||||
|
|
||||||
|
|
||||||
|
use Joomla\CMS\Factory;
|
||||||
|
use Joomla\CMS\Version;
|
||||||
|
use TrueChristianChurch\Joomla\Interfaces\Tableinterface as Table;
|
||||||
|
use TrueChristianChurch\Joomla\Interfaces\SchemaInterface;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Schema Checking
|
||||||
|
*
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
abstract class Schema implements SchemaInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The Table Class.
|
||||||
|
*
|
||||||
|
* @var Table
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected Table $table;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Database Class
|
||||||
|
*
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected $db;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The local tables
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
private array $tables;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The component table prefix
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
private string $prefix;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The field unique keys
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
private array $uniqueKeys;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The field keys
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
private array $keys;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The current table columns
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
private array $columns;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The success messages of the action
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
private array $success;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current Joomla Version We are IN
|
||||||
|
*
|
||||||
|
* @var int
|
||||||
|
* @since 3.2.1
|
||||||
|
**/
|
||||||
|
protected $currentVersion;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*
|
||||||
|
* @param Table $table The Table Class.
|
||||||
|
*
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If the database fails
|
||||||
|
*/
|
||||||
|
public function __construct(Table $table)
|
||||||
|
{
|
||||||
|
$this->table = $table;
|
||||||
|
|
||||||
|
try {
|
||||||
|
// set the database object
|
||||||
|
$this->db = Factory::getDbo();
|
||||||
|
|
||||||
|
// get current component tables
|
||||||
|
$this->tables = $this->db->getTableList();
|
||||||
|
|
||||||
|
// set the component table
|
||||||
|
$this->prefix = $this->db->getPrefix() . $this->getCode();
|
||||||
|
|
||||||
|
// set the current version
|
||||||
|
$this->currentVersion = Version::MAJOR_VERSION;
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
throw new \Exception("Error: failed to initialize schema class due to a database error.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check and update database schema for missing fields or tables.
|
||||||
|
*
|
||||||
|
* @return array The array of successful updates/actions, if empty no update/action was taken.
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If there is an error during the update process.
|
||||||
|
*/
|
||||||
|
public function update(): array
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$this->success = [
|
||||||
|
"Success: scan of the component tables started."
|
||||||
|
];
|
||||||
|
foreach ($this->table->tables() as $table)
|
||||||
|
{
|
||||||
|
$this->uniqueKeys = [];
|
||||||
|
$this->keys = [];
|
||||||
|
|
||||||
|
if ($this->tableExists($table))
|
||||||
|
{
|
||||||
|
$this->updateSchema($table);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$this->createTable($table);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
throw new \Exception("Error: updating database schema. " . $e->getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
if (count($this->success) == 1)
|
||||||
|
{
|
||||||
|
$this->success[] = "Success: scan of the component tables completed with no update needed.";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$this->success[] = "Success: scan of the component tables completed.";
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->success;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the targeted component code
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
abstract protected function getCode(): string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a table exists in the database.
|
||||||
|
*
|
||||||
|
* @param string $table The name of the table to check.
|
||||||
|
*
|
||||||
|
* @return bool True if table exists, False otherwise.
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function tableExists(string $table): bool
|
||||||
|
{
|
||||||
|
return in_array($this->getTable($table), $this->tables);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update the schema of an existing table.
|
||||||
|
*
|
||||||
|
* @param string $table The table to update.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If there is an error while updating the schema.
|
||||||
|
*/
|
||||||
|
public function updateSchema(string $table): void
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$existingColumns = $this->getExistingColumns($table);
|
||||||
|
$expectedColumns = $this->table->fields($table, true);
|
||||||
|
|
||||||
|
$missingColumns = array_diff($expectedColumns, $existingColumns);
|
||||||
|
|
||||||
|
if (!empty($missingColumns))
|
||||||
|
{
|
||||||
|
$this->addMissingColumns($table, $missingColumns);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->checkColumnsDataType($table, $expectedColumns);
|
||||||
|
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
throw new \Exception("Error: updating schema for $table table. " . $e->getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($missingColumns))
|
||||||
|
{
|
||||||
|
$column_s = (count($missingColumns) == 1) ? 'column' : 'columns';
|
||||||
|
$missingColumns = implode(', ', $missingColumns);
|
||||||
|
$this->success[] = "Success: added missing ($missingColumns) $column_s to $table table.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a table with all necessary fields.
|
||||||
|
*
|
||||||
|
* @param string $table The name of the table to create.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If there is an error creating the table.
|
||||||
|
*/
|
||||||
|
public function createTable(string $table): void
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$columns = [];
|
||||||
|
$fields = $this->table->fields($table, true);
|
||||||
|
$createTable = 'CREATE TABLE IF NOT EXISTS ' . $this->db->quoteName($this->getTable($table));
|
||||||
|
|
||||||
|
foreach ($fields as $field)
|
||||||
|
{
|
||||||
|
if (($def = $this->getColumnDefinition($table, $field)) !== null)
|
||||||
|
{
|
||||||
|
$columns[] = $def;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$columnDefinitions = implode(', ', $columns);
|
||||||
|
|
||||||
|
$keys = $this->getTableKeys();
|
||||||
|
|
||||||
|
$createTableSql = "$createTable ($columnDefinitions, $keys)";
|
||||||
|
|
||||||
|
$this->db->setQuery($createTableSql);
|
||||||
|
$this->db->execute();
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
throw new \Exception("Error: failed to create missing $table table. " . $e->getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->success[] = "Success: created missing $table table.";
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch existing columns from a database table.
|
||||||
|
*
|
||||||
|
* @param string $table The name of the table.
|
||||||
|
*
|
||||||
|
* @return array An array of column names.
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function getExistingColumns(string $table): array
|
||||||
|
{
|
||||||
|
$this->columns = $this->db->getTableColumns($this->getTable($table), false);
|
||||||
|
|
||||||
|
return array_keys($this->columns);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add missing columns to a table.
|
||||||
|
*
|
||||||
|
* @param string $table The table to update.
|
||||||
|
* @param array $columns List of missing columns/fields.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If there is an error adding columns.
|
||||||
|
*/
|
||||||
|
protected function addMissingColumns(string $table, array $columns): void
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$query = $this->db->getQuery(true);
|
||||||
|
$alterTable = 'ALTER TABLE ' . $this->db->quoteName($this->getTable($table)) . ' ';
|
||||||
|
|
||||||
|
// Start an ALTER TABLE query
|
||||||
|
$alterQueries = [];
|
||||||
|
foreach ($columns as $column)
|
||||||
|
{
|
||||||
|
if (($def = $this->getColumnDefinition($table, $column)) !== null)
|
||||||
|
{
|
||||||
|
$alterQueries[] = " ADD " . $def;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->db->setQuery($alterTable . implode(', ', $alterQueries));
|
||||||
|
$this->db->execute();
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
$column_s = (count($columns) == 1) ? 'column' : 'columns';
|
||||||
|
$columns = implode(', ', $columns);
|
||||||
|
throw new \Exception("Error: failed to add ($columns) $column_s to $table table. " . $e->getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate and update the data type of existing fields/columns
|
||||||
|
*
|
||||||
|
* @param string $table The table to update.
|
||||||
|
* @param array $columns List of columns/fields to check.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function checkColumnsDataType(string $table, array $columns): void
|
||||||
|
{
|
||||||
|
$requireUpdate = [];
|
||||||
|
foreach ($columns as $column)
|
||||||
|
{
|
||||||
|
$current = $this->columns[$column] ?? null;
|
||||||
|
if ($current === null || ($expected = $this->table->get($table, $column, 'db')) === null)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// check if the data type and size match
|
||||||
|
if ($this->isDataTypeChangeSignificant($current->Type, $expected['type']))
|
||||||
|
{
|
||||||
|
$requireUpdate[$column] = [
|
||||||
|
'column' => $column,
|
||||||
|
'current' => $current->Type,
|
||||||
|
'expected' => $expected['type']
|
||||||
|
];
|
||||||
|
|
||||||
|
// check if update of default values is needed
|
||||||
|
$this->checkDefault($table, $column);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($requireUpdate))
|
||||||
|
{
|
||||||
|
$this->updateColumnsDataType($table, $requireUpdate);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates a SQL snippet for defining a table column, incorporating column type,
|
||||||
|
* default value, nullability, and auto-increment properties.
|
||||||
|
*
|
||||||
|
* @param string $table The table name to be used.
|
||||||
|
* @param string $field The field name in the table to generate SQL for.
|
||||||
|
*
|
||||||
|
* @return string|null The SQL snippet for the column definition.
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If the schema details cannot be retrieved or the SQL statement cannot be constructed properly.
|
||||||
|
*/
|
||||||
|
protected function getColumnDefinition(string $table, string $field): ?string
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
// Retrieve the database schema details for the specified table and field
|
||||||
|
if (($db = $this->table->get($table, $field, 'db')) === null)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Prepare the column name
|
||||||
|
$column_name = $this->db->quoteName($field);
|
||||||
|
$db['name'] = $field;
|
||||||
|
|
||||||
|
// Prepare the type and default value SQL statement
|
||||||
|
$type = $db['type'] ?? 'TEXT';
|
||||||
|
$db_default = isset($db['default']) ? $db['default'] : null;
|
||||||
|
$default = $this->getDefaultValue($type, $db_default);
|
||||||
|
|
||||||
|
// Prepare the null switch, and auto increment statement
|
||||||
|
$null_switch = !empty($db['null_switch']) ? " " . $db['null_switch'] : '';
|
||||||
|
$auto_increment = !empty($db['auto_increment']) ? " AUTO_INCREMENT" : '';
|
||||||
|
|
||||||
|
$this->setKeys($db);
|
||||||
|
|
||||||
|
// Assemble the SQL snippet for the column definition
|
||||||
|
return "{$column_name} {$type}{$null_switch}{$default}{$auto_increment}";
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
throw new \Exception("Error: failed to generate column definition for ($table.$field). " . $e->getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check and Update the default values if needed, including existing data adjustments
|
||||||
|
*
|
||||||
|
* @param string $table The table to update.
|
||||||
|
* @param string $column The column/field to check.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function checkDefault(string $table, string $column): void
|
||||||
|
{
|
||||||
|
// Retrieve the expected column configuration
|
||||||
|
$expected = $this->table->get($table, $column, 'db');
|
||||||
|
|
||||||
|
// Skip updates if the column is auto_increment
|
||||||
|
if (isset($expected['auto_increment']) && $expected['auto_increment'])
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retrieve the current column configuration
|
||||||
|
$current = $this->columns[$column];
|
||||||
|
|
||||||
|
// Check if default should be empty and current default is null, skip processing
|
||||||
|
if (strtoupper($expected['default']) === 'EMPTY' && $current->Default === NULL)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Determine the new default value based on the expected settings
|
||||||
|
$type = $expected['type'] ?? 'TEXT';
|
||||||
|
$db_default = isset($expected['default']) ? $expected['default'] : null;
|
||||||
|
$newDefault = $this->getDefaultValue($type, $db_default, true);
|
||||||
|
|
||||||
|
// First, adjust existing rows to conform to the new default if necessary
|
||||||
|
if (is_numeric($newDefault) && $this->adjustExistingDefaults($table, $column, $current->Default, $newDefault))
|
||||||
|
{
|
||||||
|
$this->success[] = "Success: updated the ($column) defaults in $table table.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update the data type of the given fields.
|
||||||
|
*
|
||||||
|
* @param string $table The table to update.
|
||||||
|
* @param array $columns List of columns/fields that must be updated.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function updateColumnsDataType(string $table, array $columns): void
|
||||||
|
{
|
||||||
|
$alterTable = 'ALTER TABLE ' . $this->db->quoteName($this->getTable($table));
|
||||||
|
foreach ($columns as $column => $types)
|
||||||
|
{
|
||||||
|
if (($def = $this->getColumnDefinition($table, $column)) === null)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$dbField = $this->db->quoteName($column);
|
||||||
|
$alterQuery = "$alterTable CHANGE $dbField ". $def;
|
||||||
|
|
||||||
|
if ($this->updateColumnDataType($alterQuery, $table, $column))
|
||||||
|
{
|
||||||
|
$current = $types['current'] ?? 'error';
|
||||||
|
$expected = $types['expected'] ?? 'error';
|
||||||
|
$this->success[] = "Success: updated ($column) column datatype $current to $expected in $table table.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add the component name to get the full table name.
|
||||||
|
*
|
||||||
|
* @param string $table The table name.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function getTable(string $table): string
|
||||||
|
{
|
||||||
|
return $this->prefix . '_' . $table;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determines if the change in data type between two definitions is significant.
|
||||||
|
*
|
||||||
|
* This function checks if there's a significant difference between the current
|
||||||
|
* data type and the expected data type that would require updating the database schema.
|
||||||
|
* It ignores display width for numeric types where MySQL considers these attributes
|
||||||
|
* irrelevant for storage but considers size and other modifiers for types like VARCHAR.
|
||||||
|
*
|
||||||
|
* @param string $currentType The current data type from the database schema.
|
||||||
|
* @param string $expectedType The expected data type to validate against.
|
||||||
|
*
|
||||||
|
* @return bool Returns true if the data type change is significant, otherwise false.
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function isDataTypeChangeSignificant(string $currentType, string $expectedType): bool
|
||||||
|
{
|
||||||
|
// Normalize both input types to lowercase for case-insensitive comparison
|
||||||
|
$currentType = strtolower($currentType);
|
||||||
|
$expectedType = strtolower($expectedType);
|
||||||
|
|
||||||
|
// Regex to extract the base data type and numeric parameters with named groups
|
||||||
|
$typePattern = '/^(?<datatype>\w+)(\((?<params>\d+(,\d+)?)\))?/';
|
||||||
|
|
||||||
|
// Match types and parameters
|
||||||
|
preg_match($typePattern, $currentType, $currentMatches);
|
||||||
|
preg_match($typePattern, $expectedType, $expectedMatches);
|
||||||
|
|
||||||
|
// Compare base types
|
||||||
|
if ($currentMatches['datatype'] !== $expectedMatches['datatype'])
|
||||||
|
{
|
||||||
|
return true; // Base types differ
|
||||||
|
}
|
||||||
|
|
||||||
|
// Define types where size and other modifiers are irrelevant
|
||||||
|
$sizeIrrelevantTypes = [
|
||||||
|
'int', 'tinyint', 'smallint', 'mediumint', 'bigint',
|
||||||
|
'float', 'double', 'decimal', 'numeric' // Numeric types where display width is irrelevant
|
||||||
|
];
|
||||||
|
|
||||||
|
// If the type is not in the size irrelevant list, compare full definitions
|
||||||
|
if (!in_array($currentMatches['datatype'], $sizeIrrelevantTypes))
|
||||||
|
{
|
||||||
|
return $currentType !== $expectedType; // Use full definition for types where size matters
|
||||||
|
}
|
||||||
|
|
||||||
|
// For size irrelevant types, only compare base type, ignoring size and unsigned
|
||||||
|
$currentBaseType = preg_replace('/\(\d+(,\d+)?\)|unsigned/', '', $currentType);
|
||||||
|
$expectedBaseType = preg_replace('/\(\d+(,\d+)?\)|unsigned/', '', $expectedType);
|
||||||
|
|
||||||
|
// Perform a final comparison for numeric types ignoring size
|
||||||
|
return $currentBaseType !== $expectedBaseType;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Updates existing rows in a column to a new default value
|
||||||
|
*
|
||||||
|
* @param string $table The table to update.
|
||||||
|
* @param string $column The column to update.
|
||||||
|
* @param mixed $currentDefault Current default value.
|
||||||
|
* @param mixed $newDefault The new default value to be set.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If there is an error updating column defaults.
|
||||||
|
*/
|
||||||
|
protected function adjustExistingDefaults(string $table, string $column, $currentDefault, $newDefault): bool
|
||||||
|
{
|
||||||
|
// Determine if adjustment is needed based on new and current defaults
|
||||||
|
if ($newDefault !== $currentDefault)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
// Format the new default for SQL use
|
||||||
|
$sqlDefault = $this->db->quote($newDefault);
|
||||||
|
|
||||||
|
$updateTable = 'UPDATE ' . $this->db->quoteName($this->getTable($table));
|
||||||
|
$dbField = $this->db->quoteName($column);
|
||||||
|
|
||||||
|
// Update SQL to set new default on existing rows where the default is currently the old default
|
||||||
|
$sql = $updateTable . " SET $dbField = $sqlDefault WHERE $dbField IS NULL OR $dbField = ''";
|
||||||
|
|
||||||
|
// Execute the update
|
||||||
|
$this->db->setQuery($sql);
|
||||||
|
return $this->db->execute();
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
throw new \Exception("Error: failed to update ($column) column defaults in $table table. " . $e->getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update the data type of the given field.
|
||||||
|
*
|
||||||
|
* @param string $updateString The SQL command to update the column data type
|
||||||
|
* @param string $table The table to update.
|
||||||
|
* @param string $field Column/field that must be updated.
|
||||||
|
*
|
||||||
|
* @return bool true on succes
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If there is an error adding columns.
|
||||||
|
*/
|
||||||
|
protected function updateColumnDataType(string $updateString, string $table, string $field): bool
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$this->db->setQuery($updateString);
|
||||||
|
return $this->db->execute();
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
throw new \Exception("Error: failed to update the datatype of ($field) column in $table table. " . $e->getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Key all needed keys for this table
|
||||||
|
*
|
||||||
|
* @return string of keys
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function getTableKeys(): string
|
||||||
|
{
|
||||||
|
$keys = [];
|
||||||
|
$keys[] = 'PRIMARY KEY (`id`)'; // TODO (we may want this to be dynamicly set)
|
||||||
|
|
||||||
|
if (!empty($this->uniqueKeys))
|
||||||
|
{
|
||||||
|
$keys[] = implode(', ', $this->uniqueKeys);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($this->keys))
|
||||||
|
{
|
||||||
|
$keys[] = implode(', ', $this->keys);
|
||||||
|
}
|
||||||
|
|
||||||
|
return implode(', ', $keys);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to set the view keys
|
||||||
|
*
|
||||||
|
* @param string $column The field column database array values
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function setKeys(array $column): void
|
||||||
|
{
|
||||||
|
$this->setUniqueKey($column);
|
||||||
|
$this->setKey($column);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to set the unique key
|
||||||
|
*
|
||||||
|
* @param string $column The field column database array values
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function setUniqueKey(array $column): void
|
||||||
|
{
|
||||||
|
if (isset($column['unique_key']) && $column['unique_key'])
|
||||||
|
{
|
||||||
|
$key = $column['unique_key_name'] ?? $column['name'];
|
||||||
|
$this->uniqueKeys[] = "UNIQUE KEY `idx_" . $key . "` (`" . $column['name'] . "`)";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to set the key
|
||||||
|
*
|
||||||
|
* @param string $column The field column database array values
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function setKey(array $column): void
|
||||||
|
{
|
||||||
|
if (isset($column['key']) && $column['key'])
|
||||||
|
{
|
||||||
|
$key = $column['key_name'] ?? $column['name'];
|
||||||
|
$this->keys[] = "KEY `idx_" . $key . "` (`" . $column['name'] . "`)";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adjusts the default value SQL fragment for a database field based on its type and specific rules.
|
||||||
|
*
|
||||||
|
* If the field is of type DATETIME and the Joomla version is not 3, it sets the default to CURRENT_TIMESTAMP
|
||||||
|
* if not explicitly specified otherwise. For all other types, or when a 'EMPTY' default is specified, it handles
|
||||||
|
* defaults by either leaving them unset or applying the provided default, properly quoted for SQL safety.
|
||||||
|
*
|
||||||
|
* @param string $type The type of the database field (e.g., 'DATETIME').
|
||||||
|
* @param string|null $defaultValue Optional default value for the field, null if not provided.
|
||||||
|
* @param bool $pure Optional to add the 'DEFAULT' string or not.
|
||||||
|
*
|
||||||
|
* @return string The SQL fragment to set the default value for a field.
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
protected function getDefaultValue(string $type, ?string $defaultValue, bool $pure = false): string
|
||||||
|
{
|
||||||
|
if ($defaultValue === null || strtoupper($defaultValue) === 'EMPTY')
|
||||||
|
{
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set default for DATETIME fields in Joomla versions above 3
|
||||||
|
if (strtoupper($type) === 'DATETIME' && $this->currentVersion != 3)
|
||||||
|
{
|
||||||
|
return $pure ? "CURRENT_TIMESTAMP" : " DEFAULT CURRENT_TIMESTAMP";
|
||||||
|
}
|
||||||
|
|
||||||
|
// Apply and quote the default value
|
||||||
|
return $pure ? $defaultValue : " DEFAULT " . $this->db->quote($defaultValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,53 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @package Joomla.Component.Builder
|
||||||
|
*
|
||||||
|
* @created 4th September, 2022
|
||||||
|
* @author Llewellyn van der Merwe <https://dev.vdm.io>
|
||||||
|
* @git Joomla Component Builder <https://git.vdm.dev/joomla/Component-Builder>
|
||||||
|
* @copyright Copyright (C) 2015 Vast Development Method. All rights reserved.
|
||||||
|
* @license GNU General Public License version 2 or later; see LICENSE.txt
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace TrueChristianChurch\Joomla\Interfaces;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Schema Checking Interface
|
||||||
|
*
|
||||||
|
* @since 3.2.1
|
||||||
|
*/
|
||||||
|
interface SchemaInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Check and update database schema for missing fields or tables.
|
||||||
|
*
|
||||||
|
* @return array The array of successful updates/actions, if empty no update/action was taken.
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If there is an error during the update process.
|
||||||
|
*/
|
||||||
|
public function update(): array;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a table with all necessary fields.
|
||||||
|
*
|
||||||
|
* @param string $table The name of the table to create.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If there is an error creating the table.
|
||||||
|
*/
|
||||||
|
public function createTable(string $table): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update the schema of an existing table.
|
||||||
|
*
|
||||||
|
* @param string $table The table to update.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.2.1
|
||||||
|
* @throws \Exception If there is an error while updating the schema.
|
||||||
|
*/
|
||||||
|
public function updateSchema(string $table): void;
|
||||||
|
}
|
||||||
|
|
@ -26,15 +26,16 @@ interface Tableinterface
|
|||||||
* Example: $this->get('table_name');
|
* Example: $this->get('table_name');
|
||||||
* Get all areas/views/tables with all their item/field/column details
|
* Get all areas/views/tables with all their item/field/column details
|
||||||
* Example: $this->get('All');
|
* Example: $this->get('All');
|
||||||
|
* Example: $this->get();
|
||||||
*
|
*
|
||||||
* @param string $table The table
|
* @param string|null $table The table
|
||||||
* @param string|null $field The field
|
* @param string|null $field The field
|
||||||
* @param string|null $key The value key
|
* @param string|null $key The value key
|
||||||
*
|
*
|
||||||
* @return mixed
|
* @return mixed
|
||||||
* @since 3.2.0
|
* @since 3.2.0
|
||||||
*/
|
*/
|
||||||
public function get(string $table, ?string $field = null, ?string $key = null);
|
public function get(?string $table = null, ?string $field = null, ?string $key = null);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get title field from an area/view/table
|
* Get title field from an area/view/table
|
||||||
@ -80,10 +81,11 @@ interface Tableinterface
|
|||||||
*
|
*
|
||||||
* @param string $table The area
|
* @param string $table The area
|
||||||
* @param bool $default Add the default fields
|
* @param bool $default Add the default fields
|
||||||
|
* @param bool $details Add/Leave fields the details
|
||||||
*
|
*
|
||||||
* @return array|null On success an array of fields
|
* @return array|null On success an array of fields
|
||||||
* @since 3.2.0
|
* @since 3.2.0
|
||||||
*/
|
*/
|
||||||
public function fields(string $table, bool $default = false): ?array;
|
public function fields(string $table, bool $default = false, bool $details = false): ?array;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
187
script.php
187
script.php
@ -25,6 +25,7 @@ use Joomla\CMS\Filesystem\Folder;
|
|||||||
use Joomla\CMS\Installer\Adapter\ComponentAdapter;
|
use Joomla\CMS\Installer\Adapter\ComponentAdapter;
|
||||||
use Joomla\CMS\Version;
|
use Joomla\CMS\Version;
|
||||||
use Joomla\CMS\HTML\HTMLHelper as Html;
|
use Joomla\CMS\HTML\HTMLHelper as Html;
|
||||||
|
use TrueChristianChurch\Joomla\GetBible\Table\Schema;
|
||||||
HTML::_('bootstrap.renderModal');
|
HTML::_('bootstrap.renderModal');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1001,7 +1002,7 @@ class Com_GetbibleInstallerScript
|
|||||||
|
|
||||||
// all things to clear out
|
// all things to clear out
|
||||||
$remove = JPATH_LIBRARIES . '/jcb_powers/VDM.Joomla.GetBible';
|
$remove = JPATH_LIBRARIES . '/jcb_powers/VDM.Joomla.GetBible';
|
||||||
if (Folder::exists($remove))
|
if (is_dir($remove))
|
||||||
{
|
{
|
||||||
$it = new \RecursiveDirectoryIterator($remove, \RecursiveDirectoryIterator::SKIP_DOTS);
|
$it = new \RecursiveDirectoryIterator($remove, \RecursiveDirectoryIterator::SKIP_DOTS);
|
||||||
$files = new \RecursiveIteratorIterator($it, \RecursiveIteratorIterator::CHILD_FIRST);
|
$files = new \RecursiveIteratorIterator($it, \RecursiveIteratorIterator::CHILD_FIRST);
|
||||||
@ -1023,10 +1024,16 @@ class Com_GetbibleInstallerScript
|
|||||||
// Delete the root folder
|
// Delete the root folder
|
||||||
Folder::delete($remove);
|
Folder::delete($remove);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check that the required configuration are set for PHP
|
||||||
|
$this->phpConfigurationCheck($app);
|
||||||
}
|
}
|
||||||
// do any install needed
|
// do any install needed
|
||||||
if ($type === 'install')
|
if ($type === 'install')
|
||||||
{
|
{
|
||||||
|
|
||||||
|
// Check that the required configuration are set for PHP
|
||||||
|
$this->phpConfigurationCheck($app);
|
||||||
}
|
}
|
||||||
// check if the PHPExcel stuff is still around
|
// check if the PHPExcel stuff is still around
|
||||||
if (File::exists(JPATH_ADMINISTRATOR . '/components/com_getbible/helpers/PHPExcel.php'))
|
if (File::exists(JPATH_ADMINISTRATOR . '/components/com_getbible/helpers/PHPExcel.php'))
|
||||||
@ -1165,6 +1172,10 @@ class Com_GetbibleInstallerScript
|
|||||||
$allDone = $db->execute();
|
$allDone = $db->execute();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Check that the database is up-to date
|
||||||
|
$this->databaseSchemaCheck($app);
|
||||||
|
|
||||||
echo '<div style="background-color: #fff;" class="alert alert-info"><a target="_blank" href="https://getbible.net" title="Get Bible">
|
echo '<div style="background-color: #fff;" class="alert alert-info"><a target="_blank" href="https://getbible.net" title="Get Bible">
|
||||||
<img src="components/com_getbible/assets/images/vdm-component.jpg"/>
|
<img src="components/com_getbible/assets/images/vdm-component.jpg"/>
|
||||||
</a></div>';
|
</a></div>';
|
||||||
@ -1568,10 +1579,14 @@ class Com_GetbibleInstallerScript
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Check that the database is up-to date
|
||||||
|
$this->databaseSchemaCheck($app);
|
||||||
|
|
||||||
echo '<div style="background-color: #fff;" class="alert alert-info"><a target="_blank" href="https://getbible.net" title="Get Bible">
|
echo '<div style="background-color: #fff;" class="alert alert-info"><a target="_blank" href="https://getbible.net" title="Get Bible">
|
||||||
<img src="components/com_getbible/assets/images/vdm-component.jpg"/>
|
<img src="components/com_getbible/assets/images/vdm-component.jpg"/>
|
||||||
</a>
|
</a>
|
||||||
<h3>Upgrade to Version 3.0.8 Was Successful! Let us know if anything is not working as expected.</h3></div>';
|
<h3>Upgrade to Version 3.0.9 Was Successful! Let us know if anything is not working as expected.</h3></div>';
|
||||||
|
|
||||||
// Set db if not set already.
|
// Set db if not set already.
|
||||||
if (!isset($db))
|
if (!isset($db))
|
||||||
@ -2108,6 +2123,174 @@ class Com_GetbibleInstallerScript
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Define the required limits with specific messages for success and warning scenarios
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
* @since 3.0.8
|
||||||
|
*/
|
||||||
|
protected array $requiredPHPConfigs = [
|
||||||
|
'upload_max_filesize' => [
|
||||||
|
'value' => '64M',
|
||||||
|
'success' => 'The upload_max_filesize is appropriately set to handle large files, which is essential for uploading substantial components and media.',
|
||||||
|
'warning' => 'The current upload_max_filesize may not support large file uploads effectively, potentially causing failures during component installation.'
|
||||||
|
],
|
||||||
|
'post_max_size' => [
|
||||||
|
'value' => '128M',
|
||||||
|
'success' => 'The post_max_size setting is sufficient to manage large data submissions, ensuring smooth data processing within forms and uploads.',
|
||||||
|
'warning' => 'An insufficient post_max_size can lead to truncated data submissions, affecting form functionality and data integrity.'
|
||||||
|
],
|
||||||
|
'max_execution_time' => [
|
||||||
|
'value' => 60,
|
||||||
|
'success' => 'Max execution time is set high enough to execute complex operations without premature termination, which is crucial for lengthy operations.',
|
||||||
|
'warning' => 'A low max execution time could lead to script timeouts, especially during intensive operations, which might interrupt execution and cause failures during the compiling of a large extension.'
|
||||||
|
],
|
||||||
|
'max_input_vars' => [
|
||||||
|
'value' => 5000,
|
||||||
|
'success' => 'The max_input_vars setting supports a high number of input variables, facilitating complex forms and detailed component configurations.',
|
||||||
|
'warning' => 'Too few max_input_vars may result in lost data during processing complex forms, which can lead to incomplete configurations and operational issues.'
|
||||||
|
],
|
||||||
|
'max_input_time' => [
|
||||||
|
'value' => 60,
|
||||||
|
'success' => 'Max input time is adequate for processing inputs efficiently during high-load operations, ensuring no premature timeouts.',
|
||||||
|
'warning' => 'An insufficient max input time could result in incomplete data processing during input-heavy operations, potentially leading to errors and data loss.'
|
||||||
|
],
|
||||||
|
'memory_limit' => [
|
||||||
|
'value' => '256M',
|
||||||
|
'success' => 'The memory limit is set high to accommodate extensive operations and data processing, which enhances overall performance and stability.',
|
||||||
|
'warning' => 'A low memory limit can lead to frequent crashes and performance issues, particularly when processing large amounts of data or complex calculations.'
|
||||||
|
]
|
||||||
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper function to convert PHP INI memory values to bytes
|
||||||
|
*
|
||||||
|
* @param string $value The value to convert
|
||||||
|
*
|
||||||
|
* @return int The bytes value
|
||||||
|
* @since 3.0.8
|
||||||
|
*/
|
||||||
|
protected function convertToBytes(string $value): int
|
||||||
|
{
|
||||||
|
$value = trim($value);
|
||||||
|
$lastChar = strtolower($value[strlen($value) - 1]);
|
||||||
|
$numValue = substr($value, 0, -1);
|
||||||
|
|
||||||
|
switch ($lastChar)
|
||||||
|
{
|
||||||
|
case 'g':
|
||||||
|
return $numValue * 1024 * 1024 * 1024;
|
||||||
|
case 'm':
|
||||||
|
return $numValue * 1024 * 1024;
|
||||||
|
case 'k':
|
||||||
|
return $numValue * 1024;
|
||||||
|
default:
|
||||||
|
return (int) $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check that the required configurations are set for PHP
|
||||||
|
*
|
||||||
|
* @param $app The application
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.0.8
|
||||||
|
*/
|
||||||
|
protected function phpConfigurationCheck($app): void
|
||||||
|
{
|
||||||
|
$showHelp = false;
|
||||||
|
|
||||||
|
// Check each configuration and provide detailed feedback
|
||||||
|
foreach ($this->requiredPHPConfigs as $configName => $configDetails)
|
||||||
|
{
|
||||||
|
$currentValue = ini_get($configName);
|
||||||
|
if ($currentValue === false)
|
||||||
|
{
|
||||||
|
$app->enqueueMessage("Error: Unable to retrieve current setting for '{$configName}'.", 'error');
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$isMemoryValue = strpbrk($configDetails['value'], 'KMG') !== false;
|
||||||
|
$requiredValueBytes = $isMemoryValue ? $this->convertToBytes($configDetails['value']) : (int) $configDetails['value'];
|
||||||
|
$currentValueBytes = $isMemoryValue ? $this->convertToBytes($currentValue) : (int) $currentValue;
|
||||||
|
$conditionMet = $currentValueBytes >= $requiredValueBytes;
|
||||||
|
|
||||||
|
$messageType = $conditionMet ? 'message' : 'warning';
|
||||||
|
$messageText = $conditionMet ?
|
||||||
|
"Success: {$configName} is set to {$currentValue}. " . $configDetails['success'] :
|
||||||
|
"Warning: {$configName} configuration should be at least {$configDetails['value']} but is currently {$currentValue}. " . $configDetails['warning'];
|
||||||
|
$showHelp = ($showHelp || $messageType === 'warning') ? true : false;
|
||||||
|
$app->enqueueMessage($messageText, $messageType);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($showHelp)
|
||||||
|
{
|
||||||
|
$app->enqueueMessage('To optimize your Get Bible environment, specific PHP settings must be enhanced.<br>These settings are crucial for ensuring the successful installation and stable functionality of the extension.<br>We\'ve identified that certain configurations currently do not meet the recommended standards.<br>To adjust these settings and prevent potential issues, please consult our detailed guide available at <a href="https://git.vdm.dev/getBible/support/wiki/PHP-Settings" target="_blank">Get Bible PHP Settings Wiki</a>.
|
||||||
|
', 'notice');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make sure that the getbible database schema is up to date.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.0.8
|
||||||
|
*/
|
||||||
|
protected function databaseSchemaCheck($app): void
|
||||||
|
{
|
||||||
|
// try to load the schema class
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// make sure the class is loaded
|
||||||
|
$this->ensureClassExists(
|
||||||
|
Schema::class
|
||||||
|
);
|
||||||
|
|
||||||
|
// instantiate the schema class and check/update the database
|
||||||
|
$messages = (new Schema())->update();
|
||||||
|
}
|
||||||
|
catch (\Exception $e)
|
||||||
|
{
|
||||||
|
$app->enqueueMessage($e->getMessage(), 'warning');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($messages as $message)
|
||||||
|
{
|
||||||
|
$app->enqueueMessage($message, 'message');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensures that a class in the namespace is available.
|
||||||
|
* If the class is not already loaded, it attempts to load it via the power autoloader.
|
||||||
|
*
|
||||||
|
* @param mixed $nameClass The name::class we are looking for.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @since 3.0.8
|
||||||
|
* @throws \Exception If the class could not be loaded.
|
||||||
|
*/
|
||||||
|
protected function ensureClassExists($nameClass): void
|
||||||
|
{
|
||||||
|
if (!class_exists($nameClass, true))
|
||||||
|
{
|
||||||
|
// The power autoloader for this project admin area.
|
||||||
|
$power_autoloader = JPATH_ADMINISTRATOR . '/components/com_getbible/helpers/powerloader.php';
|
||||||
|
if (file_exists($power_autoloader))
|
||||||
|
{
|
||||||
|
require_once $power_autoloader;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check again if the class now exists after requiring it
|
||||||
|
if (!class_exists($nameClass, true))
|
||||||
|
{
|
||||||
|
throw new \Exception("We failed to find/load the $nameClass");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method to set/copy dynamic folders into place (use with caution)
|
* Method to set/copy dynamic folders into place (use with caution)
|
||||||
*
|
*
|
||||||
|
@ -18,51 +18,12 @@
|
|||||||
// No direct access to this file
|
// No direct access to this file
|
||||||
defined('_JEXEC') or die('Restricted access');
|
defined('_JEXEC') or die('Restricted access');
|
||||||
|
|
||||||
// register additional namespace
|
// The power autoloader for this project (JPATH_SITE) area.
|
||||||
\spl_autoload_register(function ($class) {
|
$power_autoloader = JPATH_SITE . '/components/com_getbible/helpers/powerloader.php';
|
||||||
// project-specific base directories and namespace prefix
|
if (file_exists($power_autoloader))
|
||||||
$search = [
|
{
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.GetBible' => 'TrueChristianChurch\\Joomla\\GetBible',
|
require_once $power_autoloader;
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Openai' => 'TrueChristianChurch\\Joomla\\Openai',
|
}
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Gitea' => 'TrueChristianChurch\\Joomla\\Gitea',
|
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla' => 'TrueChristianChurch\\Joomla'
|
|
||||||
];
|
|
||||||
// Start the search and load if found
|
|
||||||
$found = false;
|
|
||||||
$found_base_dir = "";
|
|
||||||
$found_len = 0;
|
|
||||||
foreach ($search as $base_dir => $prefix)
|
|
||||||
{
|
|
||||||
// does the class use the namespace prefix?
|
|
||||||
$len = strlen($prefix);
|
|
||||||
if (strncmp($prefix, $class, $len) === 0)
|
|
||||||
{
|
|
||||||
// we have a match so load the values
|
|
||||||
$found = true;
|
|
||||||
$found_base_dir = $base_dir;
|
|
||||||
$found_len = $len;
|
|
||||||
// done here
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// check if we found a match
|
|
||||||
if (!$found)
|
|
||||||
{
|
|
||||||
// not found so move to the next registered autoloader
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// get the relative class name
|
|
||||||
$relative_class = substr($class, $found_len);
|
|
||||||
// replace the namespace prefix with the base directory, replace namespace
|
|
||||||
// separators with directory separators in the relative class name, append
|
|
||||||
// with .php
|
|
||||||
$file = JPATH_ROOT . '/' . $found_base_dir . '/src' . str_replace('\\', '/', $relative_class) . '.php';
|
|
||||||
// if the file exists, require it
|
|
||||||
if (file_exists($file))
|
|
||||||
{
|
|
||||||
require $file;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
use Joomla\CMS\Factory;
|
use Joomla\CMS\Factory;
|
||||||
use Joomla\CMS\Language\Text;
|
use Joomla\CMS\Language\Text;
|
||||||
|
@ -18,51 +18,12 @@
|
|||||||
// No direct access to this file
|
// No direct access to this file
|
||||||
defined('_JEXEC') or die('Restricted access');
|
defined('_JEXEC') or die('Restricted access');
|
||||||
|
|
||||||
// register additional namespace
|
// The power autoloader for this project (JPATH_SITE) area.
|
||||||
\spl_autoload_register(function ($class) {
|
$power_autoloader = JPATH_SITE . '/components/com_getbible/helpers/powerloader.php';
|
||||||
// project-specific base directories and namespace prefix
|
if (file_exists($power_autoloader))
|
||||||
$search = [
|
{
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.GetBible' => 'TrueChristianChurch\\Joomla\\GetBible',
|
require_once $power_autoloader;
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Openai' => 'TrueChristianChurch\\Joomla\\Openai',
|
}
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Gitea' => 'TrueChristianChurch\\Joomla\\Gitea',
|
|
||||||
'libraries/vendor_getbible/TrueChristianChurch.Joomla' => 'TrueChristianChurch\\Joomla'
|
|
||||||
];
|
|
||||||
// Start the search and load if found
|
|
||||||
$found = false;
|
|
||||||
$found_base_dir = "";
|
|
||||||
$found_len = 0;
|
|
||||||
foreach ($search as $base_dir => $prefix)
|
|
||||||
{
|
|
||||||
// does the class use the namespace prefix?
|
|
||||||
$len = strlen($prefix);
|
|
||||||
if (strncmp($prefix, $class, $len) === 0)
|
|
||||||
{
|
|
||||||
// we have a match so load the values
|
|
||||||
$found = true;
|
|
||||||
$found_base_dir = $base_dir;
|
|
||||||
$found_len = $len;
|
|
||||||
// done here
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// check if we found a match
|
|
||||||
if (!$found)
|
|
||||||
{
|
|
||||||
// not found so move to the next registered autoloader
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// get the relative class name
|
|
||||||
$relative_class = substr($class, $found_len);
|
|
||||||
// replace the namespace prefix with the base directory, replace namespace
|
|
||||||
// separators with directory separators in the relative class name, append
|
|
||||||
// with .php
|
|
||||||
$file = JPATH_ROOT . '/' . $found_base_dir . '/src' . str_replace('\\', '/', $relative_class) . '.php';
|
|
||||||
// if the file exists, require it
|
|
||||||
if (file_exists($file))
|
|
||||||
{
|
|
||||||
require $file;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
use Joomla\CMS\Factory;
|
use Joomla\CMS\Factory;
|
||||||
use Joomla\CMS\Language\Text;
|
use Joomla\CMS\Language\Text;
|
||||||
|
65
site/helpers/powerloader.php
Normal file
65
site/helpers/powerloader.php
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
<?php
|
||||||
|
/*----------------------------------------------------------------------------------| io.vdm.dev |----/
|
||||||
|
Vast Development Method
|
||||||
|
/-------------------------------------------------------------------------------------------------------/
|
||||||
|
|
||||||
|
@package getBible.net
|
||||||
|
|
||||||
|
@created 3rd December, 2015
|
||||||
|
@author Llewellyn van der Merwe <https://getbible.net>
|
||||||
|
@git Get Bible <https://git.vdm.dev/getBible>
|
||||||
|
@github Get Bible <https://github.com/getBible>
|
||||||
|
@support Get Bible <https://git.vdm.dev/getBible/support>
|
||||||
|
@copyright Copyright (C) 2015. All Rights Reserved
|
||||||
|
@license GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
|
||||||
|
/------------------------------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
// No direct access to this file
|
||||||
|
defined('_JEXEC') or die;
|
||||||
|
|
||||||
|
// register additional namespace
|
||||||
|
spl_autoload_register(function ($class) {
|
||||||
|
// project-specific base directories and namespace prefix
|
||||||
|
$search = [
|
||||||
|
'libraries/vendor_getbible/TrueChristianChurch.Joomla.GetBible' => 'TrueChristianChurch\\Joomla\\GetBible',
|
||||||
|
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Openai' => 'TrueChristianChurch\\Joomla\\Openai',
|
||||||
|
'libraries/vendor_getbible/TrueChristianChurch.Joomla.Gitea' => 'TrueChristianChurch\\Joomla\\Gitea',
|
||||||
|
'libraries/vendor_getbible/TrueChristianChurch.Joomla' => 'TrueChristianChurch\\Joomla'
|
||||||
|
];
|
||||||
|
// Start the search and load if found
|
||||||
|
$found = false;
|
||||||
|
$found_base_dir = "";
|
||||||
|
$found_len = 0;
|
||||||
|
foreach ($search as $base_dir => $prefix)
|
||||||
|
{
|
||||||
|
// does the class use the namespace prefix?
|
||||||
|
$len = strlen($prefix);
|
||||||
|
if (strncmp($prefix, $class, $len) === 0)
|
||||||
|
{
|
||||||
|
// we have a match so load the values
|
||||||
|
$found = true;
|
||||||
|
$found_base_dir = $base_dir;
|
||||||
|
$found_len = $len;
|
||||||
|
// done here
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// check if we found a match
|
||||||
|
if (!$found)
|
||||||
|
{
|
||||||
|
// not found so move to the next registered autoloader
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// get the relative class name
|
||||||
|
$relative_class = substr($class, $found_len);
|
||||||
|
// replace the namespace prefix with the base directory, replace namespace
|
||||||
|
// separators with directory separators in the relative class name, append
|
||||||
|
// with .php
|
||||||
|
$file = JPATH_ROOT . '/' . $found_base_dir . '/src' . str_replace('\\', '/', $relative_class) . '.php';
|
||||||
|
// if the file exists, require it
|
||||||
|
if (file_exists($file))
|
||||||
|
{
|
||||||
|
require $file;
|
||||||
|
}
|
||||||
|
});
|
@ -27,6 +27,7 @@ use Joomla\Utilities\ArrayHelper;
|
|||||||
use Joomla\CMS\Router\Route;
|
use Joomla\CMS\Router\Route;
|
||||||
use Joomla\CMS\Uri\Uri;
|
use Joomla\CMS\Uri\Uri;
|
||||||
use Joomla\CMS\Layout\LayoutHelper;
|
use Joomla\CMS\Layout\LayoutHelper;
|
||||||
|
use TrueChristianChurch\Joomla\GetBible\Openai;
|
||||||
use TrueChristianChurch\Joomla\GetBible\Factory as GetBibleFactory;
|
use TrueChristianChurch\Joomla\GetBible\Factory as GetBibleFactory;
|
||||||
use TrueChristianChurch\Joomla\Utilities\JsonHelper;
|
use TrueChristianChurch\Joomla\Utilities\JsonHelper;
|
||||||
use TrueChristianChurch\Joomla\Utilities\GuidHelper;
|
use TrueChristianChurch\Joomla\Utilities\GuidHelper;
|
||||||
|
@ -118,7 +118,7 @@ class GetbibleModelOpenai extends ItemModel
|
|||||||
$app = Factory::getApplication();
|
$app = Factory::getApplication();
|
||||||
// If no data is found redirect to default page and show warning.
|
// If no data is found redirect to default page and show warning.
|
||||||
$app->enqueueMessage('The Open AI feature has not been activated. Please contact the system administrator of this website to resolve this.', 'error');
|
$app->enqueueMessage('The Open AI feature has not been activated. Please contact the system administrator of this website to resolve this.', 'error');
|
||||||
$app->redirect(\JRoute::_('index.php?option=com_getbible&view=app'));
|
$app->redirect(Route::_('index.php?option=com_getbible&view=app'));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// validate that we have a valid prompt and we have a book, chapter and verse
|
// validate that we have a valid prompt and we have a book, chapter and verse
|
||||||
@ -127,7 +127,7 @@ class GetbibleModelOpenai extends ItemModel
|
|||||||
$app = Factory::getApplication();
|
$app = Factory::getApplication();
|
||||||
// If no data is found redirect to default page and show warning.
|
// If no data is found redirect to default page and show warning.
|
||||||
$app->enqueueMessage('There has been an error!', 'error');
|
$app->enqueueMessage('There has been an error!', 'error');
|
||||||
$app->redirect(\JRoute::_('index.php?option=com_getbible&view=app'));
|
$app->redirect(Route::_('index.php?option=com_getbible&view=app'));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// validate that we have the correct translation
|
// validate that we have the correct translation
|
||||||
@ -136,7 +136,7 @@ class GetbibleModelOpenai extends ItemModel
|
|||||||
$app = Factory::getApplication();
|
$app = Factory::getApplication();
|
||||||
// If no data is found redirect to default page and show warning.
|
// If no data is found redirect to default page and show warning.
|
||||||
$app->enqueueMessage('There has been an error: mismatch!', 'error');
|
$app->enqueueMessage('There has been an error: mismatch!', 'error');
|
||||||
$app->redirect(\JRoute::_('index.php?option=com_getbible&view=app'));
|
$app->redirect(Route::_('index.php?option=com_getbible&view=app'));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ class GetbibleRouter extends JComponentRouterBase
|
|||||||
{
|
{
|
||||||
$segments = [];
|
$segments = [];
|
||||||
$view = $query['view'] ?? 'app';
|
$view = $query['view'] ?? 'app';
|
||||||
$this->defaultTranslation ??= \JComponentHelper::getParams('com_getbible')->get('default_translation', 'kjv');
|
$this->defaultTranslation ??= Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_getbible')->get('default_translation', 'kjv');
|
||||||
|
|
||||||
if ($view === 'search')
|
if ($view === 'search')
|
||||||
{
|
{
|
||||||
@ -216,7 +216,7 @@ class GetbibleRouter extends JComponentRouterBase
|
|||||||
$vars = [];
|
$vars = [];
|
||||||
$vars['view'] = 'app';
|
$vars['view'] = 'app';
|
||||||
|
|
||||||
$this->defaultTranslation ??= \JComponentHelper::getParams('com_getbible')->get('default_translation', 'kjv');
|
$this->defaultTranslation ??= Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_getbible')->get('default_translation', 'kjv');
|
||||||
|
|
||||||
$key = 0;
|
$key = 0;
|
||||||
$vars['t'] = $segments[$key] ?? '';
|
$vars['t'] = $segments[$key] ?? '';
|
||||||
|
@ -21,6 +21,7 @@ defined('_JEXEC') or die('Restricted access');
|
|||||||
use Joomla\CMS\Language\Text;
|
use Joomla\CMS\Language\Text;
|
||||||
use Joomla\CMS\HTML\HTMLHelper as Html;
|
use Joomla\CMS\HTML\HTMLHelper as Html;
|
||||||
use Joomla\CMS\Layout\LayoutHelper;
|
use Joomla\CMS\Layout\LayoutHelper;
|
||||||
|
use Joomla\CMS\Router\Route;
|
||||||
|
|
||||||
?>
|
?>
|
||||||
<div class="uk-child-width-auto uk-grid-small" uk-grid>
|
<div class="uk-child-width-auto uk-grid-small" uk-grid>
|
||||||
@ -28,11 +29,11 @@ use Joomla\CMS\Layout\LayoutHelper;
|
|||||||
<div>
|
<div>
|
||||||
<div class="uk-card">
|
<div class="uk-card">
|
||||||
<?php if ($book->nr !== $this->chapter->book_nr): ?>
|
<?php if ($book->nr !== $this->chapter->book_nr): ?>
|
||||||
<a class="uk-button uk-button-default" href="<?php echo \JRoute::_('index.php?option=com_getbible&view=app&t=' . $book->abbreviation . '&ref=' . $book->name . '&c=1&tab=chapters'); ?>">
|
<a class="uk-button uk-button-default" href="<?php echo Route::_('index.php?option=com_getbible&view=app&t=' . $book->abbreviation . '&ref=' . $book->name . '&c=1&tab=chapters'); ?>">
|
||||||
<?php echo $book->name; ?>
|
<?php echo $book->name; ?>
|
||||||
</a>
|
</a>
|
||||||
<?php else: ?>
|
<?php else: ?>
|
||||||
<a class="uk-button uk-button-default uk-active" href="<?php echo \JRoute::_('index.php?option=com_getbible&view=app&t=' . $book->abbreviation . '&ref=' . $book->name . '&c=' . $this->chapter->chapter); ?>">
|
<a class="uk-button uk-button-default uk-active" href="<?php echo Route::_('index.php?option=com_getbible&view=app&t=' . $book->abbreviation . '&ref=' . $book->name . '&c=' . $this->chapter->chapter); ?>">
|
||||||
<?php echo $book->name; ?>
|
<?php echo $book->name; ?>
|
||||||
</a>
|
</a>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
|
@ -21,6 +21,7 @@ defined('_JEXEC') or die('Restricted access');
|
|||||||
use Joomla\CMS\Language\Text;
|
use Joomla\CMS\Language\Text;
|
||||||
use Joomla\CMS\HTML\HTMLHelper as Html;
|
use Joomla\CMS\HTML\HTMLHelper as Html;
|
||||||
use Joomla\CMS\Layout\LayoutHelper;
|
use Joomla\CMS\Layout\LayoutHelper;
|
||||||
|
use Joomla\CMS\Router\Route;
|
||||||
|
|
||||||
?>
|
?>
|
||||||
<div class="uk-child-width-auto uk-text-center" uk-grid>
|
<div class="uk-child-width-auto uk-text-center" uk-grid>
|
||||||
@ -28,11 +29,11 @@ use Joomla\CMS\Layout\LayoutHelper;
|
|||||||
<div>
|
<div>
|
||||||
<div class="uk-card">
|
<div class="uk-card">
|
||||||
<?php if ($chapter->chapter !== $this->chapter->chapter): ?>
|
<?php if ($chapter->chapter !== $this->chapter->chapter): ?>
|
||||||
<a class="uk-button uk-button-default" href="<?php echo \JRoute::_('index.php?option=com_getbible&view=app&t=' . $chapter->abbreviation . '&ref=' . $chapter->book_name . '&c=' . $chapter->chapter); ?>">
|
<a class="uk-button uk-button-default" href="<?php echo Route::_('index.php?option=com_getbible&view=app&t=' . $chapter->abbreviation . '&ref=' . $chapter->book_name . '&c=' . $chapter->chapter); ?>">
|
||||||
<?php echo $chapter->chapter; ?>
|
<?php echo $chapter->chapter; ?>
|
||||||
</a>
|
</a>
|
||||||
<?php else: ?>
|
<?php else: ?>
|
||||||
<a class="uk-button uk-button-default uk-active" href="<?php echo \JRoute::_('index.php?option=com_getbible&view=app&t=' . $chapter->abbreviation . '&ref=' . $chapter->book_name . '&c=' . $chapter->chapter); ?>">
|
<a class="uk-button uk-button-default uk-active" href="<?php echo Route::_('index.php?option=com_getbible&view=app&t=' . $chapter->abbreviation . '&ref=' . $chapter->book_name . '&c=' . $chapter->chapter); ?>">
|
||||||
<?php echo $chapter->chapter; ?>
|
<?php echo $chapter->chapter; ?>
|
||||||
</a>
|
</a>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
|
@ -21,10 +21,11 @@ defined('_JEXEC') or die('Restricted access');
|
|||||||
use Joomla\CMS\Language\Text;
|
use Joomla\CMS\Language\Text;
|
||||||
use Joomla\CMS\HTML\HTMLHelper as Html;
|
use Joomla\CMS\HTML\HTMLHelper as Html;
|
||||||
use Joomla\CMS\Layout\LayoutHelper;
|
use Joomla\CMS\Layout\LayoutHelper;
|
||||||
|
use Joomla\CMS\Router\Route;
|
||||||
|
|
||||||
?>
|
?>
|
||||||
<?php if (!empty($this->defaultTranslation)): ?>
|
<?php if (!empty($this->defaultTranslation)): ?>
|
||||||
<a class="uk-button uk-button-default uk-button-small uk-width-1-1" href="<?php echo \JRoute::_('index.php?option=com_getbible&view=app&t=' . $this->defaultTranslation->abbreviation . '&b=' . $this->chapter->book_nr . '&c=' . $this->chapter->chapter); ?>">
|
<a class="uk-button uk-button-default uk-button-small uk-width-1-1" href="<?php echo Route::_('index.php?option=com_getbible&view=app&t=' . $this->defaultTranslation->abbreviation . '&b=' . $this->chapter->book_nr . '&c=' . $this->chapter->chapter); ?>">
|
||||||
<?php echo $this->defaultTranslation->translation; ?> (<?php echo $this->defaultTranslation->abbreviation; ?>)
|
<?php echo $this->defaultTranslation->translation; ?> (<?php echo $this->defaultTranslation->abbreviation; ?>)
|
||||||
</a>
|
</a>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
@ -39,11 +40,11 @@ use Joomla\CMS\Layout\LayoutHelper;
|
|||||||
<div class="uk-accordion-content">
|
<div class="uk-accordion-content">
|
||||||
<?php foreach ($translations as $translation): ?>
|
<?php foreach ($translations as $translation): ?>
|
||||||
<?php if ($translation->abbreviation !== $this->chapter->abbreviation): ?>
|
<?php if ($translation->abbreviation !== $this->chapter->abbreviation): ?>
|
||||||
<a class="uk-button uk-button-default uk-button-small uk-width-1-1 uk-margin-small-bottom" href="<?php echo \JRoute::_('index.php?option=com_getbible&view=app&t=' . $translation->abbreviation . '&b=' . $this->chapter->book_nr . '&c=' . $this->chapter->chapter); ?>">
|
<a class="uk-button uk-button-default uk-button-small uk-width-1-1 uk-margin-small-bottom" href="<?php echo Route::_('index.php?option=com_getbible&view=app&t=' . $translation->abbreviation . '&b=' . $this->chapter->book_nr . '&c=' . $this->chapter->chapter); ?>">
|
||||||
<?php echo $translation->translation; ?> (<?php echo $translation->abbreviation; ?>)
|
<?php echo $translation->translation; ?> (<?php echo $translation->abbreviation; ?>)
|
||||||
</a>
|
</a>
|
||||||
<?php else: ?>
|
<?php else: ?>
|
||||||
<a class="uk-button uk-button-default uk-button-small uk-active uk-width-1-1 uk-margin-small-bottom" href="<?php echo \JRoute::_('index.php?option=com_getbible&view=app&t=' . $translation->abbreviation . '&b=' . $this->chapter->book_nr . '&c=' . $this->chapter->chapter); ?>">
|
<a class="uk-button uk-button-default uk-button-small uk-active uk-width-1-1 uk-margin-small-bottom" href="<?php echo Route::_('index.php?option=com_getbible&view=app&t=' . $translation->abbreviation . '&b=' . $this->chapter->book_nr . '&c=' . $this->chapter->chapter); ?>">
|
||||||
<?php echo $translation->translation; ?> (<?php echo $translation->abbreviation; ?>)
|
<?php echo $translation->translation; ?> (<?php echo $translation->abbreviation; ?>)
|
||||||
</a>
|
</a>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
|
@ -701,4 +701,22 @@
|
|||||||
<maintainerurl>https://getbible.net</maintainerurl>
|
<maintainerurl>https://getbible.net</maintainerurl>
|
||||||
<targetplatform name="joomla" version="3.*"/>
|
<targetplatform name="joomla" version="3.*"/>
|
||||||
</update>
|
</update>
|
||||||
|
<update>
|
||||||
|
<name>Get Bible</name>
|
||||||
|
<description>The Bible for Joomla</description>
|
||||||
|
<element>pkg_getbible</element>
|
||||||
|
<type>package</type>
|
||||||
|
<client>site</client>
|
||||||
|
<version>3.0.9</version>
|
||||||
|
<infourl title="Get Bible!">https://getbible.net</infourl>
|
||||||
|
<downloads>
|
||||||
|
<downloadurl type="full" format="zip">https://git.vdm.dev/api/v1/repos/getBible/joomla-pkg/archive/v3.0.9.zip</downloadurl>
|
||||||
|
</downloads>
|
||||||
|
<tags>
|
||||||
|
<tag>stable</tag>
|
||||||
|
</tags>
|
||||||
|
<maintainer>Llewellyn van der Merwe</maintainer>
|
||||||
|
<maintainerurl>https://getbible.net</maintainerurl>
|
||||||
|
<targetplatform name="joomla" version="3.*"/>
|
||||||
|
</update>
|
||||||
</updates>
|
</updates>
|
Loading…
Reference in New Issue
Block a user