| Server IP : 103.161.17.216 / Your IP : 216.73.216.1 Web Server : nginx/1.18.0 System : Linux tipsysaigoncharming 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64 User : www-data ( 33) PHP Version : 7.4.3-4ubuntu2.29 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /var/www/app.houseland.info/modules/exports/services/ |
Upload File : |
<?php
namespace app\modules\exports\services;
use CI_DB_mysqli_driver;
class ContactCSVExport extends CSVExport
{
private string $defaultDirection;
public function __construct(?string $fromDate, ?string $toDate)
{
parent::__construct($fromDate, $toDate, 'contacts');
$this->defaultDirection = get_option('rtl_support_client') == 1 ? 'rtl' : 'ltr';
}
private array $excludedFields = [
'new_pass_key',
'new_pass_key_requested',
'email_verification_key',
'email_verification_sent_at',
'password',
'last_password_change',
'last_ip',
'userid',
];
public function queryData(): CI_DB_mysqli_driver
{
$this->ci->db->select(prefixed_table_fields_array(db_prefix() . 'contacts', true, $this->excludedFields) . ',' . get_sql_select_client_company());
$this->selectCustomFields(db_prefix() . 'contacts.id');
$this->ci->db->join(db_prefix() . 'clients', db_prefix() . 'clients.userid = ' . db_prefix() . 'contacts.userid', 'left');
$this->applyDateFilter(db_prefix() . 'contacts.datecreated');
return $this->ci->db->from(db_prefix() . 'contacts');
}
protected function formatRow(string $name, $value, array $row)
{
switch ($name) {
case 'profile_image':
return $this->getProfileImageUrl($row['id'], $value);
case 'direction':
return $value ?: $this->defaultDirection;
default:
return parent::formatRow($name, $value, $row);
}
}
private function getProfileImageUrl(int $contactId, ?string $profileImage): ?string
{
if (!empty($profileImage)) {
$path = 'uploads/client_profile_images/' . $contactId . '/small_' . $profileImage;
if (file_exists($path)) {
return base_url($path);
}
}
return '';
}
}