2016-02-26 02:20:09 +02:00
< ? php
2017-12-15 01:10:47 +02:00
/* --------------------------------------------------------------------------------------------------------| www . vdm . io |------/
__ __ _ _____ _ _ __ __ _ _ _
\ \ / / | | | __ \ | | | | | \ / | | | | | | |
\ \ / / _ _ ___ | | _ | | | | _____ _____ | | ___ _ __ _ __ ___ ___ _ __ | | _ | \ / | ___ | | _ | | __ ___ __ | |
\ \ / / _ ` / __| __| | | | |/ _ \ \ / / _ \ |/ _ \| '_ \| '_ ` _ \ / _ \ '_ \| __| | |\/| |/ _ \ __| ' _ \ / _ \ / _ ` |
\ / ( _ | \__ \ | _ | | __ | | __ / \ V / __ / | ( _ ) | | _ ) | | | | | | __ / | | | | _ | | | | __ / | _ | | | | ( _ ) | ( _ | |
\ / \__ , _ | ___ / \__ | | _____ / \___ | \_ / \___ | _ | \___ /| . __ /| _ | | _ | | _ | \___ | _ | | _ | \__ | | _ | | _ | \___ | \__ | _ | | _ | \___ / \__ , _ |
| |
| _ |
/-------------------------------------------------------------------------------------------------------------------------------/
@ version 2.6 . 0
@ created 30 th April , 2015
@ package Component Builder
@ subpackage compiler . php
@ author Llewellyn van der Merwe < http :// www . vdm . io >
@ my wife Roline van der Merwe < http :// www . vdm . io />
@ copyright Copyright ( C ) 2015. All Rights Reserved
@ license GNU / GPL Version 2 or later - http :// www . gnu . org / licenses / gpl - 2.0 . html
Builds Complex Joomla Components
/----------------------------------------------------------------------------------------------------------------------------- */
2016-02-26 02:20:09 +02:00
// No direct access to this file
defined ( '_JEXEC' ) or die ( 'Restricted access' );
/**
* Get class as the main compilers class
*/
class Get
{
2017-12-15 01:10:47 +02:00
2017-10-26 18:43:51 +02:00
/**
* The app
*
* @ var object
*/
public $app ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Params
*
* @ var object
*/
public $params ;
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* The placeholders
*
* @ var array
*/
public $placeholders = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Compiler Path
*
* @ var object
*/
public $compilerPath ;
2017-12-15 01:10:47 +02:00
2017-02-14 02:33:24 +02:00
/**
* Switch to add custom code placeholders
*
* @ var bool
*/
public $addPlaceholders = false ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Component data
*
* @ var object
*/
public $componentData ;
2017-12-15 01:10:47 +02:00
/* * *********************************************************************************************
* The custom script placeholders - we use the ( xxx ) to avoid detection it should be ( *** )
* ##################################---> PHP/JS <---####################################
2017-02-01 15:17:04 +02:00
*
2017-12-15 01:10:47 +02:00
* New Insert Code = / xxx [ INSERT <> $ $ $ $ ] xxx / / xxx [ / INSERT <> $ $ $ $ ] xxx /
* New Replace Code = / xxx [ REPLACE <> $ $ $ $ ] xxx / / xxx [ / REPLACE <> $ $ $ $ ] xxx /
2017-02-01 15:17:04 +02:00
*
2017-12-15 01:10:47 +02:00
* //////////////////////////////// when JCB adds it back //////////////////////////////////
* JCB Add Inserted Code = / xxx [ INSERTED $ $ $ $ ] xxx //x23x/ /xxx[/INSERTED$$$$]xxx/
* JCB Add Replaced Code = / xxx [ REPLACED $ $ $ $ ] xxx //x25x/ /xxx[/REPLACED$$$$]xxx/
2017-02-01 15:17:04 +02:00
*
2017-12-15 01:10:47 +02:00
* /////////////////////////////// changeing existing custom code /////////////////////////
* Update Inserted Code = / xxx [ INSERTED <> $ $ $ $ ] xxx //x23x/ /xxx[/INSERTED<>$$$$]xxx/
* Update Replaced Code = / xxx [ REPLACED <> $ $ $ $ ] xxx //x25x/ /xxx[/REPLACED<>$$$$]xxx/
2017-02-01 15:17:04 +02:00
*
2017-12-15 01:10:47 +02:00
* The custom script placeholders - we use the ( == ) to avoid detection it should be ( -- )
* ###################################---> HTML <---#####################################
2017-02-01 15:17:04 +02:00
*
2017-02-14 01:24:38 +02:00
* New Insert Code = <!== [ INSERT <> $ $ $ $ ] ==> <!== [ / INSERT <> $ $ $ $ ] ==>
2017-12-15 01:10:47 +02:00
* New Replace Code = <!== [ REPLACE <> $ $ $ $ ] ==> <!== [ / REPLACE <> $ $ $ $ ] ==>
2017-02-14 01:24:38 +02:00
*
2017-12-15 01:10:47 +02:00
* ///////////////////////////////// when JCB adds it back ///////////////////////////////
* JCB Add Inserted Code = <!== [ INSERTED $ $ $ $ ] ==><!== 23 ==> <!== [ / INSERTED $ $ $ $ ] ==>
* JCB Add Replaced Code = <!== [ REPLACED $ $ $ $ ] ==><!== 25 ==> <!== [ / REPLACED $ $ $ $ ] ==>
2017-02-14 01:24:38 +02:00
*
2017-12-15 01:10:47 +02:00
* //////////////////////////// changeing existing custom code ///////////////////////////
* Update Inserted Code = <!== [ INSERTED <> $ $ $ $ ] ==><!== 23 ==> <!== [ / INSERTED <> $ $ $ $ ] ==>
* Update Replaced Code = <!== [ REPLACED <> $ $ $ $ ] ==><!== 25 ==> <!== [ / REPLACED <> $ $ $ $ ] ==>
*
* ////////23 is the ID of the code in the system don't change it!!!!!!!!!!!!!!!!!!!!!!!!!!
*
* @ var array
* ********************************************************************************************* */
protected $customCodePlaceholders = array (
1 => 'REPLACE<>$$$$]' ,
2 => 'INSERT<>$$$$]' ,
3 => 'REPLACED<>$$$$]' ,
4 => 'INSERTED<>$$$$]'
);
2017-02-01 15:17:04 +02:00
/**
* The custom code to be added
*
* @ var array
*/
public $customCode ;
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* The custom code to be added
*
* @ var array
*/
protected $customCodeData = array ();
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* The function name memory ids
*
* @ var array
*/
public $functionNameMemory = array ();
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* The custom code for local memory
*
* @ var array
*/
public $customCodeMemory = array ();
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
/**
2018-01-31 15:35:54 +02:00
* The custom code in local files that already exist in system
2017-02-01 15:17:04 +02:00
*
* @ var array
*/
protected $existingCustomCode = array ();
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
/**
* The custom code in local files this are new
*
* @ var array
*/
protected $newCustomCode = array ();
2017-12-15 01:10:47 +02:00
2017-02-09 18:11:10 +02:00
/**
* The index of code already loaded
*
* @ var array
*/
2017-12-15 01:10:47 +02:00
protected $codeAreadyDone = array ();
2018-01-31 15:35:54 +02:00
/**
2018-02-03 02:13:48 +02:00
* The external code / string to be added
2018-01-31 15:35:54 +02:00
*
* @ var array
*/
2018-02-03 02:13:48 +02:00
protected $externalCodeString = array ();
2018-01-31 15:35:54 +02:00
2017-02-14 01:24:38 +02:00
/*
* The line numbers Switch
*
* @ var boolean
*/
2017-12-15 01:10:47 +02:00
public $debugLinenr = false ;
2017-04-06 09:47:51 +01:00
/*
* The percentage when a language should be added
*
* @ var boolean
*/
public $percentageLanguageAdd = 0 ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2017-04-05 14:21:10 +01:00
* The Placholder Language prefix
2016-02-26 02:20:09 +02:00
*
* @ var string
*/
2017-04-05 14:21:10 +01:00
public $langPrefix ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Language content
*
* @ var array
*/
public $langContent = array ();
2017-12-15 01:10:47 +02:00
2017-04-05 14:21:10 +01:00
/**
* The Languages bucket
*
* @ var array
*/
2017-12-15 01:10:47 +02:00
public $languages = array ( 'en-GB' => array ());
2017-04-05 14:21:10 +01:00
/**
* The Multi Languages bucket
*
* @ var array
*/
public $multiLangString = array ();
2017-12-15 01:10:47 +02:00
2017-04-05 14:21:10 +01:00
/**
* The new lang to add
*
* @ var array
*/
protected $newLangStrings = array ();
2017-12-15 01:10:47 +02:00
2017-04-05 14:21:10 +01:00
/**
* The existing lang to update
*
* @ var array
*/
protected $existingLangStrings = array ();
2017-12-15 01:10:47 +02:00
2017-12-14 15:30:21 +02:00
/**
* The Language JS matching check
*
* @ var array
*/
public $langMismatch = array ();
2017-12-15 01:10:47 +02:00
2017-12-14 15:30:21 +02:00
/**
* The Language SC matching check
*
* @ var array
*/
public $langMatch = array ();
2017-12-15 01:10:47 +02:00
2017-12-14 15:30:21 +02:00
/**
* The Language string targets
*
* @ var array
*/
public $langStringTargets = array (
2018-02-06 12:55:46 +02:00
'Joomla' . '.JText._(' ,
'JText:' . ':script(' ,
'JText:' . ':_(' ,
'JText:' . ':sprintf('
2017-12-15 01:10:47 +02:00
);
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Component Code Name
*
* @ var string
*/
public $componentCodeName ;
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* The Component ID
*
* @ var int
*/
public $componentID ;
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* The current user
*
* @ var array
*/
public $user ;
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* The database object
*
* @ var array
*/
public $db ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Component version
*
* @ var string
*/
public $component_version ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The UIKIT Switch
*
* @ var boolean
*/
2017-11-11 06:33:51 +02:00
public $uikit = 0 ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The UIKIT component checker
*
* @ var array
*/
public $uikitComp = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The FOOTABLE Switch
*
* @ var boolean
*/
public $footable = false ;
2017-12-15 01:10:47 +02:00
2016-04-22 13:03:43 +01:00
/**
* The FOOTABLE Version
*
* @ var int
*/
public $footableVersion ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Google Chart Switch per view
*
* @ var array
*/
public $googleChart = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Google Chart Switch
*
* @ var boolean
*/
public $googlechart = false ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Import & Export Switch
*
* @ var boolean
*/
public $addEximport = false ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Tag & History Switch
*
* @ var boolean
*/
public $setTagHistory = false ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The site edit views
*
* @ var array
*/
public $siteEditView = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Language target
*
* @ var string
*/
public $lang = 'admin' ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Build target Switch
*
* @ var string
*/
public $target ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The unique codes
*
* @ var array
*/
2016-02-26 15:57:30 +02:00
public $uniquecodes = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 15:57:30 +02:00
* The unique keys
*
* @ var array
*/
public $uniquekeys = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Ad contributors Switch
*
* @ var boolean
*/
public $addContributors = false ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Custom Script Builder
*
* @ var array
*/
public $customScriptBuilder = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Footable Script Builder
*
* @ var array
*/
public $footableScripts = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The pathe to the bom file to be used
*
* @ var string
*/
public $bomPath ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The SQL Tweak of admin views
*
* @ var array
*/
public $sqlTweak = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The admin views data array
*
* @ var array
*/
private $_adminViewData = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The field data array
*
* @ var array
*/
private $_fieldData = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The linked admin view tabs
*
* @ var array
*/
public $linkedAdminViews = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Add Ajax Switch
*
* @ var boolean
*/
public $addAjax = false ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Add Site Ajax Switch
*
* @ var boolean
*/
public $addSiteAjax = false ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The get Module Script Switch
*
* @ var array
*/
public $getModule = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The template data
*
* @ var array
*/
public $templateData = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The layout data
*
* @ var array
*/
public $layoutData = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2018-03-06 04:28:44 +02:00
* The Encryption Types
*
* @ var array
*/
public $cryptionTypes = array ( 'basic' , 'medium' , 'whmcs' );
/**
* The WHMCS Encryption Switch
2016-02-26 02:20:09 +02:00
*
* @ var boolean
*/
2018-03-06 04:28:44 +02:00
public $whmcsEncryption = false ;
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Basic Encryption Switch
*
* @ var boolean
*/
public $basicEncryption = false ;
2017-12-15 01:10:47 +02:00
2018-03-06 04:28:44 +02:00
/**
* The Medium Encryption Switch
*
* @ var boolean
*/
public $mediumEncryption = false ;
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The Custom field Switch per view
*
* @ var array
*/
public $customFieldScript = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The site main get
*
* @ var array
*/
public $siteMainGet = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The site dynamic get
*
* @ var array
*/
public $siteDynamicGet = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The get AS lookup
*
* @ var array
*/
public $getAsLookup = array ();
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* The site fields
*
* @ var array
*/
public $siteFields = array ();
2017-12-15 01:10:47 +02:00
2017-06-16 13:38:06 +01:00
/**
* The add SQL
*
* @ var array
*/
public $addSQL = array ();
2017-12-15 01:10:47 +02:00
2017-06-16 13:38:06 +01:00
/**
* The update SQL
*
* @ var array
*/
public $updateSQL = array ();
2017-12-15 01:10:47 +02:00
2017-12-03 20:09:04 +02:00
/**
* The Library Manager
*
* @ var array
*/
public $libManager = array ();
2017-12-15 01:10:47 +02:00
2017-12-03 20:09:04 +02:00
/**
* The Libraries
*
* @ var array
*/
public $libraries = array ();
2017-12-15 01:10:47 +02:00
2017-12-13 00:17:02 +02:00
/**
* Is Tidy Enabled
*
* @ var bool
*/
public $tidy = false ;
2017-12-15 01:10:47 +02:00
2017-12-13 00:17:02 +02:00
/**
* Set Tidy warning once switch
*
* @ var bool
*/
public $setTidyWarning = false ;
2016-02-26 02:20:09 +02:00
2017-12-15 01:10:47 +02:00
/* * *
2016-02-26 02:20:09 +02:00
* Constructor
*/
2017-12-15 01:10:47 +02:00
public function __construct ( $config = array ())
2016-02-26 02:20:09 +02:00
{
if ( isset ( $config ) && count ( $config ))
{
2017-10-26 18:43:51 +02:00
// load application
2017-12-15 01:10:47 +02:00
$this -> app = JFactory :: getApplication ();
2017-12-13 00:17:02 +02:00
// check if we have Tidy enabled
2017-12-15 01:10:47 +02:00
$this -> tidy = extension_loaded ( 'Tidy' );
2016-02-26 02:20:09 +02:00
// Set the params
2017-12-15 01:10:47 +02:00
$this -> params = JComponentHelper :: getParams ( 'com_componentbuilder' );
2016-02-26 02:20:09 +02:00
// load the compiler path
2017-12-15 01:10:47 +02:00
$this -> compilerPath = $this -> params -> get ( 'compiler_folder_path' , JPATH_COMPONENT_ADMINISTRATOR . '/compiler' );
2017-02-14 01:24:38 +02:00
// set the component ID
2017-12-15 01:10:47 +02:00
$this -> componentID = ( int ) $config [ 'componentId' ];
2017-02-14 01:24:38 +02:00
// set this components code name
2017-02-16 16:02:23 +02:00
if ( $name_code = ComponentbuilderHelper :: getVar ( 'joomla_component' , $this -> componentID , 'id' , 'name_code' ))
2017-02-14 01:24:38 +02:00
{
// set lang prefix
2017-12-15 01:10:47 +02:00
$this -> langPrefix = 'COM_' . ComponentbuilderHelper :: safeString ( $name_code , 'U' );
2017-02-14 01:24:38 +02:00
// set component code name
2017-12-15 01:10:47 +02:00
$this -> componentCodeName = ComponentbuilderHelper :: safeString ( $name_code );
2017-02-14 01:24:38 +02:00
// set if placeholders should be added to customcode
2017-12-15 01:10:47 +02:00
$global = (( int ) ComponentbuilderHelper :: getVar ( 'joomla_component' , $this -> componentID , 'id' , 'add_placeholders' ) == 1 ) ? true : false ;
$this -> addPlaceholders = (( int ) $config [ 'addPlaceholders' ] == 0 ) ? false : ((( int ) $config [ 'addPlaceholders' ] == 1 ) ? true : $global );
2017-02-14 01:24:38 +02:00
// set if line numbers should be added to comments
2017-12-15 01:10:47 +02:00
$global = (( int ) ComponentbuilderHelper :: getVar ( 'joomla_component' , $this -> componentID , 'id' , 'debug_linenr' ) == 1 ) ? true : false ;
$this -> debugLinenr = (( int ) $config [ 'debugLinenr' ] == 0 ) ? false : ((( int ) $config [ 'debugLinenr' ] == 1 ) ? true : $global );
2017-02-14 01:24:38 +02:00
// set the current user
2017-12-15 01:10:47 +02:00
$this -> user = JFactory :: getUser ();
2017-02-14 01:24:38 +02:00
// Get a db connection.
2017-12-15 01:10:47 +02:00
$this -> db = JFactory :: getDbo ();
2017-02-14 01:24:38 +02:00
// check if this component is install on the current website
if ( $paths = $this -> getLocalInstallPaths ())
{
// start Automatic import of custom code
$today = JFactory :: getDate () -> toSql ();
// get the custom code from installed files
$this -> customCodeFactory ( $paths , $today );
}
// get the component data
$this -> componentData = $this -> getComponentData ();
2017-06-16 13:38:06 +01:00
// make sure we have a version
if ( strpos ( $this -> componentData -> component_version , '.' ) === FALSE )
{
$this -> componentData -> component_version = '1.0.0' ;
}
// update the version
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> componentData -> old_component_version ) && ( ComponentbuilderHelper :: checkArray ( $this -> addSQL ) || ComponentbuilderHelper :: checkArray ( $this -> updateSQL )))
2017-06-16 13:38:06 +01:00
{
// set the new version
$version = ( array ) explode ( '.' , $this -> componentData -> component_version );
// get last key
end ( $version );
$key = key ( $version );
// just increment the last
2017-12-15 01:10:47 +02:00
$version [ $key ] ++ ;
2017-06-16 13:38:06 +01:00
// set the old version
$this -> componentData -> old_component_version = $this -> componentData -> component_version ;
// set the new version, and set update switch
$this -> componentData -> component_version = implode ( '.' , $version );
}
2017-04-06 09:47:51 +01:00
// set the percentage when a language can be added
2017-04-06 09:51:46 +01:00
$this -> percentageLanguageAdd = ( int ) $this -> params -> get ( 'percentagelanguageadd' , 50 );
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
return true ;
}
2016-02-26 02:20:09 +02:00
}
return false ;
}
2017-12-15 01:10:47 +02:00
2016-09-03 22:44:47 +01:00
/**
* Set the line number in comments
*
* @ param int $nr The line number
*
* @ return void
*
*/
private function setLine ( $nr )
{
2017-04-06 09:47:51 +01:00
if ( $this -> debugLinenr )
2016-09-03 22:44:47 +01:00
{
2017-12-15 01:10:47 +02:00
return ' [Get ' . $nr . ']' ;
2016-09-03 22:44:47 +01:00
}
return '' ;
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* get all Component Data
*
* @ param int $id The component ID
*
* @ return oject The component data
*
*/
2017-02-14 01:24:38 +02:00
public function getComponentData ()
2016-02-26 02:20:09 +02:00
{
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
2016-02-26 02:20:09 +02:00
$query -> select ( 'a.*' );
2017-10-29 13:03:06 +02:00
$query -> select (
$this -> db -> quoteName (
array (
2017-12-15 01:10:47 +02:00
'b.addadmin_views' ,
'b.id' ,
'h.addconfig' ,
'd.addcustom_admin_views' ,
'g.addcustommenus' ,
'j.addfiles' ,
'j.addfolders' ,
2018-02-16 23:53:43 +02:00
'j.addfilesfullpath' ,
'j.addfoldersfullpath' ,
2017-12-15 01:10:47 +02:00
'c.addsite_views' ,
'i.dashboard_tab' ,
'i.php_dashboard_methods' ,
'f.sql_tweak' ,
'e.version_update' ,
'e.id'
), array (
'addadmin_views' ,
'addadmin_views_id' ,
'addconfig' ,
'addcustom_admin_views' ,
'addcustommenus' ,
'addfiles' ,
'addfolders' ,
2018-02-16 23:53:43 +02:00
'addfilesfullpath' ,
'addfoldersfullpath' ,
2017-12-15 01:10:47 +02:00
'addsite_views' ,
'dashboard_tab' ,
'php_dashboard_methods' ,
'sql_tweak' ,
'version_update' ,
'version_update_id'
2017-10-29 13:03:06 +02:00
)
2017-12-15 01:10:47 +02:00
)
);
2017-10-29 13:03:06 +02:00
// from these tables
2017-02-16 16:02:23 +02:00
$query -> from ( '#__componentbuilder_joomla_component AS a' );
2017-10-29 13:03:06 +02:00
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_component_admin_views' , 'b' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'b.joomla_component' ) . ')' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_component_site_views' , 'c' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'c.joomla_component' ) . ')' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_component_custom_admin_views' , 'd' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'd.joomla_component' ) . ')' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_component_updates' , 'e' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'e.joomla_component' ) . ')' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_component_mysql_tweaks' , 'f' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'f.joomla_component' ) . ')' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_component_custom_admin_menus' , 'g' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'g.joomla_component' ) . ')' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_component_config' , 'h' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'h.joomla_component' ) . ')' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_component_dashboard' , 'i' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'i.joomla_component' ) . ')' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_component_files_folders' , 'j' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'j.joomla_component' ) . ')' );
2017-12-15 01:10:47 +02:00
$query -> where ( $this -> db -> quoteName ( 'a.id' ) . ' = ' . ( int ) $this -> componentID );
2016-02-26 02:20:09 +02:00
// Reset the query using our newly populated query object.
2017-02-14 01:24:38 +02:00
$this -> db -> setQuery ( $query );
2016-02-26 02:20:09 +02:00
// Load the results as a list of stdClass objects
2017-02-14 01:24:38 +02:00
$component = $this -> db -> loadObject ();
2017-12-15 01:10:47 +02:00
2017-10-29 13:03:06 +02:00
// set upater
$updater = array (
'unique' => array (
'addadmin_views' => array ( 'table' => 'component_admin_views' , 'val' => ( int ) $component -> addadmin_views_id , 'key' => 'id' ),
'addconfig' => array ( 'table' => 'component_config' , 'val' => ( int ) $this -> componentID , 'key' => 'joomla_component' ),
'addcustom_admin_views' => array ( 'table' => 'component_custom_admin_views' , 'val' => ( int ) $this -> componentID , 'key' => 'joomla_component' ),
'addcustommenus' => array ( 'table' => 'component_custom_admin_menus' , 'val' => ( int ) $this -> componentID , 'key' => 'joomla_component' ),
'addfiles' => array ( 'table' => 'component_files_folders' , 'val' => ( int ) $this -> componentID , 'key' => 'joomla_component' ),
'addfolders' => array ( 'table' => 'component_files_folders' , 'val' => ( int ) $this -> componentID , 'key' => 'joomla_component' ),
'addsite_views' => array ( 'table' => 'component_site_views' , 'val' => ( int ) $this -> componentID , 'key' => 'joomla_component' ),
'dashboard_tab' => array ( 'table' => 'component_dashboard' , 'val' => ( int ) $this -> componentID , 'key' => 'joomla_component' ),
'sql_tweak' => array ( 'table' => 'component_mysql_tweaks' , 'val' => ( int ) $this -> componentID , 'key' => 'joomla_component' ),
'version_update' => array ( 'table' => 'component_updates' , 'val' => ( int ) $this -> componentID , 'key' => 'joomla_component' )
),
'table' => 'joomla_component' ,
'key' => 'id' ,
'val' => ( int ) $this -> componentID
);
// repeatable fields to update
$searchRepeatables = array (
// repeatablefield => checker
'addadmin_views' => 'adminview' ,
'addconfig' => 'field' ,
'addcontributors' => 'name' ,
'addcustom_admin_views' => 'customadminview' ,
'addcustommenus' => 'name' ,
'addfiles' => 'file' ,
'addfolders' => 'folder' ,
'addsite_views' => 'siteview' ,
'dashboard_tab' => 'name' ,
'sql_tweak' => 'adminview' ,
'version_update' => 'version'
);
// update the repeatable fields
$component = ComponentbuilderHelper :: convertRepeatableFields ( $component , $searchRepeatables , $updater );
2017-12-15 01:10:47 +02:00
2017-03-06 14:06:51 +02:00
// set component place holders
$this -> placeholders [ '###component###' ] = ComponentbuilderHelper :: safeString ( $component -> name_code );
$this -> placeholders [ '###Component###' ] = ComponentbuilderHelper :: safeString ( $component -> name_code , 'F' );
$this -> placeholders [ '###COMPONENT###' ] = ComponentbuilderHelper :: safeString ( $component -> name_code , 'U' );
$this -> placeholders [ '[[[component]]]' ] = $this -> placeholders [ '###component###' ];
$this -> placeholders [ '[[[Component]]]' ] = $this -> placeholders [ '###Component###' ];
$this -> placeholders [ '[[[COMPONENT]]]' ] = $this -> placeholders [ '###COMPONENT###' ];
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
// set component sales name
$component -> sales_name = ComponentbuilderHelper :: safeString ( $component -> system_name );
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
// ensure version naming is correct
$this -> component_version = preg_replace ( '/[^0-9.]+/' , '' , $component -> component_version );
2017-12-15 01:10:47 +02:00
2018-02-16 23:53:43 +02:00
// set the add targets
$addArrayF = array ( 'files' => 'files' , 'folders' => 'folders' , 'filesfullpath' => 'files' , 'foldersfullpath' => 'folders' );
foreach ( $addArrayF as $addTarget => $targetHere )
2016-02-26 02:20:09 +02:00
{
2018-02-16 23:53:43 +02:00
// set the add target data
$component -> { 'add' . $addTarget } = ( isset ( $component -> { 'add' . $addTarget }) && ComponentbuilderHelper :: checkJson ( $component -> { 'add' . $addTarget })) ? json_decode ( $component -> { 'add' . $addTarget }, true ) : null ;
if ( ComponentbuilderHelper :: checkArray ( $component -> { 'add' . $addTarget }))
{
if ( isset ( $component -> { $targetHere }) && ComponentbuilderHelper :: checkArray ( $component -> { $targetHere }))
{
foreach ( $component -> { 'add' . $addTarget } as $taget )
{
$component -> { $targetHere }[] = $taget ;
}
}
else
{
$component -> { $targetHere } = array_values ( $component -> { 'add' . $addTarget });
}
}
unset ( $component -> { 'add' . $addTarget });
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
// set the uikit switch
2017-11-11 06:33:51 +02:00
$this -> uikit = $component -> adduikit ;
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
// set the footable switch
if ( $component -> addfootable )
{
$this -> footable = true ;
2016-04-22 13:03:43 +01:00
// add the version
$this -> footableVersion = ( 1 == $component -> addfootable || 2 == $component -> addfootable ) ? 2 : $component -> addfootable ;
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
2017-10-29 13:03:06 +02:00
// set the addcustommenus data
2017-12-15 01:10:47 +02:00
$component -> addcustommenus = ( isset ( $component -> addcustommenus ) && ComponentbuilderHelper :: checkJson ( $component -> addcustommenus )) ? json_decode ( $component -> addcustommenus , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $component -> addcustommenus ))
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
$component -> custommenus = array_values ( $component -> addcustommenus );
2016-02-26 02:20:09 +02:00
}
2017-10-29 13:03:06 +02:00
unset ( $component -> addcustommenus );
2017-12-15 01:10:47 +02:00
2017-10-29 13:03:06 +02:00
// set the sql_tweak data
2017-12-15 01:10:47 +02:00
$component -> sql_tweak = ( isset ( $component -> sql_tweak ) && ComponentbuilderHelper :: checkJson ( $component -> sql_tweak )) ? json_decode ( $component -> sql_tweak , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $component -> sql_tweak ))
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
// build the tweak settings
2017-12-15 01:10:47 +02:00
$this -> setSqlTweaking ( array_map ( function ( $array )
{
return array_map ( function ( $value )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( ! ComponentbuilderHelper :: checkArray ( $value ) && ! ComponentbuilderHelper :: checkObject ( $value ) && strval ( $value ) === strval ( intval ( $value )))
{
return ( int ) $value ;
}
return $value ;
}, $array );
}, array_values ( $component -> sql_tweak )));
2016-02-26 02:20:09 +02:00
}
2017-10-29 13:03:06 +02:00
unset ( $component -> sql_tweak );
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
// set the admin_view data
2017-12-15 01:10:47 +02:00
$component -> addadmin_views = ( isset ( $component -> addadmin_views ) && ComponentbuilderHelper :: checkJson ( $component -> addadmin_views )) ? json_decode ( $component -> addadmin_views , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $component -> addadmin_views ))
2016-02-26 02:20:09 +02:00
{
// sort the views acording to order
2017-10-29 13:03:06 +02:00
usort ( $component -> addadmin_views , function ( $a , $b )
2016-02-26 02:20:09 +02:00
{
if ( $a [ 'order' ] != 0 && $b [ 'order' ] != 0 )
{
return $a [ 'order' ] - $b [ 'order' ];
}
elseif ( $b [ 'order' ] != 0 && $a [ 'order' ] == 0 )
{
return 1 ;
}
elseif ( $a [ 'order' ] != 0 && $b [ 'order' ] == 0 )
{
return 0 ;
}
return 1 ;
});
2017-10-29 13:03:06 +02:00
// build the admin_views settings
2017-12-15 01:10:47 +02:00
$component -> admin_views = array_map ( function ( $array )
{
$array = array_map ( function ( $value )
{
if ( ! ComponentbuilderHelper :: checkArray ( $value ) && ! ComponentbuilderHelper :: checkObject ( $value ) && strval ( $value ) === strval ( intval ( $value )))
2017-10-29 13:03:06 +02:00
{
return ( int ) $value ;
}
return $value ;
}, $array );
// has become a lacacy issue, can't remove this
$array [ 'view' ] = $array [ 'adminview' ];
$array [ 'settings' ] = $this -> getAdminViewData ( $array [ 'view' ]);
2017-10-30 15:08:02 +02:00
if ( isset ( $array [ 'port' ]) && $array [ 'port' ] && ! $this -> addEximport )
2016-02-26 02:20:09 +02:00
{
$this -> addEximport = true ;
}
2017-10-30 15:08:02 +02:00
if ( isset ( $array [ 'history' ]) && $array [ 'history' ] && ! $this -> setTagHistory )
2016-02-26 02:20:09 +02:00
{
$this -> setTagHistory = true ;
}
2017-10-30 15:08:02 +02:00
if ( isset ( $array [ 'edit_create_site_view' ]) && $array [ 'edit_create_site_view' ])
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
$this -> siteEditView [ $array [ 'adminview' ]] = true ;
2016-02-26 02:20:09 +02:00
}
2017-10-29 13:03:06 +02:00
return $array ;
}, array_values ( $component -> addadmin_views ));
2016-02-26 02:20:09 +02:00
}
// set the site_view data
2017-12-15 01:10:47 +02:00
$component -> addsite_views = ( isset ( $component -> addsite_views ) && ComponentbuilderHelper :: checkJson ( $component -> addsite_views )) ? json_decode ( $component -> addsite_views , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $component -> addsite_views ))
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
$this -> lang = 'site' ;
$this -> target = 'site' ;
// build the site_views settings
2017-12-15 01:10:47 +02:00
$component -> site_views = array_map ( function ( $array )
{
2017-10-29 13:03:06 +02:00
// has become a lacacy issue, can't remove this
$array [ 'view' ] = $array [ 'siteview' ];
$array [ 'settings' ] = $this -> getCustomViewData ( $array [ 'view' ]);
2017-12-15 01:10:47 +02:00
return array_map ( function ( $value )
{
if ( ! ComponentbuilderHelper :: checkArray ( $value ) && ! ComponentbuilderHelper :: checkObject ( $value ) && strval ( $value ) === strval ( intval ( $value )))
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
return ( int ) $value ;
2016-02-26 02:20:09 +02:00
}
2017-10-29 13:03:06 +02:00
return $value ;
}, $array );
}, array_values ( $component -> addsite_views ));
// unset original value
2016-02-26 02:20:09 +02:00
unset ( $component -> addsite_views );
}
// set the custom_admin_views data
2017-12-15 01:10:47 +02:00
$component -> addcustom_admin_views = ( isset ( $component -> addcustom_admin_views ) && ComponentbuilderHelper :: checkJson ( $component -> addcustom_admin_views )) ? json_decode ( $component -> addcustom_admin_views , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $component -> addcustom_admin_views ))
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
$this -> lang = 'admin' ;
$this -> target = 'custom_admin' ;
// build the custom_admin_views settings
2017-12-15 01:10:47 +02:00
$component -> custom_admin_views = array_map ( function ( $array )
{
2017-10-29 13:03:06 +02:00
// has become a lacacy issue, can't remove this
$array [ 'view' ] = $array [ 'customadminview' ];
$array [ 'settings' ] = $this -> getCustomViewData ( $array [ 'view' ], 'custom_admin_view' );
2017-12-15 01:10:47 +02:00
return array_map ( function ( $value )
{
if ( ! ComponentbuilderHelper :: checkArray ( $value ) && ! ComponentbuilderHelper :: checkObject ( $value ) && strval ( $value ) === strval ( intval ( $value )))
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
return ( int ) $value ;
2016-02-26 02:20:09 +02:00
}
2017-10-29 13:03:06 +02:00
return $value ;
}, $array );
}, array_values ( $component -> addcustom_admin_views ));
// unset original value
2016-02-26 02:20:09 +02:00
unset ( $component -> addcustom_admin_views );
}
2017-12-03 20:09:04 +02:00
// set the config data
2017-12-15 01:10:47 +02:00
$component -> addconfig = ( isset ( $component -> addconfig ) && ComponentbuilderHelper :: checkJson ( $component -> addconfig )) ? json_decode ( $component -> addconfig , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $component -> addconfig ))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$component -> config = array_map ( function ( $array )
{
2017-10-29 13:03:06 +02:00
$array [ 'alias' ] = 0 ;
$array [ 'title' ] = 0 ;
$array [ 'settings' ] = $this -> getFieldData ( $array [ 'field' ]);
return $array ;
}, array_values ( $component -> addconfig ));
// unset original value
2016-02-26 02:20:09 +02:00
unset ( $component -> addconfig );
}
2017-12-15 01:10:47 +02:00
2017-10-29 13:03:06 +02:00
// set the addcustommenus data
2017-12-15 01:10:47 +02:00
$component -> addcontributors = ( isset ( $component -> addcontributors ) && ComponentbuilderHelper :: checkJson ( $component -> addcontributors )) ? json_decode ( $component -> addcontributors , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $component -> addcontributors ))
2016-02-26 02:20:09 +02:00
{
$this -> addContributors = true ;
2017-10-29 13:03:06 +02:00
$component -> contributors = array_values ( $component -> addcontributors );
2016-02-26 02:20:09 +02:00
}
2017-10-29 13:03:06 +02:00
unset ( $component -> addcontributors );
2017-12-15 01:10:47 +02:00
2017-10-29 13:03:06 +02:00
// set the addcustommenus data
2017-12-15 01:10:47 +02:00
$component -> version_update = ( isset ( $component -> version_update ) && ComponentbuilderHelper :: checkJson ( $component -> version_update )) ? json_decode ( $component -> version_update , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $component -> version_update ))
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
$component -> version_update = array_values ( $component -> version_update );
}
2017-12-15 01:10:47 +02:00
2017-06-16 13:38:06 +01:00
// build update SQL
2017-10-30 20:50:56 +02:00
$old_admin_views = $this -> getHistoryWatch ( 'component_admin_views' , $component -> addadmin_views_id );
$old_component = $this -> getHistoryWatch ( 'joomla_component' , $this -> componentID );
if ( $old_component || $old_admin_views )
2017-06-16 13:38:06 +01:00
{
2017-10-30 15:08:02 +02:00
if ( ComponentbuilderHelper :: checkObject ( $old_admin_views ))
2017-06-16 13:38:06 +01:00
{
2017-10-30 15:08:02 +02:00
// add new views if found
if ( isset ( $old_admin_views -> addadmin_views ) && ComponentbuilderHelper :: checkJson ( $old_admin_views -> addadmin_views ))
{
$this -> setUpdateSQL ( json_decode ( $old_admin_views -> addadmin_views , true ), $component -> addadmin_views , 'adminview' );
}
// check if a new version was manualy set
if ( ComponentbuilderHelper :: checkObject ( $old_component ))
{
$old_component_version = preg_replace ( '/[^0-9.]+/' , '' , $old_component -> component_version );
if ( $old_component_version != $this -> component_version )
{
// yes, this is a new version, this mean there may be manual sql and must be checked and updated
$component -> old_component_version = $old_component_version ;
}
// clear this data
unset ( $old_component );
}
// clear this data
unset ( $old_admin_views );
2017-06-16 13:38:06 +01:00
}
2016-02-26 02:20:09 +02:00
}
2017-10-29 13:03:06 +02:00
// unset original value
unset ( $component -> addadmin_views );
2016-02-26 02:20:09 +02:00
2017-10-06 16:53:22 +02:00
// add_javascript
if ( $component -> add_javascript == 1 )
{
$this -> customScriptBuilder [ 'component_js' ] = base64_decode ( $component -> javascript );
}
else
{
$this -> customScriptBuilder [ 'component_js' ] = '' ;
}
unset ( $component -> javascript );
2018-01-15 17:54:05 +02:00
// add global CSS
$addGlobalCss = array ( 'admin' , 'site' );
foreach ( $addGlobalCss as $area )
2016-02-26 02:20:09 +02:00
{
2018-01-15 17:54:05 +02:00
// add_css if found
if ( isset ( $component -> { 'add_css_' . $area }) && $component -> { 'add_css_' . $area } == 1 && isset ( $component -> { 'css_' . $area }) && ComponentbuilderHelper :: checkString ( $component -> { 'css_' . $area }))
{
$this -> customScriptBuilder [ 'component_css_' . $area ] = base64_decode ( $component -> { 'css_' . $area });
}
else
{
$this -> customScriptBuilder [ 'component_css_' . $area ] = '' ;
}
unset ( $component -> { 'css_' . $area });
2016-02-26 02:20:09 +02:00
}
2016-10-24 00:48:26 +02:00
// set the lang target
$this -> lang = 'admin' ;
// add PHP in ADMIN
2017-12-15 01:10:47 +02:00
$addScriptMethods = array ( 'php_preflight' , 'php_postflight' , 'php_method' );
$addScriptTypes = array ( 'install' , 'update' , 'uninstall' );
2016-10-24 00:48:26 +02:00
foreach ( $addScriptMethods as $scriptMethod )
2017-12-15 01:10:47 +02:00
{
2016-10-24 00:48:26 +02:00
foreach ( $addScriptTypes as $scriptType )
{
2017-12-15 01:10:47 +02:00
if ( isset ( $component -> { 'add_' . $scriptMethod . '_' . $scriptType }) && $component -> { 'add_' . $scriptMethod . '_' . $scriptType } == 1 && ComponentbuilderHelper :: checkString ( $component -> { $scriptMethod . '_' . $scriptType }))
2016-10-24 00:48:26 +02:00
{
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $scriptMethod ][ $scriptType ] = $this -> setDynamicValues ( base64_decode ( $component -> { $scriptMethod . '_' . $scriptType }));
2016-10-24 00:48:26 +02:00
}
else
{
$this -> customScriptBuilder [ $scriptMethod ][ $scriptType ] = '' ;
}
2017-12-15 01:10:47 +02:00
unset ( $component -> { $scriptMethod . '_' . $scriptType });
2016-10-24 00:48:26 +02:00
}
}
2016-02-26 02:20:09 +02:00
// add_php_helper
2017-03-27 14:38:51 +02:00
if ( $component -> add_php_helper_admin == 1 && ComponentbuilderHelper :: checkString ( $component -> php_helper_admin ))
2016-02-26 02:20:09 +02:00
{
$this -> lang = 'admin' ;
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ 'component_php_helper_admin' ] = PHP_EOL . PHP_EOL . $this -> setDynamicValues ( base64_decode ( $component -> php_helper_admin ));
2016-02-26 02:20:09 +02:00
}
else
{
$this -> customScriptBuilder [ 'component_php_helper_admin' ] = '' ;
}
2016-10-24 00:48:26 +02:00
unset ( $component -> php_helper );
2016-02-26 02:20:09 +02:00
// add_admin_event
2017-03-27 14:38:51 +02:00
if ( $component -> add_admin_event == 1 && ComponentbuilderHelper :: checkString ( $component -> php_admin_event ))
2016-02-26 02:20:09 +02:00
{
$this -> lang = 'admin' ;
2017-02-14 01:24:38 +02:00
$this -> customScriptBuilder [ 'component_php_admin_event' ] = $this -> setDynamicValues ( base64_decode ( $component -> php_admin_event ));
2016-02-26 02:20:09 +02:00
}
else
{
$this -> customScriptBuilder [ 'component_php_admin_event' ] = '' ;
}
2016-10-24 00:48:26 +02:00
unset ( $component -> php_admin_event );
2016-11-25 04:56:16 +02:00
// add_php_helper_both
2017-03-27 14:38:51 +02:00
if ( $component -> add_php_helper_both == 1 && ComponentbuilderHelper :: checkString ( $component -> php_helper_both ))
2016-11-25 04:56:16 +02:00
{
$this -> lang = 'both' ;
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ 'component_php_helper_both' ] = PHP_EOL . PHP_EOL . $this -> setDynamicValues ( base64_decode ( $component -> php_helper_both ));
2016-11-25 04:56:16 +02:00
}
else
{
$this -> customScriptBuilder [ 'component_php_helper_both' ] = '' ;
}
2016-02-26 02:20:09 +02:00
// add_php_helper_site
2017-03-27 14:38:51 +02:00
if ( $component -> add_php_helper_site == 1 && ComponentbuilderHelper :: checkString ( $component -> php_helper_site ))
2016-02-26 02:20:09 +02:00
{
$this -> lang = 'site' ;
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ 'component_php_helper_site' ] = PHP_EOL . PHP_EOL . $this -> setDynamicValues ( base64_decode ( $component -> php_helper_site ));
2016-02-26 02:20:09 +02:00
}
else
{
$this -> customScriptBuilder [ 'component_php_helper_site' ] = '' ;
}
2016-10-24 00:48:26 +02:00
unset ( $component -> php_helper );
2016-02-26 02:20:09 +02:00
// add_site_event
2017-03-27 14:38:51 +02:00
if ( $component -> add_site_event == 1 && ComponentbuilderHelper :: checkString ( $component -> php_site_event ))
2016-02-26 02:20:09 +02:00
{
$this -> lang = 'site' ;
2017-02-14 01:24:38 +02:00
$this -> customScriptBuilder [ 'component_php_site_event' ] = $this -> setDynamicValues ( base64_decode ( $component -> php_site_event ));
2016-02-26 02:20:09 +02:00
}
else
{
$this -> customScriptBuilder [ 'component_php_site_event' ] = '' ;
}
2016-10-24 00:48:26 +02:00
unset ( $component -> php_site_event );
2016-02-26 02:20:09 +02:00
// add_sql
if ( $component -> add_sql == 1 )
{
$this -> customScriptBuilder [ 'sql' ][ 'component_sql' ] = base64_decode ( $component -> sql );
}
2016-10-24 00:48:26 +02:00
unset ( $component -> sql );
2016-02-26 02:20:09 +02:00
// bom
if ( ComponentbuilderHelper :: checkString ( $component -> bom ))
{
2017-12-15 01:10:47 +02:00
$this -> bomPath = $this -> compilerPath . '/' . $component -> bom ;
2016-02-26 02:20:09 +02:00
}
else
{
2017-12-15 01:10:47 +02:00
$this -> bomPath = $this -> compilerPath . '/default.txt' ;
2016-02-26 02:20:09 +02:00
}
2016-10-24 00:48:26 +02:00
unset ( $component -> bom );
2016-02-26 02:20:09 +02:00
// README
if ( $component -> addreadme )
{
$component -> readme = base64_decode ( $component -> readme );
}
else
{
$component -> readme = '' ;
}
2017-12-10 21:17:26 +02:00
// set lang now
$nowLang = $this -> lang ;
$this -> lang = 'admin' ;
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
// dashboard methods
2017-12-15 01:10:47 +02:00
$component -> dashboard_tab = ( isset ( $component -> dashboard_tab ) && ComponentbuilderHelper :: checkJson ( $component -> dashboard_tab )) ? json_decode ( $component -> dashboard_tab , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $component -> dashboard_tab ))
2017-12-10 21:17:26 +02:00
{
2017-12-15 01:10:47 +02:00
$component -> dashboard_tab = array_map ( function ( $array )
{
2017-10-29 13:03:06 +02:00
$array [ 'html' ] = $this -> setDynamicValues ( $array [ 'html' ]);
return $array ;
}, array_values ( $component -> dashboard_tab ));
}
else
{
$component -> dashboard_tab = '' ;
}
// add the php of the dashboard if set
2017-10-29 15:51:43 +02:00
if ( isset ( $component -> php_dashboard_methods ) && ComponentbuilderHelper :: checkString ( $component -> php_dashboard_methods ))
2017-10-29 13:03:06 +02:00
{
2016-02-26 02:20:09 +02:00
// load the php for the dashboard model
2017-02-14 01:24:38 +02:00
$component -> php_dashboard_methods = $this -> setDynamicValues ( base64_decode ( $component -> php_dashboard_methods ));
2016-02-26 02:20:09 +02:00
}
else
{
$component -> php_dashboard_methods = '' ;
}
2017-12-10 21:17:26 +02:00
// reset back to nowlang
$this -> lang = $nowLang ;
2017-12-15 01:10:47 +02:00
2018-02-18 00:47:01 +02:00
// add the update/sales server FTP details if that is the expected protocol
$serverArray = array ( 'update_server' , 'sales_server' );
foreach ( $serverArray as $server )
2017-08-25 02:46:12 +01:00
{
2018-02-18 00:47:01 +02:00
if ( $component -> { 'add_' . $server } == 1 && is_numeric ( $component -> { $server }) && $component -> { $server } > 0 )
{
// get the server protocol
$component -> { $server . '_protocol' } = ComponentbuilderHelper :: getVar ( 'server' , ( int ) $component -> { $server }, 'id' , 'protocol' );
}
else
{
$component -> { $server } = 0 ;
2018-02-18 01:11:05 +02:00
// only change this for sales server (update server can be added loacaly to the zip file)
if ( 'sales_server' === $server )
{
$component -> { 'add_' . $server } = 0 ;
}
2018-02-18 00:47:01 +02:00
$component -> { $server . '_protocol' } = 0 ;
}
2017-08-25 02:46:12 +01:00
}
2017-09-18 02:18:23 +02:00
// set the ignore folders for repo if found
2017-09-13 02:37:43 +02:00
if ( isset ( $component -> toignore ) && ComponentbuilderHelper :: checkString ( $component -> toignore ))
{
if ( strpos ( $component -> toignore , ',' ) !== false )
{
$component -> toignore = array_map ( 'trim' , ( array ) explode ( ',' , $component -> toignore ));
}
else
{
$component -> toignore = array ( trim ( $component -> toignore ));
}
}
else
{
2017-09-18 02:18:23 +02:00
// the default is to ignore the repo folder
2017-09-13 02:37:43 +02:00
$component -> toignore = array ( '.git' );
}
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
// return the found component data
return $component ;
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Get all Admin View Data
*
* @ param int $id The view ID
*
* @ return oject The view data
*
*/
public function getAdminViewData ( $id )
{
if ( ! isset ( $this -> _adminViewData [ $id ]))
{
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
2016-02-26 02:20:09 +02:00
$query -> select ( 'a.*' );
2017-10-29 13:03:06 +02:00
$query -> select (
$this -> db -> quoteName (
array (
2017-12-15 01:10:47 +02:00
'b.addfields' ,
'b.id' ,
'c.addconditions' ,
'c.id'
), array (
'addfields' ,
'addfields_id' ,
'addconditions' ,
'addconditions_id'
2017-10-29 13:03:06 +02:00
)
2017-12-15 01:10:47 +02:00
)
);
2016-02-26 02:20:09 +02:00
$query -> from ( '#__componentbuilder_admin_view AS a' );
2017-10-29 13:03:06 +02:00
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_admin_fields' , 'b' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'b.admin_view' ) . ')' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_admin_fields_conditions' , 'c' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'c.admin_view' ) . ')' );
2017-12-15 01:10:47 +02:00
$query -> where ( $this -> db -> quoteName ( 'a.id' ) . ' = ' . ( int ) $id );
2016-02-26 02:20:09 +02:00
// Reset the query using our newly populated query object.
2017-02-14 01:24:38 +02:00
$this -> db -> setQuery ( $query );
2016-02-26 02:20:09 +02:00
// Load the results as a list of stdClass objects (see later for more options on retrieving data).
2017-02-14 01:24:38 +02:00
$view = $this -> db -> loadObject ();
2018-01-15 17:54:05 +02:00
2016-02-26 02:20:09 +02:00
// setup view name to use in storing the data
$name_single = ComponentbuilderHelper :: safeString ( $view -> name_single );
$name_list = ComponentbuilderHelper :: safeString ( $view -> name_list );
2017-12-15 01:10:47 +02:00
2017-10-29 13:03:06 +02:00
// set upater
$updater = array (
'unique' => array (
'addfields' => array ( 'table' => 'admin_fields' , 'val' => ( int ) $view -> addfields_id , 'key' => 'id' ),
'addconditions' => array ( 'table' => 'admin_fields_conditions' , 'val' => ( int ) $view -> addconditions_id , 'key' => 'id' )
),
'table' => 'admin_view' ,
'key' => 'id' ,
'val' => ( int ) $id
);
// repeatable fields to update
$searchRepeatables = array (
// repeatablefield => checker
'addfields' => 'field' ,
'addconditions' => 'target_field' ,
'ajax_input' => 'value_name' ,
'custom_button' => 'name' ,
2017-12-15 01:10:47 +02:00
'addlinked_views' => 'adminview' ,
2017-10-29 13:03:06 +02:00
'addtables' => 'table' ,
2017-12-15 01:10:47 +02:00
'addtabs' => 'name' ,
2017-10-29 13:03:06 +02:00
'addpermissions' => 'action'
);
// update the repeatable fields
$view = ComponentbuilderHelper :: convertRepeatableFields ( $view , $searchRepeatables , $updater );
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
// setup token check
2017-02-14 01:24:38 +02:00
if ( ! isset ( $this -> customScriptBuilder [ 'token' ]))
{
$this -> customScriptBuilder [ 'token' ] = array ();
}
2016-02-26 02:20:09 +02:00
$this -> customScriptBuilder [ 'token' ][ $name_single ] = false ;
$this -> customScriptBuilder [ 'token' ][ $name_list ] = false ;
2017-10-06 16:53:22 +02:00
// set some placeholders
$this -> placeholders [ '###view###' ] = ComponentbuilderHelper :: safeString ( $name_single );
$this -> placeholders [ '###views###' ] = ComponentbuilderHelper :: safeString ( $name_list );
$this -> placeholders [ '###View###' ] = ComponentbuilderHelper :: safeString ( $name_single , 'F' );
$this -> placeholders [ '###Views###' ] = ComponentbuilderHelper :: safeString ( $name_list , 'F' );
$this -> placeholders [ '###VIEW###' ] = ComponentbuilderHelper :: safeString ( $name_single , 'U' );
$this -> placeholders [ '###VIEWS###' ] = ComponentbuilderHelper :: safeString ( $name_list , 'U' );
$this -> placeholders [ '[[[view]]]' ] = $this -> placeholders [ '###view###' ];
$this -> placeholders [ '[[[views]]]' ] = $this -> placeholders [ '###views###' ];
$this -> placeholders [ '[[[View]]]' ] = $this -> placeholders [ '###View###' ];
$this -> placeholders [ '[[[Views]]]' ] = $this -> placeholders [ '###Views###' ];
$this -> placeholders [ '[[[VIEW]]]' ] = $this -> placeholders [ '###VIEW###' ];
2017-12-15 01:10:47 +02:00
$this -> placeholders [ '[[[VIEWS]]]' ] = $this -> placeholders [ '###VIEWS###' ];
2017-10-12 02:50:14 +02:00
// add the tables
2017-12-15 01:10:47 +02:00
$view -> addtables = ( isset ( $view -> addtables ) && ComponentbuilderHelper :: checkJson ( $view -> addtables )) ? json_decode ( $view -> addtables , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> addtables ))
2017-10-12 02:50:14 +02:00
{
$view -> tables = array_values ( $view -> addtables );
}
unset ( $view -> addtables );
// add the tabs
2017-12-15 01:10:47 +02:00
$view -> addtabs = ( isset ( $view -> addtabs ) && ComponentbuilderHelper :: checkJson ( $view -> addtabs )) ? json_decode ( $view -> addtabs , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> addtabs ))
2016-02-26 02:20:09 +02:00
{
2017-10-12 02:50:14 +02:00
$nr = 1 ;
foreach ( $view -> addtabs as $tab )
2016-02-26 02:20:09 +02:00
{
2017-10-26 18:43:51 +02:00
$view -> tabs [ $nr ] = trim ( $tab [ 'name' ]);
2017-10-12 02:50:14 +02:00
$nr ++ ;
2016-02-26 02:20:09 +02:00
}
}
2017-10-26 18:43:51 +02:00
// if Details tab is not set, then set it here
if ( ! isset ( $view -> tabs [ 1 ]))
{
2017-10-26 23:11:52 +02:00
$view -> tabs [ 1 ] = 'Details' ;
2017-10-26 18:43:51 +02:00
}
// always make sure that publishing is lowercase
if (( $removeKey = array_search ( 'publishing' , array_map ( 'strtolower' , $view -> tabs ))) !== false )
{
$view -> tabs [ $removeKey ] = 'publishing' ;
}
// make sure to set the publishing tab (just incase we need it)
$view -> tabs [ 15 ] = 'publishing' ;
2017-10-12 02:50:14 +02:00
unset ( $view -> addtabs );
// add permissions
2017-12-15 01:10:47 +02:00
$view -> addpermissions = ( isset ( $view -> addpermissions ) && ComponentbuilderHelper :: checkJson ( $view -> addpermissions )) ? json_decode ( $view -> addpermissions , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> addpermissions ))
2017-10-12 02:50:14 +02:00
{
$view -> permissions = array_values ( $view -> addpermissions );
2016-02-26 02:20:09 +02:00
}
2017-10-12 02:50:14 +02:00
unset ( $view -> addpermissions );
// reset fields
$view -> fields = array ();
// set fields
2017-12-15 01:10:47 +02:00
$view -> addfields = ( isset ( $view -> addfields ) && ComponentbuilderHelper :: checkJson ( $view -> addfields )) ? json_decode ( $view -> addfields , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> addfields ))
2016-02-26 02:20:09 +02:00
{
2017-10-13 01:14:17 +02:00
// build update SQL
2017-10-29 13:03:06 +02:00
if ( $old_view = $this -> getHistoryWatch ( 'admin_fields' , $view -> addfields_id ))
2017-10-13 01:14:17 +02:00
{
// add new fields were added
if ( isset ( $old_view -> addfields ) && ComponentbuilderHelper :: checkJson ( $old_view -> addfields ))
{
$this -> setUpdateSQL ( json_decode ( $old_view -> addfields , true ), $view -> addfields , 'field' , $name_single );
2017-12-15 01:10:47 +02:00
}
2017-10-13 01:14:17 +02:00
// clear this data
unset ( $old_view );
2016-02-26 02:20:09 +02:00
}
2017-10-13 01:14:17 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> addfields ))
{
2017-10-29 13:03:06 +02:00
// load the field data
2017-12-15 01:10:47 +02:00
$view -> fields = array_map ( function ( $array ) use ( $name_single , $name_list )
{
2017-10-29 13:03:06 +02:00
$array [ 'settings' ] = $this -> getFieldData ( $array [ 'field' ], $name_single , $name_list );
return $array ;
}, array_values ( $view -> addfields ));
2017-10-13 01:14:17 +02:00
// sort the fields acording to order
usort ( $view -> fields , function ( $a , $b )
{
if ( isset ( $a [ 'order_list' ]) && isset ( $b [ 'order_list' ]))
{
if ( $a [ 'order_list' ] != 0 && $b [ 'order_list' ] != 0 )
{
return $a [ 'order_list' ] - $b [ 'order_list' ];
}
elseif ( $b [ 'order_list' ] != 0 && $a [ 'order_list' ] == 0 )
{
return 1 ;
}
elseif ( $a [ 'order_list' ] != 0 && $b [ 'order_list' ] == 0 )
{
return 0 ;
}
return 1 ;
}
return 0 ;
});
}
2017-10-29 13:03:06 +02:00
}
2017-12-15 01:10:47 +02:00
unset ( $view -> addfields );
2017-10-12 02:50:14 +02:00
// build update SQL
if ( $old_view = $this -> getHistoryWatch ( 'admin_view' , $id ))
{
// check if the view name changed
if ( ComponentbuilderHelper :: checkString ( $old_view -> name_single ))
{
$this -> setUpdateSQL ( ComponentbuilderHelper :: safeString ( $old_view -> name_single ), $name_single , 'table_name' , $name_single );
2017-12-15 01:10:47 +02:00
}
2017-10-12 02:50:14 +02:00
// clear this data
unset ( $old_view );
2017-12-15 01:10:47 +02:00
}
2017-10-13 01:14:17 +02:00
// set the conditions
2017-12-15 01:10:47 +02:00
$view -> addconditions = ( isset ( $view -> addconditions ) && ComponentbuilderHelper :: checkJson ( $view -> addconditions )) ? json_decode ( $view -> addconditions , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> addconditions ))
2017-10-12 02:50:14 +02:00
{
2017-10-29 13:03:06 +02:00
$view -> conditions = array ();
$ne = 0 ;
foreach ( $view -> addconditions as $nr => $conditionValue )
2017-10-13 01:14:17 +02:00
{
2017-10-29 13:03:06 +02:00
if ( ComponentbuilderHelper :: checkArray ( $conditionValue [ 'target_field' ]) && ComponentbuilderHelper :: checkArray ( $view -> fields ))
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
foreach ( $conditionValue [ 'target_field' ] as $fieldKey => $fieldId )
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
foreach ( $view -> fields as $fieldValues )
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
if (( int ) $fieldValues [ 'field' ] == ( int ) $fieldId )
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
// load the field details
2017-12-15 01:10:47 +02:00
$required = ComponentbuilderHelper :: getBetween ( $fieldValues [ 'settings' ] -> xml , 'required="' , '"' );
$required = ( $required == true ) ? 'yes' : 'no' ;
$filter = ComponentbuilderHelper :: getBetween ( $fieldValues [ 'settings' ] -> xml , 'filter="' , '"' );
$filter = ComponentbuilderHelper :: checkString ( $filter ) ? $filter : 'none' ;
2017-10-29 13:03:06 +02:00
// get name
2017-12-15 01:10:47 +02:00
$name = ComponentbuilderHelper :: getBetween ( $fieldValues [ 'settings' ] -> xml , 'name="' , '"' );
$name = ComponentbuilderHelper :: checkString ( $name ) ? $name : $fieldValues [ 'settings' ] -> name ;
2017-10-29 13:03:06 +02:00
// get type
2017-12-15 01:10:47 +02:00
$type = ComponentbuilderHelper :: getBetween ( $fieldValues [ 'settings' ] -> xml , 'type="' , '"' );
$type = ComponentbuilderHelper :: checkString ( $type ) ? $type : $fieldValues [ 'settings' ] -> type_name ;
2017-10-29 13:03:06 +02:00
// set the field name
$conditionValue [ 'target_field' ][ $fieldKey ] = array (
'name' => ComponentbuilderHelper :: safeString ( $name ),
'type' => ComponentbuilderHelper :: safeString ( $type ),
'required' => $required ,
'filter' => $filter
2017-12-15 01:10:47 +02:00
);
2017-10-29 13:03:06 +02:00
break ;
2016-02-26 02:20:09 +02:00
}
}
}
2017-10-29 13:03:06 +02:00
}
2017-10-13 01:14:17 +02:00
2017-10-29 13:03:06 +02:00
// load match field
if ( ComponentbuilderHelper :: checkArray ( $view -> fields ) && isset ( $conditionValue [ 'match_field' ]))
{
foreach ( $view -> fields as $fieldValue )
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
if (( int ) $fieldValue [ 'field' ] == ( int ) $conditionValue [ 'match_field' ])
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
// get name
2017-12-15 01:10:47 +02:00
$name = ComponentbuilderHelper :: getBetween ( $fieldValue [ 'settings' ] -> xml , 'name="' , '"' );
2017-10-29 13:03:06 +02:00
$name = ComponentbuilderHelper :: checkString ( $name ) ? $name : $fieldValue [ 'settings' ] -> name ;
// get type
2017-12-15 01:10:47 +02:00
$type = ComponentbuilderHelper :: getBetween ( $fieldValue [ 'settings' ] -> xml , 'type="' , '"' );
2017-10-29 13:03:06 +02:00
$type = ComponentbuilderHelper :: checkString ( $type ) ? $type : $fieldValue [ 'settings' ] -> type_name ;
// set the field details
2017-12-15 01:10:47 +02:00
$conditionValue [ 'match_name' ] = ComponentbuilderHelper :: safeString ( $name );
$conditionValue [ 'match_type' ] = ComponentbuilderHelper :: safeString ( $type );
$conditionValue [ 'match_xml' ] = $fieldValue [ 'settings' ] -> xml ;
2017-10-29 13:03:06 +02:00
// if custom field load field being extended
if ( ! ComponentbuilderHelper :: typeField ( $type ))
2017-10-12 02:50:14 +02:00
{
2017-12-15 01:10:47 +02:00
$conditionValue [ 'match_extends' ] = ComponentbuilderHelper :: getBetween ( $fieldValue [ 'settings' ] -> xml , 'extends="' , '"' );
2017-10-12 02:50:14 +02:00
}
2017-10-29 13:03:06 +02:00
else
{
$conditionValue [ 'match_extends' ] = '' ;
}
break ;
2016-02-26 02:20:09 +02:00
}
}
}
2017-10-29 13:03:06 +02:00
// set condition values
$view -> conditions [ $ne ] = $conditionValue ;
$ne ++ ;
2016-02-26 02:20:09 +02:00
}
}
2017-10-29 13:03:06 +02:00
unset ( $view -> addconditions );
2016-02-26 02:20:09 +02:00
// set linked views
2017-10-12 02:50:14 +02:00
$this -> linkedAdminViews [ $name_single ] = null ;
2017-12-15 01:10:47 +02:00
$view -> addlinked_views = ( isset ( $view -> addlinked_views ) && ComponentbuilderHelper :: checkJson ( $view -> addlinked_views )) ? json_decode ( $view -> addlinked_views , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> addlinked_views ))
2017-10-12 02:50:14 +02:00
{
// setup linked views to global data sets
$this -> linkedAdminViews [ $name_single ] = array_values ( $view -> addlinked_views );
2016-02-26 02:20:09 +02:00
}
2017-10-12 02:50:14 +02:00
unset ( $view -> addlinked_views );
2016-06-23 16:05:37 +01:00
// set the lang target
$this -> lang = 'admin' ;
// add_javascript
2017-12-15 01:10:47 +02:00
$addArrayJ = array ( 'javascript_view_file' , 'javascript_view_footer' , 'javascript_views_file' , 'javascript_views_footer' );
2016-06-23 16:05:37 +01:00
foreach ( $addArrayJ as $scripter )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( isset ( $view -> { 'add_' . $scripter }) && $view -> { 'add_' . $scripter } == 1 && ComponentbuilderHelper :: checkString ( $view -> $scripter ))
2016-02-26 02:20:09 +02:00
{
2017-02-14 01:24:38 +02:00
$view -> $scripter = $this -> setDynamicValues ( base64_decode ( $view -> $scripter ));
2016-06-23 16:05:37 +01:00
$scripter_target = str_replace ( 'javascript_' , '' , $scripter );
if ( ! isset ( $this -> customScriptBuilder [ $scripter_target ][ $name_single ]))
2016-02-26 02:20:09 +02:00
{
2016-06-23 16:05:37 +01:00
if ( ! isset ( $this -> customScriptBuilder [ $scripter_target ]))
{
$this -> customScriptBuilder [ $scripter_target ] = array ();
}
$this -> customScriptBuilder [ $scripter_target ][ $name_single ] = '' ;
2016-02-26 02:20:09 +02:00
}
2016-06-23 16:05:37 +01:00
$this -> customScriptBuilder [ $scripter_target ][ $name_single ] .= $view -> $scripter ;
2017-12-15 01:10:47 +02:00
if ( strpos ( $view -> $scripter , " token " ) !== false || strpos ( $view -> $scripter , " task=ajax " ) !== false )
2016-02-26 02:20:09 +02:00
{
2016-06-23 16:05:37 +01:00
if ( ! $this -> customScriptBuilder [ 'token' ][ $name_single ])
{
$this -> customScriptBuilder [ 'token' ][ $name_single ] = true ;
}
2016-02-26 02:20:09 +02:00
}
2016-06-23 16:05:37 +01:00
unset ( $view -> $scripter );
2016-02-26 02:20:09 +02:00
}
}
2016-06-23 16:05:37 +01:00
// add_css
$addArrayC = array ( 'css_view' , 'css_views' );
foreach ( $addArrayC as $scripter )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( isset ( $view -> { 'add_' . $scripter }) && $view -> { 'add_' . $scripter } == 1 )
2016-02-26 02:20:09 +02:00
{
2016-06-23 16:05:37 +01:00
if ( ! isset ( $this -> customScriptBuilder [ $scripter ][ $name_single ]))
2016-02-26 02:20:09 +02:00
{
2016-06-23 16:05:37 +01:00
$this -> customScriptBuilder [ $scripter ][ $name_single ] = '' ;
2016-02-26 02:20:09 +02:00
}
2016-06-23 16:05:37 +01:00
$this -> customScriptBuilder [ $scripter ][ $name_single ] .= base64_decode ( $view -> $scripter );
unset ( $view -> $scripter );
2016-02-26 02:20:09 +02:00
}
}
2016-06-23 16:05:37 +01:00
// add_php
2017-12-15 01:10:47 +02:00
$addArrayP = array ( 'php_getitem' , 'php_before_save' , 'php_save' , 'php_postsavehook' , 'php_getitems' , 'php_getitems_after_all' , 'php_getlistquery' , 'php_allowedit' , 'php_before_delete' , 'php_after_delete' , 'php_before_publish' , 'php_after_publish' , 'php_batchcopy' , 'php_batchmove' , 'php_document' );
2016-06-23 16:05:37 +01:00
foreach ( $addArrayP as $scripter )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( isset ( $view -> { 'add_' . $scripter }) && $view -> { 'add_' . $scripter } == 1 )
2016-02-26 02:20:09 +02:00
{
2017-02-14 01:24:38 +02:00
$this -> customScriptBuilder [ $scripter ][ $name_single ] = $this -> setDynamicValues ( base64_decode ( $view -> $scripter ));
2016-02-26 02:20:09 +02:00
unset ( $view -> $scripter );
}
}
2017-12-15 01:10:47 +02:00
// add the custom buttons
if ( isset ( $view -> add_custom_button ) && $view -> add_custom_button == 1 )
{
2017-03-02 02:55:04 +02:00
// set for the edit views
2017-12-15 01:10:47 +02:00
if ( ComponentbuilderHelper :: checkString ( $view -> php_model ))
{
$view -> php_model = $this -> setDynamicValues ( base64_decode ( $view -> php_model ));
}
2017-03-02 02:55:04 +02:00
if ( ComponentbuilderHelper :: checkString ( $view -> php_controller ))
2017-12-15 01:10:47 +02:00
{
2017-02-14 01:24:38 +02:00
$view -> php_controller = $this -> setDynamicValues ( base64_decode ( $view -> php_controller ));
}
2017-03-02 02:55:04 +02:00
// set for the list views
2017-12-15 01:10:47 +02:00
if ( isset ( $view -> php_model_list ) && ComponentbuilderHelper :: checkString ( $view -> php_model_list ))
{
$view -> php_model_list = $this -> setDynamicValues ( base64_decode ( $view -> php_model_list ));
}
2017-03-02 02:55:04 +02:00
if ( isset ( $view -> php_controller_list ) && ComponentbuilderHelper :: checkString ( $view -> php_controller_list ))
2017-12-15 01:10:47 +02:00
{
2017-03-02 02:55:04 +02:00
$view -> php_controller_list = $this -> setDynamicValues ( base64_decode ( $view -> php_controller_list ));
}
2017-12-15 01:10:47 +02:00
// set the button array
$view -> custom_button = ( isset ( $view -> custom_button ) && ComponentbuilderHelper :: checkJson ( $view -> custom_button )) ? json_decode ( $view -> custom_button , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> custom_button ))
2017-12-15 01:10:47 +02:00
{
$view -> custom_buttons = array_values ( $view -> custom_button );
}
unset ( $view -> custom_button );
}
2016-05-04 05:53:33 +01:00
// set custom import scripts
if ( isset ( $view -> add_custom_import ) && $view -> add_custom_import == 1 )
{
2018-01-18 01:14:43 +02:00
$addImportArray = array ( 'php_import_ext' , 'php_import_display' , 'php_import' , 'php_import_setdata' , 'php_import_save' , 'php_import_headers' , 'html_import_view' );
2016-05-04 05:53:33 +01:00
foreach ( $addImportArray as $importScripter )
{
if ( isset ( $view -> $importScripter ) && strlen ( $view -> $importScripter ) > 0 )
{
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $importScripter ][ 'import_' . $name_list ] = $this -> setDynamicValues ( base64_decode ( $view -> $importScripter ));
2016-05-04 05:53:33 +01:00
unset ( $view -> $importScripter );
}
2017-03-27 14:38:51 +02:00
else
{
// load the default
2018-01-24 00:05:57 +02:00
$this -> customScriptBuilder [ $importScripter ][ 'import_' . $name_list ] = ComponentbuilderHelper :: getDynamicScripts ( $importScripter , true );
2017-03-27 14:38:51 +02:00
}
2016-05-04 05:53:33 +01:00
}
}
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
// add_Ajax for this view
2016-05-10 06:47:47 +01:00
if ( isset ( $view -> add_php_ajax ) && $view -> add_php_ajax == 1 )
2016-02-26 02:20:09 +02:00
{
2017-02-14 01:24:38 +02:00
// insure the token is added to edit view atleast
$this -> customScriptBuilder [ 'token' ][ $name_single ] = true ;
2016-02-26 02:20:09 +02:00
$addAjaxSite = false ;
if ( isset ( $this -> siteEditView [ $id ]) && $this -> siteEditView [ $id ])
{
2017-02-14 01:24:38 +02:00
// we should add this site ajax to front ajax
2016-02-26 02:20:09 +02:00
$addAjaxSite = true ;
if ( ! isset ( $this -> addSiteAjax ) || ! $this -> addSiteAjax )
{
$this -> addSiteAjax = true ;
}
}
// check if controller input as been set
2017-12-15 01:10:47 +02:00
$view -> ajax_input = ( isset ( $view -> ajax_input ) && ComponentbuilderHelper :: checkJson ( $view -> ajax_input )) ? json_decode ( $view -> ajax_input , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> ajax_input ))
2017-10-12 02:50:14 +02:00
{
if ( $addAjaxSite )
{
$this -> customScriptBuilder [ 'site' ][ 'ajax_controller' ][ $name_single ] = array_values ( $view -> ajax_input );
}
$this -> customScriptBuilder [ 'admin' ][ 'ajax_controller' ][ $name_single ] = array_values ( $view -> ajax_input );
2016-05-10 06:47:47 +01:00
$this -> addAjax = true ;
unset ( $view -> ajax_input );
}
if ( ComponentbuilderHelper :: checkString ( $view -> php_ajaxmethod ))
{
2017-02-14 01:24:38 +02:00
$this -> customScriptBuilder [ 'admin' ][ 'ajax_model' ][ $name_single ] = $this -> setDynamicValues ( base64_decode ( $view -> php_ajaxmethod ));
2016-02-26 02:20:09 +02:00
if ( $addAjaxSite )
{
2017-02-14 01:24:38 +02:00
$this -> customScriptBuilder [ 'site' ][ 'ajax_model' ][ $name_single ] = $this -> customScriptBuilder [ 'admin' ][ 'ajax_model' ][ $name_single ];
2016-02-26 02:20:09 +02:00
}
2016-05-10 06:47:47 +01:00
// unset anyway
unset ( $view -> php_ajaxmethod );
2016-02-26 02:20:09 +02:00
$this -> addAjax = true ;
}
}
// add_sql
if ( $view -> add_sql == 1 )
{
2017-08-22 23:17:19 +01:00
if ( $view -> source == 1 && isset ( $view -> tables ))
2016-02-26 02:20:09 +02:00
{
// build and add the SQL dump
2017-10-12 02:50:14 +02:00
$this -> customScriptBuilder [ 'sql' ][ $name_single ] = $this -> buildSqlDump ( $view -> tables , $name_single , $id );
2016-02-26 02:20:09 +02:00
unset ( $view -> tables );
}
2017-08-22 23:17:19 +01:00
elseif ( $view -> source == 2 && isset ( $view -> sql ))
2016-02-26 02:20:09 +02:00
{
// add the SQL dump string
$this -> customScriptBuilder [ 'sql' ][ $name_single ] = base64_decode ( $view -> sql );
unset ( $view -> sql );
}
}
2017-10-06 16:53:22 +02:00
// clear placeholders
unset ( $this -> placeholders [ '###view###' ]);
unset ( $this -> placeholders [ '###views###' ]);
unset ( $this -> placeholders [ '###View###' ]);
unset ( $this -> placeholders [ '###Views###' ]);
unset ( $this -> placeholders [ '###VIEW###' ]);
unset ( $this -> placeholders [ '###VIEWS###' ]);
unset ( $this -> placeholders [ '[[[view]]]' ]);
unset ( $this -> placeholders [ '[[[views]]]' ]);
unset ( $this -> placeholders [ '[[[View]]]' ]);
unset ( $this -> placeholders [ '[[[Views]]]' ]);
unset ( $this -> placeholders [ '[[[VIEW]]]' ]);
unset ( $this -> placeholders [ '[[[VIEWS]]]' ]);
2018-01-15 17:54:05 +02:00
2017-06-16 13:38:06 +01:00
// store this view to class object
2016-02-26 02:20:09 +02:00
$this -> _adminViewData [ $id ] = $view ;
}
// return the found view data
return $this -> _adminViewData [ $id ];
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Get all Custom View Data
*
2016-03-01 20:44:13 +02:00
* @ param int $id The view ID
2016-02-26 02:20:09 +02:00
* @ param string $table The view table
2017-10-20 18:17:46 +02:00
*
2016-02-26 02:20:09 +02:00
* @ return oject The view data
*
*/
public function getCustomViewData ( $id , $table = 'site_view' )
{
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
2016-02-26 02:20:09 +02:00
$query -> select ( 'a.*' );
2017-12-15 01:10:47 +02:00
$query -> from ( '#__componentbuilder_' . $table . ' AS a' );
$query -> where ( $this -> db -> quoteName ( 'a.id' ) . ' = ' . ( int ) $id );
2016-02-26 02:20:09 +02:00
// Reset the query using our newly populated query object.
2017-02-14 01:24:38 +02:00
$this -> db -> setQuery ( $query );
2016-02-26 02:20:09 +02:00
// Load the results as a list of stdClass objects (see later for more options on retrieving data).
2017-02-14 01:24:38 +02:00
$view = $this -> db -> loadObject ();
2017-02-01 15:17:04 +02:00
if ( $table === 'site_view' )
2016-02-26 02:20:09 +02:00
{
$this -> lang = 'site' ;
2017-10-29 13:03:06 +02:00
// repeatable fields to update
$searchRepeatables = array (
// repeatablefield => checker
'ajax_input' => 'value_name' ,
'custom_button' => 'name'
);
2016-02-26 02:20:09 +02:00
}
else
{
$this -> lang = 'admin' ;
2017-10-29 13:03:06 +02:00
// repeatable fields to update
$searchRepeatables = array (
// repeatablefield => checker
'custom_button' => 'name'
);
2016-02-26 02:20:09 +02:00
}
2017-10-29 13:03:06 +02:00
// set upater
$updater = array (
'table' => $table ,
'key' => 'id' ,
'val' => ( int ) $id
2017-12-15 01:10:47 +02:00
);
2017-10-29 13:03:06 +02:00
// update the repeatable fields
$view = ComponentbuilderHelper :: convertRepeatableFields ( $view , $searchRepeatables , $updater );
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
// set the default data
2017-02-14 01:24:38 +02:00
$view -> default = $this -> setDynamicValues ( base64_decode ( $view -> default ));
2016-02-26 02:20:09 +02:00
// fix alias to use in code
2017-02-04 02:22:17 +02:00
$view -> code = $this -> uniqueCode ( ComponentbuilderHelper :: safeString ( $view -> codename ));
2016-02-26 02:20:09 +02:00
$view -> Code = ComponentbuilderHelper :: safeString ( $view -> code , 'F' );
2017-12-15 01:10:47 +02:00
$view -> CODE = ComponentbuilderHelper :: safeString ( $view -> code , 'U' );
2017-12-10 21:17:26 +02:00
// load the library
if ( ! isset ( $this -> libManager [ $this -> target ]))
{
$this -> libManager [ $this -> target ] = array ();
}
if ( ! isset ( $this -> libManager [ $this -> target ][ $view -> code ]))
{
$this -> libManager [ $this -> target ][ $view -> code ] = array ();
}
// make sure json become array
if ( ComponentbuilderHelper :: checkJson ( $view -> libraries ))
{
$view -> libraries = json_decode ( $view -> libraries , true );
}
// if we have an array add it
if ( ComponentbuilderHelper :: checkArray ( $view -> libraries ))
{
foreach ( $view -> libraries as $library )
{
if ( ! isset ( $this -> libManager [ $this -> target ][ $view -> code ][ $library ]))
{
if ( $this -> getLibrary (( int ) $library ))
{
$this -> libManager [ $this -> target ][ $view -> code ][( int ) $library ] = true ;
}
}
}
}
elseif ( is_numeric ( $view -> libraries ) && ! isset ( $this -> libManager [ $this -> target ][ $view -> code ][( int ) $view -> libraries ]))
{
if ( $this -> getLibrary (( int ) $view -> libraries ))
{
$this -> libManager [ $this -> target ][ $view -> code ][( int ) $view -> libraries ] = true ;
}
}
// setup template array
$this -> templateData [ $this -> target ][ $view -> code ] = array ();
// setup template and layout data
2017-12-15 01:10:47 +02:00
$this -> setTemplateAndLayoutData ( $view -> default , $view -> code );
2016-02-26 02:20:09 +02:00
// insure the uikit components are loaded
2017-11-11 06:33:51 +02:00
if ( 2 == $this -> uikit || 1 == $this -> uikit )
2016-02-26 02:20:09 +02:00
{
2017-11-11 06:33:51 +02:00
if ( ! isset ( $this -> uikitComp [ $view -> code ]))
{
$this -> uikitComp [ $view -> code ] = array ();
}
2017-12-15 01:10:47 +02:00
$this -> uikitComp [ $view -> code ] = ComponentbuilderHelper :: getUikitComp ( $view -> default , $this -> uikitComp [ $view -> code ]);
2016-02-26 02:20:09 +02:00
}
// check for footable
if ( ! isset ( $this -> footableScripts [ $this -> target ][ $view -> code ]) || ! $this -> footableScripts [ $this -> target ][ $view -> code ])
{
$foundFoo = $this -> getFootableScripts ( $view -> default );
if ( $foundFoo )
{
$this -> footableScripts [ $this -> target ][ $view -> code ] = true ;
}
if ( $foundFoo && ! $this -> footableScripts )
{
$this -> footable = true ;
}
}
// check for get module
if ( ! isset ( $this -> getModule [ $this -> target ][ $view -> code ]) || ! $this -> getModule [ $this -> target ][ $view -> code ])
{
$found = $this -> getGetModule ( $view -> default );
if ( $found )
{
$this -> getModule [ $this -> target ][ $view -> code ] = true ;
}
}
// set the main get data
2017-12-15 01:10:47 +02:00
$main_get = $this -> setGetData ( array ( $view -> main_get ), $view -> code );
2016-02-26 02:20:09 +02:00
$view -> main_get = $main_get [ 0 ];
// set the custom_get data
2017-12-15 01:10:47 +02:00
$view -> custom_get = $this -> setGetData ( json_decode ( $view -> custom_get , true ), $view -> code );
2016-02-26 02:20:09 +02:00
// set array adding array of scripts
2017-12-15 01:10:47 +02:00
$addArray = array ( 'php_view' , 'php_jview' , 'php_jview_display' , 'php_document' , 'javascript_file' , 'js_document' , 'css_document' , 'css' );
2016-02-26 02:20:09 +02:00
foreach ( $addArray as $scripter )
{
2017-12-15 01:10:47 +02:00
if ( isset ( $view -> { 'add_' . $scripter }) && $view -> { 'add_' . $scripter } == 1 && ComponentbuilderHelper :: checkString ( $view -> $scripter ))
2016-02-26 02:20:09 +02:00
{
2017-02-14 01:24:38 +02:00
$view -> $scripter = $this -> setDynamicValues ( base64_decode ( $view -> $scripter ));
2017-11-11 06:33:51 +02:00
if ( 2 == $this -> uikit || 1 == $this -> uikit )
{
2017-12-13 00:17:02 +02:00
if ( ! isset ( $this -> uikitComp [ $view -> code ]))
{
$this -> uikitComp [ $view -> code ] = array ();
}
2017-11-11 06:33:51 +02:00
// set uikit to views
2017-12-15 01:10:47 +02:00
$this -> uikitComp [ $view -> code ] = ComponentbuilderHelper :: getUikitComp ( $view -> $scripter , $this -> uikitComp [ $view -> code ]);
2017-11-11 06:33:51 +02:00
}
2017-12-15 01:10:47 +02:00
$this -> setTemplateAndLayoutData ( $view -> $scripter , $view -> code );
2016-02-26 02:20:09 +02:00
// check for footable
if ( ! isset ( $this -> footableScripts [ $this -> target ][ $view -> code ]) || ! $this -> footableScripts [ $this -> target ][ $view -> code ])
{
$foundFoo = $this -> getFootableScripts ( $view -> $scripter );
if ( $foundFoo )
{
$this -> footableScripts [ $this -> target ][ $view -> code ] = true ;
}
if ( $foundFoo && ! $this -> footable )
{
$this -> footable = true ;
}
}
// check for google chart
if ( ! isset ( $this -> googleChart [ $this -> target ][ $view -> code ]) || ! $this -> googleChart [ $this -> target ][ $view -> code ])
{
$found = $this -> getGoogleChart ( $view -> $scripter );
if ( $found )
{
$this -> googleChart [ $this -> target ][ $view -> code ] = true ;
}
if ( $found && ! $this -> googlechart )
{
$this -> googlechart = true ;
}
}
// check for get module
if ( ! isset ( $this -> getModule [ $this -> target ][ $view -> code ]) || ! $this -> getModule [ $this -> target ][ $view -> code ])
{
$found = $this -> getGetModule ( $view -> $scripter );
if ( $found )
{
$this -> getModule [ $this -> target ][ $view -> code ] = true ;
}
}
}
}
// add_Ajax for this view
if ( isset ( $view -> add_php_ajax ) && $view -> add_php_ajax == 1 )
{
2018-01-15 17:54:05 +02:00
// ajax target (since we only have two options really)
if ( 'site' === $this -> target )
{
$target = 'site' ;
}
else
{
$target = 'admin' ;
}
$setAjax = false ;
2016-02-26 02:20:09 +02:00
// check if controller input as been set
2017-12-15 01:10:47 +02:00
$view -> ajax_input = ( isset ( $view -> ajax_input ) && ComponentbuilderHelper :: checkJson ( $view -> ajax_input )) ? json_decode ( $view -> ajax_input , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> ajax_input ))
2017-10-12 02:50:14 +02:00
{
2018-01-15 17:54:05 +02:00
$this -> customScriptBuilder [ $target ][ 'ajax_controller' ][ $view -> code ] = array_values ( $view -> ajax_input );
$setAjax = true ;
2016-02-26 02:20:09 +02:00
}
2017-10-29 13:03:06 +02:00
unset ( $view -> ajax_input );
// load the ajax class mathods (if set)
2016-05-10 06:47:47 +01:00
if ( ComponentbuilderHelper :: checkString ( $view -> php_ajaxmethod ))
{
2018-01-15 17:54:05 +02:00
$this -> customScriptBuilder [ $target ][ 'ajax_model' ][ $view -> code ] = $this -> setDynamicValues ( base64_decode ( $view -> php_ajaxmethod ));
$setAjax = true ;
2016-05-10 06:47:47 +01:00
}
2016-02-26 02:20:09 +02:00
// unset anyway
unset ( $view -> php_ajaxmethod );
2018-01-15 17:54:05 +02:00
// should ajax be set
if ( $setAjax )
{
// turn on ajax area
if ( 'site' === $this -> target )
{
$this -> addSiteAjax = true ;
}
else
{
$this -> addAjax = true ;
}
}
2016-02-26 02:20:09 +02:00
}
// add the custom buttons
if ( isset ( $view -> add_custom_button ) && $view -> add_custom_button == 1 )
{
if ( ComponentbuilderHelper :: checkString ( $view -> php_model ))
{
$view -> php_model = base64_decode ( $view -> php_model );
2017-02-14 01:24:38 +02:00
$view -> php_model = $this -> setDynamicValues ( $view -> php_model );
2016-02-26 02:20:09 +02:00
}
$view -> php_controller = base64_decode ( $view -> php_controller );
2017-02-14 01:24:38 +02:00
$view -> php_controller = $this -> setDynamicValues ( $view -> php_controller );
2016-02-26 02:20:09 +02:00
// set the button array
2017-12-15 01:10:47 +02:00
$view -> custom_button = ( isset ( $view -> custom_button ) && ComponentbuilderHelper :: checkJson ( $view -> custom_button )) ? json_decode ( $view -> custom_button , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $view -> custom_button ))
2017-10-12 02:50:14 +02:00
{
$view -> custom_buttons = array_values ( $view -> custom_button );
2016-02-26 02:20:09 +02:00
}
2017-10-12 02:50:14 +02:00
unset ( $view -> custom_button );
}
2016-02-26 02:20:09 +02:00
// return the found view data
return $view ;
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Get all Field Data
*
2016-03-01 20:44:13 +02:00
* @ param int $id The field ID
2016-02-26 02:20:09 +02:00
* @ param string $name_single The view edit or single name
* @ param string $name_list The view list name
*
* @ return oject The field data
*
*/
2017-10-12 02:50:14 +02:00
public function getFieldData ( $id , $name_single = null , $name_list = null )
2016-02-26 02:20:09 +02:00
{
2017-10-29 13:03:06 +02:00
if ( $id > 0 && ! isset ( $this -> _fieldData [ $id ]))
2016-02-26 02:20:09 +02:00
{
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
2016-02-26 02:20:09 +02:00
// Order it by the ordering field.
$query -> select ( 'a.*' );
2017-10-12 02:50:14 +02:00
$query -> select ( $this -> db -> quoteName ( array ( 'c.name' , 'c.properties' ), array ( 'type_name' , 'properties' )));
2016-02-26 02:20:09 +02:00
$query -> from ( '#__componentbuilder_field AS a' );
2017-02-14 01:24:38 +02:00
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_fieldtype' , 'c' ) . ' ON (' . $this -> db -> quoteName ( 'a.fieldtype' ) . ' = ' . $this -> db -> quoteName ( 'c.id' ) . ')' );
2017-12-15 01:10:47 +02:00
$query -> where ( $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quote ( $id ));
2016-02-26 02:20:09 +02:00
// Reset the query using our newly populated query object.
2017-02-14 01:24:38 +02:00
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
if ( $this -> db -> getNumRows ())
2016-06-23 16:05:37 +01:00
{
// Load the results as a list of stdClass objects (see later for more options on retrieving data).
2017-02-14 01:24:38 +02:00
$field = $this -> db -> loadObject ();
2016-02-26 02:20:09 +02:00
2016-06-23 16:05:37 +01:00
// adding a fix for the changed name of type to fieldtype
$field -> type = $field -> fieldtype ;
2017-12-15 01:10:47 +02:00
2017-10-29 13:03:06 +02:00
// repeatable fields to update
$searchRepeatables = array (
// repeatablefield => checker
'properties' => 'name'
);
// set upater
$updater = array (
'table' => 'fieldtype' ,
'key' => 'id' ,
'val' => ( int ) $id
);
// update the repeatable fields
$field = ComponentbuilderHelper :: convertRepeatableFields ( $field , $searchRepeatables , $updater );
2016-02-26 02:20:09 +02:00
2016-06-23 16:05:37 +01:00
// load the values form params
2017-02-17 20:35:18 +02:00
$field -> xml = $this -> setDynamicValues ( json_decode ( $field -> xml ));
2016-02-26 02:20:09 +02:00
2016-06-23 16:05:37 +01:00
// load the type values form type params
2017-12-15 01:10:47 +02:00
$field -> properties = ( isset ( $field -> properties ) && ComponentbuilderHelper :: checkJson ( $field -> properties )) ? json_decode ( $field -> properties , true ) : null ;
2017-10-29 15:51:43 +02:00
if ( ComponentbuilderHelper :: checkArray ( $field -> properties ))
2017-10-12 02:50:14 +02:00
{
2017-10-29 13:03:06 +02:00
$field -> properties = array_values ( $field -> properties );
2017-10-12 02:50:14 +02:00
}
2018-03-06 04:28:44 +02:00
// check if we have WHMCS encryption
if ( 4 == $field -> store && ( ! isset ( $this -> whmcsEncryption ) || ! $this -> whmcsEncryption ))
2016-06-23 16:05:37 +01:00
{
2018-03-06 04:28:44 +02:00
$this -> whmcsEncryption = true ;
2016-06-23 16:05:37 +01:00
}
// check if we have basic encryption
2017-12-15 01:10:47 +02:00
elseif ( 3 == $field -> store && ( ! isset ( $this -> basicEncryption ) || ! $this -> basicEncryption ))
2016-06-23 16:05:37 +01:00
{
2017-12-15 01:10:47 +02:00
$this -> basicEncryption = true ;
2016-06-23 16:05:37 +01:00
}
2018-03-06 04:28:44 +02:00
// check if we have better encryption
elseif ( 5 == $field -> store && ( ! isset ( $this -> mediumEncryption ) || ! $this -> mediumEncryption ))
{
$this -> mediumEncryption = true ;
}
2017-12-15 01:10:47 +02:00
2017-06-16 13:38:06 +01:00
// get the last used version
$field -> history = $this -> getHistoryWatch ( 'field' , $id );
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
$this -> _fieldData [ $id ] = $field ;
}
else
{
return false ;
}
}
// check if the script should be added to the view each time this field is called
2017-10-29 13:03:06 +02:00
if ( $id > 0 && isset ( $this -> _fieldData [ $id ]))
2017-02-01 15:17:04 +02:00
{
// check if we should load scripts for single view
if ( ComponentbuilderHelper :: checkString ( $name_single ) && ! isset ( $this -> customFieldScript [ $name_single ][ $id ]))
{
// add_javascript_view_footer
2017-03-27 14:38:51 +02:00
if ( $this -> _fieldData [ $id ] -> add_javascript_view_footer == 1 && ComponentbuilderHelper :: checkString ( $this -> _fieldData [ $id ] -> javascript_view_footer ))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> customScriptBuilder [ 'view_footer' ]))
2016-02-26 02:20:09 +02:00
{
2017-02-01 15:17:04 +02:00
$this -> customScriptBuilder [ 'view_footer' ] = array ();
}
if ( ! isset ( $this -> customScriptBuilder [ 'view_footer' ][ $name_single ]))
{
$this -> customScriptBuilder [ 'view_footer' ][ $name_single ] = '' ;
}
if ( ! isset ( $this -> _fieldData [ $id ] -> javascript_view_footer_decoded ))
{
2017-02-14 01:24:38 +02:00
$this -> _fieldData [ $id ] -> javascript_view_footer = $this -> setDynamicValues ( base64_decode ( $this -> _fieldData [ $id ] -> javascript_view_footer ));
2017-02-01 15:17:04 +02:00
$this -> _fieldData [ $id ] -> javascript_view_footer_decoded = true ;
}
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ 'view_footer' ][ $name_single ] .= PHP_EOL . $this -> _fieldData [ $id ] -> javascript_view_footer ;
if ( strpos ( $this -> _fieldData [ $id ] -> javascript_view_footer , " token " ) !== false ||
strpos ( $this -> _fieldData [ $id ] -> javascript_view_footer , " task=ajax " ) !== false )
2017-02-01 15:17:04 +02:00
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> customScriptBuilder [ 'token' ]))
2017-02-14 01:24:38 +02:00
{
$this -> customScriptBuilder [ 'token' ] = array ();
}
2017-02-01 15:17:04 +02:00
if ( ! isset ( $this -> customScriptBuilder [ 'token' ][ $name_single ]) || ! $this -> customScriptBuilder [ 'token' ][ $name_single ])
2016-06-23 16:05:37 +01:00
{
2017-02-01 15:17:04 +02:00
$this -> customScriptBuilder [ 'token' ][ $name_single ] = true ;
2016-06-23 16:05:37 +01:00
}
2016-02-26 02:20:09 +02:00
}
2017-02-01 15:17:04 +02:00
}
2016-02-26 02:20:09 +02:00
2017-02-01 15:17:04 +02:00
// add_css_view
if ( $this -> _fieldData [ $id ] -> add_css_view == 1 )
{
if ( ! isset ( $this -> customScriptBuilder [ 'css_view' ]))
2016-02-26 02:20:09 +02:00
{
2017-02-01 15:17:04 +02:00
$this -> customScriptBuilder [ 'css_view' ] = array ();
2016-02-26 02:20:09 +02:00
}
2017-02-01 15:17:04 +02:00
if ( ! isset ( $this -> customScriptBuilder [ 'css_view' ][ $name_single ]))
{
$this -> customScriptBuilder [ 'css_view' ][ $name_single ] = '' ;
}
if ( ! isset ( $this -> _fieldData [ $id ] -> css_view_decoded ))
{
2017-12-15 01:10:47 +02:00
$this -> _fieldData [ $id ] -> css_view = base64_decode ( $this -> _fieldData [ $id ] -> css_view );
2017-02-14 01:24:38 +02:00
// check for custom code
$this -> setCustomCodeData ( $this -> _fieldData [ $id ] -> css_view );
2017-02-01 15:17:04 +02:00
$this -> _fieldData [ $id ] -> css_view_decoded = true ;
}
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ 'css_view' ][ $name_single ] .= PHP_EOL . $this -> _fieldData [ $id ] -> css_view ;
2016-02-26 02:20:09 +02:00
}
2017-02-01 15:17:04 +02:00
// add this only once to view.
$this -> customFieldScript [ $name_single ][ $id ] = true ;
}
// check if we should load scripts for list views
if ( ComponentbuilderHelper :: checkString ( $name_list ) && ! isset ( $this -> customFieldScript [ $name_list ][ $id ]))
{
// add_javascript_views_footer
2017-03-27 14:38:51 +02:00
if ( $this -> _fieldData [ $id ] -> add_javascript_views_footer == 1 && ComponentbuilderHelper :: checkString ( $this -> _fieldData [ $id ] -> javascript_views_footer ))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> customScriptBuilder [ 'views_footer' ]))
2016-06-23 16:05:37 +01:00
{
2017-02-01 15:17:04 +02:00
$this -> customScriptBuilder [ 'views_footer' ] = array ();
}
if ( ! isset ( $this -> customScriptBuilder [ 'views_footer' ][ $name_list ]))
{
$this -> customScriptBuilder [ 'views_footer' ][ $name_list ] = '' ;
}
if ( ! isset ( $this -> _fieldData [ $id ] -> javascript_views_footer_decoded ))
{
2017-02-14 01:24:38 +02:00
$this -> _fieldData [ $id ] -> javascript_views_footer = $this -> setDynamicValues ( base64_decode ( $this -> _fieldData [ $id ] -> javascript_views_footer ));
2017-02-01 15:17:04 +02:00
$this -> _fieldData [ $id ] -> javascript_views_footer_decoded = true ;
2016-06-23 16:05:37 +01:00
}
2017-02-01 15:17:04 +02:00
$this -> customScriptBuilder [ 'views_footer' ][ $name_list ] .= $this -> _fieldData [ $id ] -> javascript_views_footer ;
2017-12-15 01:10:47 +02:00
if ( strpos ( $this -> _fieldData [ $id ] -> javascript_views_footer , " token " ) !== false ||
strpos ( $this -> _fieldData [ $id ] -> javascript_views_footer , " task=ajax " ) !== false )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> customScriptBuilder [ 'token' ]))
2017-02-14 01:24:38 +02:00
{
$this -> customScriptBuilder [ 'token' ] = array ();
}
if ( ! isset ( $this -> customScriptBuilder [ 'token' ][ $name_list ]) || ! $this -> customScriptBuilder [ 'token' ][ $name_list ])
2016-02-26 02:20:09 +02:00
{
2017-02-01 15:17:04 +02:00
$this -> customScriptBuilder [ 'token' ][ $name_list ] = true ;
2016-02-26 02:20:09 +02:00
}
}
}
2017-02-01 15:17:04 +02:00
// add_css_views
if ( $this -> _fieldData [ $id ] -> add_css_views == 1 )
2016-02-26 02:20:09 +02:00
{
2017-02-01 15:17:04 +02:00
if ( ! isset ( $this -> customScriptBuilder [ 'css_views' ]))
{
$this -> customScriptBuilder [ 'css_views' ] = array ();
}
if ( ! isset ( $this -> customScriptBuilder [ 'css_views' ][ $name_list ]))
{
$this -> customScriptBuilder [ 'css_views' ][ $name_list ] = '' ;
}
if ( ! isset ( $this -> _fieldData [ $id ] -> css_views_decoded ))
{
2017-12-15 01:10:47 +02:00
$this -> _fieldData [ $id ] -> css_views = base64_decode ( $this -> _fieldData [ $id ] -> css_views );
2017-02-14 01:24:38 +02:00
// check for custom code
$this -> setCustomCodeData ( $this -> _fieldData [ $id ] -> css_views );
2017-02-01 15:17:04 +02:00
$this -> _fieldData [ $id ] -> css_views_decoded = true ;
}
$this -> customScriptBuilder [ 'css_views' ][ $name_list ] .= $this -> _fieldData [ $id ] -> css_views ;
2016-02-26 02:20:09 +02:00
}
2017-02-01 15:17:04 +02:00
// add this only once to view.
$this -> customFieldScript [ $name_list ][ $id ] = true ;
2016-02-26 02:20:09 +02:00
}
}
2017-10-29 13:03:06 +02:00
if ( $id > 0 && isset ( $this -> _fieldData [ $id ]))
2017-02-01 15:17:04 +02:00
{
// return the found field data
return $this -> _fieldData [ $id ];
}
return false ;
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Set get Data
*
2016-03-01 20:44:13 +02:00
* @ param array $ids The ids of the dynamic get
2016-02-26 02:20:09 +02:00
* @ param string $view_code The view code name
*
* @ return oject the get dynamicGet data
*
*/
2017-10-06 16:53:22 +02:00
public function setGetData ( $ids , $view_code )
2016-02-26 02:20:09 +02:00
{
if ( ComponentbuilderHelper :: checkArray ( $ids ))
{
$ids = implode ( ',' , $ids );
if ( ComponentbuilderHelper :: checkString ( $ids ))
{
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
2016-02-26 02:20:09 +02:00
$query -> select ( 'a.*' );
$query -> from ( '#__componentbuilder_dynamic_get AS a' );
$query -> where ( 'a.id IN (' . $ids . ')' );
2017-02-14 01:24:38 +02:00
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
if ( $this -> db -> getNumRows ())
2016-02-26 02:20:09 +02:00
{
2017-02-14 01:24:38 +02:00
$results = $this -> db -> loadObjectList ();
2016-02-26 02:20:09 +02:00
$typeArray = array ( 1 => 'LEFT' , 2 => 'LEFT OUTER' , 3 => 'INNER' , 4 => 'RIGHT' , 5 => 'RIGHT OUTER' );
$operatorArray = array ( 1 => '=' , 2 => '!=' , 3 => '<>' , 4 => '>' , 5 => '<' , 6 => '>=' , 7 => '<=' , 8 => '!<' , 9 => '!>' , 10 => 'IN' , 11 => 'NOT IN' );
2017-10-26 18:43:51 +02:00
foreach ( $results as $_nr => & $result )
2016-02-26 02:20:09 +02:00
{
// add calculations if set
2017-12-15 01:10:47 +02:00
if ( $result -> addcalculation == 1 && ComponentbuilderHelper :: checkString ( $result -> php_calculation ))
2016-02-26 02:20:09 +02:00
{
2017-03-27 14:38:51 +02:00
$result -> php_calculation = $this -> setDynamicValues ( base64_decode ( $result -> php_calculation ));
2016-02-26 02:20:09 +02:00
}
// add php custom scripting (php_before_getitem)
2017-12-15 01:10:47 +02:00
if ( $result -> add_php_before_getitem == 1 && ComponentbuilderHelper :: checkString ( $result -> php_before_getitem ))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> customScriptBuilder [ $this -> target . '_php_before_getitem' ][ $view_code ]))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $this -> target . '_php_before_getitem' ][ $view_code ] = '' ;
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $this -> target . '_php_before_getitem' ][ $view_code ] .= $this -> setDynamicValues ( PHP_EOL . PHP_EOL . base64_decode ( $result -> php_before_getitem ));
2016-02-26 02:20:09 +02:00
unset ( $result -> php_before_getitem );
}
// add php custom scripting (php_after_getitem)
2017-12-15 01:10:47 +02:00
if ( $result -> add_php_after_getitem == 1 && ComponentbuilderHelper :: checkString ( $result -> php_after_getitem ))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> customScriptBuilder [ $this -> target . '_php_after_getitem' ][ $view_code ]))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $this -> target . '_php_after_getitem' ][ $view_code ] = '' ;
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $this -> target . '_php_after_getitem' ][ $view_code ] .= $this -> setDynamicValues ( PHP_EOL . PHP_EOL . base64_decode ( $result -> php_after_getitem ));
2016-02-26 02:20:09 +02:00
unset ( $result -> php_after_getitem );
}
// add php custom scripting (php_before_getitems)
2017-12-15 01:10:47 +02:00
if ( $result -> add_php_before_getitems == 1 && ComponentbuilderHelper :: checkString ( $result -> php_before_getitems ))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> customScriptBuilder [ $this -> target . '_php_before_getitems' ][ $view_code ]))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $this -> target . '_php_before_getitems' ][ $view_code ] = '' ;
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $this -> target . '_php_before_getitems' ][ $view_code ] .= $this -> setDynamicValues ( PHP_EOL . PHP_EOL . base64_decode ( $result -> php_before_getitems ));
2016-02-26 02:20:09 +02:00
unset ( $result -> php_before_getitems );
}
// add php custom scripting (php_after_getitems)
2017-12-15 01:10:47 +02:00
if ( $result -> add_php_after_getitems == 1 && ComponentbuilderHelper :: checkString ( $result -> php_after_getitems ))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> customScriptBuilder [ $this -> target . '_php_after_getitems' ][ $view_code ]))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $this -> target . '_php_after_getitems' ][ $view_code ] = '' ;
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $this -> target . '_php_after_getitems' ][ $view_code ] .= $this -> setDynamicValues ( PHP_EOL . PHP_EOL . base64_decode ( $result -> php_after_getitems ));
2016-02-26 02:20:09 +02:00
unset ( $result -> php_after_getitems );
}
// add php custom scripting (php_getlistquery)
2017-12-15 01:10:47 +02:00
if ( $result -> add_php_getlistquery == 1 && ComponentbuilderHelper :: checkString ( $result -> php_getlistquery ))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> customScriptBuilder [ $this -> target . '_php_getlistquery' ][ $view_code ]))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $this -> target . '_php_getlistquery' ][ $view_code ] = '' ;
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
$this -> customScriptBuilder [ $this -> target . '_php_getlistquery' ][ $view_code ] .= $this -> setDynamicValues ( PHP_EOL . base64_decode ( $result -> php_getlistquery ));
2016-02-26 02:20:09 +02:00
unset ( $result -> php_getlistquery );
}
// set the getmethod code name
2017-12-15 01:10:47 +02:00
$result -> key = ComponentbuilderHelper :: safeString ( $view_code . ' ' . $result -> name . ' ' . $result -> id );
2016-02-26 02:20:09 +02:00
// reset buckets
$result -> main_get = array ();
$result -> custom_get = array ();
// set source data
switch ( $result -> main_source )
{
case 1 :
2017-12-15 01:10:47 +02:00
// set the view data
$result -> main_get [ 0 ][ 'selection' ] = $this -> setDataSelection ( $result -> key , $view_code , $result -> view_selection , $result -> view_table_main , 'a' , '' , 'view' );
$result -> main_get [ 0 ][ 'as' ] = 'a' ;
$result -> main_get [ 0 ][ 'key' ] = $result -> key ;
unset ( $result -> view_selection );
break ;
2016-02-26 02:20:09 +02:00
case 2 :
2017-12-15 01:10:47 +02:00
// set the database data
$result -> main_get [ 0 ][ 'selection' ] = $this -> setDataSelection ( $result -> key , $view_code , $result -> db_selection , $result -> db_table_main , 'a' , '' , 'db' );
$result -> main_get [ 0 ][ 'as' ] = 'a' ;
$result -> main_get [ 0 ][ 'key' ] = $result -> key ;
unset ( $result -> db_selection );
break ;
2016-02-26 02:20:09 +02:00
case 3 :
2017-12-15 01:10:47 +02:00
// set custom script
$result -> main_get [ 0 ][ 'selection' ] = array (
'select' => base64_decode ( $result -> php_custom_get ),
'from' => '' , 'table' => '' , 'type' => '' );
break ;
2016-02-26 02:20:09 +02:00
}
// set join_view_table details
2017-10-06 16:53:22 +02:00
$result -> join_view_table = json_decode ( $result -> join_view_table , true );
if ( ComponentbuilderHelper :: checkArray ( $result -> join_view_table ))
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
foreach ( $result -> join_view_table as $nr => & $option )
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
if ( ComponentbuilderHelper :: checkString ( $option [ 'selection' ]))
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
// convert the type
2017-12-15 01:10:47 +02:00
$option [ 'type' ] = $typeArray [ $option [ 'type' ]];
2017-10-06 16:53:22 +02:00
// convert the operator
2017-12-15 01:10:47 +02:00
$option [ 'operator' ] = $operatorArray [ $option [ 'operator' ]];
2017-10-06 16:53:22 +02:00
// get the on field values
2017-12-15 01:10:47 +02:00
$on_field = array (); // array(on_field_as, on_field)
$on_field = array_map ( 'trim' , explode ( '.' , $option [ 'on_field' ]));
2017-10-06 16:53:22 +02:00
// get the join field values
2017-12-15 01:10:47 +02:00
$join_field = array (); // array(join_field_as, join_field)
$join_field = array_map ( 'trim' , explode ( '.' , $option [ 'join_field' ]));
$option [ 'selection' ] = $this -> setDataSelection ( $result -> key , $view_code , $option [ 'selection' ], $option [ 'view_table' ], $option [ 'as' ], $option [ 'row_type' ], 'view' );
2017-10-06 16:53:22 +02:00
$option [ 'key' ] = $result -> key ;
// load to the getters
if ( $option [ 'row_type' ] == 1 )
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
$result -> main_get [] = $option ;
if ( $on_field [ 0 ] === 'a' )
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
$this -> siteMainGet [ $this -> target ][ $view_code ][ $option [ 'as' ]] = $option [ 'as' ];
2016-02-26 02:20:09 +02:00
}
else
{
2017-10-06 16:53:22 +02:00
$this -> siteDynamicGet [ $this -> target ][ $view_code ][ $option [ 'as' ]][ $join_field [ 1 ]] = $on_field [ 0 ];
}
}
elseif ( $option [ 'row_type' ] == 2 )
{
$result -> custom_get [] = $option ;
if ( $on_field [ 0 ] != 'a' )
{
$this -> siteDynamicGet [ $this -> target ][ $view_code ][ $option [ 'as' ]][ $join_field [ 1 ]] = $on_field [ 0 ];
2016-02-26 02:20:09 +02:00
}
}
}
2017-10-06 16:53:22 +02:00
unset ( $result -> join_view_table [ $nr ]);
2016-02-26 02:20:09 +02:00
}
}
unset ( $result -> join_view_table );
// set join_db_table details
2017-10-06 16:53:22 +02:00
$result -> join_db_table = json_decode ( $result -> join_db_table , true );
if ( ComponentbuilderHelper :: checkArray ( $result -> join_db_table ))
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
foreach ( $result -> join_db_table as $nr => & $option1 )
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
if ( ComponentbuilderHelper :: checkString ( $option1 [ 'selection' ]))
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
// convert the type
2017-12-15 01:10:47 +02:00
$option1 [ 'type' ] = $typeArray [ $option1 [ 'type' ]];
2017-10-06 16:53:22 +02:00
// convert the operator
2017-12-15 01:10:47 +02:00
$option1 [ 'operator' ] = $operatorArray [ $option1 [ 'operator' ]];
2017-10-06 16:53:22 +02:00
// get the on field values
2017-12-15 01:10:47 +02:00
$on_field = array (); // array(on_field_as, on_field)
$on_field = array_map ( 'trim' , explode ( '.' , $option1 [ 'on_field' ]));
2017-10-06 16:53:22 +02:00
// get the join field values
2017-12-15 01:10:47 +02:00
$join_field = array (); // array(join_field_as, join_field)
$join_field = array_map ( 'trim' , explode ( '.' , $option1 [ 'join_field' ]));
$option1 [ 'selection' ] = $this -> setDataSelection ( $result -> key , $view_code , $option1 [ 'selection' ], $option1 [ 'db_table' ], $option1 [ 'as' ], $option1 [ 'row_type' ], 'db' );
2017-10-06 16:53:22 +02:00
$option1 [ 'key' ] = $result -> key ;
// load to the getters
if ( $option1 [ 'row_type' ] == 1 )
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
$result -> main_get [] = $option1 ;
if ( $on_field [ 0 ] === 'a' )
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
$this -> siteMainGet [ $this -> target ][ $view_code ][ $option1 [ 'as' ]] = $option1 [ 'as' ];
2016-02-26 02:20:09 +02:00
}
else
{
2017-10-06 16:53:22 +02:00
$this -> siteDynamicGet [ $this -> target ][ $view_code ][ $option1 [ 'as' ]][ $join_field [ 1 ]] = $on_field [ 0 ];
2016-02-26 02:20:09 +02:00
}
}
2017-10-06 16:53:22 +02:00
elseif ( $option1 [ 'row_type' ] == 2 )
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
$result -> custom_get [] = $option1 ;
if ( $on_field [ 0 ] != 'a' )
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
$this -> siteDynamicGet [ $this -> target ][ $view_code ][ $option1 [ 'as' ]][ $join_field [ 1 ]] = $on_field [ 0 ];
2016-02-26 02:20:09 +02:00
}
}
}
2017-10-06 16:53:22 +02:00
unset ( $result -> join_db_table [ $nr ]);
2016-02-26 02:20:09 +02:00
}
}
2017-10-06 16:53:22 +02:00
unset ( $result -> join_db_table );
// set filter details
$result -> filter = json_decode ( $result -> filter , true );
if ( ComponentbuilderHelper :: checkArray ( $result -> filter ))
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
foreach ( $result -> filter as $nr => & $option2 )
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
if ( isset ( $option2 [ 'operator' ]))
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
$option2 [ 'operator' ] = $operatorArray [ $option2 [ 'operator' ]];
$option2 [ 'key' ] = $result -> key ;
2016-02-26 02:20:09 +02:00
}
2017-10-06 16:53:22 +02:00
else
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
unset ( $result -> filter [ $nr ]);
2016-02-26 02:20:09 +02:00
}
}
}
// set where details
2017-10-06 16:53:22 +02:00
$result -> where = json_decode ( $result -> where , true );
if ( ComponentbuilderHelper :: checkArray ( $result -> where ))
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
foreach ( $result -> where as $nr => & $option3 )
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
if ( isset ( $option3 [ 'operator' ]))
2016-02-26 02:20:09 +02:00
{
2017-10-06 16:53:22 +02:00
$option3 [ 'operator' ] = $operatorArray [ $option3 [ 'operator' ]];
}
else
{
unset ( $result -> where [ $nr ]);
2016-02-26 02:20:09 +02:00
}
}
}
2017-10-06 16:53:22 +02:00
else
{
unset ( $result -> where );
}
// set order details
$result -> order = json_decode ( $result -> order , true );
if ( ! ComponentbuilderHelper :: checkArray ( $result -> order ))
{
unset ( $result -> order );
}
// set global details
$result -> global = json_decode ( $result -> global , true );
if ( ! ComponentbuilderHelper :: checkArray ( $result -> global ))
{
unset ( $result -> global );
}
2016-02-26 02:20:09 +02:00
}
return $results ;
}
}
}
return false ;
}
2017-12-15 01:10:47 +02:00
2017-10-29 13:03:06 +02:00
/**
* To limit the SQL Demo date build in the views
*
* @ param array $settings Tweaking array .
*
* @ return void
*
2017-12-15 01:10:47 +02:00
*/
2017-10-29 13:03:06 +02:00
public function setSqlTweaking ( $settings )
{
if ( ComponentbuilderHelper :: checkArray ( $settings ))
{
2017-12-15 01:10:47 +02:00
foreach ( $settings as $setting )
2017-10-29 13:03:06 +02:00
{
// should sql dump be added
if ( 1 == $setting [ 'add_sql' ])
{
// add sql (by option)
if ( 2 == $setting [ 'add_sql_options' ])
{
// rest always
$id_array = array ();
// by id (first remove backups)
$ids = $setting [ 'ids' ];
// now get the ids
if ( strpos ( $ids , ',' ) !== false )
{
2017-12-15 01:10:47 +02:00
$id_array = ( array ) array_map ( 'trim' , explode ( ',' , $ids ));
2017-10-29 13:03:06 +02:00
}
else
{
$id_array [] = trim ( $ids );
}
$id_array_new = array ();
// check for ranges
foreach ( $id_array as $key => $id )
{
if ( strpos ( $id , '=>' ) !== false )
{
$id_range = ( array ) array_map ( 'trim' , explode ( '=>' , $id ));
unset ( $id_array [ $key ]);
// build range
if ( count ( $id_range ) == 2 )
{
2017-12-15 01:10:47 +02:00
$range = range ( $id_range [ 0 ], $id_range [ 1 ]);
$id_array_new = array_merge ( $id_array_new , $range );
2017-10-29 13:03:06 +02:00
}
}
}
if ( ComponentbuilderHelper :: checkArray ( $id_array_new ))
{
$id_array = array_merge ( $id_array_new , $id_array );
}
// final fixing to array
if ( ComponentbuilderHelper :: checkArray ( $id_array ))
{
// uniqe
$id_array = array_unique ( $id_array , SORT_NUMERIC );
// sort
sort ( $id_array , SORT_NUMERIC );
// now set it to global
2017-12-15 01:10:47 +02:00
$this -> sqlTweak [( int ) $setting [ 'adminview' ]][ 'where' ] = implode ( ',' , $id_array );
2017-10-29 13:03:06 +02:00
}
}
}
else
{
// remove all sql dump options
2017-12-15 01:10:47 +02:00
$this -> sqlTweak [( int ) $setting [ 'adminview' ]][ 'remove' ] = true ;
2017-10-29 13:03:06 +02:00
}
}
}
}
2017-12-15 01:10:47 +02:00
2017-06-16 13:38:06 +01:00
/**
* check if an update SQL is needed
*
* @ param mix $old The old values
* @ param mix $new The new values
* @ param string $type The type of values
* @ param int $key The id / key where values changed
*
* @ return void
*
*/
protected function setUpdateSQL ( $old , $new , $type , $key = null )
{
// check if there were new items added
2017-12-15 01:10:47 +02:00
if ( ComponentbuilderHelper :: checkArray ( $new ) && ComponentbuilderHelper :: checkArray ( $old ))
2017-06-16 13:38:06 +01:00
{
2017-10-13 01:14:17 +02:00
// check if this is old repeatable field
if ( isset ( $new [ $type ]))
2017-06-16 13:38:06 +01:00
{
2017-10-13 01:14:17 +02:00
foreach ( $new [ $type ] as $item )
2017-10-12 02:50:14 +02:00
{
2017-10-13 01:14:17 +02:00
$newItem = true ;
2017-10-12 02:50:14 +02:00
// check if this is old repeatable field
if ( isset ( $old [ $type ]) && ComponentbuilderHelper :: checkArray ( $old [ $type ]))
{
2017-10-13 01:14:17 +02:00
if ( ! in_array ( $item , $old [ $type ]))
2017-10-12 02:50:14 +02:00
{
2017-10-13 01:14:17 +02:00
// we have a new item, lets add to SQL
$this -> setAddSQL ( $type , $item , $key );
2017-10-12 02:50:14 +02:00
}
2017-10-13 01:14:17 +02:00
// add only once
$newItem = false ;
2017-10-12 02:50:14 +02:00
}
elseif ( ! isset ( $old [ $type ]))
{
// we have new values
2017-12-15 01:10:47 +02:00
foreach ( $old as $oldItem )
2017-10-12 02:50:14 +02:00
{
if ( isset ( $oldItem [ $type ]))
{
if ( $oldItem [ $type ] == $item [ $type ])
{
$newItem = false ;
break ;
}
}
else
{
$newItem = false ;
break ;
}
}
}
else
{
$newItem = false ;
}
2017-10-13 01:14:17 +02:00
// add if new
if ( $newItem )
2017-06-16 13:38:06 +01:00
{
2017-10-13 01:14:17 +02:00
// we have a new item, lets add to SQL
$this -> setAddSQL ( $type , $item [ $type ], $key );
2017-06-16 13:38:06 +01:00
}
2017-10-13 01:14:17 +02:00
}
}
else
{
foreach ( $new as $item )
{
// search to see if this is a new value
$newItem = true ;
if ( isset ( $item [ $type ]))
2017-06-16 13:38:06 +01:00
{
2017-10-13 01:14:17 +02:00
// check if this is old repeatable field
if ( isset ( $old [ $type ]) && ComponentbuilderHelper :: checkArray ( $old [ $type ]))
2017-06-16 13:38:06 +01:00
{
2017-10-13 01:14:17 +02:00
if ( in_array ( $item [ $type ], $old [ $type ]))
{
$newItem = false ;
}
2017-06-16 13:38:06 +01:00
}
2017-10-13 01:14:17 +02:00
elseif ( ! isset ( $old [ $type ]))
2017-06-16 13:38:06 +01:00
{
2017-10-13 01:14:17 +02:00
// we have new values
2017-12-15 01:10:47 +02:00
foreach ( $old as $oldItem )
2017-10-13 01:14:17 +02:00
{
if ( isset ( $oldItem [ $type ]))
{
if ( $oldItem [ $type ] == $item [ $type ])
{
$newItem = false ;
break ;
}
}
else
{
$newItem = false ;
break ;
}
}
2017-06-16 13:38:06 +01:00
}
else
{
2017-10-13 01:14:17 +02:00
$newItem = false ;
2017-06-16 13:38:06 +01:00
}
}
2017-10-13 01:14:17 +02:00
else
{
break ;
}
// add if new
if ( $newItem )
{
// we have a new item, lets add to SQL
$this -> setAddSQL ( $type , $item [ $type ], $key );
}
2017-06-16 13:38:06 +01:00
}
}
}
2017-12-15 01:10:47 +02:00
elseif ( $key && ComponentbuilderHelper :: checkString ( $new ) && ComponentbuilderHelper :: checkString ( $old ) && $new !== $old )
2017-06-16 13:38:06 +01:00
{
// the string changed, lets add to SQL update
if ( ! isset ( $this -> updateSQL [ $type ]) || ! ComponentbuilderHelper :: checkArray ( $this -> updateSQL [ $type ]))
{
$this -> updateSQL [ $type ] = array ();
}
// set at key
2017-12-15 01:10:47 +02:00
$this -> updateSQL [ $type ][ $key ] = array ( 'old' => $old , 'new' => $new );
2017-06-16 13:38:06 +01:00
}
}
2017-12-15 01:10:47 +02:00
2017-10-13 01:14:17 +02:00
/**
* Set the add sql
*
* @ param string $type The type of values
* @ param int $item The item id to add
* @ param int $key The id / key where values changed
*
* @ return void
*/
protected function setAddSQL ( $type , $item , $key )
{
// we have a new item, lets add to SQL
if ( ! isset ( $this -> addSQL [ $type ]) || ! ComponentbuilderHelper :: checkArray ( $this -> addSQL [ $type ]))
{
$this -> addSQL [ $type ] = array ();
}
// add key if found
if ( $key )
{
if ( ! isset ( $this -> addSQL [ $type ][ $key ]) || ! ComponentbuilderHelper :: checkArray ( $this -> addSQL [ $type ][ $key ]))
{
$this -> addSQL [ $type ][ $key ] = array ();
}
$this -> addSQL [ $type ][ $key ][] = ( int ) $item ;
}
else
{
// convert adminview id to name
if ( 'adminview' === $type )
{
$this -> addSQL [ $type ][] = ComponentbuilderHelper :: safeString ( $this -> getAdminViewData ( $item ) -> name_single );
}
else
{
$this -> addSQL [ $type ][] = ( int ) $item ;
}
}
}
2017-12-15 01:10:47 +02:00
2017-06-16 13:38:06 +01:00
/**
* Get Item History values
*
* @ param string $type The type of item
* @ param int $id The item ID
*
* @ return oject The history
*
*/
protected function getHistoryWatch ( $type , $id )
{
// quick class object to store old history object
$this -> tmpHistory = null ;
// Create a new query object.
$query = $this -> db -> getQuery ( true );
$query -> select ( 'h.*' );
$query -> from ( '#__ucm_history AS h' );
2017-12-15 01:10:47 +02:00
$query -> where ( $this -> db -> quoteName ( 'h.ucm_item_id' ) . ' = ' . ( int ) $id );
2017-06-16 13:38:06 +01:00
// Join over the content type for the type id
$query -> join ( 'LEFT' , '#__content_types AS ct ON ct.type_id = h.ucm_type_id' );
2017-12-15 01:10:47 +02:00
$query -> where ( 'ct.type_alias = ' . $this -> db -> quote ( 'com_componentbuilder.' . $type ));
2017-06-16 13:38:06 +01:00
$query -> order ( 'h.save_date DESC' );
$this -> db -> setQuery ( $query , 0 , 1 );
$this -> db -> execute ();
if ( $this -> db -> getNumRows ())
{
// new version of this item found
// so we need to mark it as the last compiled version
$newActive = $this -> db -> loadObject ();
// set the new version watch
$this -> setHistoryWatch ( $newActive , 1 );
}
// Get last compiled verion
$query = $this -> db -> getQuery ( true );
$query -> select ( 'h.*' );
$query -> from ( '#__ucm_history AS h' );
$query -> where ( $this -> db -> quoteName ( 'h.ucm_item_id' ) . ' = ' . ( int ) $id );
$query -> where ( 'h.keep_forever = 1' );
$query -> where ( 'h.version_note LIKE ' . $this -> db -> quote ( '%component%' ));
// make sure it does not return the active version
if ( isset ( $newActive ) && isset ( $newActive -> version_id ))
{
$query -> where ( 'h.version_id != ' . ( int ) $newActive -> version_id );
}
// Join over the content type for the type id
$query -> join ( 'LEFT' , '#__content_types AS ct ON ct.type_id = h.ucm_type_id' );
2017-12-15 01:10:47 +02:00
$query -> where ( 'ct.type_alias = ' . $this -> db -> quote ( 'com_componentbuilder.' . $type ));
2017-06-16 13:38:06 +01:00
$query -> order ( 'h.save_date DESC' );
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
if ( $this -> db -> getNumRows ())
{
// the old active version was found
// so we may need to do an SQL update
// and unmark the old compiled version
$oldActives = $this -> db -> loadObjectList ();
foreach ( $oldActives as $oldActive )
{
// remove old version watch
$this -> setHistoryWatch ( $oldActive , 0 );
}
}
// return the last used history record or null.
return $this -> tmpHistory ;
}
2017-12-15 01:10:47 +02:00
2017-06-16 13:38:06 +01:00
/**
* Set Item History Watch
*
* @ param Object $object The history object
* @ param int $action The action to take
2017-12-15 01:10:47 +02:00
* 0 = remove watch
* 1 = add watch
2017-06-16 13:38:06 +01:00
* @ param string $type The type of item
*
* @ return bool
*
*/
protected function setHistoryWatch ( $object , $action )
{
// check the note
if ( ComponentbuilderHelper :: checkJson ( $object -> version_note ))
{
$version_note = json_decode ( $object -> version_note , true );
}
else
{
$version_note = array ( 'component' => array ());
}
// set watch
switch ( $action )
{
case 0 :
// remove watch
2017-12-15 01:10:47 +02:00
if ( isset ( $version_note [ 'component' ]) && ( $key = array_search ( $this -> componentID , $version_note [ 'component' ])) !== false )
2017-06-16 13:38:06 +01:00
{
// last version that was used to build/compile
$this -> tmpHistory = json_decode ( $object -> version_data );
// remove it from this component
unset ( $version_note [ 'component' ][ $key ]);
}
else
{
// since it was not found, no need to update anything
return true ;
}
2017-12-15 01:10:47 +02:00
break ;
2017-06-16 13:38:06 +01:00
case 1 :
// add watch
if ( ! in_array ( $this -> componentID , $version_note [ 'component' ]))
{
$version_note [ 'component' ][] = $this -> componentID ;
}
else
{
// since it is there already, no need to update anything
return true ;
}
2017-12-15 01:10:47 +02:00
break ;
2017-06-16 13:38:06 +01:00
}
// check if we need to still keep this locked
if ( isset ( $version_note [ 'component' ]) && ComponentbuilderHelper :: checkArray ( $version_note [ 'component' ]))
{
// insure component ids are only added once per item
$version_note [ 'component' ] = array_unique ( $version_note [ 'component' ]);
// we may change this, little risky (but since JCB does not have history notes it should be okay for now)
$object -> version_note = json_encode ( $version_note );
$object -> keep_forever = '1' ;
}
else
{
$object -> version_note = '' ;
$object -> keep_forever = '0' ;
}
// run the update
return $this -> db -> updateObject ( '#__ucm_history' , $object , 'version_id' );
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Set Template and Layout Data
*
* @ param string $default The content to check
* @ param string $view The view code name
*
* @ return void
*
*/
2017-12-15 01:10:47 +02:00
public function setTemplateAndLayoutData ( $default , $view )
2016-02-26 02:20:09 +02:00
{
// set the Tempale date
2017-12-15 01:10:47 +02:00
$temp1 = ComponentbuilderHelper :: getAllBetween ( $default , " \$ this->loadTemplate(' " , " ') " );
$temp2 = ComponentbuilderHelper :: getAllBetween ( $default , '$this->loadTemplate("' , '")' );
2016-02-26 02:20:09 +02:00
$templates = array ();
$again = array ();
if ( ComponentbuilderHelper :: checkArray ( $temp1 ) && ComponentbuilderHelper :: checkArray ( $temp2 ))
{
2017-12-15 01:10:47 +02:00
$templates = array_merge ( $temp1 , $temp2 );
2016-02-26 02:20:09 +02:00
}
else
{
if ( ComponentbuilderHelper :: checkArray ( $temp1 ))
{
$templates = $temp1 ;
}
elseif ( ComponentbuilderHelper :: checkArray ( $temp2 ))
{
$templates = $temp2 ;
}
}
if ( ComponentbuilderHelper :: checkArray ( $templates ))
{
foreach ( $templates as $template )
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> templateData [ $this -> target ][ $view ]) || ! array_key_exists ( $template , $this -> templateData [ $this -> target ][ $view ]))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$data = $this -> getDataWithAlias ( $template , 'template' , $view );
2016-02-26 02:20:09 +02:00
if ( ComponentbuilderHelper :: checkArray ( $data ))
{
$this -> templateData [ $this -> target ][ $view ][ $template ] = $data ;
// call self to get child data
2017-12-15 01:10:47 +02:00
$again [] = array ( $data [ 'html' ], $view );
$again [] = array ( $data [ 'php_view' ], $view );
2016-02-26 02:20:09 +02:00
}
}
}
}
// set the layout data
2017-12-15 01:10:47 +02:00
$lay1 = ComponentbuilderHelper :: getAllBetween ( $default , " JLayoutHelper::render(' " , " ', " );
$lay2 = ComponentbuilderHelper :: getAllBetween ( $default , 'JLayoutHelper::render("' , '",' );
;
2016-02-26 02:20:09 +02:00
if ( ComponentbuilderHelper :: checkArray ( $lay1 ) && ComponentbuilderHelper :: checkArray ( $lay2 ))
{
2017-12-15 01:10:47 +02:00
$layouts = array_merge ( $lay1 , $lay2 );
2016-02-26 02:20:09 +02:00
}
else
{
if ( ComponentbuilderHelper :: checkArray ( $lay1 ))
{
$layouts = $lay1 ;
}
elseif ( ComponentbuilderHelper :: checkArray ( $lay2 ))
{
$layouts = $lay2 ;
}
}
if ( isset ( $layouts ) && ComponentbuilderHelper :: checkArray ( $layouts ))
{
foreach ( $layouts as $layout )
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> layoutData [ $this -> target ]) || ! ComponentbuilderHelper :: checkArray ( $this -> layoutData [ $this -> target ]) || ! array_key_exists ( $layout , $this -> layoutData [ $this -> target ]))
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$data = $this -> getDataWithAlias ( $layout , 'layout' , $view );
2016-02-26 02:20:09 +02:00
if ( ComponentbuilderHelper :: checkArray ( $data ))
{
$this -> layoutData [ $this -> target ][ $layout ] = $data ;
// call self to get child data
2017-12-15 01:10:47 +02:00
$again [] = array ( $data [ 'html' ], $view );
$again [] = array ( $data [ 'php_view' ], $view );
2016-02-26 02:20:09 +02:00
}
}
}
}
if ( ComponentbuilderHelper :: checkArray ( $again ))
{
foreach ( $again as $go )
{
2017-12-15 01:10:47 +02:00
$this -> setTemplateAndLayoutData ( $go [ 0 ], $go [ 1 ]);
2016-02-26 02:20:09 +02:00
}
}
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Get Data With Alias
*
* @ param string $n_ame The alias name
* @ param string $table The table where to find the alias
* @ param string $view The view code name
*
* @ return array The data found with the alias
*
*/
2017-12-03 20:09:04 +02:00
public function getDataWithAlias ( $n_ame , $table , $view )
2016-02-26 02:20:09 +02:00
{
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
2016-02-26 02:20:09 +02:00
$query -> select ( 'a.*' );
2017-12-15 01:10:47 +02:00
$query -> from ( '#__componentbuilder_' . $table . ' AS a' );
2017-02-14 01:24:38 +02:00
$this -> db -> setQuery ( $query );
$rows = $this -> db -> loadObjectList ();
2016-02-26 02:20:09 +02:00
foreach ( $rows as $row )
{
$k_ey = ComponentbuilderHelper :: safeString ( $row -> alias );
$key = preg_replace ( " /[^A-Za-z]/ " , '' , $k_ey );
$name = preg_replace ( " /[^A-Za-z]/ " , '' , $n_ame );
if ( $k_ey == $n_ame || $key == $name )
{
$php_view = '' ;
2017-03-27 14:38:51 +02:00
if ( $row -> add_php_view == 1 && ComponentbuilderHelper :: checkString ( $row -> php_view ))
2016-02-26 02:20:09 +02:00
{
2017-02-14 01:24:38 +02:00
$php_view = $this -> setDynamicValues ( base64_decode ( $row -> php_view ));
2016-02-26 02:20:09 +02:00
}
2017-02-14 01:24:38 +02:00
$contnent = $this -> setDynamicValues ( base64_decode ( $row -> { $table }));
2017-12-10 21:17:26 +02:00
// load the library
if ( ! isset ( $this -> libManager [ $this -> target ]))
{
$this -> libManager [ $this -> target ] = array ();
}
if ( ! isset ( $this -> libManager [ $this -> target ][ $view ]))
{
$this -> libManager [ $this -> target ][ $view ] = array ();
}
// make sure json become array
if ( ComponentbuilderHelper :: checkJson ( $row -> libraries ))
{
$row -> libraries = json_decode ( $row -> libraries , true );
}
// if we have an array add it
if ( ComponentbuilderHelper :: checkArray ( $row -> libraries ))
{
foreach ( $row -> libraries as $library )
{
if ( ! isset ( $this -> libManager [ $this -> target ][ $view ][ $library ]))
{
if ( $this -> getLibrary (( int ) $library ))
{
$this -> libManager [ $this -> target ][ $view ][( int ) $library ] = true ;
}
}
}
}
elseif ( is_numeric ( $row -> libraries ) && ! isset ( $this -> libManager [ $this -> target ][ $view ][( int ) $row -> libraries ]))
{
if ( $this -> getLibrary (( int ) $row -> libraries ))
{
$this -> libManager [ $this -> target ][ $view ][( int ) $row -> libraries ] = true ;
}
}
// load UIKIT if needed
2017-11-11 06:33:51 +02:00
if ( 2 == $this -> uikit || 1 == $this -> uikit )
{
2017-12-13 00:17:02 +02:00
if ( ! isset ( $this -> uikitComp [ $view ]))
{
$this -> uikitComp [ $view ] = array ();
}
2017-11-11 06:33:51 +02:00
// set uikit to views
2017-12-15 01:10:47 +02:00
$this -> uikitComp [ $view ] = ComponentbuilderHelper :: getUikitComp ( $contnent , $this -> uikitComp [ $view ]);
2017-11-11 06:33:51 +02:00
}
2016-02-26 02:20:09 +02:00
// set footable to views and turn it on
if ( ! isset ( $this -> footableScripts [ $this -> target ][ $view ]) || ! $this -> footableScripts [ $this -> target ][ $view ])
{
$foundFoo = $this -> getFootableScripts ( $contnent );
if ( $foundFoo )
{
$this -> footableScripts [ $this -> target ][ $view ] = true ;
}
if ( $foundFoo && ! $this -> footable )
{
$this -> footable = true ;
}
}
// set google charts to views and turn it on
if ( ! isset ( $this -> googleChart [ $this -> target ][ $view ]) || ! $this -> googleChart [ $this -> target ][ $view ])
{
$foundA = $this -> getGoogleChart ( $php_view );
$foundB = $this -> getGoogleChart ( $contnent );
if ( $foundA || $foundB )
{
$this -> googleChart [ $this -> target ][ $view ] = true ;
}
if ( $foundA || $foundB && ! $this -> googlechart )
{
$this -> googlechart = true ;
}
}
// check for get module
if ( ! isset ( $this -> getModule [ $this -> target ][ $view ]) || ! $this -> getModule [ $this -> target ][ $view ])
{
$foundA = $this -> getGetModule ( $php_view );
$foundB = $this -> getGetModule ( $contnent );
if ( $foundA || $foundB )
{
$this -> getModule [ $this -> target ][ $view ] = true ;
}
}
return array ( 'id' => $row -> id , 'html' => $contnent , 'php_view' => $php_view );
}
}
return false ;
}
2017-12-15 01:10:47 +02:00
2017-12-03 20:09:04 +02:00
/**
* Get Library Data and store globaly
*
* @ param string $id the library id
*
* @ return bool true on success
*
*/
protected function getLibrary ( $id )
{
2017-12-15 01:10:47 +02:00
2017-12-10 21:17:26 +02:00
// check if the lib has already been set
if ( ! isset ( $this -> libraries [ $id ]))
{
// make sure we should continue and that the lib is not already bein loaded
switch ( $id )
{
case 1 : // No Library
return false ;
2017-12-15 01:10:47 +02:00
break ;
2017-12-10 21:17:26 +02:00
case 3 : // Uikit v3
if ( 2 == $this -> uikit || 3 == $this -> uikit )
{
// already being loaded
$this -> libraries [ $id ] = false ;
}
2017-12-15 01:10:47 +02:00
break ;
2017-12-10 21:17:26 +02:00
case 4 : // Uikit v2
if ( 2 == $this -> uikit || 1 == $this -> uikit )
{
// already being loaded
$this -> libraries [ $id ] = false ;
}
2017-12-15 01:10:47 +02:00
break ;
2017-12-10 21:17:26 +02:00
case 5 : // FooTable v2
if ( ! isset ( $this -> footableVersion ) || 2 == $this -> footableVersion )
{
// already being loaded
$this -> libraries [ $id ] = false ;
}
2017-12-15 01:10:47 +02:00
break ;
2017-12-10 21:17:26 +02:00
case 6 : // FooTable v3
if ( 3 == $this -> footableVersion )
{
// already being loaded
$this -> libraries [ $id ] = false ;
}
2017-12-15 01:10:47 +02:00
break ;
2017-12-10 21:17:26 +02:00
}
}
2017-12-03 20:09:04 +02:00
// check if the lib has already been set
if ( ! isset ( $this -> libraries [ $id ]))
{
$query = $this -> db -> getQuery ( true );
$query -> select ( 'a.*' );
$query -> select (
$this -> db -> quoteName (
array (
2017-12-15 01:10:47 +02:00
'a.id' ,
'a.name' ,
'a.how' ,
'a.type' ,
'a.addconditions' ,
'b.addconfig' ,
'c.addfiles' ,
'c.addfolders' ,
2018-02-16 23:53:43 +02:00
'c.addfilesfullpath' ,
'c.addfoldersfullpath' ,
2017-12-15 01:10:47 +02:00
'c.addurls' ,
'a.php_setdocument'
), array (
'id' ,
'name' ,
'how' ,
'type' ,
'addconditions' ,
'addconfig' ,
'addfiles' ,
'addfolders' ,
2018-02-16 23:53:43 +02:00
'addfilesfullpath' ,
'addfoldersfullpath' ,
2017-12-15 01:10:47 +02:00
'addurls' ,
'php_setdocument'
2017-12-03 20:09:04 +02:00
)
2017-12-15 01:10:47 +02:00
)
);
2017-12-03 20:09:04 +02:00
// from these tables
$query -> from ( '#__componentbuilder_library AS a' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_library_config' , 'b' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'b.library' ) . ')' );
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__componentbuilder_library_files_folders_urls' , 'c' ) . ' ON (' . $this -> db -> quoteName ( 'a.id' ) . ' = ' . $this -> db -> quoteName ( 'c.library' ) . ')' );
2017-12-15 01:10:47 +02:00
$query -> where ( $this -> db -> quoteName ( 'a.id' ) . ' = ' . ( int ) $id );
2017-12-03 20:09:04 +02:00
// Reset the query using our newly populated query object.
$this -> db -> setQuery ( $query );
// Load the results as a list of stdClass objects
$library = $this -> db -> loadObject ();
2017-12-15 01:10:47 +02:00
2017-12-10 21:17:26 +02:00
// check if this lib uses build-in behaviour
if ( $library -> how == 4 )
{
// fall back on build-in features
$buildin = array ( 3 => array ( 'uikit' => 3 ), 4 => array ( 'uikit' => 1 ), 5 => array ( 'footableVersion' => 2 , 'footable' => true ), 6 => array ( 'footableVersion' => 3 , 'footable' => true ));
if ( isset ( $buildin [ $library -> id ]) && ComponentbuilderHelper :: checkArray ( $buildin [ $library -> id ]))
{
// set the lib switch
foreach ( $buildin [ $library -> id ] as $lib => $val )
{
$this -> { $lib } = $val ;
}
// since we are falling back on build-in feature
$library -> how = 0 ;
}
else
{
// since we did not find build in behaviour we must load always.
$library -> how = 1 ;
}
}
2017-12-03 20:09:04 +02:00
// check if this lib has dynamic behaviour
if ( $library -> how > 0 )
{
2018-02-16 23:53:43 +02:00
// set the add targets
$addArray = array ( 'files' => 'files' , 'folders' => 'folders' , 'urls' => 'urls' , 'filesfullpath' => 'files' , 'foldersfullpath' => 'folders' );
foreach ( $addArray as $addTarget => $targetHere )
2017-12-03 20:09:04 +02:00
{
2018-02-16 23:53:43 +02:00
// set the add target data
$library -> { 'add' . $addTarget } = ( isset ( $library -> { 'add' . $addTarget }) && ComponentbuilderHelper :: checkJson ( $library -> { 'add' . $addTarget })) ? json_decode ( $library -> { 'add' . $addTarget }, true ) : null ;
if ( ComponentbuilderHelper :: checkArray ( $library -> { 'add' . $addTarget }))
{
if ( isset ( $library -> { $targetHere }) && ComponentbuilderHelper :: checkArray ( $library -> { $targetHere }))
{
foreach ( $library -> { 'add' . $addTarget } as $taget )
{
$library -> { $targetHere }[] = $taget ;
}
}
else
{
$library -> { $targetHere } = array_values ( $library -> { 'add' . $addTarget });
}
}
unset ( $library -> { 'add' . $addTarget });
2017-12-15 01:10:47 +02:00
}
2017-12-03 20:09:04 +02:00
// add config fields only if needed
if ( $library -> how > 1 )
{
// set the config data
2017-12-15 01:10:47 +02:00
$library -> addconfig = ( isset ( $library -> addconfig ) && ComponentbuilderHelper :: checkJson ( $library -> addconfig )) ? json_decode ( $library -> addconfig , true ) : null ;
2017-12-03 20:09:04 +02:00
if ( ComponentbuilderHelper :: checkArray ( $library -> addconfig ))
{
2017-12-15 01:10:47 +02:00
$library -> config = array_map ( function ( $array )
{
2017-12-03 20:09:04 +02:00
$array [ 'alias' ] = 0 ;
$array [ 'title' ] = 0 ;
$array [ 'settings' ] = $this -> getFieldData ( $array [ 'field' ]);
return $array ;
}, array_values ( $library -> addconfig ));
}
}
// if this lib is controlled by custom script
if ( 3 == $library -> how )
{
// set Needed PHP
2017-12-10 21:17:26 +02:00
if ( isset ( $library -> php_setdocument ) && ComponentbuilderHelper :: checkString ( $library -> php_setdocument ))
2017-12-03 20:09:04 +02:00
{
2017-12-10 21:17:26 +02:00
$library -> document = $this -> setDynamicValues ( base64_decode ( $library -> php_setdocument ));
2017-12-03 20:09:04 +02:00
}
}
// if this lib is controlled by conditions
elseif ( 2 == $library -> how )
{
// set the addconditions data
2017-12-15 01:10:47 +02:00
$library -> addconditions = ( isset ( $library -> addconditions ) && ComponentbuilderHelper :: checkJson ( $library -> addconditions )) ? json_decode ( $library -> addconditions , true ) : null ;
2017-12-03 20:09:04 +02:00
if ( ComponentbuilderHelper :: checkArray ( $library -> addconditions ))
{
$library -> conditions = array_values ( $library -> addconditions );
}
}
unset ( $library -> php_setdocument );
unset ( $library -> addconditions );
2017-12-10 21:17:26 +02:00
unset ( $library -> addconfig );
// load to global lib
$this -> libraries [ $id ] = $library ;
2017-12-03 20:09:04 +02:00
}
else
{
$this -> libraries [ $id ] = false ;
}
}
// if set return
if ( isset ( $this -> libraries [ $id ]))
{
return $this -> libraries [ $id ];
}
return false ;
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2017-02-14 01:24:38 +02:00
* Set Language Place Holders
2016-02-26 02:20:09 +02:00
*
* @ param string $content The content
*
* @ return string The content with the updated Language place holder
*
*/
2017-02-14 01:24:38 +02:00
public function setLangStrings ( $content )
2016-02-26 02:20:09 +02:00
{
2017-12-14 15:30:21 +02:00
// get targets to search for
$langStringTargets = array_filter (
2017-12-15 01:10:47 +02:00
$this -> langStringTargets , function ( $get ) use ( $content )
{
if ( strpos ( $content , $get ) !== false )
{
return true ;
}
return false ;
});
2017-12-14 15:30:21 +02:00
// check if we should continue
if ( ComponentbuilderHelper :: checkArray ( $langStringTargets ))
2017-02-14 01:24:38 +02:00
{
// insure string is not broken
2017-12-15 01:10:47 +02:00
$content = str_replace ( 'COM_###COMPONENT###' , $this -> langPrefix , $content );
2017-12-14 15:30:21 +02:00
// first get the Joomla.JText._()
2018-02-06 12:55:46 +02:00
if ( in_array ( 'Joomla' . '.JText._(' , $langStringTargets ))
2017-12-14 15:30:21 +02:00
{
2018-02-06 12:55:46 +02:00
$jsTEXT [] = ComponentbuilderHelper :: getAllBetween ( $content , " Joomla " . " .JText._(' " , " ' " );
$jsTEXT [] = ComponentbuilderHelper :: getAllBetween ( $content , 'Joomla.' . 'JText._("' , '"' );
2017-12-14 15:30:21 +02:00
// combine into one array
$jsTEXT = ComponentbuilderHelper :: mergeArrays ( $jsTEXT );
// we need to add a check to insure these JavaScript lang matchup
if ( ComponentbuilderHelper :: checkArray ( $jsTEXT )) //<-- not really needed hmmm
{
// load the JS text to mismatch array
$langCheck [] = $jsTEXT ;
$this -> langMismatch = ComponentbuilderHelper :: mergeArrays ( array ( $jsTEXT , $this -> langMismatch ));
}
}
2018-02-06 12:55:46 +02:00
// now get the JText: :script()
if ( in_array ( 'JText:' . ':script(' , $langStringTargets ))
2017-12-14 15:30:21 +02:00
{
2018-02-06 12:55:46 +02:00
$scTEXT [] = ComponentbuilderHelper :: getAllBetween ( $content , " JText: " . " :script(' " , " ' " );
$scTEXT [] = ComponentbuilderHelper :: getAllBetween ( $content , 'JText:' . ':script("' , '"' );
2017-12-14 15:30:21 +02:00
// combine into one array
$scTEXT = ComponentbuilderHelper :: mergeArrays ( $scTEXT );
// we need to add a check to insure these JavaScript lang matchup
if ( ComponentbuilderHelper :: checkArray ( $scTEXT )) //<-- not really needed hmmm
{
// load the Script text to match array
$langCheck [] = $scTEXT ;
$this -> langMatch = ComponentbuilderHelper :: mergeArrays ( array ( $scTEXT , $this -> langMatch ));
}
}
2017-02-14 01:24:38 +02:00
// set language data
2017-12-15 01:10:47 +02:00
foreach ( $langStringTargets as $langStringTarget )
2017-12-14 15:30:21 +02:00
{
// need some special treatment here
2018-02-06 12:55:46 +02:00
if ( $langStringTarget === 'Joomla' . '.JText._(' || $langStringTarget === 'JText:' . ':script(' )
2017-12-14 15:30:21 +02:00
{
continue ;
}
2017-12-15 01:10:47 +02:00
$langCheck [] = ComponentbuilderHelper :: getAllBetween ( $content , $langStringTarget . " ' " , " ' " );
$langCheck [] = ComponentbuilderHelper :: getAllBetween ( $content , $langStringTarget . '"' , '"' );
2017-12-14 15:30:21 +02:00
}
2017-02-14 01:24:38 +02:00
$langArray = ComponentbuilderHelper :: mergeArrays ( $langCheck );
2017-12-14 15:30:21 +02:00
if ( ComponentbuilderHelper :: checkArray ( $langArray )) //<-- not really needed hmmm
2016-02-26 02:20:09 +02:00
{
2017-02-14 01:24:38 +02:00
foreach ( $langArray as $string )
2016-02-26 02:20:09 +02:00
{
2017-02-14 01:24:38 +02:00
// this is there to insure we dont break already added Language strings
2017-12-15 01:10:47 +02:00
if ( ComponentbuilderHelper :: safeString ( $string , 'U' ) === $string )
2017-02-14 01:24:38 +02:00
{
continue ;
}
// only load if string is not already set
2017-12-15 01:10:47 +02:00
$keyLang = $this -> langPrefix . '_' . ComponentbuilderHelper :: safeString ( $string , 'U' );
2017-02-14 01:24:38 +02:00
if ( ! isset ( $this -> langContent [ $this -> lang ][ $keyLang ]))
{
$this -> langContent [ $this -> lang ][ $keyLang ] = trim ( $string );
}
2017-12-14 15:30:21 +02:00
// load the language targets
2017-12-15 01:10:47 +02:00
foreach ( $langStringTargets as $langStringTarget )
2017-12-14 15:30:21 +02:00
{
2017-12-15 01:10:47 +02:00
$langHolders [ $langStringTarget . " ' " . $string . " ' " ] = $langStringTarget . " ' " . $keyLang . " ' " ;
$langHolders [ $langStringTarget . '"' . $string . '"' ] = $langStringTarget . '"' . $keyLang . '"' ;
2017-12-14 15:30:21 +02:00
}
2016-02-26 02:20:09 +02:00
}
2017-03-08 06:49:54 +02:00
// only continue if we have value to replace
if ( isset ( $langHolders ) && ComponentbuilderHelper :: checkArray ( $langHolders ))
{
$content = $this -> setPlaceholders ( $content , $langHolders );
}
2016-02-26 02:20:09 +02:00
}
}
return $content ;
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Set Data Selection of the dynamic get
*
2016-03-01 20:44:13 +02:00
* @ param string $method_key The method unique key
* @ param string $view_code The code name of the view
* @ param string $string The data string
* @ param string || INT $asset The asset in question
* @ param string $as The as string
* @ param int $row_type The row type
* @ param string $type The target type ( db || view )
2016-02-26 02:20:09 +02:00
*
* @ return array the select query
*
*/
2017-10-06 16:53:22 +02:00
public function setDataSelection ( $method_key , $view_code , $string , $asset , $as , $row_type , $type )
2016-02-26 02:20:09 +02:00
{
if ( ComponentbuilderHelper :: checkString ( $string ))
{
2017-12-15 01:10:47 +02:00
$lines = explode ( PHP_EOL , $string );
2016-02-26 02:20:09 +02:00
if ( ComponentbuilderHelper :: checkArray ( $lines ))
{
2017-02-02 13:54:07 +02:00
if ( 'db' === $type )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$table = '#__' . $asset ;
2016-02-26 02:20:09 +02:00
$queryName = $asset ;
2017-12-15 01:10:47 +02:00
$view = '' ;
2016-02-26 02:20:09 +02:00
}
2017-02-02 13:54:07 +02:00
elseif ( 'view' === $type )
2016-02-26 02:20:09 +02:00
{
$view = $this -> getViewTableName ( $asset );
2017-12-15 01:10:47 +02:00
$table = '#__' . $this -> componentCodeName . '_' . $view ;
2016-02-26 02:20:09 +02:00
$queryName = $view ;
}
$gets = array ();
$keys = array ();
2017-11-16 06:37:32 +02:00
// first load all options
2016-02-26 02:20:09 +02:00
foreach ( $lines as $line )
{
2017-12-15 01:10:47 +02:00
if ( strpos ( $line , 'AS' ) !== false )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
list ( $get , $key ) = explode ( " AS " , $line );
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
elseif ( strpos ( $line , 'as' ) !== false )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
list ( $get , $key ) = explode ( " as " , $line );
2016-02-26 02:20:09 +02:00
}
else
{
$get = $line ;
$key = null ;
}
2017-11-16 06:37:32 +02:00
// set the get and key
2016-02-26 02:20:09 +02:00
$get = trim ( $get );
$key = trim ( $key );
2017-11-16 06:37:32 +02:00
// only add the view (we must adapt this)
2017-12-15 01:10:47 +02:00
if ( isset ( $this -> getAsLookup [ $method_key ][ $get ]) && 'a' != $as && 1 == $row_type && 'view' === $type && strpos ( '#' . $key , '#' . $view . '_' ) === false )
2016-02-26 02:20:09 +02:00
{
2017-11-16 06:37:32 +02:00
// this is a problem (TODO) since we may want to not add the view name.
2017-12-15 01:10:47 +02:00
$key = $view . '_' . trim ( $key );
2016-02-26 02:20:09 +02:00
}
2017-11-16 06:37:32 +02:00
// continue only if we have get
2016-02-26 02:20:09 +02:00
if ( ComponentbuilderHelper :: checkString ( $get ))
{
2017-02-14 01:24:38 +02:00
$gets [] = $this -> db -> quote ( $get );
2016-02-26 02:20:09 +02:00
if ( ComponentbuilderHelper :: checkString ( $key ))
{
$this -> getAsLookup [ $method_key ][ $get ] = $key ;
2017-02-14 01:24:38 +02:00
$keys [] = $this -> db -> quote ( $key );
2016-02-26 02:20:09 +02:00
}
else
{
2017-12-15 01:10:47 +02:00
$key = str_replace ( $as . '.' , '' , $get );
2016-02-26 02:20:09 +02:00
$this -> getAsLookup [ $method_key ][ $get ] = $key ;
2017-02-14 01:24:38 +02:00
$keys [] = $this -> db -> quote ( $key );
2016-02-26 02:20:09 +02:00
}
if ( ComponentbuilderHelper :: checkString ( $view ))
{
2017-12-15 01:10:47 +02:00
$field = str_replace ( $as . '.' , '' , $get );
2016-02-26 02:20:09 +02:00
$this -> siteFields [ $view ][ $field ][ $method_key ] = array ( 'site' => $view_code , 'get' => $get , 'as' => $as , 'key' => $key );
}
}
}
if ( ComponentbuilderHelper :: checkArray ( $gets ) && ComponentbuilderHelper :: checkArray ( $keys ))
{
2017-12-15 01:10:47 +02:00
$querySelect = '$query->select($db->quoteName(' . PHP_EOL . " \t \t \t " . 'array(' . implode ( ',' , $gets ) . '),' . PHP_EOL . " \t \t \t " . 'array(' . implode ( ',' , $keys ) . ')));' ;
$queryFrom = '$db->quoteName(' . $this -> db -> quote ( $table ) . ', ' . $this -> db -> quote ( $as ) . ')' ;
2016-02-26 02:20:09 +02:00
// return the select query
return array ( 'select' => $querySelect , 'from' => $queryFrom , 'name' => $queryName , 'table' => $table , 'type' => $type , 'select_gets' => $gets , 'select_keys' => $keys );
}
}
}
return false ;
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Get the View Table Name
*
* @ param int $id The admin view in
*
* @ return string view code name
*
*/
public function getViewTableName ( $id )
{
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
$query -> select ( $this -> db -> quoteName ( array ( 'a.name_single' )));
2017-12-15 01:10:47 +02:00
$query -> from ( $this -> db -> quoteName ( '#__componentbuilder_admin_view' , 'a' ));
$query -> where ( $this -> db -> quoteName ( 'a.id' ) . ' = ' . ( int ) $id );
2017-02-14 01:24:38 +02:00
$this -> db -> setQuery ( $query );
return ComponentbuilderHelper :: safeString ( $this -> db -> loadResult ());
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Build the SQL dump String for a view
*
* @ param string $tables The tables to use in build
* @ param string $view The target view / table to dump in
2016-03-01 20:44:13 +02:00
* @ param int $view_id The id of the target view
2016-02-26 02:20:09 +02:00
*
* @ return string on success with the Dump SQL
*
*/
2017-10-12 02:50:14 +02:00
public function buildSqlDump ( $tables , $view , $view_id )
2016-02-26 02:20:09 +02:00
{
// first build a query statment to get all the data (insure it must be added - check the tweaking)
if ( ComponentbuilderHelper :: checkArray ( $tables ) && ( ! isset ( $this -> sqlTweak [ $view_id ][ 'remove' ]) || ! $this -> sqlTweak [ $view_id ][ 'remove' ]))
{
$counter = 'a' ;
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
2016-02-26 02:20:09 +02:00
foreach ( $tables as $table )
{
2017-02-01 15:17:04 +02:00
if ( $counter === 'a' )
2016-02-26 02:20:09 +02:00
{
// the main table fields
2017-12-15 01:10:47 +02:00
if ( strpos ( $table [ 'sourcemap' ], PHP_EOL ) !== false )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$fields = explode ( PHP_EOL , $table [ 'sourcemap' ]);
2016-02-26 02:20:09 +02:00
if ( ComponentbuilderHelper :: checkArray ( $fields ))
{
// reset array buckets
$sourceArray = array ();
$targetArray = array ();
foreach ( $fields as $field )
{
2017-12-15 01:10:47 +02:00
if ( strpos ( $field , " => " ) !== false )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
list ( $source , $target ) = explode ( " => " , $field );
$sourceArray [] = $counter . '.' . trim ( $source );
2016-02-26 02:20:09 +02:00
$targetArray [] = trim ( $target );
}
}
if ( ComponentbuilderHelper :: checkArray ( $sourceArray ) && ComponentbuilderHelper :: checkArray ( $targetArray ))
{
// add to query
2017-12-15 01:10:47 +02:00
$query -> select ( $this -> db -> quoteName ( $sourceArray , $targetArray ));
$query -> from ( '#__' . $table [ 'table' ] . ' AS a' );
2016-02-26 02:20:09 +02:00
}
// we may need to filter the selection
if ( isset ( $this -> sqlTweak [ $view_id ][ 'where' ]))
{
// add to query the where filter
$query -> where ( 'a.id IN (' . $this -> sqlTweak [ $view_id ][ 'where' ] . ')' );
}
}
}
}
else
{
// the other tables
2017-12-15 01:10:47 +02:00
if ( strpos ( $table [ 'sourcemap' ], PHP_EOL ) !== false )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
$fields = explode ( PHP_EOL , $table [ 'sourcemap' ]);
2016-02-26 02:20:09 +02:00
if ( ComponentbuilderHelper :: checkArray ( $fields ))
{
// reset array buckets
$sourceArray = array ();
$targetArray = array ();
foreach ( $fields as $field )
{
2017-12-15 01:10:47 +02:00
if ( strpos ( $field , " => " ) !== false )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
list ( $source , $target ) = explode ( " => " , $field );
$sourceArray [] = $counter . '.' . trim ( $source );
2016-02-26 02:20:09 +02:00
$targetArray [] = trim ( $target );
}
2017-12-15 01:10:47 +02:00
if ( strpos ( $field , " == " ) !== false )
2016-02-26 02:20:09 +02:00
{
2017-12-15 01:10:47 +02:00
list ( $aKey , $bKey ) = explode ( " == " , $field );
2016-02-26 02:20:09 +02:00
// add to query
2017-12-15 01:10:47 +02:00
$query -> join ( 'LEFT' , $this -> db -> quoteName ( '#__' . $table [ 'table' ], $counter ) . ' ON (' . $this -> db -> quoteName ( 'a.' . trim ( $aKey )) . ' = ' . $this -> db -> quoteName ( $counter . '.' . trim ( $bKey )) . ')' );
2016-02-26 02:20:09 +02:00
}
}
if ( ComponentbuilderHelper :: checkArray ( $sourceArray ) && ComponentbuilderHelper :: checkArray ( $targetArray ))
{
// add to query
2017-12-15 01:10:47 +02:00
$query -> select ( $this -> db -> quoteName ( $sourceArray , $targetArray ));
2016-02-26 02:20:09 +02:00
}
}
}
}
$counter ++ ;
}
// now get the data
2017-02-14 01:24:38 +02:00
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
if ( $this -> db -> getNumRows ())
2016-02-26 02:20:09 +02:00
{
// get the data
2017-02-14 01:24:38 +02:00
$data = $this -> db -> loadObjectList ();
2016-02-26 02:20:09 +02:00
// start building the MySql dump
$dump = " -- " ;
2017-12-15 01:10:47 +02:00
$dump .= PHP_EOL . " -- Dumping data for table `#__[[[component]]]_ " . $view . " ` " ;
$dump .= PHP_EOL . " -- " ;
$dump .= PHP_EOL . PHP_EOL . " INSERT INTO `#__[[[component]]]_ " . $view . " ` ( " ;
2016-02-26 02:20:09 +02:00
foreach ( $data as $line )
{
$comaSet = 0 ;
2017-12-15 01:10:47 +02:00
foreach ( $line as $fieldName => $fieldValue )
2016-02-26 02:20:09 +02:00
{
if ( $comaSet == 0 )
{
2017-02-14 01:24:38 +02:00
$dump .= $this -> db -> quoteName ( $fieldName );
2016-02-26 02:20:09 +02:00
}
else
{
2017-12-15 01:10:47 +02:00
$dump .= " , " . $this -> db -> quoteName ( $fieldName );
2016-02-26 02:20:09 +02:00
}
$comaSet ++ ;
}
break ;
}
$dump .= " ) VALUES " ;
$coma = 0 ;
foreach ( $data as $line )
{
if ( $coma == 0 )
{
2017-12-15 01:10:47 +02:00
$dump .= PHP_EOL . " ( " ;
2016-02-26 02:20:09 +02:00
}
else
{
2017-12-15 01:10:47 +02:00
$dump .= " , " . PHP_EOL . " ( " ;
2016-02-26 02:20:09 +02:00
}
$comaSet = 0 ;
2017-12-15 01:10:47 +02:00
foreach ( $line as $fieldName => $fieldValue )
2016-02-26 02:20:09 +02:00
{
if ( $comaSet == 0 )
{
$dump .= $this -> mysql_escape ( $fieldValue );
}
else
{
2017-12-15 01:10:47 +02:00
$dump .= " , " . $this -> mysql_escape ( $fieldValue );
2016-02-26 02:20:09 +02:00
}
$comaSet ++ ;
}
$dump .= " ) " ;
$coma ++ ;
}
$dump .= " ; " ;
// return build dump query
return $dump ;
}
}
return false ;
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Escape the values for a SQL dump
*
* @ param string $value the value to escape
*
* @ return string on success with escaped string
*
*/
public function mysql_escape ( $value )
{
// if array then return maped
2017-12-15 01:10:47 +02:00
if ( ComponentbuilderHelper :: checkArray ( $value ))
2016-02-26 02:20:09 +02:00
{
return array_map ( __METHOD__ , $value );
}
// if string make sure it is correctly escaped
2017-12-15 01:10:47 +02:00
if ( ComponentbuilderHelper :: checkString ( $value ) && ! is_numeric ( $value ))
2016-02-26 02:20:09 +02:00
{
2017-02-14 01:24:38 +02:00
return $this -> db -> quote ( $value );
2016-02-26 02:20:09 +02:00
}
// if empty value return place holder
2017-12-15 01:10:47 +02:00
if ( empty ( $value ))
2016-02-26 02:20:09 +02:00
{
return " '' " ;
}
// if not array or string then return number
return $value ;
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Creating an uniqueCode
*
* @ param string $code The planed code
*
* @ return string The unique code
*
*/
public function uniqueCode ( $code )
{
2017-12-15 01:10:47 +02:00
if ( ! isset ( $this -> uniquecodes [ $this -> target ]) || ! in_array ( $code , $this -> uniquecodes [ $this -> target ]))
2016-02-26 02:20:09 +02:00
{
2016-02-26 15:57:30 +02:00
$this -> uniquecodes [ $this -> target ][] = $code ;
2016-02-26 02:20:09 +02:00
return $code ;
}
// make sure it is unique
2017-12-15 01:10:47 +02:00
return $this -> uniqueCode ( $code . $this -> uniquekey ( 1 ));
2016-02-26 15:57:30 +02:00
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 15:57:30 +02:00
* Creating an unique local key
*
* @ param int $size The key size
*
* @ return string The unique localkey
*
*/
2016-11-22 19:08:17 +02:00
public function uniquekey ( $size , $random = false , $newBag = " vvvvvvvvvvvvvvvvvvv " )
2016-02-26 15:57:30 +02:00
{
if ( $random )
{
$bag = " abcefghijknopqrstuwxyzABCDDEFGHIJKLLMMNOPQRSTUVVWXYZabcddefghijkllmmnopqrstuvvwxyzABCEFGHIJKNOPQRSTUWXYZ " ;
}
else
{
2016-11-22 19:08:17 +02:00
$bag = $newBag ;
2016-02-26 15:57:30 +02:00
}
$key = array ();
$bagsize = strlen ( $bag ) - 1 ;
for ( $i = 0 ; $i < $size ; $i ++ )
{
$get = rand ( 0 , $bagsize );
$key [] = $bag [ $get ];
}
$key = implode ( $key );
while ( in_array ( $key , $this -> uniquekeys ))
{
$key ++ ;
}
$this -> uniquekeys [] = $key ;
return $key ;
2016-02-26 02:20:09 +02:00
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Check for footable scripts
*
* @ param string $content The content to check
*
* @ return boolean True if found
*
*/
public function getFootableScripts ( $content )
{
2017-12-15 01:10:47 +02:00
if ( strpos ( $content , 'footable' ) !== false )
2016-02-26 02:20:09 +02:00
{
return true ;
}
return false ;
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2016-02-26 02:20:09 +02:00
* Check for getModules script
*
* @ param string $content The content to check
*
* @ return boolean True if found
*
*/
public function getGetModule ( $content )
{
2017-12-15 01:10:47 +02:00
if ( strpos ( $content , 'this->getModules(' ) !== false )
2016-02-26 02:20:09 +02:00
{
return true ;
}
return false ;
}
2017-12-15 01:10:47 +02:00
2016-03-04 02:01:43 +02:00
/**
2017-12-03 20:09:04 +02:00
* Check for get Google Chart script
2016-02-26 02:20:09 +02:00
*
* @ param string $content The content to check
*
* @ return boolean True if found
*
*/
public function getGoogleChart ( $content )
{
2017-12-15 01:10:47 +02:00
if ( strpos ( $content , 'Chartbuilder(' ) !== false )
2016-02-26 02:20:09 +02:00
{
return true ;
}
return false ;
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* Set the dynamic values in strings here
*
* @ param string $string The content to check
*
* @ return string
*
*/
public function setDynamicValues ( $string )
{
2017-03-08 06:49:54 +02:00
if ( ComponentbuilderHelper :: checkString ( $string ))
{
2018-02-03 02:13:48 +02:00
return $this -> setLangStrings ( $this -> setCustomCodeData ( $this -> setExternalCodeString ( $string )));
2017-03-08 06:49:54 +02:00
}
return $string ;
2017-02-14 01:24:38 +02:00
}
2018-02-02 19:36:22 +02:00
2018-01-31 15:35:54 +02:00
/**
2018-02-03 02:13:48 +02:00
* Set the external code string & load it in to string
2018-01-31 15:35:54 +02:00
*
* @ param string $string The content to check
*
* @ return string
*
*/
2018-02-03 02:13:48 +02:00
public function setExternalCodeString ( $string )
2018-01-31 15:35:54 +02:00
{
// check if content has custom code place holder
2018-02-03 02:13:48 +02:00
if ( strpos ( $string , '[EXTERNA' . 'LCODE=' ) !== false )
2018-01-31 15:35:54 +02:00
{
2018-02-03 02:13:48 +02:00
// target content
2018-01-31 15:35:54 +02:00
$bucket = array ();
2018-02-03 02:13:48 +02:00
$found = ComponentbuilderHelper :: getAllBetween ( $string , '[EXTERNA' . 'LCODE=' , ']' );
2018-01-31 15:35:54 +02:00
if ( ComponentbuilderHelper :: checkArray ( $found ))
{
// build local bucket
2018-02-03 02:13:48 +02:00
foreach ( $found as $target )
2018-01-31 15:35:54 +02:00
{
2018-03-06 04:28:44 +02:00
// check if user has permission to use EXTERNAL code (we may add a custom access switch - use ADMIN for now)
if ( $this -> user -> authorise ( 'core.admin' , 'com_componentbuilder' ))
2018-01-31 15:35:54 +02:00
{
2018-03-06 04:28:44 +02:00
// check if the target is valid URL or path
if (( ! filter_var ( $target , FILTER_VALIDATE_URL ) === false && ComponentbuilderHelper :: urlExists ( $target ))
|| ( JPath :: clean ( $target ) === $target && JFile :: exists ( $target )))
{
$this -> getExternalCodeString ( $target , $bucket );
}
// give notice that target is not a valid url/path
else
{
// set key
$key = '[EXTERNA' . 'LCODE=' . $target . ']' ;
// set the notice
$this -> app -> enqueueMessage ( JText :: _ ( '<hr /><h3>External Code Warning</h3>' ), 'Warning' );
$this -> app -> enqueueMessage ( JText :: sprintf ( 'The <b>%s</b> is not a valid url/path!' , $key ), 'Warning' );
$this -> app -> enqueueMessage ( '<hr />' , 'Warning' );
// remove the placeholder
$bucket [ $key ] = '' ;
}
2018-01-31 15:35:54 +02:00
}
2018-02-02 19:36:22 +02:00
else
2018-01-31 15:35:54 +02:00
{
2018-02-03 02:13:48 +02:00
// set key
$key = '[EXTERNA' . 'LCODE=' . $target . ']' ;
// set the notice
2018-03-06 04:28:44 +02:00
$this -> app -> enqueueMessage ( JText :: sprintf ( '%s, you do not have permission to use <b>EXTERNALCODE</b> feature (so it was removed from the compilation), please contact you system administrator for more info!<br /><small>(admin access required)</small>' , $this -> user -> get ( 'name' )), 'Error' );
2018-02-02 19:36:22 +02:00
// remove the placeholder
2018-02-03 02:13:48 +02:00
$bucket [ $key ] = '' ;
2018-01-31 15:35:54 +02:00
}
}
// now update local string if bucket has values
if ( ComponentbuilderHelper :: checkArray ( $bucket ))
{
$string = $this -> setPlaceholders ( $string , $bucket );
}
}
}
return $string ;
}
2018-02-02 19:36:22 +02:00
/**
2018-02-03 02:13:48 +02:00
* Get the External Code / String
2018-02-02 19:36:22 +02:00
*
* @ param string $string The content to check
* @ param array $bucket The Placeholders bucket
*
* @ return void
*
*/
2018-02-03 02:13:48 +02:00
protected function getExternalCodeString ( $target , & $bucket )
2018-02-02 19:36:22 +02:00
{
// set key
2018-02-03 02:13:48 +02:00
$key = '[EXTERNA' . 'LCODE=' . $target . ']' ;
2018-02-02 19:36:22 +02:00
// set URL key
2018-02-03 02:13:48 +02:00
$targetKey = trim ( $target );
// check if we already fetched this
if ( ! isset ( $this -> externalCodeString [ $targetKey ]))
2018-02-02 19:36:22 +02:00
{
// get the data string (code)
2018-02-03 02:13:48 +02:00
$this -> externalCodeString [ $targetKey ] = ComponentbuilderHelper :: getFileContents ( $targetKey );
2018-02-02 19:36:22 +02:00
// did we get any value
2018-02-03 02:13:48 +02:00
if ( ComponentbuilderHelper :: checkString ( $this -> externalCodeString [ $targetKey ]))
2018-02-02 19:36:22 +02:00
{
// check for changes
2018-02-03 02:13:48 +02:00
$liveHash = md5 ( $this -> externalCodeString [ $targetKey ]);
2018-02-02 19:36:22 +02:00
// check if it exist local
2018-02-03 02:13:48 +02:00
if ( $hash = ComponentbuilderHelper :: getVar ( 'external_code' , $targetKey , 'target' , 'hash' ))
2018-02-02 19:36:22 +02:00
{
if ( $hash !== $liveHash )
{
2018-02-06 12:55:46 +02:00
// update the hash since it changed
2018-02-02 19:36:22 +02:00
$object = new stdClass ();
2018-02-03 02:13:48 +02:00
$object -> target = $targetKey ;
2018-02-02 19:36:22 +02:00
$object -> hash = $liveHash ;
// update local hash
2018-02-03 02:13:48 +02:00
$this -> db -> updateObject ( '#__componentbuilder_external_code' , $object , 'target' );
2018-02-02 19:36:22 +02:00
// give notice of the change
2018-03-05 02:13:42 +02:00
$this -> app -> enqueueMessage ( JText :: _ ( '<hr /><h3>External Code Warning</h3>' ), 'Warning' );
2018-02-06 12:55:46 +02:00
$this -> app -> enqueueMessage ( JText :: sprintf ( 'The code/string from <b>%s</b> has been <b>changed</b> since the last compilation, please investigate to insure the changes are safe!' , $key ), 'Warning' );
2018-03-05 02:13:42 +02:00
$this -> app -> enqueueMessage ( '<hr />' , 'Warning' );
2018-02-02 19:36:22 +02:00
}
}
else
{
// add the hash to track changes
$object = new stdClass ();
2018-02-03 02:13:48 +02:00
$object -> target = $targetKey ;
2018-02-02 19:36:22 +02:00
$object -> hash = $liveHash ;
// insert local hash
2018-02-03 02:13:48 +02:00
$this -> db -> insertObject ( '#__componentbuilder_external_code' , $object );
2018-02-06 12:55:46 +02:00
// give notice the first time this is added
2018-03-05 02:13:42 +02:00
$this -> app -> enqueueMessage ( JText :: _ ( '<hr /><h3>External Code Notice</h3>' ), 'Notice' );
2018-02-06 12:55:46 +02:00
$this -> app -> enqueueMessage ( JText :: sprintf ( 'The code/string from <b>%s</b> has been added for the <b>first time</b>, please investigate to insure the correct code/string was used!' , $key ), 'Notice' );
2018-03-05 02:13:42 +02:00
$this -> app -> enqueueMessage ( '<hr />' , 'Notice' );
2018-02-02 19:36:22 +02:00
}
}
else
{
2018-02-03 02:13:48 +02:00
// set notice that we could not get a valid string from the target
2018-03-05 02:13:42 +02:00
$this -> app -> enqueueMessage ( JText :: _ ( '<hr /><h3>External Code Warning</h3>' ), 'Warning' );
2018-02-06 12:55:46 +02:00
$this -> app -> enqueueMessage ( JText :: sprintf ( 'The <b>%s</b> returned an invalid string!' , $key ), 'Warning' );
2018-03-05 02:13:42 +02:00
$this -> app -> enqueueMessage ( '<hr />' , 'Warning' );
2018-02-02 19:36:22 +02:00
}
}
// add to local bucket
2018-02-03 02:13:48 +02:00
if ( isset ( $this -> externalCodeString [ $targetKey ]))
2018-02-02 19:36:22 +02:00
{
2018-02-03 02:13:48 +02:00
$bucket [ $key ] = $this -> externalCodeString [ $targetKey ];
2018-02-02 19:36:22 +02:00
}
}
2017-02-14 01:24:38 +02:00
/**
* We start set the custom code data & can load it in to string
*
* @ param string $string The content to check
*
2018-01-31 15:35:54 +02:00
* @ return string
2017-02-14 01:24:38 +02:00
*
*/
public function setCustomCodeData ( $string )
{
// insure the code is loaded
$loaded = false ;
// check if content has custom code place holder
2017-12-15 01:10:47 +02:00
if ( strpos ( $string , '[CUSTO' . 'MCODE=' ) !== false )
2017-02-14 01:24:38 +02:00
{
// the ids found in this content
$bucket = array ();
2017-12-15 01:10:47 +02:00
$found = ComponentbuilderHelper :: getAllBetween ( $string , '[CUSTO' . 'MCODE=' , ']' );
2017-02-14 01:24:38 +02:00
if ( ComponentbuilderHelper :: checkArray ( $found ))
{
foreach ( $found as $key )
{
// check if we have args
if ( is_numeric ( $key ))
{
$id = ( int ) $key ;
}
elseif ( ComponentbuilderHelper :: checkString ( $key ) && strpos ( $key , '+' ) === false )
{
$getFuncName = trim ( $key );
if ( ! isset ( $this -> functionNameMemory [ $getFuncName ]))
{
2018-01-31 15:35:54 +02:00
if ( ! $found_local = ComponentbuilderHelper :: getVar ( 'custom_code' , $getFuncName , 'function_name' , 'id' ))
2017-02-14 01:24:38 +02:00
{
continue ;
}
2018-01-31 15:35:54 +02:00
$this -> functionNameMemory [ $getFuncName ] = $found_local ;
2017-02-14 01:24:38 +02:00
}
$id = ( int ) $this -> functionNameMemory [ $getFuncName ];
}
elseif ( ComponentbuilderHelper :: checkString ( $key ) && strpos ( $key , '+' ) !== false )
{
$array = explode ( '+' , $key );
// set ID
if ( is_numeric ( $array [ 0 ]))
{
$id = ( int ) $array [ 0 ];
}
elseif ( ComponentbuilderHelper :: checkString ( $array [ 0 ]))
{
$getFuncName = trim ( $array [ 0 ]);
if ( ! isset ( $this -> functionNameMemory [ $getFuncName ]))
{
2018-01-31 15:35:54 +02:00
if ( ! $found_local = ComponentbuilderHelper :: getVar ( 'custom_code' , $getFuncName , 'function_name' , 'id' ))
2017-02-14 01:24:38 +02:00
{
continue ;
}
2018-01-31 15:35:54 +02:00
$this -> functionNameMemory [ $getFuncName ] = $found_local ;
2017-02-14 01:24:38 +02:00
}
$id = ( int ) $this -> functionNameMemory [ $getFuncName ];
}
else
{
continue ;
}
// load args for this ID
if ( isset ( $array [ 1 ]))
{
if ( ! isset ( $this -> customCodeData [ $id ][ 'args' ]))
{
$this -> customCodeData [ $id ][ 'args' ] = array ();
}
// only load if not already loaded
if ( ! isset ( $this -> customCodeData [ $id ][ 'args' ][ $key ]))
{
if ( strpos ( $array [ 1 ], ',' ) !== false )
{
2017-12-15 01:10:47 +02:00
$this -> customCodeData [ $id ][ 'args' ][ $key ] = explode ( ',' , $array [ 1 ]);
2017-02-14 01:24:38 +02:00
}
elseif ( ComponentbuilderHelper :: checkString ( $array [ 1 ]))
{
$this -> customCodeData [ $id ][ 'args' ][ $key ] = array ();
$this -> customCodeData [ $id ][ 'args' ][ $key ][] = $array [ 1 ];
}
}
2017-12-15 01:10:47 +02:00
}
2017-02-14 01:24:38 +02:00
}
else
{
continue ;
}
$bucket [ $id ] = $id ;
}
}
// check if any custom code placeholders where found
if ( ComponentbuilderHelper :: checkArray ( $bucket ))
{
$_tmpLang = $this -> lang ;
// insure we add the langs to both site and admin
$this -> lang = 'both' ;
// now load the code to memory
$loaded = $this -> getCustomCode ( $bucket , false );
// revert lang to current setting
$this -> lang = $_tmpLang ;
}
// when the custom code is loaded
if ( $loaded === true )
{
$string = $this -> insertCustomCode ( $string );
}
}
return $string ;
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* Insert the custom code into the string
*
* @ param string $string The content to check
*
* @ return string on success
*
*/
protected function insertCustomCode ( $string )
{
$code = array ();
2017-12-15 01:10:47 +02:00
foreach ( $this -> customCode as $item )
2017-02-14 01:24:38 +02:00
{
$this -> buildCustomCodePlaceholders ( $item , $code );
}
// now update the string
return $this -> setPlaceholders ( $string , $code );
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* Insert the custom code into the string
*
* @ param string $string The content to check
*
* @ return string on success
*
2017-12-15 01:10:47 +02:00
*/
2017-02-14 01:24:38 +02:00
protected function buildCustomCodePlaceholders ( $item , & $code )
{
// check if there is args for this code
if ( isset ( $this -> customCodeData [ $item [ 'id' ]][ 'args' ]) && ComponentbuilderHelper :: checkArray ( $this -> customCodeData [ $item [ 'id' ]][ 'args' ]))
{
// since we have args we cant update this code via IDE (TODO)
$placeholder = $this -> getPlaceHolder ( 3 , null );
// we have args and so need to load each
foreach ( $this -> customCodeData [ $item [ 'id' ]][ 'args' ] as $key => $args )
{
$this -> setThesePlaceHolders ( 'arg' , $args );
2017-12-15 01:10:47 +02:00
$code [ '[CUSTOM' . 'CODE=' . $key . ']' ] = $placeholder [ 'start' ] . PHP_EOL . $this -> setPlaceholders ( $item [ 'code' ], $this -> placeholders ) . $placeholder [ 'end' ];
2017-02-14 01:24:38 +02:00
}
// always clear the args
$this -> clearFromPlaceHolders ( 'arg' );
}
else
{
2017-04-07 21:33:35 +01:00
if (( $keyPlaceholder = array_search ( $item [ 'id' ], $this -> functionNameMemory )) === false )
2017-02-14 01:24:38 +02:00
{
$keyPlaceholder = $item [ 'id' ];
}
// check what type of place holders we should load here
2017-12-15 01:10:47 +02:00
$placeholderType = ( int ) $item [ 'comment_type' ] . '2' ;
2017-10-06 16:53:22 +02:00
if ( stripos ( $item [ 'code' ], '[[[view' ) !== false || stripos ( $item [ 'code' ], '[[[sview' ) !== false || stripos ( $item [ 'code' ], '[[[arg' ) !== false )
2017-02-14 01:24:38 +02:00
{
// if view is being set dynamicly then we can't update this code via IDE (TODO)
$placeholderType = 3 ;
}
// if now ars were found, clear it
$this -> clearFromPlaceHolders ( 'arg' );
// load args for this code
2017-12-15 01:10:47 +02:00
$placeholder = $this -> getPlaceHolder ( $placeholderType , $item [ 'id' ]);
$code [ '[CUSTOM' . 'CODE=' . $keyPlaceholder . ']' ] = $placeholder [ 'start' ] . PHP_EOL . $this -> setPlaceholders ( $item [ 'code' ], $this -> placeholders ) . $placeholder [ 'end' ];
2017-02-14 01:24:38 +02:00
}
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* Set a type of placeholder with set of values
*
* @ param string $key The main string for placeholder key
* @ param array $values The values to add
*
* @ return void
*/
public function setThesePlaceHolders ( $key , $values )
{
// aways fist reset these
$this -> clearFromPlaceHolders ( $key );
if ( ComponentbuilderHelper :: checkArray ( $values ))
{
$number = 0 ;
foreach ( $values as $value )
{
2017-12-15 01:10:47 +02:00
$this -> placeholders [ '[[[' . $key . $number . ']]]' ] = $value ;
2017-02-14 01:24:38 +02:00
$number ++ ;
}
}
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* Remove a type of placeholder by main string
*
* @ param string $like The main string for placeholder key
*
* @ return void
*/
public function clearFromPlaceHolders ( $like )
{
foreach ( $this -> placeholders as $something => $value )
{
if ( stripos ( $something , $like ) !== false )
{
unset ( $this -> placeholders [ $something ]);
}
}
}
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
/**
* to unset stuff that are private or protected
*
*/
public function unsetNow ( $remove )
{
unset ( $this -> $remove );
}
2017-12-15 01:10:47 +02:00
2017-04-05 14:21:10 +01:00
/**
* Get the other languages
*
* @ param array $values The lang strings to get
*
*
* @ return void
*
*/
public function getMultiLangStrings ( $values )
{
// Create a new query object.
$query = $this -> db -> getQuery ( true );
2017-12-15 01:10:47 +02:00
$query -> from ( $this -> db -> quoteName ( '#__componentbuilder_language_translation' , 'a' ));
2017-04-05 14:21:10 +01:00
if ( ComponentbuilderHelper :: checkArray ( $values ))
{
2017-12-15 01:10:47 +02:00
$query -> select ( $this -> db -> quoteName ( array ( 'a.id' , 'a.translation' , 'a.entranslation' , 'a.components' , 'a.published' )));
$query -> where ( $this -> db -> quoteName ( 'a.entranslation' ) . ' IN (' . implode ( ',' , array_map ( function ( $a )
{
return $this -> db -> quote ( $a );
}, $values )) . ')' );
2017-04-05 14:21:10 +01:00
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
if ( $this -> db -> getNumRows ())
{
return $this -> db -> loadAssocList ( 'entranslation' );
}
}
return false ;
}
2017-12-15 01:10:47 +02:00
2017-04-05 14:21:10 +01:00
/**
* Set the Current language values to DB
*
*
* @ return void
*
*/
2017-04-07 21:33:35 +01:00
public function setLangPlaceholders ( $strings )
2017-04-05 14:21:10 +01:00
{
$counterInsert = 0 ;
$counterUpdate = 0 ;
$today = JFactory :: getDate () -> toSql ();
foreach ( $this -> languages [ 'en-GB' ] as $area => $placeholders )
{
foreach ( $placeholders as $placeholder => $string )
{
// to keep or remove
$remove = false ;
// build the tranlations
2017-04-05 17:26:17 +01:00
if ( ComponentbuilderHelper :: checkString ( $string ) && isset ( $this -> multiLangString [ $string ]))
2017-04-05 14:21:10 +01:00
{
// make sure we have converted the string to array
if ( isset ( $this -> multiLangString [ $string ][ 'translation' ]) && ComponentbuilderHelper :: checkJson ( $this -> multiLangString [ $string ][ 'translation' ]))
{
$this -> multiLangString [ $string ][ 'translation' ] = json_decode ( $this -> multiLangString [ $string ][ 'translation' ], true );
}
// if we have an array continue
2017-12-15 01:10:47 +02:00
if ( isset ( $this -> multiLangString [ $string ][ 'translation' ]) && ComponentbuilderHelper :: checkArray ( $this -> multiLangString [ $string ][ 'translation' ]))
2017-04-05 14:21:10 +01:00
{
// great lets build the multi languages strings
2017-09-18 02:18:23 +02:00
foreach ( $this -> multiLangString [ $string ][ 'translation' ] as $translations )
2017-04-05 14:21:10 +01:00
{
2017-09-18 02:18:23 +02:00
if ( isset ( $translations [ 'language' ]) && isset ( $translations [ 'translation' ]))
2017-04-05 14:21:10 +01:00
{
2017-09-18 02:18:23 +02:00
// build arrays
if ( ! isset ( $this -> languages [ $translations [ 'language' ]]))
{
$this -> languages [ $translations [ 'language' ]] = array ();
}
if ( ! isset ( $this -> languages [ $translations [ 'language' ]][ $area ]))
{
$this -> languages [ $translations [ 'language' ]][ $area ] = array ();
}
$this -> languages [ $translations [ 'language' ]][ $area ][ $placeholder ] = $translations [ 'translation' ];
2017-04-05 14:21:10 +01:00
}
}
}
else
{
// remove this string not to be checked again
$remove = true ;
}
}
// do the database managment
2017-12-15 01:10:47 +02:00
if ( ComponentbuilderHelper :: checkString ( $string ) && ( $key = array_search ( $string , $strings )) !== false )
2017-04-05 14:21:10 +01:00
{
if ( isset ( $this -> multiLangString [ $string ]))
{
// update the existing placeholder in db
$id = $this -> multiLangString [ $string ][ 'id' ];
if ( ComponentbuilderHelper :: checkJson ( $this -> multiLangString [ $string ][ 'components' ]))
{
$components = ( array ) json_decode ( $this -> multiLangString [ $string ][ 'components' ], true );
2017-04-07 21:33:35 +01:00
// check if we should add the component ID
2017-04-05 14:21:10 +01:00
if ( in_array ( $this -> componentID , $components ))
{
2017-04-07 21:33:35 +01:00
// only skip the update if the string is published and has the component ID
if ( $this -> multiLangString [ $string ][ 'published' ] == 1 )
{
continue ;
}
2017-04-05 14:21:10 +01:00
}
else
{
$components [] = $this -> componentID ;
}
}
else
{
$components = array ( $this -> componentID );
}
// start the bucket for this lang
2017-04-07 21:33:35 +01:00
$this -> setUpdateExistingLangStrings ( $id , $components , 1 , $today , $counterUpdate );
2017-04-05 14:21:10 +01:00
$counterUpdate ++ ;
// load to db
$this -> setExistingLangStrings ( 50 );
// remove string if needed
if ( $remove )
{
unset ( $this -> multiLangString [ $string ]);
}
}
else
{
// add the new lang placeholder to the db
2017-12-15 01:10:47 +02:00
$this -> newLangStrings [ $counterInsert ] = array ();
$this -> newLangStrings [ $counterInsert ][] = $this -> db -> quote ( json_encode ( array ( $this -> componentID ))); // 'components'
$this -> newLangStrings [ $counterInsert ][] = $this -> db -> quote ( $string ); // 'entranslation'
$this -> newLangStrings [ $counterInsert ][] = $this -> db -> quote ( 1 ); // 'published'
$this -> newLangStrings [ $counterInsert ][] = $this -> db -> quote ( $today ); // 'created'
$this -> newLangStrings [ $counterInsert ][] = $this -> db -> quote (( int ) $this -> user -> id ); // 'created_by'
$this -> newLangStrings [ $counterInsert ][] = $this -> db -> quote ( 1 ); // 'version'
$this -> newLangStrings [ $counterInsert ][] = $this -> db -> quote ( 1 ); // 'access'
2017-04-05 14:21:10 +01:00
$counterInsert ++ ;
// load to db
$this -> setNewLangStrings ( 100 );
}
// only set the string once
unset ( $strings [ $key ]);
}
}
}
// just to make sure all is done
$this -> setExistingLangStrings ();
$this -> setNewLangStrings ();
}
2017-12-15 01:10:47 +02:00
2017-04-05 14:21:10 +01:00
/**
* store the language placeholders
*
* @ param int $when To set when to update
*
* @ return void
*
*/
protected function setNewLangStrings ( $when = 1 )
{
if ( count ( $this -> newLangStrings ) >= $when )
{
// Create a new query object.
$query = $this -> db -> getQuery ( true );
$continue = false ;
// Insert columns.
2017-12-15 01:10:47 +02:00
$columns = array ( 'components' , 'entranslation' , 'published' , 'created' , 'created_by' , 'version' , 'access' );
2017-04-05 14:21:10 +01:00
// Prepare the insert query.
$query -> insert ( $this -> db -> quoteName ( '#__componentbuilder_language_translation' ));
$query -> columns ( $this -> db -> quoteName ( $columns ));
2017-12-15 01:10:47 +02:00
foreach ( $this -> newLangStrings as $values )
2017-04-05 14:21:10 +01:00
{
if ( count ( $values ) == 7 )
{
$query -> values ( implode ( ',' , $values ));
$continue = true ;
}
else
{
// TODO line mismatch... should not happen
}
}
// clear the values array
$this -> newLangStrings = array ();
if ( ! $continue )
{
return false ; // insure we dont continue if no values were loaded
}
// Set the query using our newly populated query object and execute it.
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
}
2017-12-15 01:10:47 +02:00
}
2017-04-05 14:21:10 +01:00
/**
* update the language placeholders
*
* @ param int $when To set when to update
*
* @ return void
*
*/
protected function setExistingLangStrings ( $when = 1 )
{
if ( count ( $this -> existingLangStrings ) >= $when )
{
2017-12-15 01:10:47 +02:00
foreach ( $this -> existingLangStrings as $values )
2017-04-05 14:21:10 +01:00
{
// Create a new query object.
$query = $this -> db -> getQuery ( true );
// Prepare the update query.
$query -> update ( $this -> db -> quoteName ( '#__componentbuilder_language_translation' )) -> set ( $values [ 'fields' ]) -> where ( $values [ 'conditions' ]);
// Set the query using our newly populated query object and execute it.
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
}
// clear the values array
2017-12-15 01:10:47 +02:00
$this -> existingLangStrings = array ();
2017-04-05 14:21:10 +01:00
}
2017-12-15 01:10:47 +02:00
}
2017-04-07 21:33:35 +01:00
/**
* Remove exiting language translation stings
*
* @ param int $id To string ID to remove
*
* @ return void
*
*/
protected function removeExitingLangString ( $id )
{
// Create a new query object.
$query = $this -> db -> getQuery ( true );
2017-12-15 01:10:47 +02:00
2017-04-07 21:33:35 +01:00
// delete all custom keys for user 1001.
$conditions = array (
2017-12-15 01:10:47 +02:00
$this -> db -> quoteName ( 'id' ) . ' = ' . ( int ) $id
2017-04-07 21:33:35 +01:00
);
$query -> delete ( $this -> db -> quoteName ( '#__componentbuilder_language_translation' ));
$query -> where ( $conditions );
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
}
2017-12-15 01:10:47 +02:00
2017-04-07 21:33:35 +01:00
/**
* Function to purge the unused languge strings
*
* @ param string $values the active strings
*
* @ return void
*
*/
public function purgeLanuageStrings ( $values )
{
// Create a new query object.
$query = $this -> db -> getQuery ( true );
2017-12-15 01:10:47 +02:00
$query -> from ( $this -> db -> quoteName ( '#__componentbuilder_language_translation' , 'a' ));
$query -> select ( $this -> db -> quoteName ( array ( 'a.id' , 'a.translation' , 'a.components' )));
2017-04-07 21:33:35 +01:00
// get all string that are not linked to this component
2017-12-15 01:10:47 +02:00
$query -> where ( $this -> db -> quoteName ( 'a.entranslation' ) . ' NOT IN (' . implode ( ',' , array_map ( function ( $a )
{
return $this -> db -> quote ( $a );
}, $values )) . ')' );
2017-04-07 21:33:35 +01:00
$query -> where ( $this -> db -> quoteName ( 'a.published' ) . ' = 1' );
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
if ( $this -> db -> getNumRows ())
{
$counterUpdate = 0 ;
$otherStrings = $this -> db -> loadAssocList ();
$today = JFactory :: getDate () -> toSql ();
foreach ( $otherStrings as $item )
{
if ( ComponentbuilderHelper :: checkJson ( $item [ 'components' ]))
{
$components = ( array ) json_decode ( $item [ 'components' ], true );
// if component is not found ignore this string, and do nothing
if (( $key = array_search ( $this -> componentID , $components )) !== false )
{
// first remove the component from the string
unset ( $components [ $key ]);
// check if there are more components
if ( ComponentbuilderHelper :: checkArray ( $components ))
{
// just update the string to unlink the current component
$this -> setUpdateExistingLangStrings ( $item [ 'id' ], $components , 1 , $today , $counterUpdate );
$counterUpdate ++ ;
// load to db
$this -> setExistingLangStrings ( 50 );
}
// check if this string has been worked on
elseif ( ComponentbuilderHelper :: checkJson ( $item [ 'translation' ]))
{
$translation = json_decode ( $item [ 'translation' ], true );
2017-09-18 02:18:23 +02:00
if ( ComponentbuilderHelper :: checkArray ( $translation ))
2017-04-07 21:33:35 +01:00
{
// only archive the item and update the string to unlink the current component
$this -> setUpdateExistingLangStrings ( $item [ 'id' ], $components , 2 , $today , $counterUpdate );
$counterUpdate ++ ;
// load to db
$this -> setExistingLangStrings ( 50 );
}
else
{
// remove the string since no translation found and not linked to any other component
$this -> removeExitingLangString ( $item [ 'id' ]);
}
}
else
{
// remove the string since no translation found and not linked to any other component
$this -> removeExitingLangString ( $item [ 'id' ]);
}
}
}
}
// load to db
$this -> setExistingLangStrings ();
}
}
2017-12-15 01:10:47 +02:00
2017-04-07 21:33:35 +01:00
/**
* just to add lang string to the existing Lang Strings array
*
* @ return void
*
*/
protected function setUpdateExistingLangStrings ( $id , $components , $published , $today , $counterUpdate )
{
// start the bucket for this lang
2017-12-15 01:10:47 +02:00
$this -> existingLangStrings [ $counterUpdate ] = array ();
$this -> existingLangStrings [ $counterUpdate ][ 'id' ] = ( int ) $id ;
$this -> existingLangStrings [ $counterUpdate ][ 'conditions' ] = array ();
$this -> existingLangStrings [ $counterUpdate ][ 'conditions' ][] = $this -> db -> quoteName ( 'id' ) . ' = ' . $this -> db -> quote ( $id );
$this -> existingLangStrings [ $counterUpdate ][ 'fields' ] = array ();
$this -> existingLangStrings [ $counterUpdate ][ 'fields' ][] = $this -> db -> quoteName ( 'components' ) . ' = ' . $this -> db -> quote ( json_encode ( $components ));
$this -> existingLangStrings [ $counterUpdate ][ 'fields' ][] = $this -> db -> quoteName ( 'published' ) . ' = ' . $this -> db -> quote ( $published );
$this -> existingLangStrings [ $counterUpdate ][ 'fields' ][] = $this -> db -> quoteName ( 'modified' ) . ' = ' . $this -> db -> quote ( $today );
$this -> existingLangStrings [ $counterUpdate ][ 'fields' ][] = $this -> db -> quoteName ( 'modified_by' ) . ' = ' . $this -> db -> quote (( int ) $this -> user -> id );
2017-04-05 14:21:10 +01:00
}
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
/**
* get the custom code from the system
*
* @ return void
*
*/
2017-02-14 01:24:38 +02:00
public function getCustomCode ( $ids = null , $setLang = true )
2017-02-01 15:17:04 +02:00
{
2017-02-14 01:24:38 +02:00
// should the result be stored in memory
$loadInMemory = false ;
2017-02-01 15:17:04 +02:00
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
2017-12-15 01:10:47 +02:00
$query -> from ( $this -> db -> quoteName ( '#__componentbuilder_custom_code' , 'a' ));
2017-02-14 01:24:38 +02:00
if ( ComponentbuilderHelper :: checkArray ( $ids ))
2017-02-09 18:11:10 +02:00
{
2017-02-14 01:24:38 +02:00
if ( $idArray = $this -> customCodeMemory ( $ids ))
{
2017-12-15 01:10:47 +02:00
$query -> select ( $this -> db -> quoteName ( array ( 'a.id' , 'a.code' , 'a.comment_type' )));
$query -> where ( $this -> db -> quoteName ( 'a.id' ) . ' IN (' . implode ( ',' , $idArray ) . ')' );
2017-02-14 01:24:38 +02:00
$query -> where ( $this -> db -> quoteName ( 'a.target' ) . ' = 2' ); // <--- to load the correct target
$loadInMemory = true ;
}
else
{
// all values are already in memory continue
return true ;
}
2017-02-09 18:11:10 +02:00
}
else
{
2017-12-15 01:10:47 +02:00
$query -> select ( $this -> db -> quoteName ( array ( 'a.id' , 'a.code' , 'a.comment_type' , 'a.component' , 'a.from_line' , 'a.hashtarget' , 'a.hashendtarget' , 'a.path' , 'a.to_line' , 'a.type' )));
$query -> where ( $this -> db -> quoteName ( 'a.component' ) . ' = ' . ( int ) $this -> componentData -> id );
2017-02-14 01:24:38 +02:00
$query -> where ( $this -> db -> quoteName ( 'a.target' ) . ' = 1' ); // <--- to load the correct target
$query -> order ( $this -> db -> quoteName ( 'a.from_line' ) . ' ASC' ); // <--- insrue we always add code from top of file
// reset custom code
$this -> customCode = array ();
2017-02-09 18:11:10 +02:00
}
2017-02-14 01:24:38 +02:00
$query -> where ( $this -> db -> quoteName ( 'a.published' ) . ' >= 1' );
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
if ( $this -> db -> getNumRows ())
2017-02-01 15:17:04 +02:00
{
2017-02-14 01:24:38 +02:00
$bucket = $this -> db -> loadAssocList ( 'id' );
2017-02-01 15:17:04 +02:00
// open the code
2017-12-15 01:10:47 +02:00
foreach ( $bucket as $nr => & $customCode )
2017-02-01 15:17:04 +02:00
{
$customCode [ 'code' ] = base64_decode ( $customCode [ 'code' ]);
2018-02-03 02:13:48 +02:00
// always insure that the external code is loaded
$customCode [ 'code' ] = $this -> setExternalCodeString ( $customCode [ 'code' ]);
2018-01-31 16:27:17 +02:00
// set the lang only if needed
2017-02-14 01:24:38 +02:00
if ( $setLang )
{
$customCode [ 'code' ] = $this -> setLangStrings ( $customCode [ 'code' ]);
}
2017-02-09 18:11:10 +02:00
if ( isset ( $customCode [ 'hashtarget' ]))
2017-02-01 15:17:04 +02:00
{
2017-02-09 18:11:10 +02:00
$customCode [ 'hashtarget' ] = explode ( " __ " , $customCode [ 'hashtarget' ]);
if ( $customCode [ 'type' ] == 1 && strpos ( $customCode [ 'hashendtarget' ], '__' ) !== false )
{
$customCode [ 'hashendtarget' ] = explode ( " __ " , $customCode [ 'hashendtarget' ]);
}
2017-02-01 15:17:04 +02:00
}
}
2017-02-14 01:24:38 +02:00
// load this code into memory if needed
if ( $loadInMemory === true )
{
$this -> customCodeMemory = $this -> customCodeMemory + $bucket ;
}
$this -> customCode = array_merge ( $this -> customCode , $bucket );
2017-02-09 18:11:10 +02:00
return true ;
2017-02-01 15:17:04 +02:00
}
return false ;
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* check if we already have these ids in local memory
*
* @ return void
*
*/
protected function customCodeMemory ( $ids )
{
// reset custom code
$this -> customCode = array ();
foreach ( $ids as $pointer => $id )
{
if ( isset ( $this -> customCodeMemory [ $id ]))
{
$this -> customCode [] = $this -> customCodeMemory [ $id ];
unset ( $ids [ $pointer ]);
}
}
// check if any ids left to fetch
if ( ComponentbuilderHelper :: checkArray ( $ids ))
{
return $ids ;
}
return false ;
}
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
/**
* store the code
*
* @ param int $when To set when to update
*
* @ return void
*
*/
2017-02-14 01:24:38 +02:00
protected function setNewCustomCode ( $when = 1 )
2017-02-01 15:17:04 +02:00
{
if ( count ( $this -> newCustomCode ) >= $when )
{
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
2017-02-11 04:24:26 +02:00
$continue = false ;
2017-02-01 15:17:04 +02:00
// Insert columns.
2017-12-15 01:10:47 +02:00
$columns = array ( 'path' , 'type' , 'target' , 'comment_type' , 'component' , 'published' , 'created' , 'created_by' , 'version' , 'access' , 'hashtarget' , 'from_line' , 'to_line' , 'code' , 'hashendtarget' );
2017-02-01 15:17:04 +02:00
// Prepare the insert query.
2017-02-14 01:24:38 +02:00
$query -> insert ( $this -> db -> quoteName ( '#__componentbuilder_custom_code' ));
$query -> columns ( $this -> db -> quoteName ( $columns ));
2017-12-15 01:10:47 +02:00
foreach ( $this -> newCustomCode as $values )
2017-02-09 18:11:10 +02:00
{
2017-02-14 01:24:38 +02:00
if ( count ( $values ) == 15 )
2017-02-09 18:11:10 +02:00
{
$query -> values ( implode ( ',' , $values ));
2017-02-11 04:24:26 +02:00
$continue = true ;
2017-02-09 18:11:10 +02:00
}
else
{
// TODO line mismatch... should not happen
}
2017-02-01 15:17:04 +02:00
}
// clear the values array
$this -> newCustomCode = array ();
2017-02-11 04:24:26 +02:00
if ( ! $continue )
{
return false ; // insure we dont continue if no values were loaded
}
2017-02-01 15:17:04 +02:00
// Set the query using our newly populated query object and execute it.
2017-02-14 01:24:38 +02:00
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
2017-02-01 15:17:04 +02:00
}
}
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
/**
* store the code
*
* @ param int $when To set when to update
*
* @ return void
*
*/
2017-02-14 01:24:38 +02:00
protected function setExistingCustomCode ( $when = 1 )
2017-02-01 15:17:04 +02:00
{
if ( count ( $this -> existingCustomCode ) >= $when )
{
2017-12-15 01:10:47 +02:00
foreach ( $this -> existingCustomCode as $code )
2017-02-01 15:17:04 +02:00
{
// Create a new query object.
2017-02-14 01:24:38 +02:00
$query = $this -> db -> getQuery ( true );
2017-02-01 15:17:04 +02:00
// Prepare the update query.
2017-02-14 01:24:38 +02:00
$query -> update ( $this -> db -> quoteName ( '#__componentbuilder_custom_code' )) -> set ( $code [ 'fields' ]) -> where ( $code [ 'conditions' ]);
2017-02-01 15:17:04 +02:00
// Set the query using our newly populated query object and execute it.
2017-02-14 01:24:38 +02:00
$this -> db -> setQuery ( $query );
$this -> db -> execute ();
2017-02-01 15:17:04 +02:00
}
// clear the values array
2017-12-15 01:10:47 +02:00
$this -> existingCustomCode = array ();
2017-02-01 15:17:04 +02:00
}
}
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
/**
* get the custom code from the local files
*
* @ param array $paths The local paths to parse
* @ param string $today The date for today
*
* @ return void
*
*/
2017-02-14 01:24:38 +02:00
protected function customCodeFactory ( & $paths , & $today )
2017-02-01 15:17:04 +02:00
{
// we must first store the current woking directory
$joomla = getcwd ();
2017-02-14 02:33:24 +02:00
$counter = array ( 1 => 0 , 2 => 0 );
// file types to get
2017-12-15 01:10:47 +02:00
$fileTypes = array ( '\.php' , '\.js' );
2017-02-11 04:24:26 +02:00
// set some local placeholders
$placeholders = array ();
2017-12-15 01:10:47 +02:00
$placeholders [ ComponentbuilderHelper :: safeString ( $this -> componentCodeName , 'F' ) . 'Helper::' ] = '[[[Component]]]Helper::' ;
$placeholders [ 'COM_' . ComponentbuilderHelper :: safeString ( $this -> componentCodeName , 'U' )] = 'COM_[[[COMPONENT]]]' ;
$placeholders [ 'com_' . $this -> componentCodeName ] = 'com_[[[component]]]' ;
2017-02-01 15:17:04 +02:00
foreach ( $paths as $target => $path )
{
// we are changing the working directory to the componet path
chdir ( $path );
2017-02-14 02:33:24 +02:00
foreach ( $fileTypes as $type )
2017-02-01 15:17:04 +02:00
{
2017-02-16 16:02:23 +02:00
// get a list of files in the current directory tree (only PHP and JS for now)
2017-02-14 02:33:24 +02:00
$files = JFolder :: files ( '.' , $type , true , true );
foreach ( $files as $file )
2017-02-01 15:17:04 +02:00
{
2017-02-14 02:33:24 +02:00
$this -> searchFileContent ( $counter , $file , $target , $this -> customCodePlaceholders , $placeholders , $today );
// insert new code
if ( ComponentbuilderHelper :: checkArray ( $this -> newCustomCode ))
{
$this -> setNewCustomCode ( 100 );
}
// update existing custom code
if ( ComponentbuilderHelper :: checkArray ( $this -> existingCustomCode ))
{
$this -> setExistingCustomCode ( 30 );
}
2017-02-01 15:17:04 +02:00
}
}
}
// change back to Joomla working directory
chdir ( $joomla );
// make sure all code is stored
if ( ComponentbuilderHelper :: checkArray ( $this -> newCustomCode ))
{
2017-02-14 01:24:38 +02:00
$this -> setNewCustomCode ();
2017-02-01 15:17:04 +02:00
}
// update existing custom code
if ( ComponentbuilderHelper :: checkArray ( $this -> existingCustomCode ))
{
2017-02-14 01:24:38 +02:00
$this -> setExistingCustomCode ();
2017-02-01 15:17:04 +02:00
}
}
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
/**
* search a file for placeholders and store result
*
* @ param array $counter The counter for the arrays
* @ param string $file The file path to search
2017-02-11 04:24:26 +02:00
* @ param array $searchArray The values to search for
* @ param array $placeholders The values to replace in the code being stored
2017-02-01 15:17:04 +02:00
* @ param string $today The date for today
*
* @ return array on success
*
*/
2017-02-14 01:24:38 +02:00
protected function searchFileContent ( & $counter , & $file , & $target , & $searchArray , & $placeholders , & $today )
2017-02-01 15:17:04 +02:00
{
// reset each time per file
2017-12-15 01:10:47 +02:00
$loadEndFingerPrint = false ;
$endFingerPrint = array ();
$fingerPrint = array ();
$codeBucket = array ();
$pointer = array ();
$reading = array ();
$reader = 0 ;
2017-02-14 01:24:38 +02:00
// reset found Start type
2017-12-15 01:10:47 +02:00
$commentType = 0 ;
2017-02-09 18:11:10 +02:00
// make sure we have the path correct (the script file is not in admin path for example)
// there may be more... will nead to keep our eye on this... since files could be moved during install
$file = str_replace ( './' , '' , $file );
if ( $file !== 'script.php' )
{
2017-12-15 01:10:47 +02:00
$path = $target . '/' . $file ;
2017-02-09 18:11:10 +02:00
}
else
{
2017-12-15 01:10:47 +02:00
$path = $file ;
}
2017-02-01 15:17:04 +02:00
foreach ( new SplFileObject ( $file ) as $lineNumber => $lineContent )
{
// we musk keep last few lines to dynamic find target entry later
$fingerPrint [ $lineNumber ] = trim ( $lineContent );
// load the end fingerprint
if ( $loadEndFingerPrint )
{
$endFingerPrint [ $lineNumber ] = trim ( $lineContent );
}
2017-02-11 04:24:26 +02:00
foreach ( $searchArray as $type => $search )
2017-02-01 15:17:04 +02:00
{
2017-12-15 01:10:47 +02:00
$i = ( int ) ( $type == 3 || $type == 4 ) ? 2 : 1 ;
$_type = ( int ) ( $type == 1 || $type == 3 ) ? 1 : 2 ;
2017-02-01 15:17:04 +02:00
if ( $reader === 0 || $reader === $i )
{
2017-12-15 01:10:47 +02:00
$targetKey = $type ;
$start = '/***[' . $search . '***/' ;
$end = '/***[/' . $search . '***/' ;
$startHTML = '<!--[' . $search . '-->' ;
$endHTML = '<!--[/' . $search . '-->' ;
2017-02-01 15:17:04 +02:00
// check if the ending place holder was found
2017-12-15 01:10:47 +02:00
if ( isset ( $reading [ $targetKey ]) && $reading [ $targetKey ] &&
(( trim ( $lineContent ) === $end || strpos ( $lineContent , $end ) !== false ) ||
2017-02-14 01:24:38 +02:00
( trim ( $lineContent ) === $endHTML || strpos ( $lineContent , $endHTML ) !== false )))
2017-02-01 15:17:04 +02:00
{
2017-02-14 01:24:38 +02:00
// trim the placeholder and if there is still data then load it
if ( $_line = $this -> addLineChecker ( $endReplace , 2 , $lineContent ))
{
$codeBucket [ $pointer [ $targetKey ]][] = $_line ;
}
2017-02-01 15:17:04 +02:00
// deactivate the reader
2017-12-15 01:10:47 +02:00
$reading [ $targetKey ] = false ;
2017-02-01 15:17:04 +02:00
if ( $_type == 2 )
{
// deactivate search
2017-12-15 01:10:47 +02:00
$reader = 0 ;
2017-02-01 15:17:04 +02:00
}
else
{
// activate fingerPrint for replacement end target
2017-12-15 01:10:47 +02:00
$loadEndFingerPrint = true ;
$backupTargetKey = $targetKey ;
$backupI = $i ;
2017-02-01 15:17:04 +02:00
}
// all new records we can do a bulk insert
if ( $i === 1 )
{
// end the bucket info for this code block
2017-12-15 01:10:47 +02:00
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote (( int ) $lineNumber ); // 'toline'
2017-02-14 01:24:38 +02:00
// first reverse engineer this code block
$c0de = $this -> reversePlaceholders ( implode ( '' , $codeBucket [ $pointer [ $targetKey ]]), $placeholders );
2017-12-15 01:10:47 +02:00
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( base64_encode ( $c0de )); // 'code'
2017-02-01 15:17:04 +02:00
if ( $_type == 2 )
{
// load the last value
2017-12-15 01:10:47 +02:00
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( 0 ); // 'hashendtarget'
2017-02-01 15:17:04 +02:00
}
}
2017-02-16 16:02:23 +02:00
// the record already exist so we must update instead
2017-02-01 15:17:04 +02:00
elseif ( $i === 2 )
{
2017-02-14 01:24:38 +02:00
// end the bucket info for this code block
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'to_line' ) . ' = ' . $this -> db -> quote ( $lineNumber );
// first reverse engineer this code block
$c0de = $this -> reversePlaceholders ( implode ( '' , $codeBucket [ $pointer [ $targetKey ]]), $placeholders , $this -> existingCustomCode [ $pointer [ $targetKey ]][ 'id' ]);
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'code' ) . ' = ' . $this -> db -> quote ( base64_encode ( $c0de ));
2017-02-01 15:17:04 +02:00
if ( $_type == 2 )
{
// load the last value
2017-02-14 01:24:38 +02:00
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'hashendtarget' ) . ' = ' . $this -> db -> quote ( 0 );
2017-02-01 15:17:04 +02:00
}
}
}
// check if the endfingerprint is ready to save
if ( count ( $endFingerPrint ) === 3 )
{
2017-12-15 01:10:47 +02:00
$hashendtarget = '3__' . md5 ( implode ( '' , $endFingerPrint ));
2017-02-01 15:17:04 +02:00
// all new records we can do a bulk insert
if ( $i === 1 )
{
// load the last value
2017-12-15 01:10:47 +02:00
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( $hashendtarget ); // 'hashendtarget'
2017-02-01 15:17:04 +02:00
}
// the record already exist so we must use module to update
elseif ( $i === 2 )
{
2017-02-14 01:24:38 +02:00
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'hashendtarget' ) . ' = ' . $this -> db -> quote ( $hashendtarget );
2017-02-01 15:17:04 +02:00
}
// reset the needed values
2017-12-15 01:10:47 +02:00
$endFingerPrint = array ();
$loadEndFingerPrint = false ;
2017-02-01 15:17:04 +02:00
// deactivate reader (to allow other search)
2017-12-15 01:10:47 +02:00
$reader = 0 ;
2017-02-01 15:17:04 +02:00
}
// then read in the code
if ( isset ( $reading [ $targetKey ]) && $reading [ $targetKey ])
{
2017-02-14 01:24:38 +02:00
$codeBucket [ $pointer [ $targetKey ]][] = $lineContent ;
2017-02-01 15:17:04 +02:00
}
2017-02-14 01:24:38 +02:00
// see if the custom code line starts now with PHP/JS comment type
if (( ! isset ( $reading [ $targetKey ]) || ! $reading [ $targetKey ]) && (( $i === 1 && trim ( $lineContent ) === $start ) || strpos ( $lineContent , $start ) !== false ))
{
2017-12-15 01:10:47 +02:00
$commentType = 1 ; // PHP/JS type
$startReplace = $start ;
$endReplace = $end ;
2017-02-14 01:24:38 +02:00
}
// see if the custom code line starts now with HTML comment type
elseif (( ! isset ( $reading [ $targetKey ]) || ! $reading [ $targetKey ]) && (( $i === 1 && trim ( $lineContent ) === $startHTML ) || strpos ( $lineContent , $startHTML ) !== false ))
2017-02-01 15:17:04 +02:00
{
2017-12-15 01:10:47 +02:00
$commentType = 2 ; // HTML type
$startReplace = $startHTML ;
$endReplace = $endHTML ;
2017-02-14 01:24:38 +02:00
}
// check if the starting place holder was found
2017-12-15 01:10:47 +02:00
if ( $commentType > 0 )
{
2017-02-16 16:02:23 +02:00
// if we have all on one line we have a problem (don't load it TODO)
2017-02-14 01:24:38 +02:00
if ( strpos ( $lineContent , $endReplace ) !== false )
{
2017-02-16 16:02:23 +02:00
// reset found comment type
$commentType = 0 ;
2018-02-06 12:55:46 +02:00
$this -> app -> enqueueMessage ( JText :: sprintf ( 'We found dynamic code <b>all in one line</b>, and ignored it! Please review (%s) for more details!' , $path ), 'Warning' );
2017-02-14 01:24:38 +02:00
continue ;
}
2017-02-11 04:24:26 +02:00
// do a quick check to insure we have an id
$id = false ;
2017-02-09 18:11:10 +02:00
if ( $i === 2 )
{
2017-02-14 01:24:38 +02:00
$id = $this -> getSystemID ( $lineContent , array ( 1 => $start , 2 => $startHTML ), $commentType );
2017-02-09 18:11:10 +02:00
}
if ( $i === 2 && $id > 0 )
{
// make sure we update it only once even if found again.
if ( isset ( $this -> codeAreadyDone [ $id ]))
{
2017-02-16 16:02:23 +02:00
// reset found comment type
$commentType = 0 ;
2017-02-09 18:11:10 +02:00
continue ;
}
// store the id to avoid duplication
$this -> codeAreadyDone [ $id ] = ( int ) $id ;
}
2017-02-14 01:24:38 +02:00
// start replace
$startReplace = $this -> setStartReplace ( $id , $commentType , $startReplace );
2017-02-01 15:17:04 +02:00
// set active reader (to lock out other search)
2017-12-15 01:10:47 +02:00
$reader = $i ;
2017-02-01 15:17:04 +02:00
// set pointer
2017-12-15 01:10:47 +02:00
$pointer [ $targetKey ] = $counter [ $i ];
2017-02-01 15:17:04 +02:00
// activate the reader
2017-12-15 01:10:47 +02:00
$reading [ $targetKey ] = true ;
2017-02-01 15:17:04 +02:00
// start code bucket
2017-12-15 01:10:47 +02:00
$codeBucket [ $pointer [ $targetKey ]] = array ();
2017-02-14 01:24:38 +02:00
// trim the placeholder and if there is still data then load it
if ( $_line = $this -> addLineChecker ( $startReplace , 1 , $lineContent ))
{
$codeBucket [ $pointer [ $targetKey ]][] = $_line ;
}
2017-02-01 15:17:04 +02:00
// get the finger print around the custom code
2017-12-15 01:10:47 +02:00
$inFinger = count ( $fingerPrint );
$getFinger = $inFinger - 1 ;
$hasharray = array_slice ( $fingerPrint , - $inFinger , $getFinger , true );
$hasleng = count ( $hasharray );
$hashtarget = $hasleng . '__' . md5 ( implode ( '' , $hasharray ));
2017-02-01 15:17:04 +02:00
// all new records we can do a buldk insert
if ( $i === 1 || ! $id )
{
// start the bucket for this code
2017-12-15 01:10:47 +02:00
$this -> newCustomCode [ $pointer [ $targetKey ]] = array ();
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( $path ); // 'path'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote (( int ) $_type ); // 'type'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( 1 ); // 'target'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( $commentType ); // 'comment_type'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote (( int ) $this -> componentID ); // 'component'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( 1 ); // 'published'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( $today ); // 'created'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote (( int ) $this -> user -> id ); // 'created_by'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( 1 ); // 'version'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( 1 ); // 'access'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote ( $hashtarget ); // 'hashtarget'
$this -> newCustomCode [ $pointer [ $targetKey ]][] = $this -> db -> quote (( int ) $lineNumber ); // 'fromline'
2017-02-01 15:17:04 +02:00
}
// the record already exist so we must update instead
elseif ( $i === 2 && $id > 0 )
{
// start the bucket for this code
2017-12-15 01:10:47 +02:00
$this -> existingCustomCode [ $pointer [ $targetKey ]] = array ();
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'id' ] = ( int ) $id ;
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'conditions' ] = array ();
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'conditions' ][] = $this -> db -> quoteName ( 'id' ) . ' = ' . $this -> db -> quote ( $id );
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ] = array ();
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'path' ) . ' = ' . $this -> db -> quote ( $path );
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'type' ) . ' = ' . $this -> db -> quote ( $_type );
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'comment_type' ) . ' = ' . $this -> db -> quote ( $commentType );
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'component' ) . ' = ' . $this -> db -> quote ( $this -> componentID );
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'from_line' ) . ' = ' . $this -> db -> quote ( $lineNumber );
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'modified' ) . ' = ' . $this -> db -> quote ( $today );
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'modified_by' ) . ' = ' . $this -> db -> quote ( $this -> user -> id );
$this -> existingCustomCode [ $pointer [ $targetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'hashtarget' ) . ' = ' . $this -> db -> quote ( $hashtarget );
2017-02-01 15:17:04 +02:00
}
2017-02-09 18:11:10 +02:00
else // this should actualy never happen
{
// de activate the reader
2017-12-15 01:10:47 +02:00
$reading [ $targetKey ] = false ;
$reader = 0 ;
2017-02-09 18:11:10 +02:00
}
2017-02-14 01:24:38 +02:00
// reset found comment type
$commentType = 0 ;
2017-02-01 15:17:04 +02:00
// update the counter
2017-12-15 01:10:47 +02:00
$counter [ $i ] ++ ;
2017-02-01 15:17:04 +02:00
}
}
}
// make sure only a few lines is kept at a time
if ( count ( $fingerPrint ) > 10 )
{
$fingerPrint = array_slice ( $fingerPrint , - 6 , 6 , true );
}
}
// if the code is at the end of the page and there were not three more lines
if ( count ( $endFingerPrint ) > 0 || $loadEndFingerPrint )
{
if ( count ( $endFingerPrint ) > 0 )
{
$leng = count ( $endFingerPrint );
2017-12-15 01:10:47 +02:00
$hashendtarget = $leng . '__' . md5 ( implode ( '' , $endFingerPrint ));
2017-02-01 15:17:04 +02:00
}
else
{
$hashendtarget = 0 ;
}
// all new records we can do a buldk insert
2017-02-09 18:11:10 +02:00
if ( $backupI === 1 )
2017-02-01 15:17:04 +02:00
{
// load the last value
2017-12-15 01:10:47 +02:00
$this -> newCustomCode [ $pointer [ $backupTargetKey ]][] = $this -> db -> quote ( $hashendtarget ); // 'hashendtarget'
2017-02-01 15:17:04 +02:00
}
// the record already exist so we must use module to update
2017-02-09 18:11:10 +02:00
elseif ( $backupI === 2 )
2017-02-01 15:17:04 +02:00
{
2017-02-14 01:24:38 +02:00
$this -> existingCustomCode [ $pointer [ $backupTargetKey ]][ 'fields' ][] = $this -> db -> quoteName ( 'hashendtarget' ) . ' = ' . $this -> db -> quote ( $hashendtarget );
2017-02-01 15:17:04 +02:00
}
}
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* Check if this line should be added
*
* @ param strin $replaceKey The key to remove from line
* @ param int $type The line type
* @ param string $lineContent The line to check
*
* @ return bool true on success
*
*/
protected function addLineChecker ( $replaceKey , $type , $lineContent )
{
$check = explode ( $replaceKey , $lineContent );
2017-12-15 01:10:47 +02:00
switch ( $type )
2017-02-14 01:24:38 +02:00
{
case 1 :
// beginning of code
$i = trim ( $check [ 1 ]);
if ( ComponentbuilderHelper :: checkString ( $i ))
{
return $check [ 1 ];
}
2017-12-15 01:10:47 +02:00
break ;
2017-02-14 01:24:38 +02:00
case 2 :
// end of code
$i = trim ( $check [ 0 ]);
if ( ComponentbuilderHelper :: checkString ( $i ))
{
return $check [ 0 ];
}
2017-12-15 01:10:47 +02:00
break ;
2017-02-14 01:24:38 +02:00
}
return false ;
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* search for the system id in the line given
*
* @ param int $id The comment id
* @ param int $commentType The comment type
* @ param string $startReplace The main replace string
*
* @ return array on success
*
*/
protected function setStartReplace ( $id , $commentType , $startReplace )
{
if ( $id > 0 )
{
2017-12-15 01:10:47 +02:00
switch ( $commentType )
2017-02-14 01:24:38 +02:00
{
2017-10-30 20:50:56 +02:00
case 1 : // the PHP & JS type
2017-12-15 01:10:47 +02:00
$startReplace .= '/*' . $id . '*/' ;
break ;
2017-10-30 20:50:56 +02:00
case 2 : // the HTML type
2017-12-15 01:10:47 +02:00
$startReplace .= '<!--' . $id . '-->' ;
break ;
2017-02-14 01:24:38 +02:00
}
}
return $startReplace ;
}
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
/**
* search for the system id in the line given
*
* @ param string $lineContent The file path to search
* @ param string $placeholders The values to search for
*
* @ return array on success
*
*/
2017-02-14 01:24:38 +02:00
protected function getSystemID ( & $lineContent , $placeholders , $commentType )
2017-02-01 15:17:04 +02:00
{
2017-02-14 01:24:38 +02:00
$trim = '/' ;
if ( $commentType == 2 )
{
$trim = '<!--' ;
}
2017-02-01 15:17:04 +02:00
// remove place holder from content
2017-12-15 01:10:47 +02:00
$string = trim ( str_replace ( $placeholders [ $commentType ] . $trim , '' , $lineContent ));
2017-02-01 15:17:04 +02:00
// now get all numbers
$numbers = array ();
preg_match_all ( '!\d+!' , $string , $numbers );
// return the first number
if ( isset ( $numbers [ 0 ]) && ComponentbuilderHelper :: checkArray ( $numbers [ 0 ]))
{
return reset ( $numbers [ 0 ]);
}
return false ;
}
2017-12-15 01:10:47 +02:00
2017-02-11 04:24:26 +02:00
/**
2017-02-14 01:24:38 +02:00
* Reverse Engineer the dynamic placeholders ( hmmmm )
2017-02-11 04:24:26 +02:00
*
2017-02-14 01:24:38 +02:00
* @ param string $string The string to revers
* @ param int $id The custom code id
* @ param array $placeholders The values to search for
2017-02-11 04:24:26 +02:00
*
* @ return string
*
*/
2017-02-14 01:24:38 +02:00
protected function reversePlaceholders ( $string , & $placeholders , $id = null )
2017-02-11 04:24:26 +02:00
{
2017-02-14 01:24:38 +02:00
// get local code if set
if ( $id > 0 && $code = base64_decode ( ComponentbuilderHelper :: getVar ( 'custom_code' , $id , 'id' , 'code' )))
2017-02-11 04:24:26 +02:00
{
2017-02-14 01:24:38 +02:00
$string = $this -> setReverseLangPlaceholders ( $string , $code );
}
return $this -> setPlaceholders ( $string , $placeholders , 2 );
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* Set the langs strings for the reveres prossess
*
* @ param string $updateString The string to update
* @ param string $string The string to use lang update
*
* @ return array
*
*/
protected function setReverseLangPlaceholders ( $updateString , $string )
{
2017-12-14 15:30:21 +02:00
// get targets to search for
$langStringTargets = array_filter (
2017-12-15 01:10:47 +02:00
$this -> langStringTargets , function ( $get ) use ( $string )
{
if ( strpos ( $string , $get ) !== false )
{
return true ;
}
return false ;
});
2017-12-14 15:30:21 +02:00
// check if we should continue
if ( ComponentbuilderHelper :: checkArray ( $langStringTargets ))
2017-02-14 01:24:38 +02:00
{
$langHolders = array ();
// set the lang for both since we don't know what area is being targeted
$_tmp = $this -> lang ;
$this -> lang = 'both' ;
// set language data
2017-12-15 01:10:47 +02:00
foreach ( $langStringTargets as $langStringTarget )
2017-12-14 15:30:21 +02:00
{
2017-12-15 01:10:47 +02:00
$langCheck [] = ComponentbuilderHelper :: getAllBetween ( $string , $langStringTarget . " ' " , " ' " );
$langCheck [] = ComponentbuilderHelper :: getAllBetween ( $string , $langStringTarget . " ' " , " ' " );
2017-12-14 15:30:21 +02:00
}
2017-02-14 01:24:38 +02:00
// merge arrays
$langArray = ComponentbuilderHelper :: mergeArrays ( $langCheck );
// continue only if strings were found
2017-12-14 15:30:21 +02:00
if ( ComponentbuilderHelper :: checkArray ( $langArray )) //<-- not really needed hmmm
2017-02-11 04:24:26 +02:00
{
foreach ( $langArray as $lang )
{
2017-12-15 01:10:47 +02:00
$_keyLang = ComponentbuilderHelper :: safeString ( $lang , 'U' );
2017-02-14 01:24:38 +02:00
// this is there to insure we dont break already added Language strings
if ( $_keyLang === $lang )
2017-02-11 04:24:26 +02:00
{
2017-02-14 01:24:38 +02:00
continue ;
2017-02-11 04:24:26 +02:00
}
2017-02-14 01:24:38 +02:00
// only load if string is not already set
2017-12-15 01:10:47 +02:00
$keyLang = $this -> langPrefix . '_' . $_keyLang ;
2017-02-14 01:24:38 +02:00
if ( ! isset ( $this -> langContent [ $this -> lang ][ $keyLang ]))
{
$this -> langContent [ $this -> lang ][ $keyLang ] = trim ( $lang );
}
// reverse the placeholders
2017-12-15 01:10:47 +02:00
foreach ( $langStringTargets as $langStringTarget )
2017-12-14 15:30:21 +02:00
{
2017-12-15 01:10:47 +02:00
$langHolders [ $langStringTarget . " ' " . $keyLang . " ' " ] = $langStringTarget . " ' " . $lang . " ' " ;
$langHolders [ $langStringTarget . '"' . $keyLang . '"' ] = $langStringTarget . '"' . $lang . '"' ;
2017-12-14 15:30:21 +02:00
}
2017-02-11 04:24:26 +02:00
}
2017-02-14 01:24:38 +02:00
// return the found placeholders
$updateString = $this -> setPlaceholders ( $updateString , $langHolders );
2017-02-11 04:24:26 +02:00
}
2017-02-14 01:24:38 +02:00
// reset the lang
$this -> lang = $_tmp ;
2017-02-11 04:24:26 +02:00
}
2017-02-14 01:24:38 +02:00
return $updateString ;
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* Update the data with the placeholders
*
* @ param string $data The actual data
* @ param array $placeholder The placeholders
* @ param int $action The action to use
2017-12-15 01:10:47 +02:00
* ===================================================
2017-02-14 01:24:38 +02:00
* THE ACTION OPTIONS ARE
2017-12-15 01:10:47 +02:00
* ===================================================
2017-02-14 01:24:38 +02:00
* 1 -> Just replace ( default )
* 2 -> Check if data string has placeholders
* 3 -> Remove placeholders not in data string
2017-12-15 01:10:47 +02:00
* ===================================================
2017-02-14 01:24:38 +02:00
* @ param int $langSwitch The lang switch
*
* @ return string
*
*/
public function setPlaceholders ( & $data , & $placeholder , $action = 1 )
{
2017-02-11 04:24:26 +02:00
if ( 1 == $action ) // <-- just replace (default)
{
2017-12-15 01:10:47 +02:00
return str_replace ( array_keys ( $placeholder ), array_values ( $placeholder ), $data );
2017-02-11 04:24:26 +02:00
}
elseif ( 2 == $action ) // <-- check if data string has placeholders
{
$replace = false ;
foreach ( $placeholder as $key => $val )
{
if ( strpos ( $data , $key ) !== FALSE )
{
2017-12-15 01:10:47 +02:00
$replace = true ;
break ;
2017-02-11 04:24:26 +02:00
}
}
// only replace if the data has these placeholder values
if ( $replace === true )
{
2017-12-15 01:10:47 +02:00
return str_replace ( array_keys ( $placeholder ), array_values ( $placeholder ), $data );
2017-02-11 04:24:26 +02:00
}
}
elseif ( 3 == $action ) // <-- remove placeholders not in data string
{
$replace = $placeholder ;
foreach ( $replace as $key => $val )
{
if ( strpos ( $data , $key ) === FALSE )
{
2017-12-15 01:10:47 +02:00
unset ( $replace [ $key ]);
2017-02-11 04:24:26 +02:00
}
}
// only replace if the data has these placeholder values
if ( ComponentbuilderHelper :: checkArray ( $replace ))
{
2017-12-15 01:10:47 +02:00
return str_replace ( array_keys ( $replace ), array_values ( $replace ), $data );
2017-02-11 04:24:26 +02:00
}
}
return $data ;
}
2017-12-15 01:10:47 +02:00
2017-02-01 15:17:04 +02:00
/**
* return the placeholders for insered and replaced code
*
* @ param int $type The type of placement
* @ param int $id The code id in the system
*
* @ return array on success
*
*/
2017-02-11 04:24:26 +02:00
public function getPlaceHolder ( $type , $id )
2017-02-01 15:17:04 +02:00
{
switch ( $type )
{
2017-02-14 01:24:38 +02:00
case 11 :
//***[REPLACED$$$$]***//*1*/
if ( $this -> addPlaceholders === true )
2017-02-02 14:17:31 +02:00
{
return array (
2017-12-15 01:10:47 +02:00
'start' => '/***[REPLACED$$$$]***//*' . $id . '*/' ,
2017-02-02 14:17:31 +02:00
'end' => '/***[/REPLACED$$$$]***/' );
}
else
{
return array (
2018-02-27 14:17:38 +02:00
'start' => " " ,
'end' => " " );
2017-02-02 14:17:31 +02:00
}
2017-02-01 15:17:04 +02:00
break ;
2017-02-14 01:24:38 +02:00
case 12 :
//***[INSERTED$$$$]***//*1*/
if ( $this -> addPlaceholders === true )
2017-02-02 14:17:31 +02:00
{
return array (
2017-12-15 01:10:47 +02:00
'start' => '/***[INSERTED$$$$]***//*' . $id . '*/' ,
'end' => '/***[/INSERTED$$$$]***/' );
2017-02-02 14:17:31 +02:00
}
else
{
return array (
2018-02-27 14:17:38 +02:00
'start' => " " ,
'end' => " " );
2017-02-02 14:17:31 +02:00
}
2017-02-01 15:17:04 +02:00
break ;
2017-02-14 01:24:38 +02:00
case 21 :
//<!--[REPLACED$$$$]--><!--1-->
if ( $this -> addPlaceholders === true )
{
return array (
2017-12-15 01:10:47 +02:00
'start' => '<!--[REPLACED$$$$]--><!--' . $id . '-->' ,
'end' => '<!--[/REPLACED$$$$]-->' );
2017-02-14 01:24:38 +02:00
}
else
{
return array (
2018-02-27 14:17:38 +02:00
'start' => " " ,
'end' => " " );
2017-02-14 01:24:38 +02:00
}
break ;
case 22 :
//<!--[INSERTED$$$$]--><!--1-->
if ( $this -> addPlaceholders === true )
{
return array (
2017-12-15 01:10:47 +02:00
'start' => '<!--[INSERTED$$$$]--><!--' . $id . '-->' ,
'end' => '<!--[/INSERTED$$$$]-->' );
2017-02-14 01:24:38 +02:00
}
else
{
return array (
2018-02-27 14:17:38 +02:00
'start' => " " ,
'end' => " " );
2017-02-14 01:24:38 +02:00
}
break ;
2017-02-11 04:24:26 +02:00
case 3 :
return array (
2018-02-27 14:17:38 +02:00
'start' => " " ,
'end' => " " );
2017-02-11 04:24:26 +02:00
break ;
2017-02-01 15:17:04 +02:00
}
return false ;
}
2017-12-15 01:10:47 +02:00
2017-02-14 01:24:38 +02:00
/**
* get the local installed path of this component
*
* @ return array of paths on success
*
*/
protected function getLocalInstallPaths ()
{
// set the local paths to search
$localPaths = array ();
// admin path
2017-12-15 01:10:47 +02:00
$localPaths [ 'admin' ] = JPATH_ADMINISTRATOR . '/components/com_' . $this -> componentCodeName ;
2017-02-14 01:24:38 +02:00
// site path
2017-12-15 01:10:47 +02:00
$localPaths [ 'site' ] = JPATH_ROOT . '/components/com_' . $this -> componentCodeName ;
2017-02-14 01:24:38 +02:00
// TODO later to include the JS and CSS
2017-12-15 01:10:47 +02:00
$localPaths [ 'media' ] = JPATH_ROOT . '/media/com_' . $this -> componentCodeName ;
2017-02-14 01:24:38 +02:00
// check if the local install is found
foreach ( $localPaths as $key => $localPath )
{
if ( ! JFolder :: exists ( $localPath ))
{
unset ( $localPaths [ $key ]);
}
}
if ( ComponentbuilderHelper :: checkArray ( $localPaths ))
{
return $localPaths ;
}
return false ;
}
2017-12-15 01:10:47 +02:00
2016-02-26 02:20:09 +02:00
}