403Webshell
Server IP : 80.87.202.40  /  Your IP : 216.73.216.169
Web Server : Apache
System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64
User : bitrix ( 600)
PHP Version : 8.2.27
Disable Function : NONE
MySQL : OFF |  cURL : ON |  WGET : ON |  Perl : ON |  Python : OFF |  Sudo : ON |  Pkexec : ON
Directory :  /home/bitrix/ext_www/ilovecveti.ru/bitrix/modules/calendar/lib/access/model/

Upload File :
current_dir [ Writeable] document_root [ Writeable]

 

Command :


[ Back ]     

Current File : /home/bitrix/ext_www/ilovecveti.ru/bitrix/modules/calendar/lib/access/model/sectionmodel.php
<?php

namespace Bitrix\Calendar\Access\Model;

use Bitrix\Calendar\Access\AccessibleSection;
use Bitrix\Main\Access\AccessibleItem;

class SectionModel implements AccessibleSection
{
	private static array $cache = [];

	private int $id = 0;
	private string $type = '';
	private int $ownerId = 0;

	public static function createFromId(int $itemId): AccessibleItem
	{
		if (!isset(static::$cache[$itemId]))
		{
			$model = new self();
			$model->setId($itemId);
			static::$cache[$itemId] = $model;
		}

		return static::$cache[$itemId];
	}

	public static function createNew(): self
	{
		return new self();
	}

	public static function createFromArray(array $fields): self
	{
		if (($fields['ID'] ?? false) && (int)$fields['ID'] > 0)
		{
			$model = self::createFromId((int)$fields['ID']);
		}
		else
		{
			$model = self::createNew();
		}

		if (($fields['CAL_TYPE'] ?? false) && is_string($fields['CAL_TYPE']))
		{
			$model->setType($fields['CAL_TYPE']);
		}

		if (($fields['OWNER_ID'] ?? false) && (int)$fields['OWNER_ID'] > 0)
		{
			$model->setOwnerId((int)$fields['OWNER_ID']);
		}

		return $model;
	}

	public static function createFromEventModel(EventModel $eventModel): self
	{
		if ($eventModel->getSectionId() > 0)
		{
			$model = self::createFromId($eventModel->getSectionId());
		}
		else
		{
			$model = self::createNew();
		}

		$model
			->setType($eventModel->getSectionType())
			// TODO: fix me
			// this is not right approach for group sections
			// in group sections owner_id IS group_id, so here is potential bug on further model usages
			// as example, in some cases extranet right check can fail
			->setOwnerId($eventModel->getOwnerId())
		;

		return $model;
	}

	public static function createFromEventModelParentFields(EventModel $eventModel): self
	{
		if ($eventModel->getSectionId() > 0)
		{
			$model = self::createFromId($eventModel->getParentEventSectionId());
		}
		else
		{
			$model = self::createNew();
		}

		$model
			->setType($eventModel->getParentEventSectionType())
			->setOwnerId($eventModel->getParentEventOwnerId())
		;

		return $model;
	}

	public function setId(int $id): self
	{
		$this->id = $id;
		return $this;
	}

	public function getId(): int
	{
		return $this->id;
	}

	public function setType(string $type): self
	{
		$this->type = $type;
		return $this;
	}

	public function getType(): string
	{
		return $this->type;
	}

	public function setOwnerId(int $ownerId): self
	{
		$this->ownerId = $ownerId;
		return $this;
	}

	public function getOwnerId(): int
	{
		return $this->ownerId;
	}
}

Youez - 2016 - github.com/yon3zu
LinuXploit