2017-03-27 12:38:51 +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 ;
2021-03-08 22:36:30 +00:00
use Joomla\CMS\Filesystem\File ;
use Joomla\CMS\Filesystem\Folder ;
2024-03-02 20:10:30 +00:00
use Joomla\CMS\Filesystem\Path ;
use Joomla\CMS\Filter\OutputFilter ;
use Joomla\CMS\Installer\InstallerHelper ;
use Joomla\CMS\MVC\Model\BaseDatabaseModel ;
use Joomla\String\StringHelper ;
2021-03-05 03:08:47 +00:00
use Joomla\Utilities\ArrayHelper ;
use PhpOffice\PhpSpreadsheet\IOFactory ;
2023-02-27 12:27:41 +00:00
use VDM\Joomla\Componentbuilder\Package\Factory as PackageFactory ;
use VDM\Joomla\Utilities\ObjectHelper ;
use VDM\Joomla\Utilities\JsonHelper ;
use VDM\Joomla\Utilities\FileHelper ;
use VDM\Joomla\Utilities\GetHelper ;
use VDM\Joomla\Utilities\GuidHelper ;
2024-03-02 20:10:30 +00:00
use Joomla\CMS\Component\ComponentHelper ;
use VDM\Joomla\Utilities\StringHelper as UtilitiesStringHelper ;
use VDM\Joomla\Utilities\ArrayHelper as UtilitiesArrayHelper ;
2021-03-05 03:08:47 +00:00
/**
2022-05-25 08:30:55 +00:00
* Componentbuilder Import_joomla_components Base Database Model
2021-03-05 03:08:47 +00:00
*/
2022-05-25 08:30:55 +00:00
class ComponentbuilderModelImport_joomla_components extends BaseDatabaseModel
2021-03-05 03:08:47 +00:00
{
// set uploading values
protected $use_streams = false ;
protected $allow_unsafe = false ;
2024-03-02 20:10:30 +00:00
protected $safeFileOptions = [];
2021-03-05 03:08:47 +00:00
/**
* @ var object JTable object
*/
protected $_table = null ;
/**
* @ var object JTable object
*/
protected $_url = null ;
/**
* Model context string .
*
* @ var string
*/
protected $_context = 'com_componentbuilder.import_joomla_components' ;
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Import Settings
*/
protected $getType = NULL ;
protected $dataType = NULL ;
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Method to auto - populate the model state .
*
* Note . Calling getState in this method will result in recursion .
*
* @ return void
*
*/
protected function populateState ()
{
2024-03-02 20:10:30 +00:00
$app = Factory :: getApplication ( 'administrator' );
2021-03-05 03:08:47 +00:00
$this -> setState ( 'message' , $app -> getUserState ( 'com_componentbuilder.message' ));
$app -> setUserState ( 'com_componentbuilder.message' , '' );
// Recall the 'Import from Directory' path.
$path = $app -> getUserStateFromRequest ( $this -> _context . '.import_directory' , 'import_directory' , $app -> get ( 'tmp_path' ));
$this -> setState ( 'import.directory' , $path );
parent :: populateState ();
}
2017-03-27 12:38:51 +00:00
2018-06-12 15:39:13 +00:00
public $canmerge = 1 ;
2021-08-11 12:15:35 +00:00
public $importGuidOnly = 1 ;
2018-06-12 15:39:13 +00:00
public $postfix = false ;
public $forceUpdate = 0 ;
public $hasKey = 0 ;
2022-05-16 04:27:50 +00:00
public $sleutle = '' ;
2018-06-12 15:39:13 +00:00
public $data = false ;
2018-04-17 21:25:03 +00:00
public $app ;
2018-06-12 15:39:13 +00:00
protected $dir = false ;
protected $target = false ;
protected $newID = array ();
2022-05-16 04:25:03 +00:00
protected $packageInfo = null ;
protected $noopmaker ;
2018-06-12 15:39:13 +00:00
protected $updateAfter = array ( 'field' => array (), 'adminview' => array ());
protected $divergedDataMover = array ();
protected $fieldTypes = array ();
protected $isMultiple = array ();
2018-07-07 00:12:13 +00:00
protected $tableColumns = array ();
protected $fieldImportErrors = array ();
2018-06-12 15:39:13 +00:00
protected $specialValue = false ;
protected $checksum = null ;
protected $checksumURLs = array ( 'vdm' => 'https://raw.githubusercontent.com/vdm-io/JCB-Packages/master/' , 'jcb' => 'https://raw.githubusercontent.com/vdm-io/JCB-Community-Packages/master/' );
2019-08-12 21:30:31 +00:00
protected $mustMerge = array ( 'validation_rule' , 'fieldtype' , 'snippet' , 'language' , 'language_translation' , 'class_extends' , 'class_property' , 'class_method' , 'joomla_plugin_group' );
2017-03-27 12:38:51 +00:00
/**
* Import an spreadsheet from either folder , url or upload .
*
* @ return boolean result of import
*
*/
public function import ()
{
2018-03-24 01:36:07 +00:00
// set the state to import
2017-03-27 12:38:51 +00:00
$this -> setState ( 'action' , 'import' );
2018-03-24 01:36:07 +00:00
// get App
2024-03-02 20:10:30 +00:00
$this -> app = Factory :: getApplication ();
2018-03-24 01:36:07 +00:00
// get session
2024-03-02 20:10:30 +00:00
$session = Factory :: getSession ();
2018-03-24 01:36:07 +00:00
// some defaults
$package = null ;
$continue = false ;
2017-03-27 12:38:51 +00:00
// get import type
2018-03-24 01:36:07 +00:00
$this -> getType = $this -> app -> input -> getString ( 'gettype' , NULL );
// do checksum validation
$this -> checksum = $this -> app -> input -> getString ( 'checksum' , NULL );
2017-03-27 12:38:51 +00:00
// get import type
2018-03-24 01:36:07 +00:00
$this -> dataType = $session -> get ( 'dataType_VDM_IMPORTINTO' , NULL );
// if we have no package
2017-03-27 12:38:51 +00:00
if ( $package === null )
{
2018-03-24 01:36:07 +00:00
// we must allow unsafe with smart import since it is code being imported.
2017-03-27 12:38:51 +00:00
if ( $this -> dataType === 'smart_package' )
{
$this -> allow_unsafe = true ;
}
2018-03-24 01:36:07 +00:00
// action based on get Type
2017-03-27 12:38:51 +00:00
switch ( $this -> getType )
{
case 'folder' :
// Remember the 'Import from Directory' path.
2017-03-28 14:57:59 +00:00
$this -> app -> getUserStateFromRequest ( $this -> _context . '.import_directory' , 'import_directory' );
2017-03-27 12:38:51 +00:00
$package = $this -> _getPackageFromFolder ();
break ;
case 'upload' :
$package = $this -> _getPackageFromUpload ();
break ;
case 'url' :
2024-03-02 20:10:30 +00:00
$url = Factory :: getApplication () -> input -> getString ( 'import_url' );
2022-06-02 12:05:34 +00:00
if ( $url === base64_encode ( base64_decode ( $url , true )))
{
2024-03-02 20:10:30 +00:00
Factory :: getApplication () -> input -> set ( 'import_url' , base64_decode ( $url ));
2022-06-02 12:05:34 +00:00
}
2017-03-27 12:38:51 +00:00
$package = $this -> _getPackageFromUrl ();
break ;
case 'continue-ext' :
$continue = true ;
$package = $session -> get ( 'package' , null );
$package = json_decode ( $package , true );
// clear session
$session -> clear ( 'package' );
$session -> clear ( 'dataType' );
$session -> clear ( 'hasPackage' );
2022-05-16 04:25:03 +00:00
// before we clear this, we add it locally
$packageInfo = $session -> get ( 'smart_package_info' , null );
// now clear it
2017-03-30 21:19:12 +00:00
$session -> clear ( 'smart_package_info' );
2022-05-16 04:25:03 +00:00
// convert to an array if found
2023-02-27 12:27:41 +00:00
if ( $packageInfo && JsonHelper :: check ( $packageInfo ))
2022-05-16 04:25:03 +00:00
{
$this -> packageInfo = json_decode ( $packageInfo , true );
}
2017-03-27 12:38:51 +00:00
break ;
default :
2018-03-24 01:36:07 +00:00
$package = $session -> get ( 'package' , null );
2023-02-27 12:27:41 +00:00
if ( JsonHelper :: check ( $package ))
2018-03-24 01:36:07 +00:00
{
// get package
$package = json_decode ( $package , true );
// remove zip file
if ( isset ( $package [ 'packagename' ]))
{
$this -> remove ( $package [ 'packagename' ]);
}
// check if dir is set
if ( isset ( $package [ 'dir' ]))
{
// set auto loader
ComponentbuilderHelper :: autoLoader ( 'smart' );
// get install folder
2024-10-07 22:31:55 +00:00
$dir = File :: stripExt ( $package [ 'dir' ]);
2018-03-24 01:36:07 +00:00
// remove unziped folder
ComponentbuilderHelper :: removeFolder ( $dir );
}
}
// clear session
$session -> clear ( 'package' );
$session -> clear ( 'dataType' );
$session -> clear ( 'hasPackage' );
$session -> clear ( 'smart_package_info' );
$back = $session -> get ( 'backto_VDM_IMPORT' , NULL );
$session -> clear ( 'backto_VDM_IMPORT' );
if ( $back )
{
2022-05-16 04:25:03 +00:00
$this -> app -> setUserState ( 'com_componentbuilder.redirect_url' , 'index.php?option=com_componentbuilder&view=' . $back );
2018-03-24 01:36:07 +00:00
}
$session -> clear ( 'backto_VDM_IMPORT' );
2017-03-27 12:38:51 +00:00
return false ;
break ;
}
}
// Was the package valid?
if ( ! $package || ! $package [ 'type' ])
{
if ( in_array ( $this -> getType , array ( 'upload' , 'url' )))
{
$this -> remove ( $package [ 'packagename' ]);
}
2023-02-27 12:27:41 +00:00
$this -> app -> setUserState ( 'com_componentbuilder.message' , Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_UNABLE_TO_FIND_IMPORT_PACKAGE' ));
2017-03-27 12:38:51 +00:00
return false ;
}
// first link data to table headers
2017-03-30 21:19:12 +00:00
if ( ! $continue )
{
// check if this a smart package, if true then get info
2018-03-24 01:36:07 +00:00
if ( $this -> dataType !== 'smart_package' || ! $this -> getInfo ( $package , $session ))
2017-03-30 21:19:12 +00:00
{
2023-02-27 12:27:41 +00:00
$this -> app -> setUserState ( 'com_componentbuilder.message' , Text :: _ ( 'COM_COMPONENTBUILDER_THERE_WAS_AN_ERROR_GETTING_THE_PACKAGE_INFO' ));
2018-03-24 01:36:07 +00:00
return false ;
2017-03-30 21:19:12 +00:00
}
2018-03-24 01:36:07 +00:00
// set package to session
$package = json_encode ( $package );
2017-03-27 12:38:51 +00:00
$session -> set ( 'package' , $package );
$session -> set ( 'dataType' , $this -> dataType );
$session -> set ( 'hasPackage' , true );
return true ;
}
2018-03-24 01:36:07 +00:00
// force update
$this -> forceUpdate = $this -> app -> input -> getInt ( 'force_update' , 0 );
// show more information
$this -> moreInfo = $this -> app -> input -> getInt ( 'more_info' , 0 );
2018-04-17 21:25:03 +00:00
// allow merge
$this -> canmerge = $this -> app -> input -> getInt ( 'canmerge' , 1 );
2021-08-11 12:15:35 +00:00
// forch GUID only search
$this -> importGuidOnly = $this -> app -> input -> getInt ( 'import_guid_only' , 0 );
2018-03-24 01:36:07 +00:00
// has a key
$this -> hasKey = $this -> app -> input -> getInt ( 'haskey' , 0 );
// die sleutle
2022-05-16 04:27:50 +00:00
$this -> sleutle = $this -> app -> input -> getString ( 'sleutle' , '' );
2018-03-24 01:36:07 +00:00
// try to store/set data
if ( ! $this -> setData ( $package ))
2017-03-27 12:38:51 +00:00
{
// There was an error importing the package
2023-02-27 12:27:41 +00:00
$msg = Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_ERROR' );
2017-03-28 14:57:59 +00:00
$msgType = 'error' ;
2017-03-27 12:38:51 +00:00
$back = $session -> get ( 'backto_VDM_IMPORT' , NULL );
if ( $back )
{
2017-03-28 14:57:59 +00:00
$this -> app -> setUserState ( 'com_componentbuilder.redirect_url' , 'index.php?option=com_componentbuilder&view=' . $back );
2017-03-27 12:38:51 +00:00
$session -> clear ( 'backto_VDM_IMPORT' );
}
$result = false ;
}
else
{
// Package imported sucessfully
2024-03-02 20:10:30 +00:00
$msg = Text :: sprintf ( 'COM_COMPONENTBUILDER_IMPORT_SUCCESS' , $package [ 'packagename' ]);
2017-03-28 14:57:59 +00:00
$msgType = 'success' ;
2017-03-27 12:38:51 +00:00
$back = $session -> get ( 'backto_VDM_IMPORT' , NULL );
if ( $back )
{
2018-03-24 01:36:07 +00:00
$this -> app -> setUserState ( 'com_componentbuilder.redirect_url' , 'index.php?option=com_componentbuilder&view=' . $back );
$session -> clear ( 'backto_VDM_IMPORT' );
2017-03-27 12:38:51 +00:00
}
$result = true ;
}
2017-03-28 14:57:59 +00:00
// Set message to qeue
$this -> app -> enqueueMessage ( $msg , $msgType );
2017-03-27 12:38:51 +00:00
// remove file after import
$this -> remove ( $package [ 'packagename' ]);
2018-03-24 01:36:07 +00:00
2017-03-27 12:38:51 +00:00
return $result ;
2017-03-30 21:19:12 +00:00
}
protected function getInfo ( & $package , & $session )
{
// set the data
if ( isset ( $package [ 'dir' ]))
{
// set auto loader
ComponentbuilderHelper :: autoLoader ( 'smart' );
// extract the package
2024-10-07 22:31:55 +00:00
if ( is_file ( $package [ 'dir' ]))
2017-03-30 21:19:12 +00:00
{
2018-03-24 01:36:07 +00:00
// does this package pass a checksum
$checksum = false ;
$checksumStatus = 'warning' ;
2023-02-27 12:27:41 +00:00
$checksumMessage = Text :: _ ( 'COM_COMPONENTBUILDER_PLEASE_NOTE_THAT_THIS_PACKAGE_BHAS_NOB_CHECKSUM_VALIDATION' );
2018-03-24 01:36:07 +00:00
// do hash validation here for git repos
2024-03-02 20:10:30 +00:00
if ( UtilitiesStringHelper :: check ( $this -> checksum ) && isset ( $this -> checksumURLs [ $this -> checksum ]))
2018-03-24 01:36:07 +00:00
{
// get packages checksums
2023-02-27 12:27:41 +00:00
$checksums = FileHelper :: getContent ( $this -> checksumURLs [ $this -> checksum ] . 'checksum.json' );
if ( JsonHelper :: check ( $checksums ))
2018-03-24 01:36:07 +00:00
{
// convert to array
$checksums = json_decode ( $checksums , true );
// get package name
$packageName = basename ( $package [ 'dir' ]);
// check if package is found
if ( isset ( $checksums [ $packageName ]))
{
// validate checksum
if ( $checksums [ $packageName ] === sha1_file ( $package [ 'dir' ]))
{
$validator = $this -> checksumURLs [ $this -> checksum ] . str_replace ( '.zip' , '.sha' , $packageName );
2024-03-02 20:10:30 +00:00
$checksumMessage = Text :: sprintf ( 'COM_COMPONENTBUILDER_THIS_PACKAGE_BPASSEDB_THE_CHECKSUM_VALIDATIONBR_BR_SMALLMANUALLY_ALSO_VALIDATE_THAT_THE_CORRECT_CHECKSUM_WAS_USEDSMALLBR_THIS_CHECKSUM_BSB_MUST_BE_THE_SAME_AS_THE_ONE_FOUND_A_S_SA' , $checksums [ $packageName ], 'href="' . $validator . '" target="_blank" title="verify checksum">' , $validator );
2018-03-24 01:36:07 +00:00
$checksumStatus = 'Success' ;
$checksum = true ;
}
}
// set error
if ( ! $checksum )
{
2023-02-27 12:27:41 +00:00
$checksumMessage = Text :: _ ( 'COM_COMPONENTBUILDER_BBEST_TO_NOT_CONTINUEBBR_YOU_CAN_REFRESH_AND_TRY_AGAINBR_BUT_NOTE_THAT_THIS_PACKAGE_BFAILEDB_CHECKSUM_VALIDATION_THIS_COULD_BE_A_SERIOUS_SECURITY_BREACH_DO_NOT_CONTINUE' );
2018-03-24 01:36:07 +00:00
$checksumStatus = 'error' ;
}
}
// set error
else
{
2023-02-27 12:27:41 +00:00
$checksumMessage = Text :: _ ( 'COM_COMPONENTBUILDER_BBEST_TO_NOT_CONTINUEBBR_WE_COULD_NOT_LOAD_THE_CHECKSUM_FOR_THIS_PACKAGE_AND_SO_NO_VALIDATION_WAS_POSSIBLE_THIS_MAY_BE_DUE_TO_YOUR_NETWORK_OR_A_CHANGE_TO_THAT_PACKAGE_NAME' );
2018-03-24 01:36:07 +00:00
$checksumStatus = 'error' ;
}
}
// do not have check sum validation
$this -> app -> enqueueMessage ( $checksumMessage , $checksumStatus );
2017-03-30 21:19:12 +00:00
// get the zip adapter
$zip = JArchive :: getAdapter ( 'zip' );
// set the directory name
2024-10-07 22:31:55 +00:00
$this -> dir = File :: stripExt ( $package [ 'dir' ]);
2017-03-30 21:19:12 +00:00
// unzip the package
2017-10-20 16:17:46 +00:00
$zip -> extract ( $package [ 'dir' ], $this -> dir );
2017-03-30 21:19:12 +00:00
// check for database file
2017-10-20 16:17:46 +00:00
$infoFile = $this -> dir . '/info.vdm' ;
2024-10-07 22:31:55 +00:00
if ( is_file ( $infoFile ))
2017-03-30 21:19:12 +00:00
{
// load the data
2023-10-18 07:26:30 +00:00
if ( $info = FileHelper :: getContent ( $infoFile ))
2017-03-30 21:19:12 +00:00
{
2022-05-16 04:25:03 +00:00
// unlock the info data
2023-02-27 12:27:41 +00:00
if ((( $info_ = PackageFactory :: _ ( 'Crypt' ) -> decrypt ( $info , 'local' )) !== null && JsonHelper :: check ( $info_ )) ||
(( $info_ = PackageFactory :: _ ( 'Crypt' ) -> decrypt ( $info , 'local.legacy' )) !== null && JsonHelper :: check ( $info_ )) ||
(( $info_ = PackageFactory :: _ ( 'Crypt' ) -> decrypt ( $info , 'local.fof' )) !== null && JsonHelper :: check ( $info_ )))
2017-03-30 21:19:12 +00:00
{
2022-05-16 04:25:03 +00:00
// we only continue if info could be opened
2023-02-27 12:27:41 +00:00
$session -> set ( 'smart_package_info' , $info_ );
2017-03-30 21:19:12 +00:00
return true ;
}
2022-05-16 04:25:03 +00:00
// do not have check sum validation
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_HTWOWE_COULD_NOT_OPEN_THE_PACKAGEHTWOTHIS_COULD_BE_DUE_TO_THE_FOFENCRYPTION_THAT_IS_NO_LONGER_SUPPORTED_IN_JOOMLA_PLEASE_EXPORT_YOUR_PACKAGES_WITH_JCB_VTHREEZEROELEVENPRO_OR_VTWOONETWOSEVENTEENPUBLIC_OR_HIGHER_TO_BE_ABLE_TO_IMPORT_IT_INTO_THIS_VERSION_OF_JCB' ), 'error' );
2017-03-30 21:19:12 +00:00
}
}
2017-10-20 16:17:46 +00:00
ComponentbuilderHelper :: removeFolder ( $this -> dir );
2017-03-30 21:19:12 +00:00
}
}
return false ;
2024-03-02 20:10:30 +00:00
}
2021-03-05 03:08:47 +00:00
/**
* Works out an importation spreadsheet from a HTTP upload
*
* @ return spreadsheet definition or false on failure
*/
protected function _getPackageFromUpload ()
2024-03-02 20:10:30 +00:00
{
2021-03-05 03:08:47 +00:00
// Get the uploaded file information
2024-03-02 20:10:30 +00:00
$app = Factory :: getApplication ();
2021-03-05 03:08:47 +00:00
$input = $app -> input ;
// Do not change the filter type 'raw'. We need this to let files containing PHP code to upload. See JInputFiles::get.
$userfile = $input -> files -> get ( 'import_package' , null , 'raw' );
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
// Make sure that file uploads are enabled in php
if ( ! ( bool ) ini_get ( 'file_uploads' ))
{
2024-03-02 20:10:30 +00:00
$app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_MSG_WARNIMPORTFILE' ), 'warning' );
2021-03-05 03:08:47 +00:00
return false ;
}
// If there is no uploaded file, we have a problem...
if ( ! is_array ( $userfile ))
{
2024-03-02 20:10:30 +00:00
$app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_MSG_NO_FILE_SELECTED' ), 'warning' );
2021-03-05 03:08:47 +00:00
return false ;
}
// Check if there was a problem uploading the file.
if ( $userfile [ 'error' ] || $userfile [ 'size' ] < 1 )
{
2024-03-02 20:10:30 +00:00
$app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_MSG_WARNIMPORTUPLOADERROR' ), 'warning' );
2021-03-05 03:08:47 +00:00
return false ;
}
// Build the appropriate paths
2024-03-02 20:10:30 +00:00
$config = Factory :: getConfig ();
2021-03-05 03:08:47 +00:00
$tmp_dest = $config -> get ( 'tmp_path' ) . '/' . $userfile [ 'name' ];
$tmp_src = $userfile [ 'tmp_name' ];
// Move uploaded file
2021-03-08 22:36:30 +00:00
$p_file = File :: upload ( $tmp_src , $tmp_dest , $this -> use_streams , $this -> allow_unsafe , $this -> safeFileOptions );
2021-03-05 03:08:47 +00:00
// Was the package downloaded?
if ( ! $p_file )
{
2024-03-02 20:10:30 +00:00
$session = Factory :: getSession ();
2021-03-05 03:08:47 +00:00
$session -> clear ( 'package' );
$session -> clear ( 'dataType' );
$session -> clear ( 'hasPackage' );
// was not uploaded
return false ;
}
// check that this is a valid spreadsheet
$package = $this -> check ( $userfile [ 'name' ]);
return $package ;
}
/**
* Import an spreadsheet from a directory
*
* @ return array Spreadsheet details or false on failure
*
*/
protected function _getPackageFromFolder ()
{
2024-03-02 20:10:30 +00:00
$app = Factory :: getApplication ();
2021-03-05 03:08:47 +00:00
$input = $app -> input ;
// Get the path to the package to import
$p_dir = $input -> getString ( 'import_directory' );
2024-03-02 20:10:30 +00:00
$p_dir = Path :: clean ( $p_dir );
2021-03-05 03:08:47 +00:00
// Did you give us a valid path?
if ( ! file_exists ( $p_dir ))
{
2024-03-02 20:10:30 +00:00
$app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_MSG_PLEASE_ENTER_A_PACKAGE_DIRECTORY' ), 'warning' );
2021-03-05 03:08:47 +00:00
return false ;
}
// Detect the package type
$type = $this -> getType ;
// Did you give us a valid package?
if ( ! $type )
{
2024-03-02 20:10:30 +00:00
$app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_MSG_PATH_DOES_NOT_HAVE_A_VALID_PACKAGE' ), 'warning' );
2021-03-05 03:08:47 +00:00
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
// check the extention
if ( ! $this -> checkExtension ( $p_dir ))
{
// set error message
2024-03-02 20:10:30 +00:00
$app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_MSG_DOES_NOT_HAVE_A_VALID_FILE_TYPE' ), 'warning' );
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
$package [ 'packagename' ] = null ;
$package [ 'dir' ] = $p_dir ;
$package [ 'type' ] = $type ;
return $package ;
}
/**
* Import an spreadsheet from a URL
*
* @ return Package details or false on failure
*
*/
protected function _getPackageFromUrl ()
{
2024-03-02 20:10:30 +00:00
$app = Factory :: getApplication ();
2021-03-05 03:08:47 +00:00
$input = $app -> input ;
// Get the URL of the package to import
$url = $input -> getString ( 'import_url' );
// Did you give us a URL?
if ( ! $url )
{
2024-03-02 20:10:30 +00:00
$app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_MSG_ENTER_A_URL' ), 'warning' );
2021-03-05 03:08:47 +00:00
return false ;
}
// Download the package at the URL given
2024-03-02 20:10:30 +00:00
$p_file = InstallerHelper :: downloadPackage ( $url );
2021-03-05 03:08:47 +00:00
// Was the package downloaded?
if ( ! $p_file )
{
2024-03-02 20:10:30 +00:00
$app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_MSG_INVALID_URL' ), 'warning' );
2021-03-05 03:08:47 +00:00
return false ;
}
// check that this is a valid spreadsheet
$package = $this -> check ( $p_file );
return $package ;
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Check a file and verifies it as a spreadsheet file
* Supports . csv . xlsx . xls and . ods
*
* @ param string $p_filename The uploaded package filename or import directory
*
* @ return array of elements
*
*/
protected function check ( $archivename )
{
2024-03-02 20:10:30 +00:00
$app = Factory :: getApplication ();
2021-03-05 03:08:47 +00:00
// Clean the name
2024-03-02 20:10:30 +00:00
$archivename = Path :: clean ( $archivename );
2021-03-05 03:08:47 +00:00
// check the extention
if ( ! $this -> checkExtension ( $archivename ))
{
// Cleanup the import files
$this -> remove ( $archivename );
2024-03-02 20:10:30 +00:00
$app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_IMPORT_MSG_DOES_NOT_HAVE_A_VALID_FILE_TYPE' ), 'warning' );
2021-03-05 03:08:47 +00:00
return false ;
}
2024-03-02 20:10:30 +00:00
$config = Factory :: getConfig ();
2021-03-05 03:08:47 +00:00
// set Package Name
$check [ 'packagename' ] = $archivename ;
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
// set directory
$check [ 'dir' ] = $config -> get ( 'tmp_path' ) . '/' . $archivename ;
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
// set type
$check [ 'type' ] = $this -> getType ;
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
return $check ;
}
2017-03-27 12:38:51 +00:00
/**
* Check the extension
*
* @ param string $file Name of the uploaded file
*
* @ return boolean True on success
*
*/
protected function checkExtension ( $file )
{
// check the extension
switch ( strtolower ( pathinfo ( $file , PATHINFO_EXTENSION )))
{
case 'zip' :
if ( $this -> dataType === 'smart_package' )
{
return true ;
}
break ;
}
return false ;
2021-03-05 03:08:47 +00:00
}
/**
* Clean up temporary uploaded spreadsheet
*
* @ param string $package Name of the uploaded spreadsheet file
*
* @ return boolean True on success
*
*/
protected function remove ( $package )
{
2024-03-02 20:10:30 +00:00
$config = Factory :: getConfig ();
2021-03-05 03:08:47 +00:00
$package = $config -> get ( 'tmp_path' ) . '/' . $package ;
// Is the package file a valid file?
if ( is_file ( $package ))
{
2021-03-08 22:36:30 +00:00
File :: delete ( $package );
2021-03-05 03:08:47 +00:00
}
2024-03-02 20:10:30 +00:00
elseif ( is_file ( Path :: clean ( $package )))
2021-03-05 03:08:47 +00:00
{
// It might also be just a base filename
2024-03-02 20:10:30 +00:00
File :: delete ( Path :: clean ( $package ));
2021-03-05 03:08:47 +00:00
}
}
2017-03-27 12:38:51 +00:00
/**
* Set the data from the spreadsheet to the database
*
* @ param string $package Paths to the uploaded package file
*
* @ return boolean false on failure
*
**/
2018-03-24 01:36:07 +00:00
protected function setData ( $package )
2017-03-27 12:38:51 +00:00
{
2024-03-02 20:10:30 +00:00
$jinput = Factory :: getApplication () -> input ;
2017-03-27 12:38:51 +00:00
// set the data based on the type of import being done
2018-03-24 01:36:07 +00:00
if ( 'continue-ext' === $this -> getType )
2017-03-27 12:38:51 +00:00
{
// set the data
if ( isset ( $package [ 'dir' ]))
{
// set auto loader
ComponentbuilderHelper :: autoLoader ( 'smart' );
// extract the package
2024-10-07 22:31:55 +00:00
if ( is_file ( $package [ 'dir' ]))
2017-03-27 12:38:51 +00:00
{
// set the directory name
2024-10-07 22:31:55 +00:00
$this -> dir = File :: stripExt ( $package [ 'dir' ]);
2017-03-27 12:38:51 +00:00
// check for database file
2017-10-20 16:17:46 +00:00
$dbFile = $this -> dir . '/db.vdm' ;
2024-10-07 22:31:55 +00:00
if ( ! is_file ( $dbFile ))
2017-03-30 21:19:12 +00:00
{
// get the zip adapter
$zip = JArchive :: getAdapter ( 'zip' );
// unzip the package
2017-10-20 16:17:46 +00:00
$zip -> extract ( $package [ 'dir' ], $this -> dir );
2017-03-30 21:19:12 +00:00
}
// check again
2024-10-07 22:31:55 +00:00
if ( is_file ( $dbFile ))
2017-03-27 12:38:51 +00:00
{
// load the data
2023-10-18 07:26:30 +00:00
if ( $data = FileHelper :: getContent ( $dbFile ))
2017-03-27 12:38:51 +00:00
{
// prep the data
2017-10-20 16:17:46 +00:00
if ( $this -> extractData ( $data ))
2017-03-27 12:38:51 +00:00
{
2024-03-02 20:10:30 +00:00
if ( isset ( $this -> data [ 'joomla_component' ]) && UtilitiesArrayHelper :: check ( $this -> data [ 'joomla_component' ]))
2017-03-27 12:38:51 +00:00
{
2017-03-28 14:57:59 +00:00
// save the smart data
2017-10-20 16:17:46 +00:00
if ( $this -> saveSmartComponents ())
2017-03-28 14:57:59 +00:00
{
2017-10-20 16:17:46 +00:00
ComponentbuilderHelper :: removeFolder ( $this -> dir );
2017-03-28 14:57:59 +00:00
return true ;
}
2017-03-27 12:38:51 +00:00
}
}
}
}
2017-10-20 16:17:46 +00:00
ComponentbuilderHelper :: removeFolder ( $this -> dir );
2017-03-27 12:38:51 +00:00
}
}
}
return false ;
2017-03-28 14:57:59 +00:00
}
/**
* Extract the data from the string
*
* @ param string $data The data string
*
* @ return object false on failure
*
**/
protected function extractData ( $data )
{
// remove all line breaks
2023-10-18 07:26:30 +00:00
if (( $data = $this -> decrypt ( $data , $this -> sleutle )) !== null )
2017-03-28 14:57:59 +00:00
{
// final check if we have success
$data = @ unserialize ( $data );
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $data ))
2017-03-28 14:57:59 +00:00
{
2017-10-20 16:17:46 +00:00
// set the data global
$this -> data = $data ;
return true ;
2017-03-28 14:57:59 +00:00
}
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_HTWODATA_IS_CORRUPTHTWOTHIS_COULD_BE_DUE_TO_BKEY_ERRORB_OR_BROKEN_PACKAGE' ), 'error' );
2017-03-28 14:57:59 +00:00
return false ;
}
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_HTWODATA_IS_CORRUPTHTWOTHIS_COULD_BE_DUE_TO_BROKEN_PACKAGE' ), 'error' );
2017-03-28 14:57:59 +00:00
return false ;
2021-03-05 03:08:47 +00:00
}
2017-03-27 12:38:51 +00:00
/**
* Save the smart components
*
* @ return boolean false on failure
*
**/
2017-10-20 16:17:46 +00:00
protected function saveSmartComponents ()
2017-03-27 12:38:51 +00:00
{
// get user object
2024-03-02 20:10:30 +00:00
$this -> user = Factory :: getUser ();
2017-03-27 12:38:51 +00:00
// set some defaults
2024-03-02 20:10:30 +00:00
$this -> today = Factory :: getDate () -> toSql ();
2018-04-17 21:25:03 +00:00
// if we can't merge add postfix to name
if ( ! $this -> canmerge )
{
// set some postfix
2024-03-02 20:10:30 +00:00
$this -> postfix = ' (' . UtilitiesStringHelper :: random ( 2 ) . ')' ;
2018-04-17 21:25:03 +00:00
}
2017-10-29 16:07:37 +00:00
// the array of tables to store
$tables = array (
2021-12-21 14:44:50 +00:00
'power' , 'validation_rule' , 'fieldtype' , 'field' , 'admin_view' , 'snippet' , 'dynamic_get' , 'custom_admin_view' , 'site_view' ,
2020-04-03 18:45:48 +00:00
'template' , 'layout' , 'joomla_component' , 'language' , 'custom_code' , 'placeholder' , 'class_extends' ,
2019-12-07 01:39:16 +00:00
'joomla_module' , 'joomla_module_files_folders_urls' , 'joomla_module_updates' ,
2019-08-12 21:30:31 +00:00
'joomla_plugin_group' , 'class_property' , 'class_method' , 'joomla_plugin' , 'joomla_plugin_files_folders_urls' , 'joomla_plugin_updates' ,
2018-08-24 21:46:41 +00:00
'admin_fields' , 'admin_fields_conditions' , 'admin_fields_relations' , 'admin_custom_tabs' , 'component_admin_views' ,
'component_site_views' , 'component_custom_admin_views' , 'component_updates' , 'component_mysql_tweaks' ,
2019-02-15 22:03:21 +00:00
'component_custom_admin_menus' , 'component_config' , 'component_dashboard' , 'component_files_folders' ,
2020-04-03 18:45:48 +00:00
'component_placeholders' , 'component_modules' , 'component_plugins' , 'language_translation'
2017-10-29 16:07:37 +00:00
);
2018-07-07 00:12:13 +00:00
// get prefix
$prefix = $this -> _db -> getPrefix ();
// get local tables
$localTables = $this -> _db -> getTableList ();
2017-10-29 16:07:37 +00:00
// smart table loop
foreach ( $tables as $table )
{
2018-07-07 00:12:13 +00:00
// only continue the import if the table is available locally
if ( in_array ( $prefix . 'componentbuilder_' . $table , $localTables ))
2017-10-29 16:07:37 +00:00
{
2018-07-07 00:12:13 +00:00
// save the table to database
if ( ! $this -> saveSmartItems ( $table ))
{
return false ;
}
}
else
{
2021-12-21 14:44:50 +00:00
// check if it is the power table
if ( $table === 'power' )
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_TABLE_BSB_NOT_FOUND_IN_THE_LOCAL_DATABASE_SO_ITS_VALUES_COULD_NOT_BE_IMPORTED_THE_WHOLE_POWERS_FEATURE_IS_ONLY_AVAILABLE_TO_A_HREFSPRO_MEMBERSA_AT_THIS_TIME' , '#__componentbuilder_' . $table , '"https://vdm.bz/get-jcb-pro-membership" target="_blank" title="Join PRO Membership today!"' ), 'warning' );
2021-12-21 14:44:50 +00:00
}
else
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_TABLE_BSB_NOT_FOUND_IN_THE_LOCAL_DATABASE_SO_ITS_VALUES_COULD_NOT_BE_IMPORTED_PLEASE_UPDATE_YOUR_JCB_INSTALL_AND_TRY_AGAIN' , '#__componentbuilder_' . $table ), 'warning' );
2021-12-21 14:44:50 +00:00
}
2017-10-29 16:07:37 +00:00
}
2017-03-27 12:38:51 +00:00
}
2017-03-31 21:28:16 +00:00
// do a after all run on all items that need it
2018-04-20 21:14:49 +00:00
$this -> updateAfterAll ();
2017-10-19 03:53:55 +00:00
// finally move the old datasets
$this -> moveDivergedData ();
2017-03-27 12:38:51 +00:00
// lets move all the files to its correct location
2017-10-20 16:17:46 +00:00
if ( ! $this -> moveSmartStuff ())
2017-03-27 12:38:51 +00:00
{
return false ;
}
return true ;
}
/**
2017-10-20 16:17:46 +00:00
* Save the smart items
*
2018-04-20 21:14:49 +00:00
* @ param string $table The table
2017-03-27 12:38:51 +00:00
*
2017-10-20 16:17:46 +00:00
* @ return boolean false on failure
*
**/
2018-04-17 21:25:03 +00:00
public function saveSmartItems ( $table )
2017-10-20 16:17:46 +00:00
{
2024-03-02 20:10:30 +00:00
if ( isset ( $this -> data [ $table ]) && UtilitiesArrayHelper :: check ( $this -> data [ $table ]))
2017-10-20 16:17:46 +00:00
{
2018-08-30 16:33:30 +00:00
// add pre import event
$this -> preImportEvent ( $table );
2017-10-20 16:17:46 +00:00
// get global action permissions
2018-03-24 01:36:07 +00:00
$canDo = ComponentbuilderHelper :: getActions ( $table );
$canEdit = $canDo -> get ( 'core.edit' );
$canState = $canDo -> get ( 'core.edit.state' );
$canCreate = $canDo -> get ( 'core.create' );
2018-04-17 21:25:03 +00:00
// check if we should allow merge of local values
$canmerge = $this -> allowMerge ( $table );
2017-10-20 16:17:46 +00:00
// set id keeper
if ( ! isset ( $this -> newID [ $table ]))
{
$this -> newID [ $table ] = array ();
}
foreach ( $this -> data [ $table ] as $item )
{
$oldID = ( int ) $item -> id ;
// first check if exist
2018-08-23 01:37:42 +00:00
if ( $canmerge && ( $local = $this -> getLocalItem ( $item , $table , 1 )) !== false )
2017-10-20 16:17:46 +00:00
{
2018-03-21 02:45:51 +00:00
// display more import info
if ( $this -> moreInfo )
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_BSB_WAS_FOUND' , $table . ' id:' . $oldID . '->' . $local -> id ), 'success' );
2018-03-21 02:45:51 +00:00
}
2017-10-20 16:17:46 +00:00
$dbDate = strtotime ( $item -> modified );
$localDate = strtotime ( $local -> modified );
// okay we have it local (check if the version is newer)
if ( $this -> forceUpdate == 1 || $dbDate > $localDate )
{
// add some local values to item to combine
if ( $table === 'language_translation' )
{
$item -> localComponents = $local -> components ;
2020-04-03 18:45:48 +00:00
$item -> localModules = $local -> modules ;
$item -> localPlugins = $local -> plugins ;
2017-10-20 16:17:46 +00:00
$item -> localTranslation = $local -> translation ;
}
// make sure we have the correct ID set
$item -> id = $local -> id ;
// yes it is newer, lets update (or is being forced)
2018-08-23 01:37:42 +00:00
if ( $canEdit && ( $id = $this -> updateLocalItem ( $item , $table , $canState )) !== false )
2017-10-20 16:17:46 +00:00
{
// we had success in
2018-08-23 01:37:42 +00:00
$this -> newID [ $table ][ $oldID ] = ( int ) $local -> id ;
2018-03-21 02:45:51 +00:00
// display more import info
if ( $this -> moreInfo )
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_BSB_HAS_BEEN_UPDATED' , $table . ' id:' . $oldID . '->' . $id ), 'success' );
2018-03-21 02:45:51 +00:00
}
2017-10-20 16:17:46 +00:00
}
else
{
$notice = '!' ;
if ( ! $canEdit )
{
2023-02-27 12:27:41 +00:00
$notice = Text :: sprintf ( " COM_COMPONENTBUILDER__SINCE_YOU_DONT_HAVE_PERMISSION_TO_EDIT_S " , $table );
2017-10-20 16:17:46 +00:00
}
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_BSB_COULD_NOT_BE_IMPORTEDS' , $table . ' id:' . $oldID , $notice ), 'error' );
2017-10-20 16:17:46 +00:00
}
}
// insure to load the local ID to link imported values with it
if ( ! isset ( $this -> newID [ $table ][ $oldID ]))
{
$this -> newID [ $table ][ $oldID ] = ( int ) $local -> id ;
}
}
2018-08-23 01:37:42 +00:00
elseif ( $canCreate && ( $id = $this -> addLocalItem ( $item , $table )) !== false )
2017-10-20 16:17:46 +00:00
{
// not found in local db so add
$this -> newID [ $table ][ $oldID ] = ( int ) $id ;
2018-03-21 02:45:51 +00:00
// display more import info
if ( $this -> moreInfo )
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_BSB_HAS_BEEN_IMPORTED' , $table . ' id:' . $oldID . '->' . $id ), 'success' );
2018-03-21 02:45:51 +00:00
}
2017-10-20 16:17:46 +00:00
}
else
{
$notice = '!' ;
if ( ! $canCreate )
{
2023-02-27 12:27:41 +00:00
$notice = Text :: sprintf ( " COM_COMPONENTBUILDER__SINCE_YOU_DONT_HAVE_PERMISSION_TO_CREATE_S " , $table );
2017-10-20 16:17:46 +00:00
}
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_BSB_COULD_NOT_BE_IMPORTEDS' , $table . ' id:' . $oldID , $notice ), 'error' );
2017-10-20 16:17:46 +00:00
}
}
}
2018-03-24 01:36:07 +00:00
return true ;
2017-10-20 16:17:46 +00:00
}
2018-08-30 16:33:30 +00:00
/**
* Check if this table needs some house cleaning before we import the data
*
* @ return void
*
**/
protected function preImportEvent ( $table )
{
// if this is custom code table
// remove all custom code linked to these components
// since some code may have been removed and changed
// best unpublish all and let the import publish those still active
2024-03-02 20:10:30 +00:00
if ( 'custom_code' === $table && isset ( $this -> newID [ 'joomla_component' ]) && UtilitiesArrayHelper :: check ( $this -> newID [ 'joomla_component' ]))
2018-08-30 16:33:30 +00:00
{
$query = $this -> _db -> getQuery ( true );
// Field to update.
$fields = array (
$this -> _db -> quoteName ( 'published' ) . ' = 0'
);
// Conditions for which records should be updated.
$conditions = array (
$this -> _db -> quoteName ( 'component' ) . ' IN (' . implode ( ', ' , array_values ( $this -> newID [ 'joomla_component' ])) . ')'
);
$query -> update ( $this -> _db -> quoteName ( '#__componentbuilder_custom_code' )) -> set ( $fields ) -> where ( $conditions );
$this -> _db -> setQuery ( $query );
$this -> _db -> execute ();
}
}
2018-04-17 21:25:03 +00:00
/**
* Check if we should allow merge for this table
*
* @ return boolean
*
**/
protected function allowMerge ( $table )
{
if ( $this -> canmerge == 1 || in_array ( $table , $this -> mustMerge ))
{
return true ;
}
return false ;
}
2017-10-20 16:17:46 +00:00
/**
* Move the smart content ( files & folders ) into place
2017-03-27 12:38:51 +00:00
*
* @ return boolean false on failure
*
**/
2017-10-20 16:17:46 +00:00
protected function moveSmartStuff ()
2017-03-27 12:38:51 +00:00
{
2017-04-01 13:59:54 +00:00
// make sure to first unlock files
2018-03-02 01:37:04 +00:00
$this -> unLockFiles ();
2017-03-27 12:38:51 +00:00
// set params
2024-03-02 20:10:30 +00:00
$params = ComponentHelper :: getParams ( 'com_componentbuilder' );
2017-03-27 12:38:51 +00:00
// set custom folder path
2017-04-08 20:52:51 +00:00
$customPath = str_replace ( '//' , '/' , $params -> get ( 'custom_folder_path' , JPATH_COMPONENT_ADMINISTRATOR . '/custom' ));
$imagesPath = str_replace ( '//' , '/' , JPATH_SITE . '/images' );
2017-03-28 14:57:59 +00:00
$success = true ;
2017-03-27 12:38:51 +00:00
// check if we have custom files
2017-10-20 16:17:46 +00:00
$customDir = str_replace ( '//' , '/' , $this -> dir . '/custom' );
2024-10-07 22:31:55 +00:00
if ( is_dir ( $customDir ))
2017-03-27 12:38:51 +00:00
{
// great we have some custom stuff lets move it
2024-10-07 22:31:55 +00:00
if ( ! Folder :: copy ( $customDir , $customPath , '' , true ))
2017-03-28 14:57:59 +00:00
{
2024-03-02 20:10:30 +00:00
$this -> app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_BCUSTOM_FILESB_NOT_MOVED_TO_CORRECT_LOCATION' ), 'error' );
2017-03-28 14:57:59 +00:00
$success = false ;
}
2018-03-24 01:36:07 +00:00
// display more import info
elseif ( $this -> moreInfo )
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_SOME_BCUSTOM_FILESB_WERE_MOVED_TO_BSB' , $customPath ), 'success' );
2018-03-24 01:36:07 +00:00
}
2017-03-27 12:38:51 +00:00
}
// check if we have images
2017-10-20 16:17:46 +00:00
$imageDir = str_replace ( '//' , '/' , $this -> dir . '/images' );
2024-10-07 22:31:55 +00:00
if ( is_dir ( $imageDir ))
2017-03-27 12:38:51 +00:00
{
// great we have some images lets move them
2024-10-07 22:31:55 +00:00
if ( ! Folder :: copy ( $imageDir , $imagesPath , '' , true ))
2017-03-28 14:57:59 +00:00
{
2024-03-02 20:10:30 +00:00
$this -> app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_BIMAGESB_NOT_MOVED_TO_CORRECT_LOCATION' ), 'error' );
2017-03-28 14:57:59 +00:00
$success = false ;
}
2018-03-24 01:36:07 +00:00
// display more import info
elseif ( $this -> moreInfo )
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_SOME_BIMAGESB_WERE_MOVED_TO_BSB' , $imagesPath ), 'success' );
2018-03-24 01:36:07 +00:00
}
2017-03-27 12:38:51 +00:00
}
2018-03-02 01:37:04 +00:00
// now move the dynamic files if found
$dynamicDir = str_replace ( '//' , '/' , $this -> dir . '/dynamic' );
2024-10-07 22:31:55 +00:00
if ( is_dir ( $dynamicDir ))
2018-03-02 01:37:04 +00:00
{
// get a list of folders
2024-10-07 22:31:55 +00:00
$folders = Folder :: folders ( $dynamicDir );
2018-03-02 01:37:04 +00:00
// check if we have files
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $folders ))
2018-03-02 01:37:04 +00:00
{
foreach ( $folders as $folder )
{
$destination = $this -> setDynamicPath ( $folder );
$fullPath = str_replace ( '//' , '/' , $dynamicDir . '/' . $folder );
2024-10-07 22:31:55 +00:00
if ( ! is_dir ( $fullPath ) || ! Folder :: copy ( $fullPath , $destination , '' , true ))
2018-03-02 01:37:04 +00:00
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_FOLDER_BSB_WAS_NOT_MOVED_TO_BSB' , $folder , $destination ), 'error' );
2018-03-02 01:37:04 +00:00
$success = false ;
}
2018-03-24 01:36:07 +00:00
// display more import info
elseif ( $this -> moreInfo )
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_FOLDER_BSB_WAS_MOVED_TO_BSB' , $folder , $destination ), 'success' );
2018-03-24 01:36:07 +00:00
}
2018-03-02 01:37:04 +00:00
}
}
// get a list of files
2024-10-07 22:31:55 +00:00
$files = Folder :: files ( $dynamicDir );
2018-03-02 01:37:04 +00:00
// check if we have files
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $files ))
2018-03-02 01:37:04 +00:00
{
foreach ( $files as $file )
{
$destination = $this -> setDynamicPath ( $file );
$fullPath = str_replace ( '//' , '/' , $dynamicDir . '/' . $file );
2024-10-07 22:31:55 +00:00
if ( ! is_file ( $fullPath ) || ! File :: copy ( $fullPath , $destination ))
2018-03-02 01:37:04 +00:00
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_FILE_BSB_WAS_NOT_MOVED_TO_BSB' , $file , $destination ), 'error' );
2018-03-02 01:37:04 +00:00
$success = false ;
}
2018-03-24 01:36:07 +00:00
// display more import info
elseif ( $this -> moreInfo )
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_FILE_BSB_WAS_MOVED_TO_BSB' , $file , $destination ), 'success' );
2018-03-24 01:36:07 +00:00
}
2018-03-02 01:37:04 +00:00
}
}
}
2017-03-28 14:57:59 +00:00
return $success ;
2017-03-27 12:38:51 +00:00
}
2017-04-01 13:59:54 +00:00
/**
2022-05-16 04:25:03 +00:00
* Method to unlock all files in all folders of this package
2017-04-01 13:59:54 +00:00
*
* @ return void
*/
2017-10-20 16:17:46 +00:00
protected function unLockFiles ()
2017-04-01 13:59:54 +00:00
{
// lock the data if set
2024-03-02 20:10:30 +00:00
if ( UtilitiesStringHelper :: check ( $this -> sleutle ) && strlen ( $this -> sleutle ) == 32 )
2017-04-01 13:59:54 +00:00
{
// we must first store the current working directory
$joomla = getcwd ();
2018-03-02 01:37:04 +00:00
// to avoid that it decrypt the db and info file again we must move per/folder
$folders = array ( 'images' , 'custom' , 'dynamic' );
// loop the folders
foreach ( $folders as $folder )
2017-04-01 13:59:54 +00:00
{
2018-03-02 01:37:04 +00:00
$subPath = str_replace ( '//' , '/' , $this -> dir . '/' . $folder );
// go to the package sub folder if found
2024-10-07 22:31:55 +00:00
if ( is_dir ( $subPath ))
2018-03-02 01:37:04 +00:00
{
2022-05-16 04:25:03 +00:00
$this -> unLockFile ( $subPath );
2018-03-02 01:37:04 +00:00
}
2017-04-01 13:59:54 +00:00
}
// change back to working dir
chdir ( $joomla );
}
}
/**
2022-05-16 04:25:03 +00:00
* The unlocking files
2017-04-01 13:59:54 +00:00
*
* @ return void
*/
2022-05-16 04:25:03 +00:00
protected function unLockFile ( & $tmpPath )
2017-04-01 13:59:54 +00:00
{
// we are changing the working directory to the tmp path (important)
chdir ( $tmpPath );
// get a list of files in the current directory tree (all)
2024-10-07 22:31:55 +00:00
$files = Folder :: files ( '.' , '.' , true , true );
2017-04-01 13:59:54 +00:00
// read in the file content
foreach ( $files as $file )
{
2022-05-16 04:25:03 +00:00
// open the file content
2023-10-18 07:26:30 +00:00
if (( $data = $this -> decrypt ( file_get_contents ( $file ), $this -> sleutle )) !== null )
2017-04-01 13:59:54 +00:00
{
// write the decrypted data back to file
2023-02-27 12:27:41 +00:00
if ( ! FileHelper :: write ( $file , $data ))
2017-04-01 13:59:54 +00:00
{
2018-03-24 01:36:07 +00:00
// in case file could not be unlocked
2024-03-02 20:10:30 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_FILE_BSB_COULD_NOT_BE_STORED' , $file ), 'error' );
2018-03-24 01:36:07 +00:00
}
// display more import info
elseif ( $this -> moreInfo )
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_FILE_BSB_WAS_SUCCESSFULLY_UNLOCKED' , $file ), 'success' );
2017-04-01 13:59:54 +00:00
}
}
2022-05-16 04:25:03 +00:00
else
{
// in case file could not be unlocked
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_FILE_BSB_COULD_NOT_BE_UNLOCKED' , $file ), 'error' );
2022-05-16 04:25:03 +00:00
}
2017-04-01 13:59:54 +00:00
}
}
2022-05-16 04:25:03 +00:00
/**
2022-05-16 04:27:50 +00:00
* decrypt data
2022-05-16 04:25:03 +00:00
*
2023-02-27 12:27:41 +00:00
* @ param string $data The data string
* @ param string $password The key to unlock
* @ param bool $force Should we force phpseclib decryption
2022-05-16 04:25:03 +00:00
*
* @ return mixed the data , or false
*
* @ since 3.0 . 11
**/
2022-05-16 04:27:50 +00:00
protected function decrypt ( string $data , string $password , bool $force = false )
2022-05-16 04:25:03 +00:00
{
// remove all line breaks
2023-02-27 12:27:41 +00:00
$data = $this -> removeLineBreaks ( $data );
2022-05-16 04:25:03 +00:00
// make sure we have base64
2023-02-27 12:27:41 +00:00
if ( $this -> isBase64Encoded ( $data ))
2022-05-16 04:25:03 +00:00
{
// open the data
2023-02-27 12:27:41 +00:00
if ( $this -> isValidPassword ( $password ))
2022-05-16 04:25:03 +00:00
{
2023-02-27 12:27:41 +00:00
// try phpseclib version 3
if (( $this -> isPhpseclib3Enabled () || $force ) &&
2023-10-18 07:26:30 +00:00
( $data_ = $this -> decryptWithPhpseclib3 ( $data , $password )) !== null )
2022-05-16 04:25:03 +00:00
{
2023-02-27 12:27:41 +00:00
return $data_ ;
2022-05-16 04:25:03 +00:00
}
2023-02-27 12:27:41 +00:00
// try phpseclib version 2
if (( $this -> isPhpseclib2Enabled () || $force ) &&
2023-10-18 07:26:30 +00:00
( $data_ = $this -> decryptWithPhpseclib2 ( $data , $password )) !== null )
2022-05-16 04:25:03 +00:00
{
2023-02-27 12:27:41 +00:00
return $data_ ;
2022-05-16 04:25:03 +00:00
}
2023-02-27 12:27:41 +00:00
// try FOF the outdated method
2023-10-18 07:26:30 +00:00
if (( $data_ = $this -> decryptWithFof ( $data , $password )) !== null )
2023-02-27 12:27:41 +00:00
{
return $data_ ;
}
2023-05-02 00:10:55 +00:00
$this -> app -> enqueueMessage ( Text :: _ ( 'COM_COMPONENTBUILDER_HTWOWE_COULD_NOT_OPEN_THE_ENCRYPT_DATAHTWO_THIS_COULD_BE_DUE_TO_THE_FOFENCRYPTION_THAT_IS_NO_LONGER_SUPPORTED_IN_JOOMLABR_PLEASE_EXPORT_YOUR_PACKAGES_WITH_JCB_VTHREEONEONEEIGHT_OR_HIGHER_TO_BE_ABLE_TO_IMPORT_IT_INTO_THIS_VERSION_OF_JCB' ), 'error' );
2022-05-16 04:25:03 +00:00
}
else
{
return base64_decode ( $data );
}
}
2023-02-27 12:27:41 +00:00
2022-05-16 04:25:03 +00:00
return false ;
}
2023-02-27 12:27:41 +00:00
/**
* Removes all line breaks from a string
*
* @ param string $data
*
* @ return string
*/
private function removeLineBreaks ( string $data ) : string
{
return str_replace ( " \n " , '' , $data );
}
/**
* Check if the data is base64 encoded
*
* @ param string $data
*
* @ return bool
*/
private function isBase64Encoded ( string $data ) : bool
{
return $data === base64_encode ( base64_decode ( $data , true ));
}
/**
* Check if a password is set and has a length of 32 characters
*
* @ param string $password
*
* @ return bool
*/
private function isValidPassword ( string $password ) : bool
{
2024-03-02 20:10:30 +00:00
return UtilitiesStringHelper :: check ( $password ) && strlen ( $password ) == 32 ;
2023-02-27 12:27:41 +00:00
}
/**
* Check if we can use phpseclib library version 2
*
* @ return bool
*/
private function isPhpseclib2Enabled () : bool
{
return ( bool ) isset ( $this -> packageInfo [ 'phpseclib' ]) && $this -> packageInfo [ 'phpseclib' ];
}
/**
* Decrypts data using the phpseclib library version 2
*
* @ param string $data
* @ param string $password
*
2023-10-18 07:26:30 +00:00
* @ return string | null
2023-02-27 12:27:41 +00:00
*/
2023-10-18 07:26:30 +00:00
private function decryptWithPhpseclib2 ( string $data , string $password ) : ? string
2023-02-27 12:27:41 +00:00
{
$data_ = PackageFactory :: _ ( 'Crypt' ) -> decrypt ( $data , 'legacy' , $password );
2023-10-18 07:26:30 +00:00
if ( $data_ !== null )
{
return strcmp ( $data , $data_ ) !== 0 ? $data_ : null ;
}
return null ;
2023-02-27 12:27:41 +00:00
}
/**
* Check if we can use phpseclib library version 3
*
* @ return bool
*/
private function isPhpseclib3Enabled () : bool
{
return ( bool ) isset ( $this -> packageInfo [ 'phpseclib3' ]) && $this -> packageInfo [ 'phpseclib3' ];
}
/**
* Decrypts data using the phpseclib library version 3
*
* @ param string $data
* @ param string $password
*
2023-10-18 07:26:30 +00:00
* @ return string | null
2023-02-27 12:27:41 +00:00
*/
2023-10-18 07:26:30 +00:00
private function decryptWithPhpseclib3 ( string $data , string $password ) : ? string
2023-02-27 12:27:41 +00:00
{
$data_ = PackageFactory :: _ ( 'Crypt' ) -> decrypt ( $data , 'aes' , $password );
2023-10-18 07:26:30 +00:00
if ( $data_ !== null )
{
return strcmp ( $data , $data_ ) !== 0 ? $data_ : null ;
}
return null ;
2023-02-27 12:27:41 +00:00
}
/**
* Decrypts data using the FOF library ( outdated method )
*
* @ param string $data
* @ param string $password
*
2023-10-18 07:26:30 +00:00
* @ return string | null
2023-02-27 12:27:41 +00:00
*/
2023-10-18 07:26:30 +00:00
private function decryptWithFof ( string $data , string $password ) : ? string
2023-02-27 12:27:41 +00:00
{
$data_ = PackageFactory :: _ ( 'Crypt' ) -> decrypt ( $data , 'fof' , $password );
2023-10-18 07:26:30 +00:00
if ( $data_ !== null )
{
return strcmp ( $data , $data_ ) !== 0 ? $data_ : null ;
}
return null ;
2023-02-27 12:27:41 +00:00
}
2017-03-31 21:28:16 +00:00
/**
* Update some items after all
*
* @ return void
*
**/
2018-04-20 21:14:49 +00:00
public function updateAfterAll ()
2017-03-31 21:28:16 +00:00
{
2018-06-13 20:38:32 +00:00
// update the fields
2024-03-02 20:10:30 +00:00
if ( isset ( $this -> updateAfter [ 'field' ]) && UtilitiesArrayHelper :: check ( $this -> updateAfter [ 'field' ]))
2017-03-31 21:28:16 +00:00
{
// update repeatable
2018-08-23 01:37:42 +00:00
foreach ( $this -> updateAfter [ 'field' ] as $field => $action )
2017-03-31 21:28:16 +00:00
{
2021-12-21 14:44:50 +00:00
// if added we must get the ID now, yet if update the id is already set
2018-08-23 01:37:42 +00:00
if ( 'add' === $action && isset ( $this -> newID [ 'field' ][ $field ]))
2017-03-31 21:28:16 +00:00
{
$field = $this -> newID [ 'field' ][ $field ];
}
// get the field from db
2023-02-27 12:27:41 +00:00
if ( $xml = GetHelper :: var ( 'field' , $field , 'id' , 'xml' ))
2017-03-31 21:28:16 +00:00
{
2023-02-27 12:27:41 +00:00
if ( JsonHelper :: check ( $xml ))
2017-03-31 21:28:16 +00:00
{
$xml = json_decode ( $xml );
2023-02-27 12:27:41 +00:00
$fields = GetHelper :: between ( $xml , 'fields="' , '"' );
2017-03-31 21:28:16 +00:00
$fieldsSets = array ();
if ( strpos ( $fields , ',' ) !== false )
{
// multiple fields
$fieldsSets = array_map ( 'trim' , ( array ) explode ( ',' , $fields ));
}
elseif ( is_numeric ( $fields ))
{
// single field
$fieldsSets [] = ( int ) $fields ;
}
// update the fields
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $fieldsSets ))
2017-03-31 21:28:16 +00:00
{
$bucket = array ();
foreach ( $fieldsSets as $id )
{
2017-10-20 16:17:46 +00:00
if ( isset ( $this -> newID [ 'field' ][( int ) $id ]))
2017-03-31 21:28:16 +00:00
{
2017-10-20 16:17:46 +00:00
$bucket [] = $this -> newID [ 'field' ][( int ) $id ];
2017-03-31 21:28:16 +00:00
}
else
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_BMULTIPLE_FIELD_REPEATABLE_MODEB_IDS_MISMATCH_IN_BFIELDSB_AND_WAS_EMREMOVEDEM_FROM_THE_FIELD' , $id , $field ), 'warning' );
2017-03-31 21:28:16 +00:00
}
}
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $bucket ))
2017-03-31 21:28:16 +00:00
{
$string = implode ( ',' , $bucket );
$xml = json_encode ( str_replace ( 'fields="' . $fields . '"' , 'fields="' . $string . '"' , $xml ));
}
else
{
$xml = '' ;
}
2024-03-02 20:10:30 +00:00
$object = new \stdClass ;
2017-03-31 21:28:16 +00:00
$object -> id = $field ;
$object -> xml = $xml ;
// update the field
2017-08-23 20:38:09 +00:00
$this -> _db -> updateObject ( '#__componentbuilder_field' , $object , 'id' );
2017-03-31 21:28:16 +00:00
}
}
}
}
}
// do a after all run on admin views that need it
2024-03-02 20:10:30 +00:00
if ( isset ( $this -> updateAfter [ 'adminview' ]) && UtilitiesArrayHelper :: check ( $this -> updateAfter [ 'adminview' ]))
2017-03-31 21:28:16 +00:00
{
// update the addlinked_views
2018-08-23 01:37:42 +00:00
foreach ( $this -> updateAfter [ 'adminview' ] as $adminview => $action )
2017-03-31 21:28:16 +00:00
{
2021-12-21 14:44:50 +00:00
// if added we must get the ID now, yet if update the id is already set
2018-08-23 01:37:42 +00:00
if ( 'add' === $action && isset ( $this -> newID [ 'admin_view' ][( int ) $adminview ]))
2017-03-31 21:28:16 +00:00
{
2017-10-20 16:17:46 +00:00
$adminview = $this -> newID [ 'admin_view' ][( int ) $adminview ];
2017-03-31 21:28:16 +00:00
}
// get the field from db
2023-02-27 12:27:41 +00:00
if ( $addlinked_views = GetHelper :: var ( 'admin_view' , $adminview , 'id' , 'addlinked_views' ))
2018-06-12 15:39:13 +00:00
{
2023-02-27 12:27:41 +00:00
if ( JsonHelper :: check ( $addlinked_views ))
2017-03-31 21:28:16 +00:00
{
$addlinked_views = json_decode ( $addlinked_views , true );
2018-04-20 21:14:49 +00:00
// convert Repeatable Fields
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $addlinked_views ) && isset ( $addlinked_views [ 'adminview' ]))
2017-03-31 21:28:16 +00:00
{
2017-10-29 11:03:06 +00:00
$addlinked_views = ComponentbuilderHelper :: convertRepeatable ( $addlinked_views , 'addlinked_views' );
2017-03-31 21:28:16 +00:00
}
2017-10-19 03:53:55 +00:00
// update the view IDs
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $addlinked_views ))
2017-10-19 03:53:55 +00:00
{
// only update the view IDs
2021-12-21 14:44:50 +00:00
$addlinked_views = $this -> updateIDs ( $addlinked_views , 'admin_view' , array ( 'adminview' => 'admin_view' ));
2018-06-12 15:39:13 +00:00
}
2017-10-19 03:53:55 +00:00
// update the fields
2024-03-02 20:10:30 +00:00
$object = new \stdClass ;
2017-10-19 03:53:55 +00:00
$object -> id = $adminview ;
2017-12-25 12:46:35 +00:00
$object -> addlinked_views = json_encode ( $addlinked_views , JSON_FORCE_OBJECT );
2017-10-19 03:53:55 +00:00
// update the admin view
$this -> _db -> updateObject ( '#__componentbuilder_admin_view' , $object , 'id' );
}
}
}
}
2018-06-12 15:39:13 +00:00
// update the joomla_component dashboard
2024-03-02 20:10:30 +00:00
if ( isset ( $this -> updateAfter [ 'joomla_component' ]) && UtilitiesArrayHelper :: check ( $this -> updateAfter [ 'joomla_component' ]))
2018-06-12 15:39:13 +00:00
{
// update dashboard of the components
2018-08-23 01:37:42 +00:00
foreach ( $this -> updateAfter [ 'joomla_component' ] as $component => $action )
2018-06-12 15:39:13 +00:00
{
2021-12-21 14:44:50 +00:00
// if added we must get the ID now, yet if update the id is already set
2018-08-23 01:37:42 +00:00
if ( 'add' === $action && isset ( $this -> newID [ 'joomla_component' ][( int ) $component ]))
2018-06-12 15:39:13 +00:00
{
$component = $this -> newID [ 'joomla_component' ][( int ) $component ];
}
// get the dashboard from db
2023-02-27 12:27:41 +00:00
if ( $dashboard = GetHelper :: var ( 'joomla_component' , $component , 'id' , 'dashboard' ))
2018-06-12 15:39:13 +00:00
{
2024-03-02 20:10:30 +00:00
if ( UtilitiesStringHelper :: check ( $dashboard ))
2018-06-12 15:39:13 +00:00
{
// get id
$id = ( int ) preg_replace ( " /[^0-9]/ " , " " , $dashboard );
// update the value
$update = false ;
// admin_view
if (( strpos ( $dashboard , 'A' ) !== false || strpos ( $dashboard , 'a' ) !== false ) && isset ( $this -> newID [ 'admin_view' ][ $id ]))
{
// set the new value
$dashboard = 'A_' . $this -> newID [ 'admin_view' ][ $id ];
// update the value
$update = true ;
}
// custom_admin_view
elseif (( strpos ( $dashboard , 'C' ) !== false || strpos ( $dashboard , 'c' ) !== false ) && isset ( $this -> newID [ 'custom_admin_view' ][ $id ]))
{
// set the new value
$dashboard = 'C_' . $this -> newID [ 'custom_admin_view' ][ $id ];
// update the value
$update = true ;
}
// did we get a new value
if ( $update )
{
// now update the joomla_component dashboard value
2024-03-02 20:10:30 +00:00
$object = new \stdClass ;
2018-06-12 15:39:13 +00:00
$object -> id = ( int ) $component ;
$object -> dashboard = $dashboard ;
// update the admin view
$this -> _db -> updateObject ( '#__componentbuilder_joomla_component' , $object , 'id' );
}
}
}
}
}
2018-06-13 20:38:32 +00:00
// update the admin_fields_relations
2024-03-02 20:10:30 +00:00
if ( isset ( $this -> updateAfter [ 'relations' ]) && UtilitiesArrayHelper :: check ( $this -> updateAfter [ 'relations' ]))
2018-06-13 20:38:32 +00:00
{
// update repeatable
2018-08-23 01:37:42 +00:00
foreach ( $this -> updateAfter [ 'relations' ] as $relation => $action )
2018-06-13 20:38:32 +00:00
{
// check if we must update this relation
$update = false ;
2021-12-21 14:44:50 +00:00
// if added we must get the ID now, yet if update the id is already set
2018-08-23 01:37:42 +00:00
if ( 'add' === $action && isset ( $this -> newID [ 'admin_fields_relations' ][ $relation ]))
2018-06-13 20:38:32 +00:00
{
$relation = $this -> newID [ 'admin_fields_relations' ][ $relation ];
}
// get the set relation from db
2023-02-27 12:27:41 +00:00
if ( $addrelations = GetHelper :: var ( 'admin_fields_relations' , $relation , 'id' , 'addrelations' ))
2018-06-13 20:38:32 +00:00
{
2023-02-27 12:27:41 +00:00
if ( JsonHelper :: check ( $addrelations ))
2018-06-13 20:38:32 +00:00
{
$addrelations = json_decode ( $addrelations , true );
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $addrelations ))
2018-06-13 20:38:32 +00:00
{
foreach ( $addrelations as $nr => & $value )
{
// reset the buckets
$bucket = array ();
// get fields
2023-02-27 12:27:41 +00:00
$found = GetHelper :: allBetween ( $value [ 'set' ], '[field=' , ']' );
2018-06-13 20:38:32 +00:00
// if found
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $found ))
2018-06-13 20:38:32 +00:00
{
$bucket [] = $found ;
}
// get fields
2023-02-27 12:27:41 +00:00
$found = GetHelper :: allBetween ( $value [ 'set' ], '$item->{' , '}' );
2018-06-13 20:38:32 +00:00
// if found
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $found ))
2018-06-13 20:38:32 +00:00
{
$bucket [] = $found ;
}
// check if we have values
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $bucket ))
2018-06-13 20:38:32 +00:00
{
2024-03-02 20:10:30 +00:00
$fields = UtilitiesArrayHelper :: merge ( $bucket );
2018-06-13 20:38:32 +00:00
// reset the buckets
$bucket = array ();
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $fields ))
2018-06-13 20:38:32 +00:00
{
foreach ( $fields as $field )
{
if ( isset ( $this -> newID [ 'field' ][( int ) $field ]))
{
$bucket [ '[field=' . ( int ) $field . ']' ] = '[field=' . ( int ) $this -> newID [ 'field' ][( int ) $field ] . ']' ;
$bucket [ '$item->{' . ( int ) $field . '}' ] = '$item->{' . ( int ) $this -> newID [ 'field' ][( int ) $field ] . '}' ;
}
else
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_BADMIN_FIELDS_RELATIONSB_IDS_MISMATCH_IN_BFIELDSB_AND_WAS_NOT_UPDATED_IN_THE_CUSTOM_CODE' , $relation , $field ), 'warning' );
2018-06-13 20:38:32 +00:00
}
}
// check if we have a bucket of values to update
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $bucket ))
2018-06-13 20:38:32 +00:00
{
$value [ 'set' ] = str_replace ( array_keys ( $bucket ), array_values ( $bucket ), $value [ 'set' ]);
$update = true ;
}
}
}
}
// update only if needed
if ( $update )
{
2024-03-02 20:10:30 +00:00
$object = new \stdClass ;
2018-06-13 20:38:32 +00:00
$object -> id = $relation ;
$object -> addrelations = json_encode ( $addrelations , JSON_FORCE_OBJECT );
// update the field
$this -> _db -> updateObject ( '#__componentbuilder_admin_fields_relations' , $object , 'id' );
}
}
}
}
}
}
2021-12-21 14:44:50 +00:00
// update the verious power linked to these powers
2024-03-02 20:10:30 +00:00
if ( isset ( $this -> updateAfter [ 'power' ]) && UtilitiesArrayHelper :: check ( $this -> updateAfter [ 'power' ]))
2021-12-21 14:44:50 +00:00
{
// update repeatable
foreach ( $this -> updateAfter [ 'power' ] as $power => $action )
{
// check if we must update this power
$update = false ;
// if added we must get the ID now, yet if update the id is already set
if ( 'add' === $action && isset ( $this -> newID [ 'power' ][ $power ]))
{
$power = $this -> newID [ 'power' ][ $power ];
}
// get the power
$query = $this -> _db -> getQuery ( true );
2022-05-16 04:25:03 +00:00
$query -> select ( array ( 'a.id' , 'a.property_selection' , 'a.method_selection' ));
2021-12-21 14:44:50 +00:00
$query -> from ( $this -> _db -> quoteName ( '#__componentbuilder_power' , 'a' ));
$query -> where ( $this -> _db -> quoteName ( 'a.id' ) . ' = ' . ( int ) $power );
// see if we get an item
$this -> _db -> setQuery ( $query );
$this -> _db -> execute ();
if ( $this -> _db -> getNumRows ())
{
$item = $this -> _db -> loadObject ();
// subform fields to target
$updaterT = array (
// subformfield => array( field => type_value )
'property_selection' => array ( 'property' => 'class_property' ),
'method_selection' => array ( 'method' => 'class_method' )
);
// update the subform ids
$this -> updateSubformsIDs ( $item , 'power' , $updaterT );
// update the power
$this -> _db -> updateObject ( '#__componentbuilder_power' , $item , 'id' );
}
}
}
2017-10-19 03:53:55 +00:00
}
/**
* Moving of diverged data
*
* @ return void
*
**/
2018-04-17 21:25:03 +00:00
public function moveDivergedData ()
2017-10-19 03:53:55 +00:00
{
// check if there is data to move
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $this -> divergedDataMover ))
2017-10-19 03:53:55 +00:00
{
foreach ( $this -> divergedDataMover as $table => $values )
{
foreach ( $values as $value )
{
// first check if exist (only add if it does not)
2018-03-02 01:37:04 +00:00
if ( ! $this -> getLocalItem ( $value , $table , 1 , 1 , true ))
2017-10-19 03:53:55 +00:00
{
// add the diverged data
2018-03-02 01:37:04 +00:00
$this -> addLocalItem ( $value , $table , true );
2017-03-31 21:28:16 +00:00
}
}
}
}
}
2021-12-21 14:44:50 +00:00
/**
* Update Many Params IDs
*
* @ param array $values The values to update the IDs in
* @ param string $table The table these values belong to
* @ param array $targets The target to update and its type
*
* @ return void
*/
2023-02-27 12:27:41 +00:00
private function updateParamIDs ( & $item , $table , $targets )
2021-12-21 14:44:50 +00:00
{
// update the params fields if exist
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> params ) && JsonHelper :: check ( $item -> params ))
2021-12-21 14:44:50 +00:00
{
$paramsArray = json_decode ( $item -> params , true );
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $paramsArray ))
2021-12-21 14:44:50 +00:00
{
foreach ( $targets as $field => $targetArray )
{
if ( isset ( $paramsArray [ $field ]))
{
$target_array = array ();
foreach ( $targetArray as $key => $field_table )
{
// sub form in params
if ( strpos ( $key , '.' ) !== false )
{
$key_array = explode ( '.' , $key );
// set the target
$target_array [ $key_array [ 0 ]][ $key_array [ 1 ]] = $field_table ;
}
elseif ( isset ( $paramsArray [ $field ][ $key ]))
{
// load it back
$paramsArray [ $field ] = $this -> setNewID ( $paramsArray [ $field ], $key , $field_table , $table );
}
}
// check if we had some subforms
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $target_array ))
2021-12-21 14:44:50 +00:00
{
$paramsArray [ $field ] = $this -> updateIDs ( $paramsArray [ $field ], $table , $target_array );
}
}
}
}
// add the params back
$item -> params = json_encode ( $paramsArray , JSON_FORCE_OBJECT );
}
}
2017-10-19 03:53:55 +00:00
/**
* Update Many Subform IDs
*
* @ param array $values The values to update the IDs in
* @ param string $table The table these values belong to
* @ param array $targets The target to update and its type
*
* @ return void
*/
2023-02-27 12:27:41 +00:00
private function updateSubformsIDs ( & $item , $table , $targets )
2017-10-19 03:53:55 +00:00
{
// update the repeatable fields
foreach ( $targets as $field => $targetArray )
{
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> { $field }) && JsonHelper :: check ( $item -> { $field }))
2017-10-19 03:53:55 +00:00
{
$updateArray = json_decode ( $item -> { $field }, true );
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $updateArray ))
2017-10-19 03:53:55 +00:00
{
// load it back
2021-12-21 14:44:50 +00:00
$item -> { $field } = json_encode ( $this -> updateIDs ( $updateArray , $table , $targetArray ), JSON_FORCE_OBJECT );
2017-10-19 03:53:55 +00:00
}
}
}
}
/**
2021-12-21 14:44:50 +00:00
* Update IDs
2017-10-19 03:53:55 +00:00
*
2023-02-27 12:27:41 +00:00
* @ param array $values The values to update the IDs in
* @ param string $table The table these values belong to
* @ param array $targets The target to update and its type
2017-10-19 03:53:55 +00:00
*
* @ return void
*/
2023-02-27 12:27:41 +00:00
private function updateIDs ( $values , $table , $targets )
2017-10-19 03:53:55 +00:00
{
$isJson = false ;
2023-02-27 12:27:41 +00:00
if ( JsonHelper :: check ( $values ))
2017-10-19 03:53:55 +00:00
{
$values = json_decode ( $values , true );
$isJson = true ;
}
// now update the fields
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $values ))
2017-10-19 03:53:55 +00:00
{
foreach ( $values as $nr => & $value )
{
foreach ( $targets as $target => $target_type )
{
if ( isset ( $value [ $target ]))
{
2017-10-20 16:17:46 +00:00
$value = $this -> setNewID ( $value , $target , $target_type , $table );
2017-10-19 03:53:55 +00:00
}
}
}
}
if ( $isJson )
{
2017-12-25 12:46:35 +00:00
return json_encode ( $values , JSON_FORCE_OBJECT );
2017-10-19 03:53:55 +00:00
}
return $values ;
}
2017-10-20 16:17:46 +00:00
/**
* Set the new ID
*
* @ param array $item The values to update the IDs in
* @ param string $target The target field
* @ param string $type The table of that field
* @ param string $table The table these values belong to
*
* @ return boolean True on success
*
*/
2023-02-27 12:27:41 +00:00
private function setNewID ( $item , $target , $type , $table )
2017-10-20 16:17:46 +00:00
{
$isJson = false ;
2023-02-27 12:27:41 +00:00
if ( JsonHelper :: check ( $item ))
2017-10-20 16:17:46 +00:00
{
$item = json_decode ( $item , true );
$isJson = true ;
}
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $item ) && isset ( $item [ $target ]))
2017-10-20 16:17:46 +00:00
{
// set item ID
2021-12-21 14:44:50 +00:00
$itemId = ( isset ( $item [ 'id' ])) ? $item [ 'id' ] : 'id_unknow' ;
2017-10-20 16:17:46 +00:00
// check if it is json
$isJsonTarget = false ;
2023-02-27 12:27:41 +00:00
if ( JsonHelper :: check ( $item [ $target ]))
2017-10-20 16:17:46 +00:00
{
$item [ $target ] = json_decode ( $item [ $target ], true );
$isJsonTarget = true ;
}
// update the target
2024-03-02 20:10:30 +00:00
if ( UtilitiesStringHelper :: check ( $item [ $target ]) || is_numeric ( $item [ $target ]))
2017-10-20 16:17:46 +00:00
{
2021-12-21 14:44:50 +00:00
if ( $item [ $target ] <= 0 )
2017-10-20 16:17:46 +00:00
{
2021-12-21 14:44:50 +00:00
if ( $item [ $target ] == 0 )
{
$item [ $target ] = '' ;
}
2017-10-20 16:17:46 +00:00
}
elseif ( isset ( $this -> newID [ $type ][( int ) $item [ $target ]]))
{
$item [ $target ] = $this -> newID [ $type ][( int ) $item [ $target ]];
}
else
{
$this -> enqueueIdMismatchMessage ( $item [ $target ], $itemId , $target , $type , $table );
$item [ $target ] = '' ;
}
}
2024-03-02 20:10:30 +00:00
elseif ( UtilitiesArrayHelper :: check ( $item [ $target ]))
2017-10-20 16:17:46 +00:00
{
// the bucket to load the items back
$bucket = array ();
foreach ( $item [ $target ] as $nr => $id )
{
2021-12-21 14:44:50 +00:00
if ( $id <= 0 )
2017-10-20 16:17:46 +00:00
{
2021-12-21 14:44:50 +00:00
if ( $id == 0 )
{
continue ;
}
// we add negative numbers back
$bucket [] = $id ;
2017-10-20 16:17:46 +00:00
}
2024-03-02 20:10:30 +00:00
elseif (( UtilitiesStringHelper :: check ( $id ) || is_numeric ( $id )) && isset ( $this -> newID [ $type ][( int ) $id ]))
2017-10-20 16:17:46 +00:00
{
$bucket [] = $this -> newID [ $type ][( int ) $id ];
}
else
{
$this -> enqueueIdMismatchMessage ( $id , $itemId , $target , $type , $table );
}
}
// set ids back
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $bucket ))
2017-10-20 16:17:46 +00:00
{
$item [ $target ] = $bucket ;
}
}
// convert back to json
if ( $isJsonTarget )
{
2018-09-11 21:37:48 +00:00
$item [ $target ] = json_encode ( $item [ $target ], JSON_FORCE_OBJECT );
2017-10-20 16:17:46 +00:00
}
}
2023-02-27 12:27:41 +00:00
elseif ( ObjectHelper :: check ( $item ) && isset ( $item -> { $target }))
2017-10-20 16:17:46 +00:00
{
// set item ID
2021-12-21 14:44:50 +00:00
$itemId = ( isset ( $item -> id )) ? $item -> id : 'id_unknow' ;
2017-10-20 16:17:46 +00:00
// check if it is json
$isJsonTarget = false ;
2023-02-27 12:27:41 +00:00
if ( JsonHelper :: check ( $item -> { $target }))
2017-10-20 16:17:46 +00:00
{
$item -> { $target } = json_decode ( $item -> { $target }, true );
$isJsonTarget = true ;
}
// update the target
2024-03-02 20:10:30 +00:00
if ( UtilitiesStringHelper :: check ( $item -> { $target }) || is_numeric ( $item -> { $target }))
2017-10-20 16:17:46 +00:00
{
2021-12-21 14:44:50 +00:00
if ( $item -> { $target } <= 0 )
2017-10-20 16:17:46 +00:00
{
2021-12-21 14:44:50 +00:00
if ( $item -> { $target } == 0 )
{
$item -> { $target } = '' ;
}
2017-10-20 16:17:46 +00:00
}
elseif ( isset ( $this -> newID [ $type ][( int ) $item -> { $target }]))
{
$item -> { $target } = $this -> newID [ $type ][( int ) $item -> { $target }];
}
else
{
$this -> enqueueIdMismatchMessage ( $item -> { $target }, $itemId , $target , $type , $table );
$item -> { $target } = '' ;
}
}
2024-03-02 20:10:30 +00:00
elseif ( UtilitiesArrayHelper :: check ( $item -> { $target }))
2017-10-20 16:17:46 +00:00
{
// the bucket to load the items back
$bucket = array ();
foreach ( $item -> { $target } as $id )
{
2021-12-21 14:44:50 +00:00
if ( $id <= 0 )
2017-10-20 16:17:46 +00:00
{
2021-12-21 14:44:50 +00:00
if ( $id == 0 )
{
continue ;
}
// we add negative numbers back
$bucket [] = $id ;
2017-10-20 16:17:46 +00:00
}
2024-03-02 20:10:30 +00:00
elseif (( UtilitiesStringHelper :: check ( $id ) || is_numeric ( $id )) && isset ( $this -> newID [ $type ][( int ) $id ]))
2017-10-20 16:17:46 +00:00
{
$bucket [] = $this -> newID [ $type ][( int ) $id ];
}
else
{
$this -> enqueueIdMismatchMessage ( $id , $itemId , $target , $type , $table );
$bucket [] = '' ;
}
}
// set ids back
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $bucket ))
2017-10-20 16:17:46 +00:00
{
$item -> { $target } = $bucket ;
}
}
// convert back to json
if ( $isJsonTarget )
{
2018-09-11 21:37:48 +00:00
$item -> { $target } = json_encode ( $item -> { $target }, JSON_FORCE_OBJECT );
2017-10-20 16:17:46 +00:00
}
}
// return as json if received as json
if ( $isJson )
{
return json_encode ( $item );
}
return $item ;
}
/**
* Set the new ID
*
* @ param int $id The field ID
* @ param int $itemId The item ID
* @ param string $target The target field
* @ param string $type The table of that field
* @ param string $table The table these values belong to
*
* @ return void
*
*/
2023-02-27 12:27:41 +00:00
private function enqueueIdMismatchMessage ( $id , $itemId , $target , $type , $table )
2017-10-20 16:17:46 +00:00
{
2024-03-02 20:10:30 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_BSBS_IN_BSB_HAS_ID_MISMATCH_SO_THE_BSB_WAS_REMOVED' , UtilitiesStringHelper :: safe ( $type , 'Ww' ), UtilitiesStringHelper :: safe ( $target , 'Ww' ) , UtilitiesStringHelper :: safe ( $table , 'w' ) . ':' . $itemId , $type . ':' . $id ), 'warning' );
2017-10-20 16:17:46 +00:00
}
2017-03-27 12:38:51 +00:00
/**
* Prep the item
*
2018-03-02 01:37:04 +00:00
* @ param object $item The item to prep
* @ param string $type The type of values
* @ param string $action The action ( add / update )
* @ param bool $diverged The diverged data switch
2017-03-27 12:38:51 +00:00
*
* @ return mixed false on failure
2017-08-23 20:38:09 +00:00
* object on success
2017-03-27 12:38:51 +00:00
*
**/
2023-02-27 12:27:41 +00:00
private function prepItem ( $item , $type , $action , $diverged = false )
2017-03-27 12:38:51 +00:00
{
2017-11-10 02:13:36 +00:00
// remove access
if ( isset ( $item -> access ))
{
unset ( $item -> access );
}
// remove metadata
if ( isset ( $item -> metadata ))
{
unset ( $item -> metadata );
}
// remove metadesc
if ( isset ( $item -> metadesc ))
{
unset ( $item -> metadesc );
}
// remove metakey
if ( isset ( $item -> metakey ))
{
unset ( $item -> metakey );
}
2018-04-13 20:06:45 +00:00
// remove not_required
if ( isset ( $item -> not_required ))
{
unset ( $item -> not_required );
}
2017-11-10 02:13:36 +00:00
// actions to effect all
2017-03-27 12:38:51 +00:00
if ( isset ( $item -> asset_id ))
{
unset ( $item -> asset_id );
}
if ( isset ( $item -> checked_out ))
{
$item -> checked_out = 0 ;
}
if ( isset ( $item -> checked_out_time ))
{
$item -> checked_out_time = '0000-00-00 00:00:00' ;
}
// do the id fix for the new ids
switch ( $type )
{
2017-10-19 03:53:55 +00:00
case 'fieldtype' :
// repeatable fields to update
$updaterR = array (
// repeatablefield => checker
'properties' => 'name'
);
// update the repeatable fields
2017-10-29 11:03:06 +00:00
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
2017-10-19 03:53:55 +00:00
break ;
2017-03-27 12:38:51 +00:00
case 'field' :
// update the fieldtype
2017-10-20 16:17:46 +00:00
if ( isset ( $item -> fieldtype ) && is_numeric ( $item -> fieldtype ) && $item -> fieldtype > 0 && isset ( $this -> newID [ 'fieldtype' ][( int ) $item -> fieldtype ]))
2017-03-27 12:38:51 +00:00
{
2017-10-20 16:17:46 +00:00
$item -> fieldtype = $this -> newID [ 'fieldtype' ][( int ) $item -> fieldtype ];
2017-09-18 02:20:50 +00:00
// update multi field values
if ( $this -> checkMultiFields ( $item -> fieldtype ))
2017-03-31 21:28:16 +00:00
{
2018-08-23 01:37:42 +00:00
$this -> updateAfter [ 'field' ][( int ) $item -> id ] = $action ; // multi field
2017-03-31 21:28:16 +00:00
}
}
elseif ( ! is_numeric ( $item -> fieldtype ) || $item -> fieldtype == 0 )
{
2024-03-02 20:10:30 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_BFIELD_TYPEB_NOT_SET_FOR_BSB' , UtilitiesStringHelper :: safe ( $type , 'w' ) . ':' . $item -> id ), 'warning' );
2017-03-31 21:28:16 +00:00
unset ( $item -> fieldtype );
2017-03-27 12:38:51 +00:00
}
else
{
2024-03-02 20:10:30 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_BFIELD_TYPEB_IDS_MISMATCH_IN_BSB' , $item -> fieldtype , UtilitiesStringHelper :: safe ( $type , 'w' ) . ':' . $item -> id ), 'error' );
2017-03-27 12:38:51 +00:00
return false ;
}
2018-04-17 21:25:03 +00:00
// if we can't merge add postfix to name
if ( $this -> postfix )
{
$item -> name = $item -> name . $this -> postfix ;
}
2017-03-27 12:38:51 +00:00
break ;
case 'dynamic_get' :
// update the view_table_main ID
2017-10-20 16:17:46 +00:00
if ( isset ( $item -> main_source ) && $item -> main_source == 1 )
2017-03-27 12:38:51 +00:00
{
2017-10-20 16:17:46 +00:00
$item = $this -> setNewID ( $item , 'view_table_main' , 'admin_view' , $type );
2017-03-27 12:38:51 +00:00
}
2017-10-06 14:53:22 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'join_view_table' => 'view_table' ,
'join_db_table' => 'db_table' ,
'order' => 'table_key' ,
'where' => 'table_key' ,
'global' => 'name' ,
'filter' => 'filter_type'
);
2017-10-06 14:53:22 +00:00
// update the repeatable fields
2017-10-29 11:03:06 +00:00
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
2017-10-19 03:53:55 +00:00
// subform fields to target
$updaterT = array (
2018-03-27 09:57:16 +00:00
// subformfield => field => type_value
'join_view_table' => array ( 'view_table' => 'admin_view' )
);
2017-10-19 03:53:55 +00:00
// update the subform ids
$this -> updateSubformsIDs ( $item , 'dynamic_get' , $updaterT );
2018-04-17 21:25:03 +00:00
// if we can't merge add postfix to name
if ( $this -> postfix )
{
$item -> name = $item -> name . $this -> postfix ;
}
2017-03-27 12:38:51 +00:00
break ;
case 'layout' :
case 'template' :
// update the dynamic_get
2017-10-20 16:17:46 +00:00
$item = $this -> setNewID ( $item , 'dynamic_get' , 'dynamic_get' , $type );
2017-03-31 21:28:16 +00:00
// update the snippet
2017-10-20 16:17:46 +00:00
$item = $this -> setNewID ( $item , 'snippet' , 'snippet' , $type );
2018-04-17 21:25:03 +00:00
// if we can't merge add postfix to name
if ( $this -> postfix )
{
$item -> name = $item -> name . $this -> postfix ;
}
2017-03-27 12:38:51 +00:00
break ;
case 'custom_admin_view' :
case 'site_view' :
// update the main_get
2017-10-20 16:17:46 +00:00
$item = $this -> setNewID ( $item , 'main_get' , 'dynamic_get' , $type );
2017-03-27 12:38:51 +00:00
// update the dynamic_get
2017-10-20 16:17:46 +00:00
$item = $this -> setNewID ( $item , 'dynamic_get' , 'dynamic_get' , $type );
2017-03-27 12:38:51 +00:00
// update the custom_get
2017-10-20 16:17:46 +00:00
$item = $this -> setNewID ( $item , 'custom_get' , 'dynamic_get' , $type );
2017-03-31 21:28:16 +00:00
// update the snippet
2017-10-20 16:17:46 +00:00
$item = $this -> setNewID ( $item , 'snippet' , 'snippet' , $type );
2017-10-16 17:14:23 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'ajax_input' => 'value_name' ,
'custom_button' => 'name'
);
2017-10-19 03:53:55 +00:00
// update the repeatable fields
2017-10-29 11:03:06 +00:00
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
2018-04-17 21:25:03 +00:00
// if we can't merge add postfix to name
if ( $this -> postfix )
{
$item -> system_name = $item -> system_name . $this -> postfix ;
}
2017-03-27 12:38:51 +00:00
break ;
case 'admin_view' :
2017-10-29 16:07:37 +00:00
// set the getters anchors
$getter = array ( 'admin_view' => $item -> id );
2017-03-27 12:38:51 +00:00
// we must clear the demo content (since it was not moved as far as we know) TODO
2017-08-23 14:52:31 +00:00
if ( $item -> add_sql == 1 && $item -> source == 1 )
{
// only if it is mapped to a table
unset ( $item -> add_sql );
unset ( $item -> source );
unset ( $item -> addtables );
}
2017-10-16 17:14:23 +00:00
// update the addfields (old dataset)
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> addfields ) && JsonHelper :: check ( $item -> addfields ))
2017-03-27 12:38:51 +00:00
{
2017-10-16 17:14:23 +00:00
// move the old data
2017-10-19 03:53:55 +00:00
$this -> setDivergedDataMover ( $item -> addfields , 'admin_fields' , 'addfields' , $getter );
2017-03-27 12:38:51 +00:00
}
2017-10-29 16:07:37 +00:00
// remove from this dataset
unset ( $item -> addfields );
2017-03-27 12:38:51 +00:00
// update the addlinked_views
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> addlinked_views ) && JsonHelper :: check ( $item -> addlinked_views ))
2017-03-27 12:38:51 +00:00
{
2018-08-23 01:37:42 +00:00
$this -> updateAfter [ 'adminview' ][( int ) $item -> id ] = $action ; // addlinked_views
2017-03-27 12:38:51 +00:00
}
2017-10-19 03:53:55 +00:00
elseif ( isset ( $item -> addlinked_views ))
2017-03-27 12:38:51 +00:00
{
unset ( $item -> addlinked_views );
}
2017-10-16 17:14:23 +00:00
// update the addconditions (old dataset)
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> addconditions ) && JsonHelper :: check ( $item -> addconditions ))
2017-03-27 12:38:51 +00:00
{
2017-10-16 17:14:23 +00:00
// move the old data
2017-10-19 03:53:55 +00:00
$this -> setDivergedDataMover ( $item -> addconditions , 'admin_fields_conditions' , 'addconditions' , $getter );
2017-03-27 12:38:51 +00:00
}
2017-10-29 16:07:37 +00:00
// remove from this dataset
unset ( $item -> addconditions );
2017-10-16 17:14:23 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'ajax_input' => 'value_name' ,
'custom_button' => 'name' ,
'addtables' => 'table' ,
'addlinked_views' => 'adminview' ,
'addtabs' => 'name' ,
'addpermissions' => 'action'
);
2017-10-16 17:14:23 +00:00
// update the repeatable fields
2017-10-29 11:03:06 +00:00
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
2021-12-21 14:44:50 +00:00
// param fields to target
$updaterP = array (
// param_field => field* => field_table
'fieldordering' => array (
'admin_ordering_fields.field' => 'field' ,
'linked_ordering_fields.field' => 'field'
),
'privacy' => array (
'anonymize_fields.field' => 'field' ,
'other_user_fields' => 'field'
)
);
// update the params ids
$this -> updateParamIDs ( $item , $type , $updaterP );
2018-04-17 21:25:03 +00:00
// if we can't merge add postfix to name
if ( $this -> postfix )
{
$item -> system_name = $item -> system_name . $this -> postfix ;
}
2017-03-27 12:38:51 +00:00
break ;
case 'joomla_component' :
2018-06-12 15:39:13 +00:00
// update custom dash after
if ( isset ( $item -> dashboard_type ) && 2 == $item -> dashboard_type )
{
// update the custom dash ID
2018-08-23 01:37:42 +00:00
$this -> updateAfter [ 'joomla_component' ][( int ) $item -> id ] = $action ; // dashboard
2018-06-12 15:39:13 +00:00
}
2017-10-29 16:07:37 +00:00
// set the anchors getters
$getter = array ( 'joomla_component' => $item -> id );
2017-03-27 12:38:51 +00:00
// update the addconfig
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> addconfig ) && JsonHelper :: check ( $item -> addconfig ))
2017-03-27 12:38:51 +00:00
{
2017-10-29 16:07:37 +00:00
// move the old data
$this -> setDivergedDataMover ( $item -> addconfig , 'component_config' , 'addconfig' , $getter );
2017-03-27 12:38:51 +00:00
}
2017-10-29 16:07:37 +00:00
// remove from this dataset
unset ( $item -> addconfig );
2017-03-27 12:38:51 +00:00
// update the addadmin_views
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> addadmin_views ) && JsonHelper :: check ( $item -> addadmin_views ))
2017-03-27 12:38:51 +00:00
{
2017-10-29 16:07:37 +00:00
// move the old data
$this -> setDivergedDataMover ( $item -> addadmin_views , 'component_admin_views' , 'addadmin_views' , $getter );
2017-03-27 12:38:51 +00:00
}
2017-10-29 16:07:37 +00:00
// remove from this dataset
unset ( $item -> addadmin_views );
2017-03-27 12:38:51 +00:00
// update the addcustom_admin_views
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> addcustom_admin_views ) && JsonHelper :: check ( $item -> addcustom_admin_views ))
2017-03-27 12:38:51 +00:00
{
2017-10-29 16:07:37 +00:00
// move the old data
$this -> setDivergedDataMover ( $item -> addcustom_admin_views , 'component_custom_admin_views' , 'addcustom_admin_views' , $getter );
2017-03-27 12:38:51 +00:00
}
2017-10-29 16:07:37 +00:00
// remove from this dataset
unset ( $item -> addcustom_admin_views );
2017-03-27 12:38:51 +00:00
// update the addsite_views
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> addsite_views ) && JsonHelper :: check ( $item -> addsite_views ))
2017-03-27 12:38:51 +00:00
{
2017-10-29 16:07:37 +00:00
// move the old data
$this -> setDivergedDataMover ( $item -> addsite_views , 'component_site_views' , 'addsite_views' , $getter );
}
// remove from this dataset
unset ( $item -> addsite_views );
// update the version_update
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> version_update ) && JsonHelper :: check ( $item -> version_update ))
2017-10-29 16:07:37 +00:00
{
// move the old data
$this -> setDivergedDataMover ( $item -> version_update , 'component_updates' , 'version_update' , $getter );
}
// remove from this dataset
unset ( $item -> version_update );
// update the sql_tweak
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> sql_tweak ) && JsonHelper :: check ( $item -> sql_tweak ))
2017-10-29 16:07:37 +00:00
{
// move the old data
$this -> setDivergedDataMover ( $item -> sql_tweak , 'component_mysql_tweaks' , 'sql_tweak' , $getter );
}
// remove from this dataset
unset ( $item -> sql_tweak );
// update the addcustommenus
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> addcustommenus ) && JsonHelper :: check ( $item -> addcustommenus ))
2017-10-29 16:07:37 +00:00
{
// move the old data
$this -> setDivergedDataMover ( $item -> addcustommenus , 'component_custom_admin_menus' , 'addcustommenus' , $getter );
}
// remove from this dataset
unset ( $item -> addcustommenus );
// update the dashboard_tab
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> dashboard_tab ) && JsonHelper :: check ( $item -> dashboard_tab ))
2017-10-29 16:07:37 +00:00
{
// move the old data
$this -> setDivergedDataMover ( $item -> dashboard_tab , 'component_dashboard' , 'dashboard_tab' , $getter );
}
// remove from this dataset
unset ( $item -> dashboard_tab );
// update the php_dashboard_methods
if ( isset ( $item -> php_dashboard_methods ))
{
// move the old data
$this -> setDivergedDataMover ( $item -> php_dashboard_methods , 'component_dashboard' , 'php_dashboard_methods' , $getter );
2017-03-27 12:38:51 +00:00
}
2017-10-29 16:07:37 +00:00
// remove from this dataset
unset ( $item -> php_dashboard_methods );
unset ( $item -> add_php_dashboard_methods );
// update the addfiles
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> addfiles ) && JsonHelper :: check ( $item -> addfiles ))
2017-10-29 16:07:37 +00:00
{
// move the old data
$this -> setDivergedDataMover ( $item -> addfiles , 'component_files_folders' , 'addfiles' , $getter );
}
// remove from this dataset
unset ( $item -> addfiles );
// update the addfolders
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> addfolders ) && JsonHelper :: check ( $item -> addfolders ))
2017-10-29 16:07:37 +00:00
{
// move the old data
$this -> setDivergedDataMover ( $item -> addfolders , 'component_files_folders' , 'addfolders' , $getter );
}
// remove from this dataset
unset ( $item -> addfolders );
2018-01-16 12:35:54 +00:00
// update the add_css
if ( isset ( $item -> add_css ))
{
$item -> add_css_admin = $item -> add_css ;
}
// remove from this dataset
unset ( $item -> add_css );
// update the css
2024-03-02 20:10:30 +00:00
if ( isset ( $item -> css ) && UtilitiesStringHelper :: check ( $item -> css ))
2018-01-16 12:35:54 +00:00
{
$item -> css_admin = $item -> css ;
}
// remove from this dataset
unset ( $item -> css );
2018-02-27 12:17:38 +00:00
// rename sales_server_ftp field
if ( isset ( $item -> sales_server_ftp ))
{
$item -> sales_server = $item -> sales_server_ftp ;
unset ( $item -> sales_server_ftp );
}
// rename update_server_ftp field
if ( isset ( $item -> update_server_ftp ))
{
$item -> update_server = $item -> update_server_ftp ;
unset ( $item -> update_server_ftp );
}
2018-05-05 14:47:48 +00:00
// rename export_package_link field
if ( isset ( $item -> export_package_link ))
{
$item -> joomla_source_link = $item -> export_package_link ;
unset ( $item -> export_package_link );
}
2017-10-29 16:07:37 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'addcontributors' => 'name'
);
2017-10-29 16:07:37 +00:00
// update the repeatable fields
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
2018-04-17 21:25:03 +00:00
// if we can't merge add postfix to name
if ( $this -> postfix )
{
$item -> system_name = $item -> system_name . $this -> postfix ;
}
2017-10-29 16:07:37 +00:00
break ;
case 'component_admin_views' :
2018-03-02 01:37:04 +00:00
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
2017-10-29 16:07:37 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'addadmin_views' => 'adminview'
);
2017-10-29 16:07:37 +00:00
// update the repeatable fields
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
// subform fields to target
$updaterT = array (
2018-03-27 09:57:16 +00:00
// subformfield => array( field => type_value )
'addadmin_views' => array ( 'adminview' => 'admin_view' )
);
2017-10-29 16:07:37 +00:00
// update the subform ids
$this -> updateSubformsIDs ( $item , 'component_admin_views' , $updaterT );
break ;
case 'component_site_views' :
2018-03-02 01:37:04 +00:00
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
2017-10-29 16:07:37 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'addsite_views' => 'siteview'
);
2017-10-29 16:07:37 +00:00
// update the repeatable fields
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
// subform fields to target
$updaterT = array (
2018-03-27 09:57:16 +00:00
// subformfield => array( field => type_value )
'addsite_views' => array ( 'siteview' => 'site_view' )
);
2017-10-29 16:07:37 +00:00
// update the subform ids
$this -> updateSubformsIDs ( $item , 'component_site_views' , $updaterT );
break ;
case 'component_custom_admin_views' :
2018-03-02 01:37:04 +00:00
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
2017-10-29 16:07:37 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'addcustom_admin_views' => 'customadminview'
);
2017-10-29 16:07:37 +00:00
// update the repeatable fields
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
// subform fields to target
$updaterT = array (
2018-03-27 09:57:16 +00:00
// subformfield => array( field => type_value )
'addcustom_admin_views' => array ( 'customadminview' => 'custom_admin_view' , 'adminviews' => 'admin_view' , 'before' => 'admin_view' )
);
2017-10-29 16:07:37 +00:00
// update the subform ids
$this -> updateSubformsIDs ( $item , 'component_custom_admin_views' , $updaterT );
break ;
case 'component_updates' :
2018-03-02 01:37:04 +00:00
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
2017-10-29 16:07:37 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'version_update' => 'version'
);
2017-10-29 16:07:37 +00:00
// update the repeatable fields
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
break ;
case 'component_mysql_tweaks' :
2018-03-02 01:37:04 +00:00
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
2017-10-29 16:07:37 +00:00
// repeatable fields to update
$updaterR = array (
2018-04-20 21:14:49 +00:00
// repeatablefield => checker
'sql_tweak' => 'adminview'
);
2017-10-29 16:07:37 +00:00
// update the repeatable fields
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
// subform fields to target
$updaterT = array (
2018-03-27 09:57:16 +00:00
// subformfield => array( field => type_value )
'sql_tweak' => array ( 'adminview' => 'admin_view' )
);
2017-10-29 16:07:37 +00:00
// update the subform ids
$this -> updateSubformsIDs ( $item , 'component_mysql_tweaks' , $updaterT );
break ;
case 'component_custom_admin_menus' :
2018-03-02 01:37:04 +00:00
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
2017-10-29 16:07:37 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'addcustommenus' => 'name'
);
2017-10-29 16:07:37 +00:00
// update the repeatable fields
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
// subform fields to target
$updaterT = array (
2018-03-27 09:57:16 +00:00
// subformfield => array( field => type_value )
'addcustommenus' => array ( 'before' => 'admin_view' )
);
2017-10-29 16:07:37 +00:00
// update the subform ids
$this -> updateSubformsIDs ( $item , 'component_custom_admin_menus' , $updaterT );
break ;
case 'component_config' :
2018-03-02 01:37:04 +00:00
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
2017-10-29 16:07:37 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'addconfig' => 'field'
);
2017-10-29 16:07:37 +00:00
// update the repeatable fields
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
// subform fields to target
$updaterT = array (
2018-03-27 09:57:16 +00:00
// subformfield => array( field => type_value )
'addconfig' => array ( 'field' => 'field' )
);
2017-10-29 16:07:37 +00:00
// update the subform ids
$this -> updateSubformsIDs ( $item , 'component_config' , $updaterT );
break ;
case 'component_dashboard' :
2018-03-02 01:37:04 +00:00
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
2017-10-29 16:07:37 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'dashboard_tab' => 'name'
);
2017-10-29 16:07:37 +00:00
// update the repeatable fields
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
break ;
2019-02-15 22:03:21 +00:00
case 'component_placeholders' :
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
break ;
2019-12-07 01:39:16 +00:00
case 'component_modules' :
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
// subform fields to target
$updaterT = array (
// subformfield => array( field => type_value )
'addjoomla_modules' => array ( 'module' => 'joomla_module' )
);
// update the subform ids
$this -> updateSubformsIDs ( $item , 'component_modules' , $updaterT );
break ;
2019-07-19 02:17:15 +00:00
case 'component_plugins' :
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
// subform fields to target
$updaterT = array (
// subformfield => array( field => type_value )
'addjoomla_plugins' => array ( 'plugin' => 'joomla_plugin' )
);
// update the subform ids
$this -> updateSubformsIDs ( $item , 'component_plugins' , $updaterT );
break ;
2017-10-29 16:07:37 +00:00
case 'component_files_folders' :
2018-03-02 01:37:04 +00:00
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_component ID where needed
$item = $this -> setNewID ( $item , 'joomla_component' , 'joomla_component' , $type );
}
2017-10-29 16:07:37 +00:00
// repeatable fields to update
$updaterR = array (
2018-03-27 09:57:16 +00:00
// repeatablefield => checker
'addfiles' => 'file' ,
'addfolders' => 'folder'
);
2017-10-29 16:07:37 +00:00
// update the repeatable fields
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
2017-03-27 12:38:51 +00:00
break ;
2019-12-07 01:39:16 +00:00
case 'joomla_module' :
// update the custom_get
$item = $this -> setNewID ( $item , 'custom_get' , 'dynamic_get' , $type );
// if we can't merge add postfix to name
if ( $this -> postfix )
{
$item -> system_name = $item -> system_name . $this -> postfix ;
}
// subform fields to target
$updaterT = array (
// subformfield => array( field => type_value )
'fields' => array ( 'field' => 'field' )
);
// update the subform ids
$this -> updateSubformsIDs ( $item , 'joomla_module' , $updaterT );
break ;
case 'joomla_module_files_folders_urls' :
case 'joomla_module_updates' :
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_module ID where needed
$item = $this -> setNewID ( $item , 'joomla_module' , 'joomla_module' , $type );
}
break ;
2019-08-12 21:30:31 +00:00
case 'joomla_plugin_group' :
// diverged id already updated
if ( ! $diverged )
{
// update the class_extends ID where needed
$item = $this -> setNewID ( $item , 'class_extends' , 'class_extends' , $type );
}
break ;
case 'class_method' :
case 'class_property' :
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_plugin_group ID where needed
$item = $this -> setNewID ( $item , 'joomla_plugin_group' , 'joomla_plugin_group' , $type );
}
break ;
case 'joomla_plugin' :
// diverged id already updated
if ( ! $diverged )
{
// update the class_extends ID where needed
$item = $this -> setNewID ( $item , 'class_extends' , 'class_extends' , $type );
// update the joomla_plugin_group ID where needed
$item = $this -> setNewID ( $item , 'joomla_plugin_group' , 'joomla_plugin_group' , $type );
}
// if we can't merge add postfix to name
if ( $this -> postfix )
{
$item -> system_name = $item -> system_name . $this -> postfix ;
}
// subform fields to target
$updaterT = array (
// subformfield => array( field => type_value )
'fields' => array ( 'field' => 'field' ),
'property_selection' => array ( 'property' => 'class_property' ),
'method_selection' => array ( 'method' => 'class_method' )
);
// update the subform ids
$this -> updateSubformsIDs ( $item , 'joomla_plugin' , $updaterT );
break ;
case 'joomla_plugin_files_folders_urls' :
case 'joomla_plugin_updates' :
// diverged id already updated
if ( ! $diverged )
{
// update the joomla_plugin ID where needed
$item = $this -> setNewID ( $item , 'joomla_plugin' , 'joomla_plugin' , $type );
}
break ;
2021-12-21 14:44:50 +00:00
case 'power' :
// update the powers after.... since no power is yet found
$this -> updateAfter [ 'power' ][( int ) $item -> id ] = $action ;
break ;
2017-03-27 12:38:51 +00:00
case 'custom_code' :
// update the component ID where needed
2017-10-20 16:17:46 +00:00
$item = $this -> setNewID ( $item , 'component' , 'joomla_component' , $type );
2017-03-27 12:38:51 +00:00
break ;
2017-04-06 21:40:22 +00:00
case 'language_translation' :
2020-04-03 18:45:48 +00:00
$langKeys = array (
array ( 'target' => 'components' , 'parent' => 'joomla_component' , 'local' => 'localComponents' ),
array ( 'target' => 'modules' , 'parent' => 'joomla_module' , 'local' => 'localModules' ),
array ( 'target' => 'plugins' , 'parent' => 'joomla_plugin' , 'local' => 'localPlugins' )
);
// we have a few to check so we loop them
foreach ( $langKeys as $lang )
2017-04-06 21:40:22 +00:00
{
2020-04-03 18:45:48 +00:00
// update the target ID where needed
$item = $this -> setNewID ( $item , $lang [ 'target' ], 'joomla_component' , $type );
// load the local targets if found
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> { $lang [ 'local' ]}) && JsonHelper :: check ( $item -> { $lang [ 'local' ]}))
2017-04-06 21:40:22 +00:00
{
2020-04-03 18:45:48 +00:00
$targets = array ();
2023-02-27 12:27:41 +00:00
if ( isset ( $item -> { $lang [ 'target' ]}) && JsonHelper :: check ( $item -> { $lang [ 'target' ]}))
2017-04-06 21:40:22 +00:00
{
2020-04-03 18:45:48 +00:00
$targets = json_decode ( $item -> { $lang [ 'target' ]}, true );
2017-04-06 21:40:22 +00:00
}
2020-04-03 18:45:48 +00:00
$localComponents = json_decode ( $item -> { $lang [ 'local' ]}, true );
foreach ( $localComponents as $lid )
2017-04-06 21:40:22 +00:00
{
2020-04-03 18:45:48 +00:00
if ( ! is_numeric ( $lid ))
{
continue ;
}
// add if not already there
if ( ! in_array ( $lid , $targets ))
{
$targets [] = $lid ;
}
2017-04-06 21:40:22 +00:00
}
}
2020-04-03 18:45:48 +00:00
// remove the localComponents
if ( isset ( $item -> { $lang [ 'local' ]}))
{
unset ( $item -> { $lang [ 'local' ]});
}
2017-04-06 21:40:22 +00:00
// load it back
2024-03-02 20:10:30 +00:00
if ( isset ( $targets ) && UtilitiesArrayHelper :: check ( $targets ))
2020-04-03 18:45:48 +00:00
{
// load it back
$item -> { $lang [ 'target' ]} = json_encode ( array_values ( $targets ), JSON_FORCE_OBJECT );
}
2017-04-06 21:40:22 +00:00
}
// merge the translations where needed
if ( isset ( $item -> translation ) && isset ( $item -> localTranslation )
2023-02-27 12:27:41 +00:00
&& JsonHelper :: check ( $item -> translation )
&& JsonHelper :: check ( $item -> localTranslation ))
2017-04-06 21:40:22 +00:00
{
2017-09-18 00:18:23 +00:00
$newTranslations = json_decode ( $item -> translation , true );
$localTranslations = json_decode ( $item -> localTranslation , true ); // always the new format
$translations = array ();
$pointer = 0 ;
$checker = array ();
// okay we have the old format lets merge on that basis
if ( isset ( $newTranslations [ 'translation' ]))
2017-04-06 21:40:22 +00:00
{
2017-09-18 00:18:23 +00:00
foreach ( $localTranslations as $value )
2017-04-06 21:40:22 +00:00
{
2017-09-18 00:18:23 +00:00
// only keep old translation if the new does not have this translation & language
if ( ! in_array ( $value [ 'language' ], $newTranslations [ 'language' ]))
{
$translations [ 'translation' . $pointer ] = array ( 'translation' => $value [ 'translation' ], 'language' => $value [ 'language' ]);
$pointer ++ ;
}
}
foreach ( $newTranslations [ 'translation' ] as $nr => $newTrans )
{
// now convert the new translation array
$translations [ 'translation' . $pointer ] = array ( 'translation' => $newTrans , 'language' => $newTranslations [ 'language' ][ $nr ]);
$pointer ++ ;
}
}
// okay this is the new format lets merge on that basis
2024-03-02 20:10:30 +00:00
elseif ( UtilitiesArrayHelper :: check ( $newTranslations ))
2017-09-18 00:18:23 +00:00
{
$translations = $newTranslations ;
$pointer = count ( $translations );
foreach ( $localTranslations as $value )
{
$keepLocal = true ;
foreach ( $newTranslations as $newValue )
{
// only keep old translation if the new does not have this translation & language
if ( $value [ 'language' ] === $newValue [ 'language' ])
{
$keepLocal = false ;
}
}
if ( $keepLocal )
{
$translations [ 'translation' . $pointer ] = array ( 'translation' => $value [ 'translation' ], 'language' => $value [ 'language' ]);
$pointer ++ ;
}
2017-04-06 21:40:22 +00:00
}
}
2017-09-18 00:18:23 +00:00
// okay seem to only have local translations
2024-03-02 20:10:30 +00:00
elseif ( UtilitiesArrayHelper :: check ( $localTranslations ))
2017-09-18 00:18:23 +00:00
{
$translations = $localTranslations ;
}
// only update if we have translations
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $translations ))
2017-09-18 00:18:23 +00:00
{
2017-12-25 12:46:35 +00:00
$item -> translation = json_encode ( $translations , JSON_FORCE_OBJECT );
2017-09-18 00:18:23 +00:00
}
2017-04-06 21:40:22 +00:00
}
2023-02-27 12:27:41 +00:00
elseif ( isset ( $item -> localTranslation ) && JsonHelper :: check ( $item -> localTranslation ))
2017-04-06 21:40:22 +00:00
{
$item -> translation = $item -> localTranslation ;
}
// remove the localTranslation
if ( isset ( $item -> localTranslation ))
{
unset ( $item -> localTranslation );
}
2018-04-20 21:14:49 +00:00
// move entranslation to source
if ( isset ( $item -> entranslation ))
{
$item -> source = $item -> entranslation ;
// also remove the old field
unset ( $item -> entranslation );
}
2017-04-06 21:40:22 +00:00
break ;
2017-10-19 03:53:55 +00:00
case 'admin_fields' :
case 'admin_fields_conditions' :
2018-05-26 10:03:08 +00:00
case 'admin_fields_relations' :
2018-08-24 21:46:41 +00:00
case 'admin_custom_tabs' :
2018-03-02 01:37:04 +00:00
// diverged id already updated
if ( ! $diverged )
{
// update the admin_view ID where needed
$item = $this -> setNewID ( $item , 'admin_view' , 'admin_view' , $type );
}
2018-05-26 10:03:08 +00:00
$updaterR = array ();
2017-10-20 16:17:46 +00:00
// set the updater
2017-10-19 03:53:55 +00:00
if ( 'admin_fields' === $type )
{
// repeatable fields to update
$updaterR = array (
// repeatablefield => checker
'addfields' => 'field'
);
// subform fields to target
$updaterT = array (
// subformfield => field => type_value
'addfields' => array ( 'field' => 'field' )
);
// little tweak... oops
if ( isset ( $item -> addconditions ))
{
unset ( $item -> addconditions );
}
}
2018-05-26 10:03:08 +00:00
elseif ( 'admin_fields_conditions' === $type )
2017-10-19 03:53:55 +00:00
{
// repeatable fields to update
$updaterR = array (
// repeatablefield => checker
'addconditions' => 'target_field'
);
// subform fields to target
$updaterT = array (
// subformfield => field => type_value
'addconditions' => array ( 'target_field' => 'field' , 'match_field' => 'field' )
);
}
2018-05-26 10:03:08 +00:00
elseif ( 'admin_fields_relations' === $type )
{
// subform fields to target
$updaterT = array (
// subformfield => field => type_value
'addrelations' => array ( 'listfield' => 'field' , 'joinfields' => 'field' )
2018-06-13 20:38:32 +00:00
);
// special fix for custom code
2018-08-23 01:37:42 +00:00
$this -> updateAfter [ 'relations' ][( int ) $item -> id ] = $action ; // addrelations->set
2018-05-26 10:03:08 +00:00
}
2017-10-19 03:53:55 +00:00
// update the repeatable fields
2024-03-02 20:10:30 +00:00
if ( isset ( $updaterR ) && UtilitiesArrayHelper :: check ( $updaterR ))
2018-05-26 10:03:08 +00:00
{
$item = ComponentbuilderHelper :: convertRepeatableFields ( $item , $updaterR );
}
2017-10-19 03:53:55 +00:00
// update the subform ids
2024-03-02 20:10:30 +00:00
if ( isset ( $updaterT ) && UtilitiesArrayHelper :: check ( $updaterT ))
2018-08-24 21:46:41 +00:00
{
$this -> updateSubformsIDs ( $item , $type , $updaterT );
}
2021-12-21 14:44:50 +00:00
break ;
2017-03-27 12:38:51 +00:00
}
2018-07-07 00:12:13 +00:00
// remove all fields/columns not part of the current table
$this -> removingFields ( $type , $item );
2017-03-27 12:38:51 +00:00
// final action prep
switch ( $action )
{
case 'update' :
// set values to follow the update conventions
if ( isset ( $item -> created_by ))
{
unset ( $item -> created_by );
}
2017-08-23 20:38:09 +00:00
$item -> modified_by = $this -> user -> id ;
$item -> modified = $this -> today ;
2017-03-27 12:38:51 +00:00
// return the item
return $item ;
break ;
case 'add' :
// remove the ID
2017-10-20 16:17:46 +00:00
if ( isset ( $item -> id ))
{
unset ( $item -> id );
}
2017-03-27 12:38:51 +00:00
// set values to follow the adding conventions
2017-08-23 20:38:09 +00:00
$item -> created_by = $this -> user -> id ;
$item -> modified_by = $this -> user -> id ;
$item -> modified = $this -> today ;
2017-03-27 12:38:51 +00:00
// return the item
return $item ;
break ;
}
return false ;
}
2018-07-07 00:12:13 +00:00
/**
* remove all fields / columns not part of the current table
*
* @ param string $type The table this item belongs to
* @ param object $item The item to clean
*
* @ return viod
*/
2023-02-27 12:27:41 +00:00
private function removingFields ( $type , & $item )
2018-07-07 00:12:13 +00:00
{
// get the columns
$columns = $this -> getTableColumns ( " #__componentbuilder_ " . $type );
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $columns ))
2018-07-07 00:12:13 +00:00
{
foreach ( $item as $name => $value )
{
if ( ! isset ( $columns [ $name ]))
{
// we must show a warning that this field was not imported (but just once)
if ( ! isset ( $this -> fieldImportErrors [ $type . $name ]))
{
2023-02-27 12:27:41 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_FIELD_BSB_NOT_FOUND_IN_LOCAL_DATABASE_TABLE_S_SO_IMPORTED_OF_ITS_VALUES_FAILED_PLEASE_UPDATE_YOUR_JCB_INSTALL_AND_TRY_AGAIN' , $name , '#__componentbuilder_' . $type ), 'warning' );
2018-07-07 00:12:13 +00:00
// make sure the message is not loaded again
$this -> fieldImportErrors [ $type . $name ] = true ;
}
// remove the field & value
unset ( $item -> { $name });
}
}
}
}
/**
* get table columns
*
* @ param string $table The table
*
* @ return array
*/
2023-02-27 12:27:41 +00:00
private function getTableColumns ( $table )
2018-07-07 00:12:13 +00:00
{
// check if the columns are in memory
if ( ! isset ( $this -> tableColumns [ $table ]))
{
// get the columns
$this -> tableColumns [ $table ] = $this -> _db -> getTableColumns ( $table );
}
return $this -> tableColumns [ $table ];
}
2017-10-19 03:53:55 +00:00
/**
* Set the data that should be moved
*
* @ param array / json $values The values / data to move
* @ param string $table The table to move the values to
* @ param string $type The type of values
* @ param array $getters The get values used to anchor the values to the new table
*
* @ return bool
*/
2023-02-27 12:27:41 +00:00
private function setDivergedDataMover ( $values , $table , $type , $getters )
2017-10-19 03:53:55 +00:00
{
// we need to move this to the new $table based on anchors
2024-03-02 20:10:30 +00:00
if ( UtilitiesArrayHelper :: check ( $getters ))
2017-10-19 03:53:55 +00:00
{
if ( ! isset ( $this -> divergedDataMover [ $table ]))
{
$this -> divergedDataMover [ $table ] = array ();
}
// set unique key
$uniqueKey = md5 ( serialize ( $getters ));
if ( ! isset ( $this -> divergedDataMover [ $table ][ $uniqueKey ]))
{
2024-03-02 20:10:30 +00:00
$this -> divergedDataMover [ $table ][ $uniqueKey ] = new \stdClass ;
2017-10-19 03:53:55 +00:00
foreach ( $getters as $name => $value )
{
$this -> divergedDataMover [ $table ][ $uniqueKey ] -> { $name } = $value ;
}
}
// add the data to the mover
$this -> divergedDataMover [ $table ][ $uniqueKey ] -> { $type } = $values ;
2018-03-24 01:36:07 +00:00
// display more import info
if ( $this -> moreInfo )
{
2024-03-02 20:10:30 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_WE_SUCCESSFULLY_MOVED_BSB' , UtilitiesStringHelper :: safe ( $type , 'Ww' ) . ' to (' . UtilitiesStringHelper :: safe ( $table , 'w' ) . ')' ), 'success' );
2018-03-24 01:36:07 +00:00
}
2017-10-19 03:53:55 +00:00
// success
return true ;
}
2024-03-02 20:10:30 +00:00
$this -> app -> enqueueMessage ( Text :: sprintf ( 'COM_COMPONENTBUILDER_WE_FAILED_TO_MOVE_BSB' , UtilitiesStringHelper :: safe ( $type , 'Ww' ) . ' to (' . UtilitiesStringHelper :: safe ( $table , 'w' ) . ')' ), 'warning' );
2017-10-19 03:53:55 +00:00
// failure
return false ;
}
2017-03-31 21:28:16 +00:00
/**
2017-09-18 02:20:50 +00:00
* Check if a field has multiple fields
2017-03-31 21:28:16 +00:00
*
* @ param string $typeID The type ID
*
* @ return bool true on success
*
*/
2023-02-27 12:27:41 +00:00
private function checkMultiFields ( $typeID )
2017-03-31 21:28:16 +00:00
{
2017-09-18 02:20:50 +00:00
if ( isset ( $this -> isMultiple [ $typeID ]))
2017-03-31 21:28:16 +00:00
{
2017-09-18 02:20:50 +00:00
return $this -> isMultiple [ $typeID ];
2017-03-31 21:28:16 +00:00
}
2021-12-21 14:44:50 +00:00
elseif (( $type = $this -> getFieldType ( $typeID )) !== false )
2017-03-31 21:28:16 +00:00
{
2017-09-18 02:20:50 +00:00
if ( 'repeatable' === $type || 'subform' === $type )
2017-03-31 21:28:16 +00:00
{
2017-09-18 02:20:50 +00:00
$this -> isMultiple [ $typeID ] = true ;
}
else
{
$this -> isMultiple [ $typeID ] = false ;
2017-03-31 21:28:16 +00:00
}
2017-09-18 02:20:50 +00:00
return $this -> isMultiple [ $typeID ];
2017-03-31 21:28:16 +00:00
}
return false ;
}
/**
* Get the field type
*
* @ param string $id The field type id
*
* @ return string field type
*
*/
2023-02-27 12:27:41 +00:00
private function getFieldType ( $id )
2017-03-31 21:28:16 +00:00
{
if ( ! isset ( $this -> fieldTypes [ $id ]))
{
2023-02-27 12:27:41 +00:00
$properties = GetHelper :: var ( 'fieldtype' , $id , 'id' , 'properties' );
if ( JsonHelper :: check ( $properties ))
2017-03-31 21:28:16 +00:00
{
$properties = json_decode ( $properties , true );
2017-10-06 14:53:22 +00:00
// check if this is old values for repeatable fields
if ( isset ( $properties [ 'name' ]))
{
2017-10-29 11:03:06 +00:00
$properties = ComponentbuilderHelper :: convertRepeatable ( $properties , 'properties' );
2017-10-06 14:53:22 +00:00
}
// now check to find type
2017-09-18 02:20:50 +00:00
foreach ( $properties as $property )
2017-03-31 21:28:16 +00:00
{
2017-09-18 02:20:50 +00:00
if ( 'type' === $property [ 'name' ])
2017-03-31 21:28:16 +00:00
{
2024-03-02 20:10:30 +00:00
if ( isset ( $property [ 'example' ]) && UtilitiesStringHelper :: check ( $property [ 'example' ]))
2017-03-31 21:28:16 +00:00
{
2017-09-18 02:20:50 +00:00
$this -> fieldTypes [ $id ] = $property [ 'example' ];
break ;
2017-03-31 21:28:16 +00:00
}
}
}
}
// if not found
2023-02-27 12:27:41 +00:00
if ( ! isset ( $this -> fieldTypes [ $id ]) && $name = GetHelper :: var ( 'fieldtype' , $id , 'id' , 'name' ))
2017-03-31 21:28:16 +00:00
{
2024-03-02 20:10:30 +00:00
$this -> fieldTypes [ $id ] = UtilitiesStringHelper :: safe ( $name );
2017-03-31 21:28:16 +00:00
}
}
// return the type
if ( isset ( $this -> fieldTypes [ $id ]))
{
return $this -> fieldTypes [ $id ];
}
return false ;
}
2017-03-27 12:38:51 +00:00
/**
* Update the local item
*
2017-10-16 17:14:23 +00:00
* @ param object $item The item to update
* @ param string $type The type of values
* @ param bool $canState The switch to set state
2017-03-27 12:38:51 +00:00
*
* @ return mixed false on failure
* ID int on success
*
**/
2023-02-27 12:27:41 +00:00
private function updateLocalItem ( & $item , $type , & $canState )
2017-03-27 12:38:51 +00:00
{
// prep the item
2017-08-23 20:38:09 +00:00
if ( $update = $this -> prepItem ( $item , $type , 'update' ))
2017-03-27 12:38:51 +00:00
{
// remove the published state if not allowed to edit it
if ( ! $canState && isset ( $update -> published ))
{
unset ( $update -> published );
}
// update the item
2017-08-23 20:38:09 +00:00
if ( $result = $this -> _db -> updateObject ( '#__componentbuilder_' . $type , $update , 'id' ))
2017-03-27 12:38:51 +00:00
{
2018-08-23 01:37:42 +00:00
// return success
2017-03-27 12:38:51 +00:00
return $update -> id ;
}
}
return false ;
}
/**
* add the local item
*
2018-03-02 01:37:04 +00:00
* @ param object $item The item to update
* @ param string $type The type of values
* @ param bool $diverged The diverged data switch
2017-03-27 12:38:51 +00:00
*
* @ return mixed false on failure
* ID int on success
*
**/
2023-02-27 12:27:41 +00:00
private function addLocalItem ( & $item , $type , $diverged = false )
2017-03-27 12:38:51 +00:00
{
// prep the item
2018-03-02 01:37:04 +00:00
if ( $add = $this -> prepItem ( $item , $type , 'add' , $diverged ))
2017-03-27 12:38:51 +00:00
{
// insert/add the item
2017-08-23 20:38:09 +00:00
if ( $result = $this -> _db -> insertObject ( '#__componentbuilder_' . $type , $add ))
2017-03-27 12:38:51 +00:00
{
2017-08-23 20:38:09 +00:00
$aId = $this -> _db -> insertid ();
2017-03-27 12:38:51 +00:00
// make sure the access of asset is set
ComponentbuilderHelper :: setAsset ( $aId , $type );
// set new ID
return $aId ;
}
}
return false ;
}
/**
* Get the local item
*
2018-03-02 01:37:04 +00:00
* @ param object $item The item to get
* @ param string $type The type of values
* @ param bool $retry The retry switch
* @ param bool $get The query get switch
* @ param bool $diverged The diverged data switch
2017-03-27 12:38:51 +00:00
*
* @ return mixed false on failure
2017-08-23 20:38:09 +00:00
* ID int on success
2017-03-27 12:38:51 +00:00
*
**/
2023-02-27 12:27:41 +00:00
private function getLocalItem ( $item , $type , $retry = false , $get = 1 , $diverged = false )
2017-03-27 12:38:51 +00:00
{
2017-08-23 20:38:09 +00:00
$query = $this -> _db -> getQuery ( true );
2017-05-20 07:36:26 +00:00
$query -> select ( 'a.*' );
2017-08-23 20:38:09 +00:00
$query -> from ( $this -> _db -> quoteName ( '#__componentbuilder_' . $type , 'a' ));
2017-10-19 03:53:55 +00:00
// only run query if where is set
$runQuery = false ;
2021-08-11 12:15:35 +00:00
// we first try to get the item by GUID
if ( $get == 1 && isset ( $item -> guid ))
{
2023-02-27 12:27:41 +00:00
if (( $item = GuidHelper :: item ( $item -> guid , $type , 'a.*' )) !== false )
2021-08-11 12:15:35 +00:00
{
return $item ;
}
// check if we should continue the search
2021-12-21 14:44:50 +00:00
// we only link powers by GUID
elseif ( $this -> importGuidOnly == 1 || $type === 'power' )
2021-08-11 12:15:35 +00:00
{
return false ;
}
}
// continue search
2018-04-20 21:14:49 +00:00
if ( $get == 1 && isset ( $item -> created ) && isset ( $item -> id ) && ( isset ( $item -> name ) || isset ( $item -> system_name )))
2017-03-27 12:38:51 +00:00
{
2018-04-20 21:14:49 +00:00
// to prefent crazy mismatch with old IDs (I know very weired)
if ( isset ( $item -> system_name ))
{
$query -> where ( $this -> _db -> quoteName ( 'a.system_name' ) . ' = ' . $this -> _db -> quote ( $item -> system_name ));
}
// to prefent crazy mismatch with old IDs (I know very weired)
if ( isset ( $item -> name ))
{
$query -> where ( $this -> _db -> quoteName ( 'a.name' ) . ' = ' . $this -> _db -> quote ( $item -> name ));
}
// load the created and id
2017-08-23 20:38:09 +00:00
$query -> where ( $this -> _db -> quoteName ( 'a.created' ) . ' = ' . $this -> _db -> quote ( $item -> created ));
$query -> where ( $this -> _db -> quoteName ( 'a.id' ) . ' = ' . ( int ) $item -> id );
2018-06-13 20:38:32 +00:00
// set to run query
2017-10-19 03:53:55 +00:00
$runQuery = true ;
2017-03-27 12:38:51 +00:00
}
2024-03-02 20:10:30 +00:00
elseif ( UtilitiesArrayHelper :: check ( $get ))
2017-03-27 12:38:51 +00:00
{
foreach ( $get as $field )
{
2018-06-13 20:38:32 +00:00
// set to run query
$runQuery = true ;
2017-10-19 03:53:55 +00:00
if ( isset ( $item -> { $field }))
2017-03-27 12:38:51 +00:00
{
2017-04-01 13:59:54 +00:00
// set the value
2017-10-19 03:53:55 +00:00
$value = $item -> { $field };
2017-04-01 13:59:54 +00:00
// check if we have special value
2024-03-02 20:10:30 +00:00
if ( $this -> specialValue && UtilitiesArrayHelper :: check ( $this -> specialValue ) && isset ( $this -> specialValue [ $field ]))
2017-03-27 12:38:51 +00:00
{
2017-04-01 13:59:54 +00:00
$value = $this -> specialValue [ $field ];
2017-03-27 12:38:51 +00:00
}
2017-04-01 13:59:54 +00:00
// load to query
if ( is_numeric ( $value ) && is_int ( $value ))
2017-03-27 12:38:51 +00:00
{
2017-08-23 20:38:09 +00:00
$query -> where ( $this -> _db -> quoteName ( 'a.' . $field ) . ' = ' . ( int ) $value );
2017-03-27 12:38:51 +00:00
}
2017-04-01 13:59:54 +00:00
elseif ( is_numeric ( $value ) && is_float ( $value ))
2017-03-27 12:38:51 +00:00
{
2017-08-23 20:38:09 +00:00
$query -> where ( $this -> _db -> quoteName ( 'a.' . $field ) . ' = ' . ( float ) $value );
2017-04-01 13:59:54 +00:00
}
2024-03-02 20:10:30 +00:00
elseif ( UtilitiesStringHelper :: check ( $value )) // do not allow empty strings (since it could be major mis match)
2017-04-01 13:59:54 +00:00
{
2017-08-23 20:38:09 +00:00
$query -> where ( $this -> _db -> quoteName ( 'a.' . $field ) . ' = ' . $this -> _db -> quote ( $value ));
2017-03-27 12:38:51 +00:00
}
else
{
2018-06-13 20:38:32 +00:00
// do not run query
$runQuery = false ;
2017-03-27 12:38:51 +00:00
}
}
else
{
2018-06-13 20:38:32 +00:00
// do not run query
$runQuery = false ;
2017-03-27 12:38:51 +00:00
}
}
}
2018-04-20 21:14:49 +00:00
elseif ( isset ( $item -> { $get }))
2017-03-27 12:38:51 +00:00
{
2018-06-13 20:38:32 +00:00
// set to run query
$runQuery = true ;
2017-04-01 13:59:54 +00:00
// set the value
2017-10-19 03:53:55 +00:00
$value = $item -> { $get };
2017-04-01 13:59:54 +00:00
// check if we have special value
2024-03-02 20:10:30 +00:00
if ( $this -> specialValue && UtilitiesArrayHelper :: check ( $this -> specialValue ) && isset ( $this -> specialValue [ $get ]))
2017-04-01 13:59:54 +00:00
{
$value = $this -> specialValue [ $get ];
}
// load to query
2018-04-20 21:14:49 +00:00
if ( is_numeric ( $value ) && is_int ( $value ))
2017-03-27 12:38:51 +00:00
{
2017-08-23 20:38:09 +00:00
$query -> where ( $this -> _db -> quoteName ( 'a.' . $get ) . ' = ' . ( int ) $value );
2017-03-27 12:38:51 +00:00
}
2018-04-20 21:14:49 +00:00
elseif ( is_numeric ( $value ) && is_float ( $value ))
2017-03-27 12:38:51 +00:00
{
2017-08-23 20:38:09 +00:00
$query -> where ( $this -> _db -> quoteName ( 'a.' . $get ) . ' = ' . ( float ) $value );
2017-03-27 12:38:51 +00:00
}
2024-03-02 20:10:30 +00:00
elseif ( UtilitiesStringHelper :: check ( $value )) // do not allow empty strings (since it could be major mis match)
2018-04-20 21:14:49 +00:00
{
$query -> where ( $this -> _db -> quoteName ( 'a.' . $get ) . ' = ' . $this -> _db -> quote ( $value ));
}
2017-03-27 12:38:51 +00:00
else
{
2018-06-13 20:38:32 +00:00
$runQuery = false ; // really not needed but who knows for sure...
2017-03-27 12:38:51 +00:00
}
}
2017-10-19 03:53:55 +00:00
// since where has been set run the query
if ( $runQuery )
2017-03-27 12:38:51 +00:00
{
2017-10-19 03:53:55 +00:00
// see if we get an item
$this -> _db -> setQuery ( $query );
$this -> _db -> execute ();
if ( $this -> _db -> getNumRows ())
{
return $this -> _db -> loadObject ();
}
2017-03-27 12:38:51 +00:00
}
2017-10-19 03:53:55 +00:00
// retry to get the item
if ( $retry )
2017-03-27 12:38:51 +00:00
{
$retryAgain = false ;
2017-04-01 13:59:54 +00:00
$this -> specialValue = false ;
2017-03-27 12:38:51 +00:00
// set the getter
switch ( $type )
{
2017-10-16 17:14:23 +00:00
case 'admin_fields' :
case 'admin_fields_conditions' :
2018-05-26 10:03:08 +00:00
case 'admin_fields_relations' :
2018-08-24 21:46:41 +00:00
case 'admin_custom_tabs' :
2017-10-16 17:14:23 +00:00
// get by admin_view (since there should only be one of each name)
2017-10-19 03:53:55 +00:00
$getter = array ( 'admin_view' );
$this -> specialValue = array ();
2018-03-02 01:37:04 +00:00
// Yet if diverged it makes sense that the ID is updated.
if ( $diverged )
{
$this -> specialValue [ 'admin_view' ] = ( int ) $item -> admin_view ;
}
elseif ( isset ( $this -> newID [ 'admin_view' ][( int ) $item -> admin_view ]))
{
$this -> specialValue [ 'admin_view' ] = $this -> newID [ 'admin_view' ][( int ) $item -> admin_view ];
}
2018-04-20 21:14:49 +00:00
// (TODO) I have seen this happen, seems dangerous!
else
{
return false ;
}
2017-10-16 17:14:23 +00:00
break ;
2018-03-30 09:32:22 +00:00
case 'validation_rule' :
2017-03-27 12:38:51 +00:00
case 'fieldtype' :
// get by name (since there should only be one of each name)
$getter = 'name' ;
break ;
case 'field' :
// get by name and xml to target correct field
2017-04-01 13:59:54 +00:00
if ( $retry == 2 )
{
2018-06-13 20:38:32 +00:00
// get by name + xml...
2017-04-01 13:59:54 +00:00
$getter = array ( 'name' , 'datatype' , 'store' , 'indexes' , 'null_switch' , 'xml' );
2018-06-13 20:38:32 +00:00
$retryAgain = 3 ;
}
elseif ( $retry == 3 )
{
// get by name + created...
$getter = array ( 'name' , 'datatype' , 'created' );
2017-04-01 13:59:54 +00:00
}
else
{
2018-06-13 20:38:32 +00:00
// get by name + xml or type..
2017-04-01 13:59:54 +00:00
$getter = array ( 'name' , 'datatype' , 'store' , 'indexes' , 'null_switch' );
// lets try to add the fieldtype
2017-10-20 16:17:46 +00:00
if ( isset ( $item -> fieldtype ) && is_numeric ( $item -> fieldtype ) && $item -> fieldtype > 0 && isset ( $this -> newID [ 'fieldtype' ][( int ) $item -> fieldtype ]) && $this -> newID [ 'fieldtype' ][( int ) $item -> fieldtype ] > 0 )
2017-04-01 13:59:54 +00:00
{
$getter [] = 'fieldtype' ;
$this -> specialValue = array ();
2017-10-20 16:17:46 +00:00
$this -> specialValue [ 'fieldtype' ] = $this -> newID [ 'fieldtype' ][( int ) $item -> fieldtype ];
2017-04-01 13:59:54 +00:00
$retryAgain = 2 ;
}
else
{
$getter [] = 'xml' ;
2018-06-13 20:38:32 +00:00
$retryAgain = 3 ;
2017-04-01 13:59:54 +00:00
}
}
2017-03-27 12:38:51 +00:00
break ;
case 'site_view' :
case 'custom_admin_view' :
// get by name, system_name and codename
2017-04-01 13:59:54 +00:00
$getter = array ( 'name' , 'system_name' , 'codename' );
// lets try to add the main_get
2017-10-20 16:17:46 +00:00
if ( isset ( $item -> main_get ) && is_numeric ( $item -> main_get ) && $item -> main_get > 0 && isset ( $this -> newID [ 'dynamic_get' ][( int ) $item -> main_get ]) && $this -> newID [ 'dynamic_get' ][( int ) $item -> main_get ] > 0 )
2017-04-01 13:59:54 +00:00
{
$getter [] = 'main_get' ;
$this -> specialValue = array ();
2017-10-20 16:17:46 +00:00
$this -> specialValue [ 'main_get' ] = $this -> newID [ 'dynamic_get' ][( int ) $item -> main_get ];
2017-04-01 13:59:54 +00:00
}
2017-03-27 12:38:51 +00:00
break ;
case 'template' :
case 'layout' :
// get by code name (since there should only be one)
$getter = 'alias' ;
break ;
2017-03-31 21:28:16 +00:00
case 'snippet' :
// get by snippet (since there should only be one snippet like that)
if ( $retry == 2 )
{
$getter = array ( 'name' , 'snippet' , 'url' , 'type' , 'heading' );
}
else
{
// get by id name..
$getter = array ( 'id' , 'name' , 'snippet' , 'url' , 'type' , 'heading' );
$retryAgain = 2 ;
}
break ;
2019-03-04 12:47:28 +00:00
case 'placeholder' :
// search for placeholder (since there should only be one)
$getter = 'target' ;
break ;
2017-03-27 12:38:51 +00:00
case 'custom_code' :
2018-08-19 20:15:43 +00:00
// search for custom code
$getter = array ( 'comment_type' , 'target' );
2018-08-30 16:33:30 +00:00
$this -> specialValue = array ();
// search for Hash (automation)
if ( isset ( $item -> target ) && $item -> target == 1 )
2017-03-27 12:38:51 +00:00
{
$getter [] = 'path' ;
2018-08-30 16:33:30 +00:00
$getter [] = 'hashtarget' ;
$getter [] = 'component' ;
// Yet if diverged it makes sense that the ID is updated.
if ( $diverged )
{
// set a special value
$this -> specialValue [ 'component' ] = ( int ) $item -> component ;
}
elseif ( isset ( $this -> newID [ 'joomla_component' ][( int ) $item -> component ]))
{
// set a special value
$this -> specialValue [ 'component' ] = $this -> newID [ 'joomla_component' ][( int ) $item -> component ];
}
// (TODO) I have seen this happen, seems dangerous!
else
{
return false ;
}
2017-03-27 12:38:51 +00:00
}
2018-08-30 16:33:30 +00:00
// search for JCB (manual)
elseif ( isset ( $item -> target ) && $item -> target == 2 )
2017-03-27 12:38:51 +00:00
{
$getter [] = 'function_name' ;
}
2018-08-30 16:33:30 +00:00
else
2017-03-27 12:38:51 +00:00
{
2018-08-30 16:33:30 +00:00
return false ;
2017-03-27 12:38:51 +00:00
}
break ;
case 'dynamic_get' :
if ( $retry == 2 )
{
// get by name ...
$getter = array ( 'name' , 'gettype' , 'main_source' ); // risky will look at this again
// add some more advanced search
2024-03-02 20:10:30 +00:00
if ( isset ( $item -> main_source ) && $item -> main_source == 1 && isset ( $item -> view_selection ) && UtilitiesStringHelper :: check ( $item -> view_selection ))
2017-03-27 12:38:51 +00:00
{
$getter [] = 'view_selection' ;
}
2024-03-02 20:10:30 +00:00
elseif ( isset ( $item -> main_source ) && $item -> main_source == 2 && isset ( $item -> db_selection ) && UtilitiesStringHelper :: check ( $item -> db_selection ))
2017-03-27 12:38:51 +00:00
{
$getter [] = 'db_selection' ;
}
2024-03-02 20:10:30 +00:00
elseif ( isset ( $item -> main_source ) && $item -> main_source == 3 && isset ( $item -> php_custom_get ) && UtilitiesStringHelper :: check ( $item -> php_custom_get ))
2017-03-27 12:38:51 +00:00
{
$getter [] = 'php_custom_get' ;
}
// add some extra
2024-03-02 20:10:30 +00:00
if ( isset ( $item -> getcustom ) && UtilitiesStringHelper :: check ( $item -> getcustom ))
2017-03-27 12:38:51 +00:00
{
$getter [] = 'getcustom' ;
}
}
else
{
// get by id name gettype and main_source
$getter = array ( 'id' , 'name' , 'gettype' , 'main_source' ); // risky will look at this again
$retryAgain = 2 ;
}
break ;
case 'admin_view' :
if ( $retry == 2 )
{
// get by name ...
$getter = array ( 'name_list' , 'name_single' , 'short_description' , 'system_name' ); // risky will look at this again
}
else
{
// get by id name ...
$getter = array ( 'id' , 'name_list' , 'name_single' , 'short_description' , 'system_name' ); // risky will look at this again
$retryAgain = 2 ;
}
break ;
case 'joomla_component' :
2018-01-24 12:47:57 +00:00
if ( $retry == 3 )
{
2018-02-27 12:17:38 +00:00
// get by names only
$getter = array ( 'name' , 'name_code' , 'system_name' );
2018-01-24 12:47:57 +00:00
}
elseif ( $retry == 2 )
2017-03-27 12:38:51 +00:00
{
// get by name ...
2018-02-27 12:17:38 +00:00
$getter = array ( 'name' , 'name_code' , 'short_description' , 'author' , 'email' , 'component_version' , 'companyname' , 'system_name' , 'website' , 'bom' , 'copyright' , 'license' );
2018-01-24 12:47:57 +00:00
$retryAgain = 3 ;
2017-03-27 12:38:51 +00:00
}
else
{
// get by id name ...
2018-02-27 12:17:38 +00:00
$getter = array ( 'id' , 'name' , 'name_code' , 'short_description' , 'author' , 'component_version' , 'companyname' , 'system_name' );
2017-03-27 12:38:51 +00:00
$retryAgain = 2 ;
}
break ;
2017-10-29 16:07:37 +00:00
case 'component_admin_views' :
case 'component_site_views' :
case 'component_custom_admin_views' :
case 'component_updates' :
case 'component_mysql_tweaks' :
case 'component_custom_admin_menus' :
case 'component_config' :
case 'component_dashboard' :
2019-02-15 22:03:21 +00:00
case 'component_placeholders' :
2017-10-29 16:07:37 +00:00
case 'component_files_folders' :
2019-12-07 01:39:16 +00:00
case 'component_modules' :
2019-08-12 21:30:31 +00:00
case 'component_plugins' :
2018-04-20 21:14:49 +00:00
// get by joomla_component (since there should only be one of each component)
$getter = array ( 'joomla_component' );
$this -> specialValue = array ();
// Yet if diverged it makes sense that the ID is updated.
if ( $diverged )
{
$this -> specialValue [ 'joomla_component' ] = ( int ) $item -> joomla_component ;
}
elseif ( isset ( $this -> newID [ 'joomla_component' ][( int ) $item -> joomla_component ]))
{
$this -> specialValue [ 'joomla_component' ] = $this -> newID [ 'joomla_component' ][( int ) $item -> joomla_component ];
}
// (TODO) I have seen this happen, seems dangerous!
else
{
return false ;
}
2017-10-29 16:07:37 +00:00
break ;
2017-04-06 21:40:22 +00:00
case 'language_translation' :
2018-04-20 21:14:49 +00:00
// get by source translation since there should just be one
$getter = 'source' ;
if ( isset ( $item -> entranslation ))
{
$item -> source = $item -> entranslation ;
}
2017-04-06 21:40:22 +00:00
break ;
case 'language' :
2019-08-12 21:30:31 +00:00
// get by language tag since there should just be one
$getter = 'langtag' ;
break ;
2019-12-07 01:39:16 +00:00
case 'joomla_module' :
// get
if ( $retry == 3 )
{
// get by names, exteneded and group only
$getter = array ( 'name' , 'system_name' );
}
elseif ( $retry == 2 )
{
// get by description
$getter = array ( 'name' , 'system_name' , 'description' );
$retryAgain = 3 ;
}
else
{
// get by id
$getter = array ( 'id' , 'name' , 'system_name' );
$retryAgain = 2 ;
}
break ;
case 'joomla_module_files_folders_urls' :
case 'joomla_module_updates' :
// get by admin_view (since there should only be one of each name)
$getter = array ( 'joomla_module' );
$this -> specialValue = array ();
// Yet if diverged it makes sense that the ID is updated.
if ( $diverged )
{
$this -> specialValue [ 'joomla_module' ] = ( int ) $item -> joomla_module ;
}
elseif ( isset ( $this -> newID [ 'joomla_module' ][( int ) $item -> joomla_module ]))
{
$this -> specialValue [ 'joomla_module' ] = $this -> newID [ 'joomla_module' ][( int ) $item -> joomla_module ];
}
// (TODO) I have seen this happen, seems dangerous!
else
{
return false ;
}
break ;
2019-08-12 21:30:31 +00:00
case 'joomla_plugin' :
// get
if ( $retry == 3 )
{
// get by names, exteneded and group only
$getter = array ( 'name' , 'system_name' , 'class_extends' , 'joomla_plugin_group' );
}
elseif ( $retry == 2 )
{
// get by description
$getter = array ( 'name' , 'system_name' , 'class_extends' , 'joomla_plugin_group' , 'description' );
$retryAgain = 3 ;
}
else
{
// get by id
$getter = array ( 'id' , 'name' , 'system_name' , 'class_extends' , 'joomla_plugin_group' );
$retryAgain = 2 ;
}
$this -> specialValue = array ();
// Yet if diverged it makes sense that the ID is updated.
if ( $diverged )
{
$this -> specialValue [ 'class_extends' ] = ( int ) $item -> class_extends ;
$this -> specialValue [ 'joomla_plugin_group' ] = ( int ) $item -> joomla_plugin_group ;
}
elseif ( isset ( $this -> newID [ 'class_extends' ][( int ) $item -> class_extends ]) && isset ( $this -> newID [ 'joomla_plugin_group' ][( int ) $item -> joomla_plugin_group ]))
{
$this -> specialValue [ 'class_extends' ] = $this -> newID [ 'class_extends' ][( int ) $item -> class_extends ];
$this -> specialValue [ 'joomla_plugin_group' ] = $this -> newID [ 'joomla_plugin_group' ][( int ) $item -> joomla_plugin_group ];
}
// (TODO) I have seen this happen, seems dangerous!
else
{
return false ;
}
break ;
case 'joomla_plugin_files_folders_urls' :
case 'joomla_plugin_updates' :
// get by admin_view (since there should only be one of each name)
$getter = array ( 'joomla_plugin' );
$this -> specialValue = array ();
// Yet if diverged it makes sense that the ID is updated.
if ( $diverged )
{
$this -> specialValue [ 'joomla_plugin' ] = ( int ) $item -> joomla_plugin ;
}
elseif ( isset ( $this -> newID [ 'joomla_plugin' ][( int ) $item -> joomla_plugin ]))
{
$this -> specialValue [ 'joomla_plugin' ] = $this -> newID [ 'joomla_plugin' ][( int ) $item -> joomla_plugin ];
}
// (TODO) I have seen this happen, seems dangerous!
else
{
return false ;
}
break ;
case 'joomla_plugin_group' :
// get by name since there should just be one
$getter = array ( 'name' , 'class_extends' );
$this -> specialValue = array ();
// Yet if diverged it makes sense that the ID is updated.
if ( $diverged )
{
$this -> specialValue [ 'class_extends' ] = ( int ) $item -> class_extends ;
}
elseif ( isset ( $this -> newID [ 'class_extends' ][( int ) $item -> class_extends ]))
{
$this -> specialValue [ 'class_extends' ] = $this -> newID [ 'class_extends' ][( int ) $item -> class_extends ];
}
// (TODO) I have seen this happen, seems dangerous!
else
{
return false ;
}
break ;
case 'class_extends' :
case 'class_method' :
case 'class_property' :
// get by name since there should just be one
$getter = array ( 'name' , 'extension_type' );
// Yet if diverged it makes sense that the ID is updated.
if ( 'plugins' === $item -> extension_type && isset ( $item -> joomla_plugin_group ))
{
$getter [] = 'joomla_plugin_group' ;
$this -> specialValue = array ();
if ( $diverged )
{
$this -> specialValue [ 'joomla_plugin_group' ] = ( int ) $item -> joomla_plugin_group ;
}
elseif ( isset ( $this -> newID [ 'joomla_plugin_group' ][( int ) $item -> joomla_plugin_group ]))
{
$this -> specialValue [ 'joomla_plugin_group' ] = $this -> newID [ 'joomla_plugin_group' ][( int ) $item -> joomla_plugin_group ];
}
// (TODO) I have seen this happen, seems dangerous!
else
{
return false ;
}
}
2017-04-06 21:40:22 +00:00
break ;
2017-03-27 12:38:51 +00:00
default :
// can't be found so return false
return false ;
break ;
}
// we try again
2017-08-23 20:38:09 +00:00
return $this -> getLocalItem ( $item , $type , $retryAgain , $getter );
2017-03-27 12:38:51 +00:00
}
return false ;
}
2018-03-02 01:37:04 +00:00
/**
* Update constant path with real full path value
*
* @ param string $path The full path
*
* @ return string The updated path
*
*/
2023-02-27 12:27:41 +00:00
private function setFullPath ( $path )
2018-03-02 01:37:04 +00:00
{
return str_replace ( array_keys ( ComponentbuilderHelper :: $constantPaths ), array_values ( ComponentbuilderHelper :: $constantPaths ), $path );
}
/**
* Convert the name to a path
*
* @ param string $path The path name
*
* @ return string The full path *
*/
2023-02-27 12:27:41 +00:00
private function setDynamicPath ( $path )
2018-03-02 01:37:04 +00:00
{
// now convert to path
$path = str_replace ( '__v_d_m__' , '/' , $path );
// add the full path if possible
return str_replace ( '//' , '/' , $this -> setFullPath ( $path ));
2023-02-27 12:27:41 +00:00
}
2021-03-05 03:08:47 +00:00
protected function getAlias ( $name , $type = false )
{
// sanitize the name to an alias
2024-03-02 20:10:30 +00:00
if ( Factory :: getConfig () -> get ( 'unicodeslugs' ) == 1 )
2021-03-05 03:08:47 +00:00
{
2024-03-02 20:10:30 +00:00
$alias = OutputFilter :: stringURLUnicodeSlug ( $name );
2021-03-05 03:08:47 +00:00
}
else
{
2024-03-02 20:10:30 +00:00
$alias = OutputFilter :: stringURLSafe ( $name );
2021-03-05 03:08:47 +00:00
}
// must be a uniqe alias
if ( $type )
{
return $this -> getUniqe ( $alias , 'alias' , $type );
}
return $alias ;
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
/**
* Method to generate a uniqe value .
*
* @ param string $field name .
* @ param string $value data .
* @ param string $type table .
*
* @ return string New value .
*/
protected function getUniqe ( $value , $field , $type )
{
// insure the filed is always uniqe
while ( isset ( $this -> uniqeValueArray [ $type ][ $field ][ $value ]))
{
2024-03-02 20:10:30 +00:00
$value = StringHelper :: increment ( $value , 'dash' );
2021-03-05 03:08:47 +00:00
}
$this -> uniqeValueArray [ $type ][ $field ][ $value ] = $value ;
return $value ;
}
2024-03-02 20:10:30 +00:00
2021-03-05 03:08:47 +00:00
protected function getAliasesUsed ( $table )
{
// Get a db connection.
2024-03-02 20:10:30 +00:00
$db = Factory :: getDbo ();
2021-03-05 03:08:47 +00:00
// first we check if there is a alias column
$columns = $db -> getTableColumns ( '#__componentbuilder_' . $table );
if ( isset ( $columns [ 'alias' ])){
// Create a new query object.
$query = $db -> getQuery ( true );
$query -> select ( $db -> quoteName ( array ( 'alias' )));
$query -> from ( $db -> quoteName ( '#__componentbuilder_' . $table ));
$db -> setQuery ( $query );
$db -> execute ();
if ( $db -> getNumRows ())
{
$aliases = $db -> loadColumn ();
foreach ( $aliases as $alias )
{
$this -> uniqeValueArray [ $table ][ 'alias' ][ $alias ] = $alias ;
}
}
return true ;
}
return false ;
}
}