2015-12-01 05:06:34 +00:00
< ? php
/*----------------------------------------------------------------------------------| www . giz . de |----/
Deutsche Gesellschaft für International Zusammenarbeit ( GIZ ) Gmb
/-------------------------------------------------------------------------------------------------------/
@ version 3.0 . 8
@ build 1 st December , 2015
@ created 15 th June , 2012
@ package Cost Benefit Projection
@ subpackage service_provider . php
@ author Llewellyn van der Merwe < http :// www . vdm . io >
@ owner Deutsche Gesellschaft für International Zusammenarbeit ( GIZ ) Gmb
@ copyright Copyright ( C ) 2015. All Rights Reserved
@ license GNU / GPL Version 2 or later - http :// www . gnu . org / licenses / gpl - 2.0 . html
/-------------------------------------------------------------------------------------------------------/
Cost Benefit Projection Tool .
/------------------------------------------------------------------------------------------------------*/
// No direct access to this file
defined ( '_JEXEC' ) or die ( 'Restricted access' );
use Joomla\Registry\Registry ;
// import Joomla modelform library
jimport ( 'joomla.application.component.modeladmin' );
/**
* Costbenefitprojection Service_provider Model
*/
class CostbenefitprojectionModelService_provider extends JModelAdmin
{
/**
* @ var string The prefix to use with controller messages .
* @ since 1.6
*/
protected $text_prefix = 'COM_COSTBENEFITPROJECTION' ;
/**
* The type alias for this content type .
*
* @ var string
* @ since 3.2
*/
public $typeAlias = 'com_costbenefitprojection.service_provider' ;
/**
* Returns a Table object , always creating it
*
* @ param type $type The table type to instantiate
* @ param string $prefix A prefix for the table class name . Optional .
* @ param array $config Configuration array for model . Optional .
*
* @ return JTable A database object
*
* @ since 1.6
*/
public function getTable ( $type = 'service_provider' , $prefix = 'CostbenefitprojectionTable' , $config = array ())
{
return JTable :: getInstance ( $type , $prefix , $config );
}
/**
* Method to get a single record .
*
* @ param integer $pk The id of the primary key .
*
* @ return mixed Object on success , false on failure .
*
* @ since 1.6
*/
public function getItem ( $pk = null )
{
if ( $item = parent :: getItem ( $pk ))
{
if ( ! empty ( $item -> params ))
{
// Convert the params field to an array.
$registry = new Registry ;
$registry -> loadString ( $item -> params );
$item -> params = $registry -> toArray ();
}
if ( ! empty ( $item -> metadata ))
{
// Convert the metadata field to an array.
$registry = new Registry ;
$registry -> loadString ( $item -> metadata );
$item -> metadata = $registry -> toArray ();
}
if ( ! empty ( $item -> id ))
{
$item -> tags = new JHelperTags ;
$item -> tags -> getTagIds ( $item -> id , 'com_costbenefitprojection.service_provider' );
}
}
2015-12-01 05:18:34 +00:00
$this -> serviceproviderodiy = $item -> id ;
2015-12-01 05:06:34 +00:00
return $item ;
}
/**
* Method to get list data .
*
* @ return mixed An array of data items on success , false on failure .
*/
2015-12-01 05:18:34 +00:00
public function getUvzcompanies ()
2015-12-01 05:06:34 +00:00
{
// [6945] Get the user object.
$user = JFactory :: getUser ();
// [6947] Create a new query object.
$db = JFactory :: getDBO ();
$query = $db -> getQuery ( true );
// [6950] Select some fields
$query -> select ( 'a.*' );
// [6957] From the costbenefitprojection_company table
$query -> from ( $db -> quoteName ( '#__costbenefitprojection_company' , 'a' ));
// Filter by companies (admin sees all)
if ( ! $user -> authorise ( 'core.options' , 'com_costbenefitprojection' ))
{
$companies = CostbenefitprojectionHelper :: hisCompanies ( $user -> id );
if ( CostbenefitprojectionHelper :: checkArray ( $companies ))
{
$companies = implode ( ',' , $companies );
// only load this users companies
$query -> where ( 'a.id IN (' . $companies . ')' );
}
else
{
// dont allow user to see any companies
$query -> where ( 'a.id = -4' );
}
}
// [7550] From the users table.
$query -> select ( $db -> quoteName ( 'g.name' , 'user_name' ));
$query -> join ( 'LEFT' , $db -> quoteName ( '#__users' , 'g' ) . ' ON (' . $db -> quoteName ( 'a.user' ) . ' = ' . $db -> quoteName ( 'g.id' ) . ')' );
// [7550] From the costbenefitprojection_country table.
$query -> select ( $db -> quoteName ( 'h.name' , 'country_name' ));
$query -> join ( 'LEFT' , $db -> quoteName ( '#__costbenefitprojection_country' , 'h' ) . ' ON (' . $db -> quoteName ( 'a.country' ) . ' = ' . $db -> quoteName ( 'h.id' ) . ')' );
// [7550] From the costbenefitprojection_service_provider table.
$query -> select ( $db -> quoteName ( 'i.user' , 'serviceprovider_user' ));
$query -> join ( 'LEFT' , $db -> quoteName ( '#__costbenefitprojection_service_provider' , 'i' ) . ' ON (' . $db -> quoteName ( 'a.serviceprovider' ) . ' = ' . $db -> quoteName ( 'i.id' ) . ')' );
2015-12-01 05:18:34 +00:00
// [6973] Filter by serviceproviderodiy global.
$serviceproviderodiy = $this -> serviceproviderodiy ;
if ( is_numeric ( $serviceproviderodiy ))
2015-12-01 05:06:34 +00:00
{
2015-12-01 05:18:34 +00:00
$query -> where ( 'a.serviceprovider = ' . ( int ) $serviceproviderodiy );
2015-12-01 05:06:34 +00:00
}
2015-12-01 05:18:34 +00:00
elseif ( is_string ( $serviceproviderodiy ))
2015-12-01 05:06:34 +00:00
{
2015-12-01 05:18:34 +00:00
$query -> where ( 'a.serviceprovider = ' . $db -> quote ( $serviceproviderodiy ));
2015-12-01 05:06:34 +00:00
}
else
{
$query -> where ( 'a.serviceprovider = -5' );
}
// [6990] Join over the asset groups.
$query -> select ( 'ag.title AS access_level' );
$query -> join ( 'LEFT' , '#__viewlevels AS ag ON ag.id = a.access' );
// [6993] Filter by access level.
if ( $access = $this -> getState ( 'filter.access' ))
{
$query -> where ( 'a.access = ' . ( int ) $access );
}
// [6998] Implement View Level Access
if ( ! $user -> authorise ( 'core.options' , 'com_costbenefitprojection' ))
{
$groups = implode ( ',' , $user -> getAuthorisedViewLevels ());
$query -> where ( 'a.access IN (' . $groups . ')' );
}
// [7005] Order the results by ordering
$query -> order ( 'a.ordering ASC' );
// [7007] Load the items
$db -> setQuery ( $query );
$db -> execute ();
if ( $db -> getNumRows ())
{
$items = $db -> loadObjectList ();
// [10611] set values to display correctly.
if ( CostbenefitprojectionHelper :: checkArray ( $items ))
{
// [10614] get user object.
$user = JFactory :: getUser ();
foreach ( $items as $nr => & $item )
{
$access = ( $user -> authorise ( 'company.access' , 'com_costbenefitprojection.company.' . ( int ) $item -> id ) && $user -> authorise ( 'company.access' , 'com_costbenefitprojection' ));
if ( ! $access )
{
unset ( $items [ $nr ]);
continue ;
}
}
}
// [10877] set selection value to a translatable value
if ( CostbenefitprojectionHelper :: checkArray ( $items ))
{
foreach ( $items as $nr => & $item )
{
// [10884] convert department
2015-12-01 05:18:34 +00:00
$item -> department = $this -> selectionTranslationUvzcompanies ( $item -> department , 'department' );
2015-12-01 05:06:34 +00:00
// [10884] convert per
2015-12-01 05:18:34 +00:00
$item -> per = $this -> selectionTranslationUvzcompanies ( $item -> per , 'per' );
2015-12-01 05:06:34 +00:00
}
}
return $items ;
}
return false ;
}
/**
* Method to convert selection values to translatable string .
*
* @ return translatable string
*/
2015-12-01 05:18:34 +00:00
public function selectionTranslationUvzcompanies ( $value , $name )
2015-12-01 05:06:34 +00:00
{
// [10910] Array of department language strings
if ( $name == 'department' )
{
$departmentArray = array (
1 => 'COM_COSTBENEFITPROJECTION_COMPANY_BASIC' ,
2 => 'COM_COSTBENEFITPROJECTION_COMPANY_ADVANCED'
);
// [10941] Now check if value is found in this array
if ( isset ( $departmentArray [ $value ]) && CostbenefitprojectionHelper :: checkString ( $departmentArray [ $value ]))
{
return $departmentArray [ $value ];
}
}
// [10910] Array of per language strings
if ( $name == 'per' )
{
$perArray = array (
1 => 'COM_COSTBENEFITPROJECTION_COMPANY_OPEN' ,
0 => 'COM_COSTBENEFITPROJECTION_COMPANY_LOCKED'
);
// [10941] Now check if value is found in this array
if ( isset ( $perArray [ $value ]) && CostbenefitprojectionHelper :: checkString ( $perArray [ $value ]))
{
return $perArray [ $value ];
}
}
return $value ;
}
/**
* Method to get the record form .
*
* @ param array $data Data for the form .
* @ param boolean $loadData True if the form is to load its own data ( default case ), false if not .
*
* @ return mixed A JForm object on success , false on failure
*
* @ since 1.6
*/
public function getForm ( $data = array (), $loadData = true )
{ // [9566] Get the form.
$form = $this -> loadForm ( 'com_costbenefitprojection.service_provider' , 'service_provider' , array ( 'control' => 'jform' , 'load_data' => $loadData ));
if ( empty ( $form ))
{
return false ;
}
$jinput = JFactory :: getApplication () -> input ;
// [9651] The front end calls this model and uses a_id to avoid id clashes so we need to check for that first.
if ( $jinput -> get ( 'a_id' ))
{
$id = $jinput -> get ( 'a_id' , 0 , 'INT' );
}
// [9656] The back end uses id so we use that the rest of the time and set it to 0 by default.
else
{
$id = $jinput -> get ( 'id' , 0 , 'INT' );
}
$user = JFactory :: getUser ();
// [9662] Check for existing item.
// [9663] Modify the form based on Edit State access controls.
if ( $id != 0 && ( ! $user -> authorise ( 'service_provider.edit.state' , 'com_costbenefitprojection.service_provider.' . ( int ) $id ))
|| ( $id == 0 && ! $user -> authorise ( 'service_provider.edit.state' , 'com_costbenefitprojection' )))
{
// [9676] Disable fields for display.
$form -> setFieldAttribute ( 'ordering' , 'disabled' , 'true' );
$form -> setFieldAttribute ( 'published' , 'disabled' , 'true' );
// [9679] Disable fields while saving.
$form -> setFieldAttribute ( 'ordering' , 'filter' , 'unset' );
$form -> setFieldAttribute ( 'published' , 'filter' , 'unset' );
}
// [9684] Modify the form based on Edit Creaded By access controls.
if ( ! $user -> authorise ( 'core.edit.created_by' , 'com_costbenefitprojection' ))
{
// [9696] Disable fields for display.
$form -> setFieldAttribute ( 'created_by' , 'disabled' , 'true' );
// [9698] Disable fields for display.
$form -> setFieldAttribute ( 'created_by' , 'readonly' , 'true' );
// [9700] Disable fields while saving.
$form -> setFieldAttribute ( 'created_by' , 'filter' , 'unset' );
}
// [9703] Modify the form based on Edit Creaded Date access controls.
if ( ! $user -> authorise ( 'core.edit.created' , 'com_costbenefitprojection' ))
{
// [9715] Disable fields for display.
$form -> setFieldAttribute ( 'created' , 'disabled' , 'true' );
// [9717] Disable fields while saving.
$form -> setFieldAttribute ( 'created' , 'filter' , 'unset' );
}
return $form ;
}
/**
* Method to get the script that have to be included on the form
*
* @ return string script files
*/
public function getScript ()
{
return 'administrator/components/com_costbenefitprojection/models/forms/service_provider.js' ;
}
/**
* Method to test whether a record can be deleted .
*
* @ param object $record A record object .
*
* @ return boolean True if allowed to delete the record . Defaults to the permission set in the component .
*
* @ since 1.6
*/
protected function canDelete ( $record )
{
if ( ! empty ( $record -> id ))
{
if ( $record -> published != - 2 )
{
return ;
}
$user = JFactory :: getUser ();
// [9867] The record has been set. Check the record permissions.
return $user -> authorise ( 'service_provider.delete' , 'com_costbenefitprojection.service_provider.' . ( int ) $record -> id );
}
return false ;
}
/**
* Method to test whether a record can have its state edited .
*
* @ param object $record A record object .
*
* @ return boolean True if allowed to change the state of the record . Defaults to the permission set in the component .
*
* @ since 1.6
*/
protected function canEditState ( $record )
{
$user = JFactory :: getUser ();
$recordId = ( ! empty ( $record -> id )) ? $record -> id : 0 ;
if ( $recordId )
{
// [9954] The record has been set. Check the record permissions.
$permission = $user -> authorise ( 'service_provider.edit.state' , 'com_costbenefitprojection.service_provider.' . ( int ) $recordId );
if ( ! $permission && ! is_null ( $permission ))
{
return false ;
}
}
// [9971] In the absense of better information, revert to the component permissions.
return $user -> authorise ( 'service_provider.edit.state' , 'com_costbenefitprojection' );
}
/**
* Method override to check if you can edit an existing record .
*
* @ param array $data An array of input data .
* @ param string $key The name of the key for the primary key .
*
* @ return boolean
* @ since 2.5
*/
protected function allowEdit ( $data = array (), $key = 'id' )
{
// [9779] Check specific edit permission then general edit permission.
$user = JFactory :: getUser ();
$recordId = ( int ) isset ( $data [ $key ]) ? $data [ $key ] : 0 ;
if ( ! $user -> authorise ( 'core.options' , 'com_costbenefitprojection' ))
{
// make absolutely sure that this Service Providers can be edited
$serviceproviders = CostbenefitprojectionHelper :: hisServiceProviders ( $user -> id );
if ( ! CostbenefitprojectionHelper :: checkArray ( $serviceproviders ) || ! in_array ( $recordId , $serviceproviders ))
{
return false ;
}
}
return $user -> authorise ( 'service_provider.edit' , 'com_costbenefitprojection.service_provider.' . (( int ) isset ( $data [ $key ]) ? $data [ $key ] : 0 )) or $user -> authorise ( 'service_provider.edit' , 'com_costbenefitprojection' );
}
/**
* Prepare and sanitise the table data prior to saving .
*
* @ param JTable $table A JTable object .
*
* @ return void
*
* @ since 1.6
*/
protected function prepareTable ( $table )
{
$date = JFactory :: getDate ();
$user = JFactory :: getUser ();
if ( isset ( $table -> name ))
{
$table -> name = htmlspecialchars_decode ( $table -> name , ENT_QUOTES );
}
if ( isset ( $table -> alias ) && empty ( $table -> alias ))
{
$table -> generateAlias ();
}
if ( empty ( $table -> id ))
{
$table -> created = $date -> toSql ();
// set the user
if ( $table -> created_by == 0 )
{
$table -> created_by = $user -> id ;
}
// Set ordering to the last item if not set
if ( empty ( $table -> ordering ))
{
$db = JFactory :: getDbo ();
$query = $db -> getQuery ( true )
-> select ( 'MAX(ordering)' )
-> from ( $db -> quoteName ( '#__costbenefitprojection_service_provider' ));
$db -> setQuery ( $query );
$max = $db -> loadResult ();
$table -> ordering = $max + 1 ;
}
}
else
{
$table -> modified = $date -> toSql ();
$table -> modified_by = $user -> id ;
}
if ( ! empty ( $table -> id ))
{
// Increment the items version number.
$table -> version ++ ;
}
}
/**
* Method to get the data that should be injected in the form .
*
* @ return mixed The data for the form .
*
* @ since 1.6
*/
protected function loadFormData ()
{
// Check the session for previously entered form data.
$data = JFactory :: getApplication () -> getUserState ( 'com_costbenefitprojection.edit.service_provider.data' , array ());
if ( empty ( $data ))
{
$data = $this -> getItem ();
}
return $data ;
}
/**
* Method to get the unique fields of this table .
*
* @ return mixed An array of field names , boolean false if none is set .
*
* @ since 3.0
*/
protected function getUniqeFields ()
{
return false ;
}
/**
* Method to perform batch operations on an item or a set of items .
*
* @ param array $commands An array of commands to perform .
* @ param array $pks An array of item ids .
* @ param array $contexts An array of item contexts .
*
* @ return boolean Returns true on success , false on failure .
*
* @ since 12.2
*/
public function batch ( $commands , $pks , $contexts )
{
// Sanitize ids.
$pks = array_unique ( $pks );
JArrayHelper :: toInteger ( $pks );
// Remove any values of zero.
if ( array_search ( 0 , $pks , true ))
{
unset ( $pks [ array_search ( 0 , $pks , true )]);
}
if ( empty ( $pks ))
{
$this -> setError ( JText :: _ ( 'JGLOBAL_NO_ITEM_SELECTED' ));
return false ;
}
$done = false ;
// Set some needed variables.
$this -> user = JFactory :: getUser ();
$this -> table = $this -> getTable ();
$this -> tableClassName = get_class ( $this -> table );
$this -> contentType = new JUcmType ;
$this -> type = $this -> contentType -> getTypeByTable ( $this -> tableClassName );
$this -> canDo = CostbenefitprojectionHelper :: getActions ( 'service_provider' );
$this -> batchSet = true ;
if ( ! $this -> canDo -> get ( 'core.batch' ))
{
$this -> setError ( JText :: _ ( 'JLIB_APPLICATION_ERROR_INSUFFICIENT_BATCH_INFORMATION' ));
return false ;
}
if ( $this -> type == false )
{
$type = new JUcmType ;
$this -> type = $type -> getTypeByAlias ( $this -> typeAlias );
}
$this -> tagsObserver = $this -> table -> getObserverOfClass ( 'JTableObserverTags' );
if ( ! empty ( $commands [ 'move_copy' ]))
{
$cmd = JArrayHelper :: getValue ( $commands , 'move_copy' , 'c' );
if ( $cmd == 'c' )
{
$result = $this -> batchCopy ( $commands , $pks , $contexts );
if ( is_array ( $result ))
{
foreach ( $result as $old => $new )
{
$contexts [ $new ] = $contexts [ $old ];
}
$pks = array_values ( $result );
}
else
{
return false ;
}
}
elseif ( $cmd == 'm' && ! $this -> batchMove ( $commands , $pks , $contexts ))
{
return false ;
}
$done = true ;
}
if ( ! $done )
{
$this -> setError ( JText :: _ ( 'JLIB_APPLICATION_ERROR_INSUFFICIENT_BATCH_INFORMATION' ));
return false ;
}
// Clear the cache
$this -> cleanCache ();
return true ;
}
/**
* Batch copy items to a new category or current .
*
* @ param integer $values The new values .
* @ param array $pks An array of row IDs .
* @ param array $contexts An array of item contexts .
*
* @ return mixed An array of new IDs on success , boolean false on failure .
*
* @ since 12.2
*/
protected function batchCopy ( $values , $pks , $contexts )
{
if ( empty ( $this -> batchSet ))
{
// [4932] Set some needed variables.
$this -> user = JFactory :: getUser ();
$this -> table = $this -> getTable ();
$this -> tableClassName = get_class ( $this -> table );
$this -> contentType = new JUcmType ;
$this -> type = $this -> contentType -> getTypeByTable ( $this -> tableClassName );
$this -> canDo = CostbenefitprojectionHelper :: getActions ( 'service_provider' );
}
if ( ! $this -> canDo -> get ( 'service_provider.create' ) && ! $this -> canDo -> get ( 'service_provider.batch' ))
{
return false ;
}
if ( ! $this -> user -> authorise ( 'core.options' , 'com_costbenefitprojection' ))
{
// make absolutely sure that this Service Providers can be copied
$serviceproviders = CostbenefitprojectionHelper :: hisServiceProviders ( $this -> user -> id );
if ( CostbenefitprojectionHelper :: checkArray ( $serviceproviders ))
{
foreach ( $pks as $nr => $pk )
{
if ( ! in_array ( $pk , $serviceproviders ))
{
unset ( $pks [ $nr ]);
}
}
if ( empty ( $pks ))
{
$this -> setError ( JText :: _ ( 'JLIB_APPLICATION_ERROR_BATCH_CANNOT_EDIT' ));
return false ;
}
}
else
{
$this -> setError ( JText :: _ ( 'JLIB_APPLICATION_ERROR_BATCH_CANNOT_EDIT' ));
return false ;
}
}
// [4952] get list of uniqe fields
$uniqeFields = $this -> getUniqeFields ();
// [4954] remove move_copy from array
unset ( $values [ 'move_copy' ]);
// [4957] make sure published is set
if ( ! isset ( $values [ 'published' ]))
{
$values [ 'published' ] = 0 ;
}
elseif ( isset ( $values [ 'published' ]) && ! $this -> canDo -> get ( 'service_provider.edit.state' ))
{
$values [ 'published' ] = 0 ;
}
$newIds = array ();
// [4994] Parent exists so let's proceed
while ( ! empty ( $pks ))
{
// [4997] Pop the first ID off the stack
$pk = array_shift ( $pks );
$this -> table -> reset ();
// [5002] only allow copy if user may edit this item.
if ( ! $this -> user -> authorise ( 'service_provider.edit' , $contexts [ $pk ]))
{
// [5012] Not fatal error
$this -> setError ( JText :: sprintf ( 'JLIB_APPLICATION_ERROR_BATCH_MOVE_ROW_NOT_FOUND' , $pk ));
continue ;
}
// [5017] Check that the row actually exists
if ( ! $this -> table -> load ( $pk ))
{
if ( $error = $this -> table -> getError ())
{
// [5022] Fatal error
$this -> setError ( $error );
return false ;
}
else
{
// [5029] Not fatal error
$this -> setError ( JText :: sprintf ( 'JLIB_APPLICATION_ERROR_BATCH_MOVE_ROW_NOT_FOUND' , $pk ));
continue ;
}
}
// [5065] insert all set values
if ( CostbenefitprojectionHelper :: checkArray ( $values ))
{
foreach ( $values as $key => $value )
{
if ( strlen ( $value ) > 0 && isset ( $this -> table -> $key ))
{
$this -> table -> $key = $value ;
}
}
}
// [5077] update all uniqe fields
if ( CostbenefitprojectionHelper :: checkArray ( $uniqeFields ))
{
foreach ( $uniqeFields as $uniqeField )
{
$this -> table -> $uniqeField = $this -> generateUniqe ( $uniqeField , $this -> table -> $uniqeField );
}
}
// [5086] Reset the ID because we are making a copy
$this -> table -> id = 0 ;
// [5089] TODO: Deal with ordering?
// [5090] $this->table->ordering = 1;
// [5092] Check the row.
if ( ! $this -> table -> check ())
{
$this -> setError ( $this -> table -> getError ());
return false ;
}
if ( ! empty ( $this -> type ))
{
$this -> createTagsHelper ( $this -> tagsObserver , $this -> type , $pk , $this -> typeAlias , $this -> table );
}
// [5105] Store the row.
if ( ! $this -> table -> store ())
{
$this -> setError ( $this -> table -> getError ());
return false ;
}
// [5113] Get the new item ID
$newId = $this -> table -> get ( 'id' );
// [5116] Add the new ID to the array
$newIds [ $pk ] = $newId ;
}
// [5120] Clean the cache
$this -> cleanCache ();
return $newIds ;
}
/**
* Batch move items to a new category
*
* @ param integer $value The new category ID .
* @ param array $pks An array of row IDs .
* @ param array $contexts An array of item contexts .
*
* @ return boolean True if successful , false otherwise and internal error is set .
*
* @ since 12.2
*/
protected function batchMove ( $values , $pks , $contexts )
{
if ( empty ( $this -> batchSet ))
{
// [4734] Set some needed variables.
$this -> user = JFactory :: getUser ();
$this -> table = $this -> getTable ();
$this -> tableClassName = get_class ( $this -> table );
$this -> contentType = new JUcmType ;
$this -> type = $this -> contentType -> getTypeByTable ( $this -> tableClassName );
$this -> canDo = CostbenefitprojectionHelper :: getActions ( 'service_provider' );
}
if ( ! $this -> canDo -> get ( 'service_provider.edit' ) && ! $this -> canDo -> get ( 'service_provider.batch' ))
{
$this -> setError ( JText :: _ ( 'JLIB_APPLICATION_ERROR_BATCH_CANNOT_EDIT' ));
return false ;
}
if ( ! $this -> user -> authorise ( 'core.options' , 'com_costbenefitprojection' ))
{
// make absolutely sure that this Service Providers can be moved
$serviceproviders = CostbenefitprojectionHelper :: hisServiceProviders ( $this -> user -> id );
if ( CostbenefitprojectionHelper :: checkArray ( $serviceproviders ))
{
foreach ( $pks as $nr => $pk )
{
if ( ! in_array ( $pk , $serviceproviders ))
{
unset ( $pks [ $nr ]);
}
}
if ( empty ( $pks ))
{
$this -> setError ( JText :: sprintf ( 'JLIB_APPLICATION_ERROR_BATCH_MOVE_ROW_NOT_FOUND' , 0 ));
return false ;
}
}
else
{
$this -> setError ( JText :: sprintf ( 'JLIB_APPLICATION_ERROR_BATCH_MOVE_ROW_NOT_FOUND' , 0 ));
return false ;
}
}
// [4756] make sure published only updates if user has the permission.
if ( isset ( $values [ 'published' ]) && ! $this -> canDo -> get ( 'service_provider.edit.state' ))
{
unset ( $values [ 'published' ]);
}
// [4769] remove move_copy from array
unset ( $values [ 'move_copy' ]);
// [4790] Parent exists so we proceed
foreach ( $pks as $pk )
{
if ( ! $this -> user -> authorise ( 'service_provider.edit' , $contexts [ $pk ]))
{
$this -> setError ( JText :: _ ( 'JLIB_APPLICATION_ERROR_BATCH_CANNOT_EDIT' ));
return false ;
}
// [4807] Check that the row actually exists
if ( ! $this -> table -> load ( $pk ))
{
if ( $error = $this -> table -> getError ())
{
// [4812] Fatal error
$this -> setError ( $error );
return false ;
}
else
{
// [4819] Not fatal error
$this -> setError ( JText :: sprintf ( 'JLIB_APPLICATION_ERROR_BATCH_MOVE_ROW_NOT_FOUND' , $pk ));
continue ;
}
}
// [4825] insert all set values.
if ( CostbenefitprojectionHelper :: checkArray ( $values ))
{
foreach ( $values as $key => $value )
{
// [4830] Do special action for access.
if ( 'access' == $key && strlen ( $value ) > 0 )
{
$this -> table -> $key = $value ;
}
elseif ( strlen ( $value ) > 0 && isset ( $this -> table -> $key ))
{
$this -> table -> $key = $value ;
}
}
}
// [4842] Check the row.
if ( ! $this -> table -> check ())
{
$this -> setError ( $this -> table -> getError ());
return false ;
}
if ( ! empty ( $this -> type ))
{
$this -> createTagsHelper ( $this -> tagsObserver , $this -> type , $pk , $this -> typeAlias , $this -> table );
}
// [4855] Store the row.
if ( ! $this -> table -> store ())
{
$this -> setError ( $this -> table -> getError ());
return false ;
}
}
// [4864] Clean the cache
$this -> cleanCache ();
return true ;
}
/**
* Method to save the form data .
*
* @ param array $data The form data .
*
* @ return boolean True on success .
*
* @ since 1.6
*/
public function save ( $data )
{
$input = JFactory :: getApplication () -> input ;
$filter = JFilterInput :: getInstance ();
// set the metadata to the Item Data
if ( isset ( $data [ 'metadata' ]) && isset ( $data [ 'metadata' ][ 'author' ]))
{
$data [ 'metadata' ][ 'author' ] = $filter -> clean ( $data [ 'metadata' ][ 'author' ], 'TRIM' );
$metadata = new JRegistry ;
$metadata -> loadArray ( $data [ 'metadata' ]);
$data [ 'metadata' ] = ( string ) $metadata ;
}
// Set the Params Items to data
if ( isset ( $data [ 'params' ]) && is_array ( $data [ 'params' ]))
{
$params = new JRegistry ;
$params -> loadArray ( $data [ 'params' ]);
$data [ 'params' ] = ( string ) $params ;
}
// [5212] Alter the uniqe field for save as copy
if ( $input -> get ( 'task' ) == 'save2copy' )
{
// [5215] Automatic handling of other uniqe fields
$uniqeFields = $this -> getUniqeFields ();
if ( CostbenefitprojectionHelper :: checkArray ( $uniqeFields ))
{
foreach ( $uniqeFields as $uniqeField )
{
$data [ $uniqeField ] = $this -> generateUniqe ( $uniqeField , $data [ $uniqeField ]);
}
}
}
if ( parent :: save ( $data ))
{
return true ;
}
return false ;
}
/**
* Method to generate a uniqe value .
*
* @ param string $field name .
* @ param string $value data .
*
* @ return string New value .
*
* @ since 3.0
*/
protected function generateUniqe ( $field , $value )
{
// set field value uniqe
$table = $this -> getTable ();
while ( $table -> load ( array ( $field => $value )))
{
$value = JString :: increment ( $value );
}
return $value ;
}
/**
* Method to change the title & alias .
*
* @ param string $title The title .
*
* @ return array Contains the modified title and alias .
*
*/
protected function _generateNewTitle ( $title )
{
// [5270] Alter the title
$table = $this -> getTable ();
while ( $table -> load ( array ( 'title' => $title )))
{
$title = JString :: increment ( $title );
}
return $title ;
}
}