2016-01-30 20:28:43 +00:00
< ? php
2021-03-05 03:08:47 +00:00
/**
* @ package Joomla . Component . Builder
*
* @ created 30 th April , 2015
2022-07-09 15:45:08 +00:00
* @ author Llewellyn van der Merwe < https :// dev . vdm . io >
* @ git Joomla Component Builder < https :// git . vdm . dev / joomla / Component - Builder >
2021-03-05 03:08:47 +00:00
* @ copyright Copyright ( C ) 2015 Vast Development Method . All rights reserved .
* @ license GNU General Public License version 2 or later ; see LICENSE . txt
*/
// No direct access to this file
defined ( '_JEXEC' ) or die ( 'Restricted access' );
2024-03-02 20:10:30 +00:00
use Joomla\CMS\Factory ;
use Joomla\CMS\Language\Text ;
use Joomla\CMS\Component\ComponentHelper ;
use Joomla\CMS\Filter\InputFilter ;
use Joomla\CMS\Filter\OutputFilter ;
2022-05-25 08:30:55 +00:00
use Joomla\CMS\MVC\Model\AdminModel ;
2024-03-02 20:10:30 +00:00
use Joomla\CMS\Table\Table ;
use Joomla\CMS\UCM\UCMType ;
2020-10-21 03:10:19 +00:00
use Joomla\Registry\Registry ;
use Joomla\String\StringHelper ;
2021-03-05 03:08:47 +00:00
use Joomla\Utilities\ArrayHelper ;
2024-03-02 20:10:30 +00:00
use Joomla\CMS\Helper\TagsHelper ;
2023-10-18 07:26:30 +00:00
use VDM\Joomla\Utilities\StringHelper as UtilitiesStringHelper ;
use VDM\Joomla\Utilities\ObjectHelper ;
2024-03-02 20:10:30 +00:00
use VDM\Joomla\Utilities\GuidHelper ;
2023-10-18 07:26:30 +00:00
use VDM\Joomla\FOF\Encrypt\AES ;
use VDM\Joomla\Utilities\ArrayHelper as UtilitiesArrayHelper ;
2024-04-09 11:07:08 +00:00
use VDM\Joomla\Utilities\String\ComponentCodeNameHelper ;
2023-10-18 07:26:30 +00:00
use VDM\Joomla\Utilities\GetHelper ;
2024-03-06 13:06:11 +00:00
use VDM\Joomla\Componentbuilder\Extrusion\Helper\Extrusion ;
2021-03-05 03:08:47 +00:00
/**
2022-05-25 08:30:55 +00:00
* Componentbuilder Joomla_component Admin Model
2021-03-05 03:08:47 +00:00
*/
2022-05-25 08:30:55 +00:00
class ComponentbuilderModelJoomla_component extends AdminModel
2021-03-05 03:08:47 +00:00
{
/**
* The tab layout fields array .
*
* @ var array
*/
2019-07-01 16:10:28 +00:00
protected $tabLayoutFields = array (
'details' => array (
'left' => array (
'name' ,
'name_code' ,
'component_version' ,
'debug_linenr' ,
'add_placeholders' ,
2020-08-19 00:54:09 +00:00
'remove_line_breaks' ,
2019-07-01 16:10:28 +00:00
'mvc_versiondate' ,
2021-12-21 14:44:50 +00:00
'note_version_options_1' ,
'note_version_options_2' ,
'note_version_options_3' ,
2019-07-01 16:10:28 +00:00
'short_description' ,
2020-08-19 00:54:09 +00:00
'description'
2019-07-01 16:10:28 +00:00
),
'right' => array (
'companyname' ,
'author' ,
'email' ,
'website' ,
'license' ,
'bom' ,
2020-08-19 00:54:09 +00:00
'image' ,
'copyright'
2019-07-01 16:10:28 +00:00
),
'above' => array (
2022-05-16 04:25:03 +00:00
'system_name' ,
2024-03-07 19:23:32 +00:00
'preferred_joomla_version' ,
2022-05-16 04:25:03 +00:00
'add_powers'
2019-07-01 16:10:28 +00:00
),
'under' => array (
'not_required'
)
),
2022-05-16 04:25:03 +00:00
'dynamic_integration' => array (
'left' => array (
'add_update_server' ,
'update_server_url' ,
'update_server_target' ,
'note_update_server_note_ftp' ,
'note_update_server_note_zip' ,
'note_update_server_note_other' ,
'update_server' ,
'add_sales_server' ,
2023-10-24 07:46:36 +00:00
'sales_server' ,
'add_backup_folder_path' ,
'note_backup_folder_path' ,
'backup_folder_path' ,
'add_git_folder_path' ,
'note_git_folder_path' ,
2024-04-06 17:48:58 +00:00
'git_folder_path' ,
'add_jcb_powers_path' ,
'jcb_powers_path'
2022-05-16 04:25:03 +00:00
),
'right' => array (
'translation_tool' ,
'note_crowdin' ,
'crowdin_project_identifier' ,
'crowdin_project_api_key' ,
'crowdin_username' ,
'crowdin_account_api_key'
)
),
2024-06-20 23:32:05 +00:00
'mysql' => array (
'fullwidth' => array (
'add_sql' ,
'sql' ,
'add_sql_uninstall' ,
'sql_uninstall' ,
'assets_table_fix'
)
),
2019-07-01 16:10:28 +00:00
'dash_install' => array (
'left' => array (
'dashboard_type'
),
'right' => array (
'note_dynamic_dashboard' ,
'dashboard' ,
'note_botton_component_dashboard'
),
'fullwidth' => array (
'add_php_preflight_install' ,
'php_preflight_install' ,
'add_php_preflight_update' ,
'php_preflight_update' ,
'add_php_postflight_install' ,
'php_postflight_install' ,
'add_php_postflight_update' ,
'php_postflight_update' ,
'add_php_method_uninstall' ,
2024-04-21 22:59:42 +00:00
'php_method_uninstall' ,
'add_php_method_install' ,
'php_method_install'
2024-03-07 19:23:32 +00:00
)
),
2024-06-20 23:32:05 +00:00
'libs_helpers' => array (
'fullwidth' => array (
'creatuserhelper' ,
'adduikit' ,
'addfootable' ,
'add_email_helper' ,
'add_php_helper_both' ,
'php_helper_both' ,
'add_php_helper_admin' ,
'php_helper_admin' ,
'add_admin_event' ,
'php_admin_event' ,
'add_php_helper_site' ,
'php_helper_site' ,
'add_site_event' ,
'php_site_event' ,
'add_javascript' ,
'javascript' ,
'add_css_admin' ,
'css_admin' ,
'add_css_site' ,
'css_site'
)
),
2024-04-06 17:48:58 +00:00
'readme' => array (
'left' => array (
'addreadme' ,
'readme'
),
'right' => array (
'note_readme'
2021-01-30 13:36:03 +00:00
)
),
2024-04-21 22:59:42 +00:00
'dynamic_build' => array (
'fullwidth' => array (
'note_buildcomp_dynamic_mysql' ,
'buildcomp' ,
'buildcompsql'
)
),
2019-07-01 16:10:28 +00:00
'settings' => array (
'left' => array (
'note_moved_views' ,
2021-12-21 14:44:50 +00:00
'spacer_hr_1' ,
2019-07-01 16:10:28 +00:00
'note_mysql_tweak_options' ,
2021-12-21 14:44:50 +00:00
'spacer_hr_2' ,
2019-07-01 16:10:28 +00:00
'note_add_custom_menus' ,
2021-12-21 14:44:50 +00:00
'spacer_hr_3' ,
2019-07-01 16:10:28 +00:00
'note_add_config'
),
'right' => array (
'note_component_files_folders' ,
2021-12-21 14:44:50 +00:00
'spacer_hr_4' ,
2024-03-02 20:10:30 +00:00
'add_namespace_prefix' ,
'namespace_prefix' ,
'spacer_hr_5' ,
2019-07-01 16:10:28 +00:00
'add_menu_prefix' ,
'menu_prefix' ,
2024-03-02 20:10:30 +00:00
'spacer_hr_6' ,
2019-07-01 16:10:28 +00:00
'to_ignore_note' ,
'toignore' ,
2024-03-02 20:10:30 +00:00
'spacer_hr_7' ,
2019-07-01 16:10:28 +00:00
'jcb_export_package_note' ,
'export_key' ,
'joomla_source_link' ,
'export_buy_link'
),
'fullwidth' => array (
2024-03-02 20:10:30 +00:00
'spacer_hr_8' ,
2019-07-01 16:10:28 +00:00
'note_on_contributors' ,
'addcontributors' ,
'emptycontributors' ,
'number'
)
),
'admin_views' => array (
'fullwidth' => array (
'note_on_admin_views' ,
'note_display_component_admin_views'
)
),
'site_views' => array (
'fullwidth' => array (
'note_on_site_views' ,
'note_display_component_site_views'
)
),
'custom_admin_views' => array (
'fullwidth' => array (
'note_on_custom_admin_views' ,
'note_display_component_custom_admin_views'
)
)
2021-03-05 03:08:47 +00:00
);
/**
* @ var string The prefix to use with controller messages .
* @ since 1.6
*/
protected $text_prefix = 'COM_COMPONENTBUILDER' ;
/**
* The type alias for this content type .
*
* @ var string
* @ since 3.2
*/
public $typeAlias = 'com_componentbuilder.joomla_component' ;
/**
* Returns a Table object , always creating it
*
* @ param type $type The table type to instantiate
* @ param string $prefix A prefix for the table class name . Optional .
* @ param array $config Configuration array for model . Optional .
*
2024-03-02 20:10:30 +00:00
* @ return Table A database object
2021-03-05 03:08:47 +00:00
*
* @ since 1.6
*/
2024-03-02 20:10:30 +00:00
public function getTable ( $type = 'joomla_component' , $prefix = 'ComponentbuilderTable' , $config = [])
2021-03-05 03:08:47 +00:00
{
// add table path for when model gets used from other component
$this -> addTablePath ( JPATH_ADMINISTRATOR . '/components/com_componentbuilder/tables' );
// get instance of the table
2024-03-02 20:10:30 +00:00
return Table :: getInstance ( $type , $prefix , $config );
2017-10-26 16:43:51 +00:00
}
2019-11-08 16:07:08 +00:00
2019-07-04 23:53:54 +00:00
/**
2024-07-08 20:53:46 +00:00
* Retrieves or generates a Vast Development Method ( VDM ) key for the current item .
2019-07-04 23:53:54 +00:00
*
2024-07-08 20:53:46 +00:00
* This function performs the following operations :
* 1. Checks if the VDM key is already set . If not , it proceeds to generate or retrieve one .
* 2. Determines the item ID based on the presence of a specific argument .
* 3. Attempts to retrieve an existing VDM key from a helper method using the item ID .
* 4. If a VDM key is not found , it generates a new random VDM key .
* 5. Stores the VDM key and associates it with the item ID in a helper method .
* 6. Optionally , stores return and GUID values if available .
* 7. Returns the VDM key .
2019-07-04 23:53:54 +00:00
*
2024-07-08 20:53:46 +00:00
* @ return string The VDM key for the current item .
2019-07-04 23:53:54 +00:00
*/
2017-10-26 16:43:51 +00:00
public function getVDM ()
{
2019-11-08 16:07:08 +00:00
if ( ! isset ( $this -> vastDevMod ))
{
$_id = 0 ; // new item probably (since it was not set in the getItem method)
if ( empty ( $_id ))
{
$id = 0 ;
}
else
{
$id = $_id ;
}
// set the id and view name to session
if ( $vdm = ComponentbuilderHelper :: get ( 'joomla_component__' . $id ))
{
$this -> vastDevMod = $vdm ;
}
else
{
// set the vast development method key
2023-10-18 07:26:30 +00:00
$this -> vastDevMod = UtilitiesStringHelper :: random ( 50 );
2019-11-08 16:07:08 +00:00
ComponentbuilderHelper :: set ( $this -> vastDevMod , 'joomla_component__' . $id );
ComponentbuilderHelper :: set ( 'joomla_component__' . $id , $this -> vastDevMod );
// set a return value if found
2024-03-02 20:10:30 +00:00
$jinput = Factory :: getApplication () -> input ;
2019-11-08 16:07:08 +00:00
$return = $jinput -> get ( 'return' , null , 'base64' );
ComponentbuilderHelper :: set ( $this -> vastDevMod . '__return' , $return );
// set a GUID value if found
2023-10-18 07:26:30 +00:00
if ( isset ( $item ) && ObjectHelper :: check ( $item ) && isset ( $item -> guid )
2024-03-02 20:10:30 +00:00
&& GuidHelper :: valid ( $item -> guid ))
2019-11-08 16:07:08 +00:00
{
ComponentbuilderHelper :: set ( $this -> vastDevMod . '__guid' , $item -> guid );
}
}
}
2017-10-26 16:43:51 +00:00
return $this -> vastDevMod ;
2016-01-30 20:28:43 +00:00
}
2019-07-04 23:53:54 +00:00
2020-01-03 01:41:55 +00:00
/**
* The assistant form fields
*
* @ var array
*/
public $assistantForm = array (
'left' => array (
'name' ,
'short_description' ,
2020-01-03 03:36:47 +00:00
'guid' ,
2020-01-03 01:41:55 +00:00
'copyright'
),
'right' => array (
2020-01-03 03:36:47 +00:00
'name_code' ,
2020-01-03 01:41:55 +00:00
'license' ,
'bom' ,
'image'
)
);
2021-03-05 03:08:47 +00:00
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Method to get a single record .
*
* @ param integer $pk The id of the primary key .
*
* @ return mixed Object on success , false on failure .
*
* @ since 1.6
*/
public function getItem ( $pk = null )
{
if ( $item = parent :: getItem ( $pk ))
{
if ( ! empty ( $item -> params ) && ! is_array ( $item -> params ))
{
// Convert the params field to an array.
$registry = new Registry ;
$registry -> loadString ( $item -> params );
$item -> params = $registry -> toArray ();
}
if ( ! empty ( $item -> metadata ))
{
// Convert the metadata field to an array.
$registry = new Registry ;
$registry -> loadString ( $item -> metadata );
$item -> metadata = $registry -> toArray ();
2016-01-30 20:28:43 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> sql_uninstall ))
2023-10-24 07:46:36 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode sql_uninstall.
$item -> sql_uninstall = base64_decode ( $item -> sql_uninstall );
2023-10-24 07:46:36 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> php_postflight_update ))
2024-04-06 17:48:58 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode php_postflight_update.
$item -> php_postflight_update = base64_decode ( $item -> php_postflight_update );
2024-04-06 17:48:58 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> css_site ))
2024-04-06 17:48:58 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode css_site.
$item -> css_site = base64_decode ( $item -> css_site );
2024-04-06 17:48:58 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> php_helper_site ))
2024-04-21 22:59:42 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode php_helper_site.
$item -> php_helper_site = base64_decode ( $item -> php_helper_site );
2024-04-21 22:59:42 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> javascript ))
2024-04-21 22:59:42 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode javascript.
$item -> javascript = base64_decode ( $item -> javascript );
2024-04-21 22:59:42 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> php_method_install ))
2024-04-21 22:59:42 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode php_method_install.
$item -> php_method_install = base64_decode ( $item -> php_method_install );
2024-04-21 22:59:42 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> php_admin_event ))
2024-04-21 22:59:42 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode php_admin_event.
$item -> php_admin_event = base64_decode ( $item -> php_admin_event );
2024-04-21 22:59:42 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> php_site_event ))
2020-01-03 01:41:55 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode php_site_event.
$item -> php_site_event = base64_decode ( $item -> php_site_event );
2020-01-03 01:41:55 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> css_admin ))
2018-03-09 03:26:44 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode css_admin.
$item -> css_admin = base64_decode ( $item -> css_admin );
2018-03-09 03:26:44 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> php_preflight_update ))
2020-01-03 01:41:55 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode php_preflight_update.
$item -> php_preflight_update = base64_decode ( $item -> php_preflight_update );
2020-01-03 01:41:55 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> php_preflight_install ))
2018-03-09 03:26:44 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode php_preflight_install.
$item -> php_preflight_install = base64_decode ( $item -> php_preflight_install );
2018-03-09 03:26:44 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> php_postflight_install ))
2020-01-03 01:41:55 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode php_postflight_install.
$item -> php_postflight_install = base64_decode ( $item -> php_postflight_install );
2020-01-03 01:41:55 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> php_method_uninstall ))
2018-03-09 03:26:44 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode php_method_uninstall.
$item -> php_method_uninstall = base64_decode ( $item -> php_method_uninstall );
2018-07-08 20:18:32 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> sql ))
2020-01-03 01:41:55 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode sql.
$item -> sql = base64_decode ( $item -> sql );
2020-01-03 01:41:55 +00:00
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> buildcompsql ))
2024-04-06 17:48:58 +00:00
{
2024-06-20 23:32:05 +00:00
// base64 Decode buildcompsql.
$item -> buildcompsql = base64_decode ( $item -> buildcompsql );
2024-04-06 17:48:58 +00:00
}
2020-01-03 01:41:55 +00:00
if ( ! empty ( $item -> readme ))
2017-03-18 11:16:07 +00:00
{
2020-01-03 01:41:55 +00:00
// base64 Decode readme.
$item -> readme = base64_decode ( $item -> readme );
2017-03-18 11:16:07 +00:00
}
2024-04-21 22:59:42 +00:00
if ( ! empty ( $item -> php_helper_both ))
{
// base64 Decode php_helper_both.
$item -> php_helper_both = base64_decode ( $item -> php_helper_both );
}
2024-06-20 23:32:05 +00:00
if ( ! empty ( $item -> php_helper_admin ))
{
// base64 Decode php_helper_admin.
$item -> php_helper_admin = base64_decode ( $item -> php_helper_admin );
}
2017-09-13 00:37:43 +00:00
// Get the basic encryption.
2016-01-30 20:28:43 +00:00
$basickey = ComponentbuilderHelper :: getCryptKey ( 'basic' );
2017-09-13 00:37:43 +00:00
// Get the encryption object.
2023-10-18 07:26:30 +00:00
$basic = new AES ( $basickey );
2016-01-30 20:28:43 +00:00
2024-04-06 17:48:58 +00:00
if ( ! empty ( $item -> crowdin_username ) && $basickey && ! is_numeric ( $item -> crowdin_username ) && $item -> crowdin_username === base64_encode ( base64_decode ( $item -> crowdin_username , true )))
{
// basic decrypt data crowdin_username.
$item -> crowdin_username = rtrim ( $basic -> decryptString ( $item -> crowdin_username ), " \0 " );
}
2017-03-28 14:57:59 +00:00
if ( ! empty ( $item -> export_key ) && $basickey && ! is_numeric ( $item -> export_key ) && $item -> export_key === base64_encode ( base64_decode ( $item -> export_key , true )))
{
2017-09-13 00:37:43 +00:00
// basic decrypt data export_key.
2017-03-28 14:57:59 +00:00
$item -> export_key = rtrim ( $basic -> decryptString ( $item -> export_key ), " \0 " );
2017-10-26 16:43:51 +00:00
}
2020-01-03 01:41:55 +00:00
if ( ! empty ( $item -> crowdin_project_api_key ) && $basickey && ! is_numeric ( $item -> crowdin_project_api_key ) && $item -> crowdin_project_api_key === base64_encode ( base64_decode ( $item -> crowdin_project_api_key , true )))
2019-05-15 17:39:27 +00:00
{
2020-01-03 01:41:55 +00:00
// basic decrypt data crowdin_project_api_key.
$item -> crowdin_project_api_key = rtrim ( $basic -> decryptString ( $item -> crowdin_project_api_key ), " \0 " );
}
if ( ! empty ( $item -> crowdin_account_api_key ) && $basickey && ! is_numeric ( $item -> crowdin_account_api_key ) && $item -> crowdin_account_api_key === base64_encode ( base64_decode ( $item -> crowdin_account_api_key , true )))
{
// basic decrypt data crowdin_account_api_key.
$item -> crowdin_account_api_key = rtrim ( $basic -> decryptString ( $item -> crowdin_account_api_key ), " \0 " );
2019-05-15 17:39:27 +00:00
}
2018-04-30 12:06:05 +00:00
if ( ! empty ( $item -> addcontributors ))
{
// Convert the addcontributors field to an array.
$addcontributors = new Registry ;
$addcontributors -> loadString ( $item -> addcontributors );
$item -> addcontributors = $addcontributors -> toArray ();
}
2018-02-27 12:17:38 +00:00
2017-10-26 16:43:51 +00:00
if ( empty ( $item -> id ))
{
$id = 0 ;
}
else
{
$id = $item -> id ;
2019-01-31 21:44:21 +00:00
}
2017-10-26 16:43:51 +00:00
// set the id and view name to session
if ( $vdm = ComponentbuilderHelper :: get ( 'joomla_component__' . $id ))
{
$this -> vastDevMod = $vdm ;
}
else
{
2018-08-18 12:09:17 +00:00
// set the vast development method key
2023-10-18 07:26:30 +00:00
$this -> vastDevMod = UtilitiesStringHelper :: random ( 50 );
2017-10-26 16:43:51 +00:00
ComponentbuilderHelper :: set ( $this -> vastDevMod , 'joomla_component__' . $id );
ComponentbuilderHelper :: set ( 'joomla_component__' . $id , $this -> vastDevMod );
2018-08-18 12:09:17 +00:00
// set a return value if found
2024-03-02 20:10:30 +00:00
$jinput = Factory :: getApplication () -> input ;
2018-08-18 12:09:17 +00:00
$return = $jinput -> get ( 'return' , null , 'base64' );
ComponentbuilderHelper :: set ( $this -> vastDevMod . '__return' , $return );
2019-11-08 16:07:08 +00:00
// set a GUID value if found
2023-10-18 07:26:30 +00:00
if ( isset ( $item ) && ObjectHelper :: check ( $item ) && isset ( $item -> guid )
2024-03-02 20:10:30 +00:00
&& GuidHelper :: valid ( $item -> guid ))
2019-11-08 16:07:08 +00:00
{
ComponentbuilderHelper :: set ( $this -> vastDevMod . '__guid' , $item -> guid );
}
2018-02-27 12:17:38 +00:00
}
2017-10-26 16:43:51 +00:00
// update the fields
2024-03-02 20:10:30 +00:00
$objectUpdate = new \stdClass ();
2017-10-26 16:43:51 +00:00
$objectUpdate -> id = ( int ) $item -> id ;
// repeatable values to check
$arrayChecker = array (
'addcontributors' => 'name'
);
foreach ( $arrayChecker as $_value => $checker )
{
// check what type of array we have here (should be subform... but just in case)
// This could happen due to huge data sets
if ( isset ( $item -> { $_value }) && isset ( $item -> { $_value }[ $checker ]))
{
$bucket = array ();
foreach ( $item -> { $_value } as $option => $values )
{
foreach ( $values as $nr => $value )
{
$bucket [ $_value . $nr ][ $option ] = $value ;
}
}
$item -> { $_value } = $bucket ;
2017-12-25 12:46:35 +00:00
$objectUpdate -> { $_value } = json_encode ( $bucket , JSON_FORCE_OBJECT );
2017-10-26 16:43:51 +00:00
}
}
// be sure to update the table if we found repeatable fields that are still not converted
if ( count (( array ) $objectUpdate ) > 1 )
{
$this -> _db -> updateObject ( '#__componentbuilder_joomla_component' , $objectUpdate , 'id' );
2021-03-05 03:08:47 +00:00
}
}
return $item ;
}
/**
* Method to get the record form .
*
* @ param array $data Data for the form .
* @ param boolean $loadData True if the form is to load its own data ( default case ), false if not .
* @ param array $options Optional array of options for the form creation .
*
* @ return mixed A JForm object on success , false on failure
*
* @ since 1.6
*/
2024-03-02 20:10:30 +00:00
public function getForm ( $data = [], $loadData = true , $options = array ( 'control' => 'jform' ))
2021-03-05 03:08:47 +00:00
{
// set load data option
2018-08-23 01:37:42 +00:00
$options [ 'load_data' ] = $loadData ;
2020-01-03 01:41:55 +00:00
// check if xpath was set in options
2019-10-11 13:41:00 +00:00
$xpath = false ;
if ( isset ( $options [ 'xpath' ]))
{
$xpath = $options [ 'xpath' ];
unset ( $options [ 'xpath' ]);
}
2020-01-03 01:41:55 +00:00
// check if clear form was set in options
2019-10-11 13:41:00 +00:00
$clear = false ;
if ( isset ( $options [ 'clear' ]))
{
$clear = $options [ 'clear' ];
unset ( $options [ 'clear' ]);
}
2017-09-13 00:37:43 +00:00
// Get the form.
2019-10-11 13:41:00 +00:00
$form = $this -> loadForm ( 'com_componentbuilder.joomla_component' , 'joomla_component' , $options , $clear , $xpath );
2017-09-13 00:37:43 +00:00
if ( empty ( $form ))
{
return false ;
}
2024-03-02 20:10:30 +00:00
$jinput = Factory :: getApplication () -> input ;
2017-09-13 00:37:43 +00:00
// The front end calls this model and uses a_id to avoid id clashes so we need to check for that first.
if ( $jinput -> get ( 'a_id' ))
{
$id = $jinput -> get ( 'a_id' , 0 , 'INT' );
}
// The back end uses id so we use that the rest of the time and set it to 0 by default.
else
{
$id = $jinput -> get ( 'id' , 0 , 'INT' );
}
2024-03-02 20:10:30 +00:00
$user = Factory :: getUser ();
2017-09-13 00:37:43 +00:00
// Check for existing item.
// Modify the form based on Edit State access controls.
2017-10-14 18:07:23 +00:00
if ( $id != 0 && ( ! $user -> authorise ( 'joomla_component.edit.state' , 'com_componentbuilder.joomla_component.' . ( int ) $id ))
|| ( $id == 0 && ! $user -> authorise ( 'joomla_component.edit.state' , 'com_componentbuilder' )))
2017-09-13 00:37:43 +00:00
{
// Disable fields for display.
$form -> setFieldAttribute ( 'ordering' , 'disabled' , 'true' );
$form -> setFieldAttribute ( 'published' , 'disabled' , 'true' );
// Disable fields while saving.
$form -> setFieldAttribute ( 'ordering' , 'filter' , 'unset' );
$form -> setFieldAttribute ( 'published' , 'filter' , 'unset' );
}
// If this is a new item insure the greated by is set.
if ( 0 == $id )
{
// Set the created_by to this user
$form -> setValue ( 'created_by' , null , $user -> id );
}
// Modify the form based on Edit Creaded By access controls.
2017-10-14 18:07:23 +00:00
if ( $id != 0 && ( ! $user -> authorise ( 'joomla_component.edit.created_by' , 'com_componentbuilder.joomla_component.' . ( int ) $id ))
|| ( $id == 0 && ! $user -> authorise ( 'joomla_component.edit.created_by' , 'com_componentbuilder' )))
2017-09-13 00:37:43 +00:00
{
// Disable fields for display.
$form -> setFieldAttribute ( 'created_by' , 'disabled' , 'true' );
// Disable fields for display.
$form -> setFieldAttribute ( 'created_by' , 'readonly' , 'true' );
// Disable fields while saving.
$form -> setFieldAttribute ( 'created_by' , 'filter' , 'unset' );
}
// Modify the form based on Edit Creaded Date access controls.
2017-10-14 18:07:23 +00:00
if ( $id != 0 && ( ! $user -> authorise ( 'joomla_component.edit.created' , 'com_componentbuilder.joomla_component.' . ( int ) $id ))
|| ( $id == 0 && ! $user -> authorise ( 'joomla_component.edit.created' , 'com_componentbuilder' )))
2017-09-13 00:37:43 +00:00
{
// Disable fields for display.
$form -> setFieldAttribute ( 'created' , 'disabled' , 'true' );
// Disable fields while saving.
$form -> setFieldAttribute ( 'created' , 'filter' , 'unset' );
}
2016-02-20 18:13:00 +00:00
// Only load these values if no id is found
if ( 0 == $id )
{
2018-08-07 12:25:26 +00:00
// Set redirected view name
$redirectedView = $jinput -> get ( 'ref' , null , 'STRING' );
// Set field name (or fall back to view name)
$redirectedField = $jinput -> get ( 'field' , $redirectedView , 'STRING' );
// Set redirected view id
$redirectedId = $jinput -> get ( 'refid' , 0 , 'INT' );
// Set field id (or fall back to redirected view id)
$redirectedValue = $jinput -> get ( 'field_id' , $redirectedId , 'INT' );
2016-02-20 18:13:00 +00:00
if ( 0 != $redirectedValue && $redirectedField )
{
// Now set the local-redirected field default value
$form -> setValue ( $redirectedField , null , $redirectedValue );
}
}
2020-01-03 01:41:55 +00:00
// Only load these values if no id is found
if ( 0 == $id )
{
// set company defaults
2024-03-02 20:10:30 +00:00
$form -> setValue ( 'companyname' , null , ComponentHelper :: getParams ( 'com_componentbuilder' ) -> get ( 'export_company' , '' ));
$form -> setValue ( 'author' , null , ComponentHelper :: getParams ( 'com_componentbuilder' ) -> get ( 'export_owner' , '' ));
$form -> setValue ( 'email' , null , ComponentHelper :: getParams ( 'com_componentbuilder' ) -> get ( 'export_email' , '' ));
$form -> setValue ( 'website' , null , ComponentHelper :: getParams ( 'com_componentbuilder' ) -> get ( 'export_website' , '' ));
$form -> setValue ( 'copyright' , null , ComponentHelper :: getParams ( 'com_componentbuilder' ) -> get ( 'export_copyright' , 'Copyright (C) 2015. All Rights Reserved' ));
$form -> setValue ( 'license' , null , ComponentHelper :: getParams ( 'com_componentbuilder' ) -> get ( 'export_license' , 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html' ));
2020-01-03 01:41:55 +00:00
}
2016-01-30 20:28:43 +00:00
2018-07-06 13:46:30 +00:00
// update all editors to use this components global editor
2024-03-02 20:10:30 +00:00
$global_editor = ComponentHelper :: getParams ( 'com_componentbuilder' ) -> get ( 'editor' , 'none' );
2018-07-06 22:27:29 +00:00
// now get all the editor fields
2018-07-06 13:46:30 +00:00
$editors = $form -> getXml () -> xpath ( " //field[@type='editor'] " );
2018-07-06 22:27:29 +00:00
// check if we found any
2023-10-18 07:26:30 +00:00
if ( UtilitiesArrayHelper :: check ( $editors ))
2018-07-06 13:46:30 +00:00
{
2018-07-06 22:27:29 +00:00
foreach ( $editors as $editor )
{
// get the field names
$name = ( string ) $editor [ 'name' ];
// set the field editor value (with none as fallback)
$form -> setFieldAttribute ( $name , 'editor' , $global_editor . '|none' );
}
2018-07-06 13:46:30 +00:00
}
2019-05-15 23:07:38 +00:00
2020-01-03 01:41:55 +00:00
2020-06-25 19:22:30 +00:00
// Only load the GUID if new item (or empty)
if ( 0 == $id || ! ( $val = $form -> getValue ( 'guid' )))
2019-05-15 23:07:38 +00:00
{
2023-10-18 07:26:30 +00:00
$form -> setValue ( 'guid' , null , GuidHelper :: get ());
2020-01-03 01:41:55 +00:00
}
2021-03-05 03:08:47 +00:00
return $form ;
}
/**
* Method to get the script that have to be included on the form
*
2024-03-02 20:10:30 +00:00
* @ return string script files
2021-03-05 03:08:47 +00:00
*/
public function getScript ()
{
2021-03-16 23:14:54 +00:00
return 'media/com_componentbuilder/js/joomla_component.js' ;
2021-03-05 03:08:47 +00:00
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Method to test whether a record can be deleted .
*
* @ param object $record A record object .
*
* @ return boolean True if allowed to delete the record . Defaults to the permission set in the component .
*
* @ since 1.6
*/
protected function canDelete ( $record )
2016-01-30 20:28:43 +00:00
{
if ( ! empty ( $record -> id ))
{
if ( $record -> published != - 2 )
{
return ;
}
2024-03-02 20:10:30 +00:00
$user = Factory :: getUser ();
2016-01-30 20:28:43 +00:00
// The record has been set. Check the record permissions.
2017-10-14 18:07:23 +00:00
return $user -> authorise ( 'joomla_component.delete' , 'com_componentbuilder.joomla_component.' . ( int ) $record -> id );
2016-01-30 20:28:43 +00:00
}
2021-03-05 03:08:47 +00:00
return false ;
}
/**
* Method to test whether a record can have its state edited .
*
* @ param object $record A record object .
*
* @ return boolean True if allowed to change the state of the record . Defaults to the permission set in the component .
*
* @ since 1.6
*/
protected function canEditState ( $record )
2016-01-30 20:28:43 +00:00
{
2024-03-02 20:10:30 +00:00
$user = Factory :: getUser ();
$recordId = $record -> id ? ? 0 ;
2016-01-30 20:28:43 +00:00
if ( $recordId )
{
// The record has been set. Check the record permissions.
2017-10-14 18:07:23 +00:00
$permission = $user -> authorise ( 'joomla_component.edit.state' , 'com_componentbuilder.joomla_component.' . ( int ) $recordId );
2016-01-30 20:28:43 +00:00
if ( ! $permission && ! is_null ( $permission ))
{
return false ;
}
}
2023-10-18 07:26:30 +00:00
// In the absence of better information, revert to the component permissions.
2021-03-05 03:08:47 +00:00
return $user -> authorise ( 'joomla_component.edit.state' , 'com_componentbuilder' );
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Method override to check if you can edit an existing record .
*
2024-03-02 20:10:30 +00:00
* @ param array $data An array of input data .
* @ param string $key The name of the key for the primary key .
2021-03-05 03:08:47 +00:00
*
2024-03-02 20:10:30 +00:00
* @ return boolean
* @ since 2.5
2021-03-05 03:08:47 +00:00
*/
2024-03-02 20:10:30 +00:00
protected function allowEdit ( $data = [], $key = 'id' )
2016-01-30 20:28:43 +00:00
{
// Check specific edit permission then general edit permission.
2024-03-02 20:10:30 +00:00
$user = Factory :: getUser ();
2016-01-30 20:28:43 +00:00
2021-03-05 03:08:47 +00:00
return $user -> authorise ( 'joomla_component.edit' , 'com_componentbuilder.joomla_component.' . (( int ) isset ( $data [ $key ]) ? $data [ $key ] : 0 )) or $user -> authorise ( 'joomla_component.edit' , 'com_componentbuilder' );
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Prepare and sanitise the table data prior to saving .
*
2024-03-02 20:10:30 +00:00
* @ param Table $table A Table object .
2021-03-05 03:08:47 +00:00
*
* @ return void
*
* @ since 1.6
*/
protected function prepareTable ( $table )
{
2024-03-02 20:10:30 +00:00
$date = Factory :: getDate ();
$user = Factory :: getUser ();
2021-03-05 03:08:47 +00:00
if ( isset ( $table -> name ))
{
$table -> name = htmlspecialchars_decode ( $table -> name , ENT_QUOTES );
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
if ( isset ( $table -> alias ) && empty ( $table -> alias ))
{
$table -> generateAlias ();
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
if ( empty ( $table -> id ))
{
$table -> created = $date -> toSql ();
// set the user
if ( $table -> created_by == 0 || empty ( $table -> created_by ))
{
$table -> created_by = $user -> id ;
}
// Set ordering to the last item if not set
if ( empty ( $table -> ordering ))
{
2024-03-02 20:10:30 +00:00
$db = Factory :: getDbo ();
2021-03-05 03:08:47 +00:00
$query = $db -> getQuery ( true )
-> select ( 'MAX(ordering)' )
-> from ( $db -> quoteName ( '#__componentbuilder_joomla_component' ));
$db -> setQuery ( $query );
$max = $db -> loadResult ();
$table -> ordering = $max + 1 ;
}
}
else
{
$table -> modified = $date -> toSql ();
$table -> modified_by = $user -> id ;
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
if ( ! empty ( $table -> id ))
{
// Increment the items version number.
$table -> version ++ ;
}
}
/**
* Method to get the data that should be injected in the form .
*
* @ return mixed The data for the form .
*
* @ since 1.6
*/
2024-03-02 20:10:30 +00:00
protected function loadFormData ()
2021-03-05 03:08:47 +00:00
{
// Check the session for previously entered form data.
2024-03-02 20:10:30 +00:00
$data = Factory :: getApplication () -> getUserState ( 'com_componentbuilder.edit.joomla_component.data' , []);
2021-03-05 03:08:47 +00:00
if ( empty ( $data ))
{
$data = $this -> getItem ();
// run the perprocess of the data
$this -> preprocessData ( 'com_componentbuilder.joomla_component' , $data );
}
return $data ;
2016-01-30 20:28:43 +00:00
}
/**
2018-05-26 10:03:08 +00:00
* Method to validate the form data .
*
* @ param JForm $form The form to validate against .
* @ param array $data The data to validate .
* @ param string $group The name of the field group to validate .
*
* @ return mixed Array of filtered data if valid , false otherwise .
*
* @ see JFormRule
* @ see JFilterInput
* @ since 12.2
*/
2016-01-30 20:28:43 +00:00
public function validate ( $form , $data , $group = null )
{
// check if the not_required field is set
2024-03-02 20:10:30 +00:00
if ( isset ( $data [ 'not_required' ]) && UtilitiesStringHelper :: check ( $data [ 'not_required' ]))
2016-01-30 20:28:43 +00:00
{
$requiredFields = ( array ) explode ( ',' ,( string ) $data [ 'not_required' ]);
$requiredFields = array_unique ( $requiredFields );
// now change the required field attributes value
foreach ( $requiredFields as $requiredField )
{
// make sure there is a string value
2024-03-02 20:10:30 +00:00
if ( UtilitiesStringHelper :: check ( $requiredField ))
2016-01-30 20:28:43 +00:00
{
// change to false
$form -> setFieldAttribute ( $requiredField , 'required' , 'false' );
// also clear the data set
$data [ $requiredField ] = '' ;
}
}
}
return parent :: validate ( $form , $data , $group );
2018-09-11 20:28:17 +00:00
}
2016-01-30 20:28:43 +00:00
/**
* Method to get the unique fields of this table .
*
* @ return mixed An array of field names , boolean false if none is set .
*
* @ since 3.0
*/
2020-05-21 23:38:20 +00:00
protected function getUniqueFields ()
2016-01-30 20:28:43 +00:00
{
2020-05-21 23:38:20 +00:00
return array ( 'guid' );
2021-03-05 03:08:47 +00:00
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Method to delete one or more records .
*
* @ param array & $pks An array of record primary keys .
*
* @ return boolean True if successful , false if an error occurs .
*
* @ since 12.2
*/
public function delete ( & $pks )
{
if ( ! parent :: delete ( $pks ))
{
return false ;
2017-10-26 16:43:51 +00:00
}
// we must also delete the linked tables found
2023-10-18 07:26:30 +00:00
if ( UtilitiesArrayHelper :: check ( $pks ))
2017-10-26 16:43:51 +00:00
{
$_tablesArray = array (
2018-02-27 12:17:38 +00:00
'component_admin_views' => 'joomla_component' ,
'component_site_views' => 'joomla_component' ,
'component_custom_admin_views' => 'joomla_component' ,
'component_updates' => 'joomla_component' ,
'component_mysql_tweaks' => 'joomla_component' ,
'component_custom_admin_menus' => 'joomla_component' ,
'component_config' => 'joomla_component' ,
'component_dashboard' => 'joomla_component' ,
'component_files_folders' => 'joomla_component' ,
2019-05-15 17:39:27 +00:00
'component_placeholders' => 'joomla_component' ,
2024-03-09 19:41:29 +00:00
'custom_code' => 'component' ,
'component_router' => 'joomla_component'
2017-10-26 16:43:51 +00:00
);
2018-02-27 12:17:38 +00:00
foreach ( $_tablesArray as $_updateTable => $_key )
2017-10-26 16:43:51 +00:00
{
// get the linked IDs
2018-02-27 12:17:38 +00:00
if ( $_pks = ComponentbuilderHelper :: getVars ( $_updateTable , $pks , $_key , 'id' ))
2017-10-26 16:43:51 +00:00
{
// load the model
$_Model = ComponentbuilderHelper :: getModel ( $_updateTable );
2019-09-12 20:06:52 +00:00
// delete items
2017-10-26 16:43:51 +00:00
$_Model -> delete ( $_pks );
}
}
2021-03-05 03:08:47 +00:00
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
return true ;
}
/**
* Method to change the published state of one or more records .
*
* @ param array & $pks A list of the primary keys to change .
* @ param integer $value The value of the published state .
*
* @ return boolean True on success .
*
* @ since 12.2
*/
public function publish ( & $pks , $value = 1 )
{
if ( ! parent :: publish ( $pks , $value ))
{
return false ;
2017-10-26 16:43:51 +00:00
}
// we must also update all linked tables
2023-10-18 07:26:30 +00:00
if ( UtilitiesArrayHelper :: check ( $pks ))
2017-10-26 16:43:51 +00:00
{
$_tablesArray = array (
2018-02-27 12:17:38 +00:00
'component_admin_views' => 'joomla_component' ,
'component_site_views' => 'joomla_component' ,
'component_custom_admin_views' => 'joomla_component' ,
'component_updates' => 'joomla_component' ,
'component_mysql_tweaks' => 'joomla_component' ,
'component_custom_admin_menus' => 'joomla_component' ,
'component_config' => 'joomla_component' ,
'component_dashboard' => 'joomla_component' ,
'component_files_folders' => 'joomla_component' ,
2019-05-15 17:39:27 +00:00
'component_placeholders' => 'joomla_component' ,
2024-03-09 19:41:29 +00:00
'custom_code' => 'component' ,
'component_router' => 'joomla_component'
2017-10-26 16:43:51 +00:00
);
2018-02-27 12:17:38 +00:00
foreach ( $_tablesArray as $_updateTable => $_key )
2017-10-26 16:43:51 +00:00
{
// get the linked IDs
2018-02-27 12:17:38 +00:00
if ( $_pks = ComponentbuilderHelper :: getVars ( $_updateTable , $pks , $_key , 'id' ))
2017-10-26 16:43:51 +00:00
{
// load the model
$_Model = ComponentbuilderHelper :: getModel ( $_updateTable );
// change publish state
$_Model -> publish ( $_pks , $value );
}
}
2021-03-05 03:08:47 +00:00
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
return true ;
2024-03-02 20:10:30 +00:00
}
2021-03-05 03:08:47 +00:00
/**
* Method to perform batch operations on an item or a set of items .
*
* @ param array $commands An array of commands to perform .
* @ param array $pks An array of item ids .
* @ param array $contexts An array of item contexts .
*
* @ return boolean Returns true on success , false on failure .
*
* @ since 12.2
*/
public function batch ( $commands , $pks , $contexts )
{
// Sanitize ids.
$pks = array_unique ( $pks );
ArrayHelper :: toInteger ( $pks );
// Remove any values of zero.
if ( array_search ( 0 , $pks , true ))
{
unset ( $pks [ array_search ( 0 , $pks , true )]);
}
if ( empty ( $pks ))
{
2024-03-02 20:10:30 +00:00
$this -> setError ( Text :: _ ( 'JGLOBAL_NO_ITEM_SELECTED' ));
2021-03-05 03:08:47 +00:00
return false ;
}
$done = false ;
// Set some needed variables.
2024-03-02 20:10:30 +00:00
$this -> user = Factory :: getUser ();
$this -> table = $this -> getTable ();
$this -> tableClassName = get_class ( $this -> table );
$this -> contentType = new UCMType ;
$this -> type = $this -> contentType -> getTypeByTable ( $this -> tableClassName );
$this -> canDo = ComponentbuilderHelper :: getActions ( 'joomla_component' );
$this -> batchSet = true ;
2021-03-05 03:08:47 +00:00
if ( ! $this -> canDo -> get ( 'core.batch' ))
{
2024-03-02 20:10:30 +00:00
$this -> setError ( Text :: _ ( 'JLIB_APPLICATION_ERROR_INSUFFICIENT_BATCH_INFORMATION' ));
2021-03-05 03:08:47 +00:00
return false ;
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
if ( $this -> type == false )
{
2024-03-02 20:10:30 +00:00
$type = new UCMType ;
2021-03-05 03:08:47 +00:00
$this -> type = $type -> getTypeByAlias ( $this -> typeAlias );
}
$this -> tagsObserver = $this -> table -> getObserverOfClass ( 'JTableObserverTags' );
if ( ! empty ( $commands [ 'move_copy' ]))
{
$cmd = ArrayHelper :: getValue ( $commands , 'move_copy' , 'c' );
if ( $cmd == 'c' )
{
$result = $this -> batchCopy ( $commands , $pks , $contexts );
if ( is_array ( $result ))
{
foreach ( $result as $old => $new )
{
$contexts [ $new ] = $contexts [ $old ];
}
$pks = array_values ( $result );
}
else
{
return false ;
}
}
elseif ( $cmd == 'm' && ! $this -> batchMove ( $commands , $pks , $contexts ))
{
return false ;
}
$done = true ;
}
if ( ! $done )
{
2024-03-02 20:10:30 +00:00
$this -> setError ( Text :: _ ( 'JLIB_APPLICATION_ERROR_INSUFFICIENT_BATCH_INFORMATION' ));
2021-03-05 03:08:47 +00:00
return false ;
}
// Clear the cache
$this -> cleanCache ();
return true ;
2016-01-30 20:28:43 +00:00
}
/**
* Batch copy items to a new category or current .
*
* @ param integer $values The new values .
* @ param array $pks An array of row IDs .
* @ param array $contexts An array of item contexts .
*
* @ return mixed An array of new IDs on success , boolean false on failure .
*
2018-05-26 10:03:08 +00:00
* @ since 12.2
2016-01-30 20:28:43 +00:00
*/
2016-02-26 12:46:15 +00:00
protected function batchCopy ( $values , $pks , $contexts )
2016-01-30 20:28:43 +00:00
{
if ( empty ( $this -> batchSet ))
{
// Set some needed variables.
2024-03-02 20:10:30 +00:00
$this -> user = Factory :: getUser ();
2016-01-30 20:28:43 +00:00
$this -> table = $this -> getTable ();
$this -> tableClassName = get_class ( $this -> table );
2017-02-16 14:02:23 +00:00
$this -> canDo = ComponentbuilderHelper :: getActions ( 'joomla_component' );
2016-01-30 20:28:43 +00:00
}
2017-10-14 18:07:23 +00:00
if ( ! $this -> canDo -> get ( 'joomla_component.create' ) && ! $this -> canDo -> get ( 'joomla_component.batch' ))
2016-01-30 20:28:43 +00:00
{
return false ;
}
2020-05-21 23:38:20 +00:00
// get list of unique fields
$uniqueFields = $this -> getUniqueFields ();
2016-01-30 20:28:43 +00:00
// remove move_copy from array
unset ( $values [ 'move_copy' ]);
// make sure published is set
if ( ! isset ( $values [ 'published' ]))
{
$values [ 'published' ] = 0 ;
}
2017-10-14 18:07:23 +00:00
elseif ( isset ( $values [ 'published' ]) && ! $this -> canDo -> get ( 'joomla_component.edit.state' ))
2016-01-30 20:28:43 +00:00
{
$values [ 'published' ] = 0 ;
}
2024-03-02 20:10:30 +00:00
$newIds = [];
2016-01-30 20:28:43 +00:00
// Parent exists so let's proceed
while ( ! empty ( $pks ))
{
// Pop the first ID off the stack
$pk = array_shift ( $pks );
$this -> table -> reset ();
// only allow copy if user may edit this item.
2017-10-14 18:07:23 +00:00
if ( ! $this -> user -> authorise ( 'joomla_component.edit' , $contexts [ $pk ]))
2016-01-30 20:28:43 +00:00
{
// Not fatal error
2024-03-02 20:10:30 +00:00
$this -> setError ( Text :: sprintf ( 'JLIB_APPLICATION_ERROR_BATCH_MOVE_ROW_NOT_FOUND' , $pk ));
2016-01-30 20:28:43 +00:00
continue ;
}
// Check that the row actually exists
if ( ! $this -> table -> load ( $pk ))
{
if ( $error = $this -> table -> getError ())
{
// Fatal error
$this -> setError ( $error );
return false ;
}
else
{
// Not fatal error
2024-03-02 20:10:30 +00:00
$this -> setError ( Text :: sprintf ( 'JLIB_APPLICATION_ERROR_BATCH_MOVE_ROW_NOT_FOUND' , $pk ));
2016-01-30 20:28:43 +00:00
continue ;
}
}
2018-02-27 12:17:38 +00:00
// Only for strings
2024-03-02 20:10:30 +00:00
if ( UtilitiesStringHelper :: check ( $this -> table -> system_name ) && ! is_numeric ( $this -> table -> system_name ))
2018-02-27 12:17:38 +00:00
{
2020-05-21 23:38:20 +00:00
$this -> table -> system_name = $this -> generateUnique ( 'system_name' , $this -> table -> system_name );
2018-02-27 12:17:38 +00:00
}
2016-01-30 20:28:43 +00:00
// insert all set values
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $values ))
2016-01-30 20:28:43 +00:00
{
foreach ( $values as $key => $value )
{
if ( strlen ( $value ) > 0 && isset ( $this -> table -> $key ))
{
$this -> table -> $key = $value ;
}
}
}
2020-05-21 23:38:20 +00:00
// update all unique fields
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $uniqueFields ))
2016-01-30 20:28:43 +00:00
{
2020-05-21 23:38:20 +00:00
foreach ( $uniqueFields as $uniqueField )
2016-01-30 20:28:43 +00:00
{
2020-05-21 23:38:20 +00:00
$this -> table -> $uniqueField = $this -> generateUnique ( $uniqueField , $this -> table -> $uniqueField );
2016-01-30 20:28:43 +00:00
}
}
// Reset the ID because we are making a copy
$this -> table -> id = 0 ;
// TODO: Deal with ordering?
2018-05-26 10:03:08 +00:00
// $this->table->ordering = 1;
2016-01-30 20:28:43 +00:00
// Check the row.
if ( ! $this -> table -> check ())
{
$this -> setError ( $this -> table -> getError ());
return false ;
}
if ( ! empty ( $this -> type ))
{
$this -> createTagsHelper ( $this -> tagsObserver , $this -> type , $pk , $this -> typeAlias , $this -> table );
}
// Store the row.
if ( ! $this -> table -> store ())
{
$this -> setError ( $this -> table -> getError ());
return false ;
}
// Get the new item ID
$newId = $this -> table -> get ( 'id' );
// Add the new ID to the array
$newIds [ $pk ] = $newId ;
}
// Clean the cache
$this -> cleanCache ();
return $newIds ;
2018-09-11 20:28:17 +00:00
}
2016-01-30 20:28:43 +00:00
/**
* Batch move items to a new category
*
* @ param integer $value The new category ID .
* @ param array $pks An array of row IDs .
* @ param array $contexts An array of item contexts .
*
* @ return boolean True if successful , false otherwise and internal error is set .
*
2018-05-26 10:03:08 +00:00
* @ since 12.2
2016-01-30 20:28:43 +00:00
*/
2016-02-26 12:46:15 +00:00
protected function batchMove ( $values , $pks , $contexts )
2016-01-30 20:28:43 +00:00
{
if ( empty ( $this -> batchSet ))
{
// Set some needed variables.
2024-03-02 20:10:30 +00:00
$this -> user = Factory :: getUser ();
2016-01-30 20:28:43 +00:00
$this -> table = $this -> getTable ();
$this -> tableClassName = get_class ( $this -> table );
2017-02-16 14:02:23 +00:00
$this -> canDo = ComponentbuilderHelper :: getActions ( 'joomla_component' );
2016-01-30 20:28:43 +00:00
}
2017-10-14 18:07:23 +00:00
if ( ! $this -> canDo -> get ( 'joomla_component.edit' ) && ! $this -> canDo -> get ( 'joomla_component.batch' ))
2016-01-30 20:28:43 +00:00
{
2024-03-02 20:10:30 +00:00
$this -> setError ( Text :: _ ( 'JLIB_APPLICATION_ERROR_BATCH_CANNOT_EDIT' ));
2016-01-30 20:28:43 +00:00
return false ;
}
// make sure published only updates if user has the permission.
2017-10-14 18:07:23 +00:00
if ( isset ( $values [ 'published' ]) && ! $this -> canDo -> get ( 'joomla_component.edit.state' ))
2016-01-30 20:28:43 +00:00
{
unset ( $values [ 'published' ]);
}
// remove move_copy from array
unset ( $values [ 'move_copy' ]);
// Parent exists so we proceed
foreach ( $pks as $pk )
{
2017-10-14 18:07:23 +00:00
if ( ! $this -> user -> authorise ( 'joomla_component.edit' , $contexts [ $pk ]))
2016-01-30 20:28:43 +00:00
{
2024-03-02 20:10:30 +00:00
$this -> setError ( Text :: _ ( 'JLIB_APPLICATION_ERROR_BATCH_CANNOT_EDIT' ));
2016-01-30 20:28:43 +00:00
return false ;
}
// Check that the row actually exists
if ( ! $this -> table -> load ( $pk ))
{
if ( $error = $this -> table -> getError ())
{
// Fatal error
$this -> setError ( $error );
return false ;
}
else
{
// Not fatal error
2024-03-02 20:10:30 +00:00
$this -> setError ( Text :: sprintf ( 'JLIB_APPLICATION_ERROR_BATCH_MOVE_ROW_NOT_FOUND' , $pk ));
2016-01-30 20:28:43 +00:00
continue ;
}
}
// insert all set values.
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $values ))
2016-01-30 20:28:43 +00:00
{
foreach ( $values as $key => $value )
{
// Do special action for access.
2017-02-02 11:54:07 +00:00
if ( 'access' === $key && strlen ( $value ) > 0 )
2016-01-30 20:28:43 +00:00
{
$this -> table -> $key = $value ;
}
elseif ( strlen ( $value ) > 0 && isset ( $this -> table -> $key ))
{
$this -> table -> $key = $value ;
}
}
}
// Check the row.
if ( ! $this -> table -> check ())
{
$this -> setError ( $this -> table -> getError ());
return false ;
}
if ( ! empty ( $this -> type ))
{
$this -> createTagsHelper ( $this -> tagsObserver , $this -> type , $pk , $this -> typeAlias , $this -> table );
}
// Store the row.
if ( ! $this -> table -> store ())
{
$this -> setError ( $this -> table -> getError ());
return false ;
}
}
// Clean the cache
$this -> cleanCache ();
return true ;
2021-03-05 03:08:47 +00:00
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Method to save the form data .
*
* @ param array $data The form data .
*
* @ return boolean True on success .
*
* @ since 1.6
*/
public function save ( $data )
{
2024-03-02 20:10:30 +00:00
$input = Factory :: getApplication () -> input ;
$filter = InputFilter :: getInstance ();
2021-03-05 03:08:47 +00:00
// set the metadata to the Item Data
if ( isset ( $data [ 'metadata' ]) && isset ( $data [ 'metadata' ][ 'author' ]))
{
$data [ 'metadata' ][ 'author' ] = $filter -> clean ( $data [ 'metadata' ][ 'author' ], 'TRIM' );
2024-03-02 20:10:30 +00:00
$metadata = new Registry ;
2021-03-05 03:08:47 +00:00
$metadata -> loadArray ( $data [ 'metadata' ]);
$data [ 'metadata' ] = ( string ) $metadata ;
2018-09-11 20:28:17 +00:00
}
2016-01-30 20:28:43 +00:00
2018-02-27 12:17:38 +00:00
// if system name is empty create from name
2023-10-18 07:26:30 +00:00
if ( empty ( $data [ 'system_name' ]) || ! UtilitiesStringHelper :: check ( $data [ 'system_name' ]))
2018-02-27 12:17:38 +00:00
{
$data [ 'system_name' ] = $data [ 'name' ];
2020-01-03 01:41:55 +00:00
}
2024-04-09 11:07:08 +00:00
// make sure that the component code name is safe.
2024-04-16 17:05:17 +00:00
if ( isset ( $data [ 'name_code' ]) && is_string ( $data [ 'name_code' ]))
{
$data [ 'name_code' ] = ComponentCodeNameHelper :: safe ( $data [ 'name_code' ]);
}
2020-01-03 01:41:55 +00:00
// Set the GUID if empty or not valid
2020-06-25 19:22:30 +00:00
if ( empty ( $data [ 'guid' ]) && $data [ 'id' ] > 0 )
{
// get the existing one
2023-10-18 07:26:30 +00:00
$data [ 'guid' ] = ( string ) GetHelper :: var ( 'joomla_component' , $data [ 'id' ], 'id' , 'guid' );
2020-06-25 19:22:30 +00:00
}
2023-10-18 07:26:30 +00:00
2020-06-25 19:22:30 +00:00
// Set the GUID if empty or not valid
2023-10-18 07:26:30 +00:00
while ( ! GuidHelper :: valid ( $data [ 'guid' ], " joomla_component " , $data [ 'id' ]))
2020-01-03 01:41:55 +00:00
{
2020-06-25 19:22:30 +00:00
// must always be set
2023-10-18 07:26:30 +00:00
$data [ 'guid' ] = ( string ) GuidHelper :: get ();
}
2018-02-27 12:17:38 +00:00
2017-10-26 16:43:51 +00:00
// Set the addcontributors items to data.
if ( isset ( $data [ 'addcontributors' ]) && is_array ( $data [ 'addcontributors' ]))
2017-02-02 11:54:07 +00:00
{
2024-03-02 20:10:30 +00:00
$addcontributors = new Registry ;
2017-10-26 16:43:51 +00:00
$addcontributors -> loadArray ( $data [ 'addcontributors' ]);
$data [ 'addcontributors' ] = ( string ) $addcontributors ;
}
elseif ( ! isset ( $data [ 'addcontributors' ]))
{
// Set the empty addcontributors to data
$data [ 'addcontributors' ] = '' ;
2017-02-02 11:54:07 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the sql_uninstall string to base64 string.
if ( isset ( $data [ 'sql_uninstall' ]))
2023-10-24 07:46:36 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'sql_uninstall' ] = base64_encode ( $data [ 'sql_uninstall' ]);
2023-10-24 07:46:36 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the php_postflight_update string to base64 string.
if ( isset ( $data [ 'php_postflight_update' ]))
2024-04-06 17:48:58 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'php_postflight_update' ] = base64_encode ( $data [ 'php_postflight_update' ]);
2024-04-06 17:48:58 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the css_site string to base64 string.
if ( isset ( $data [ 'css_site' ]))
2024-04-06 17:48:58 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'css_site' ] = base64_encode ( $data [ 'css_site' ]);
2024-04-06 17:48:58 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the php_helper_site string to base64 string.
if ( isset ( $data [ 'php_helper_site' ]))
2024-04-21 22:59:42 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'php_helper_site' ] = base64_encode ( $data [ 'php_helper_site' ]);
2024-04-21 22:59:42 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the javascript string to base64 string.
if ( isset ( $data [ 'javascript' ]))
2024-04-21 22:59:42 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'javascript' ] = base64_encode ( $data [ 'javascript' ]);
2024-04-21 22:59:42 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the php_method_install string to base64 string.
if ( isset ( $data [ 'php_method_install' ]))
2024-04-21 22:59:42 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'php_method_install' ] = base64_encode ( $data [ 'php_method_install' ]);
2024-04-21 22:59:42 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the php_admin_event string to base64 string.
if ( isset ( $data [ 'php_admin_event' ]))
2024-04-21 22:59:42 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'php_admin_event' ] = base64_encode ( $data [ 'php_admin_event' ]);
2024-04-21 22:59:42 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the php_site_event string to base64 string.
if ( isset ( $data [ 'php_site_event' ]))
2020-01-03 01:41:55 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'php_site_event' ] = base64_encode ( $data [ 'php_site_event' ]);
2020-01-03 01:41:55 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the css_admin string to base64 string.
if ( isset ( $data [ 'css_admin' ]))
2018-03-09 03:26:44 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'css_admin' ] = base64_encode ( $data [ 'css_admin' ]);
2018-03-09 03:26:44 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the php_preflight_update string to base64 string.
if ( isset ( $data [ 'php_preflight_update' ]))
2020-01-03 01:41:55 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'php_preflight_update' ] = base64_encode ( $data [ 'php_preflight_update' ]);
2020-01-03 01:41:55 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the php_preflight_install string to base64 string.
if ( isset ( $data [ 'php_preflight_install' ]))
2018-03-09 03:26:44 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'php_preflight_install' ] = base64_encode ( $data [ 'php_preflight_install' ]);
2018-03-09 03:26:44 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the php_postflight_install string to base64 string.
if ( isset ( $data [ 'php_postflight_install' ]))
2020-01-03 01:41:55 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'php_postflight_install' ] = base64_encode ( $data [ 'php_postflight_install' ]);
2020-01-03 01:41:55 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the php_method_uninstall string to base64 string.
if ( isset ( $data [ 'php_method_uninstall' ]))
2018-03-09 03:26:44 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'php_method_uninstall' ] = base64_encode ( $data [ 'php_method_uninstall' ]);
2018-07-08 20:18:32 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the sql string to base64 string.
if ( isset ( $data [ 'sql' ]))
2020-01-03 01:41:55 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'sql' ] = base64_encode ( $data [ 'sql' ]);
2020-01-03 01:41:55 +00:00
}
2024-06-20 23:32:05 +00:00
// Set the buildcompsql string to base64 string.
if ( isset ( $data [ 'buildcompsql' ]))
2024-04-06 17:48:58 +00:00
{
2024-06-20 23:32:05 +00:00
$data [ 'buildcompsql' ] = base64_encode ( $data [ 'buildcompsql' ]);
2024-04-06 17:48:58 +00:00
}
2020-01-03 01:41:55 +00:00
// Set the readme string to base64 string.
if ( isset ( $data [ 'readme' ]))
2017-03-18 11:16:07 +00:00
{
2020-01-03 01:41:55 +00:00
$data [ 'readme' ] = base64_encode ( $data [ 'readme' ]);
2017-03-18 11:16:07 +00:00
}
2024-04-21 22:59:42 +00:00
// Set the php_helper_both string to base64 string.
if ( isset ( $data [ 'php_helper_both' ]))
{
$data [ 'php_helper_both' ] = base64_encode ( $data [ 'php_helper_both' ]);
}
2024-06-20 23:32:05 +00:00
// Set the php_helper_admin string to base64 string.
if ( isset ( $data [ 'php_helper_admin' ]))
{
$data [ 'php_helper_admin' ] = base64_encode ( $data [ 'php_helper_admin' ]);
}
2017-09-13 00:37:43 +00:00
// Get the basic encryption key.
2016-01-30 20:28:43 +00:00
$basickey = ComponentbuilderHelper :: getCryptKey ( 'basic' );
2017-09-13 00:37:43 +00:00
// Get the encryption object
2023-10-18 07:26:30 +00:00
$basic = new AES ( $basickey );
2016-01-30 20:28:43 +00:00
2024-04-06 17:48:58 +00:00
// Encrypt data crowdin_username.
if ( isset ( $data [ 'crowdin_username' ]) && $basickey )
{
$data [ 'crowdin_username' ] = $basic -> encryptString ( $data [ 'crowdin_username' ]);
}
2017-09-13 00:37:43 +00:00
// Encrypt data export_key.
2017-03-28 14:57:59 +00:00
if ( isset ( $data [ 'export_key' ]) && $basickey )
{
$data [ 'export_key' ] = $basic -> encryptString ( $data [ 'export_key' ]);
}
2020-01-03 01:41:55 +00:00
// Encrypt data crowdin_project_api_key.
if ( isset ( $data [ 'crowdin_project_api_key' ]) && $basickey )
2019-05-15 17:39:27 +00:00
{
2020-01-03 01:41:55 +00:00
$data [ 'crowdin_project_api_key' ] = $basic -> encryptString ( $data [ 'crowdin_project_api_key' ]);
}
// Encrypt data crowdin_account_api_key.
if ( isset ( $data [ 'crowdin_account_api_key' ]) && $basickey )
{
$data [ 'crowdin_account_api_key' ] = $basic -> encryptString ( $data [ 'crowdin_account_api_key' ]);
2019-05-15 17:39:27 +00:00
}
2016-12-30 10:47:19 +00:00
// we check if component should be build from sql file
2018-07-06 22:01:30 +00:00
if ( isset ( $data [ 'buildcomp' ]) && 1 == $data [ 'buildcomp' ])
{
2024-03-06 13:06:11 +00:00
$extruder__ = new Extrusion ( $data );
2021-03-05 03:08:47 +00:00
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
// Set the Params Items to data
if ( isset ( $data [ 'params' ]) && is_array ( $data [ 'params' ]))
{
2024-03-02 20:10:30 +00:00
$params = new Registry ;
2021-03-05 03:08:47 +00:00
$params -> loadArray ( $data [ 'params' ]);
$data [ 'params' ] = ( string ) $params ;
2016-01-30 20:28:43 +00:00
}
2020-05-21 23:38:20 +00:00
// Alter the unique field for save as copy
2017-02-01 13:17:04 +00:00
if ( $input -> get ( 'task' ) === 'save2copy' )
2016-01-30 20:28:43 +00:00
{
2020-05-21 23:38:20 +00:00
// Automatic handling of other unique fields
$uniqueFields = $this -> getUniqueFields ();
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $uniqueFields ))
2016-01-30 20:28:43 +00:00
{
2020-05-21 23:38:20 +00:00
foreach ( $uniqueFields as $uniqueField )
2016-01-30 20:28:43 +00:00
{
2020-05-21 23:38:20 +00:00
$data [ $uniqueField ] = $this -> generateUnique ( $uniqueField , $data [ $uniqueField ]);
2016-01-30 20:28:43 +00:00
}
}
2021-03-05 03:08:47 +00:00
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
if ( parent :: save ( $data ))
{
return true ;
}
return false ;
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Method to generate a unique value .
*
* @ param string $field name .
* @ param string $value data .
*
* @ return string New value .
*
* @ since 3.0
*/
2024-08-20 20:32:57 +00:00
protected function generateUnique ( $field , $value )
2021-03-05 03:08:47 +00:00
{
// set field value unique
$table = $this -> getTable ();
while ( $table -> load ( array ( $field => $value )))
{
$value = StringHelper :: increment ( $value );
}
return $value ;
2016-01-30 20:28:43 +00:00
}
/**
2018-05-26 10:03:08 +00:00
* Method to change the title
*
* @ param string $title The title .
*
* @ return array Contains the modified title and alias .
*
*/
2016-02-26 12:46:15 +00:00
protected function _generateNewTitle ( $title )
2016-01-30 20:28:43 +00:00
{
// Alter the title
$table = $this -> getTable ();
2024-03-02 20:10:30 +00:00
while ( $table -> load ([ 'title' => $title ]))
2016-01-30 20:28:43 +00:00
{
2020-05-21 23:38:20 +00:00
$title = StringHelper :: increment ( $title );
2016-01-30 20:28:43 +00:00
}
return $title ;
2021-03-05 03:08:47 +00:00
}
}