social/lib/Model/StreamDetails.php

209 wiersze
3.7 KiB
PHP

<?php
declare(strict_types=1);
/**
* Nextcloud - Social Support
*
* This file is licensed under the Affero General Public License version 3 or
* later. See the COPYING file.
*
* @author Maxence Lange <maxence@artificial-owl.com>
* @copyright 2018, Maxence Lange <maxence@artificial-owl.com>
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
namespace OCA\Social\Model;
use daita\MySmallPhpTools\Traits\TArrayTools;
use JsonSerializable;
use OCA\Social\Model\ActivityPub\Actor\Person;
use OCA\Social\Model\ActivityPub\Stream;
/**
* Class StreamDetails
*
* @package OCA\Social\Model
*/
class StreamDetails implements JsonSerializable {
use TArrayTools;
/** @var Stream */
private $stream;
/** @var Person[] */
private $homeViewers = [];
/** @var Person[] */
private $directViewers = [];
/** @var bool */
private $public = false;
/** @var bool */
private $federated = false;
/**
* StreamDetails constructor.
*
* @param Stream|null $stream
*/
public function __construct(Stream $stream = null) {
$this->stream = $stream;
}
/**
* @return Stream
*/
public function getStream(): Stream {
return $this->stream;
}
/**
* @param Stream $stream
*
* @return StreamDetails
*/
public function setStream(Stream $stream): self {
$this->stream = $stream;
return $this;
}
/**
* @return Person[]
*/
public function getHomeViewers(): array {
return $this->homeViewers;
}
/**
* @param Person[] $viewers
*
* @return StreamDetails
*/
public function setHomeViewers(array $viewers): self {
$this->homeViewers = $viewers;
return $this;
}
/**
* @param Person $viewer
*
* @return StreamDetails
*/
public function addHomeViewer(Person $viewer): self {
$this->homeViewers[] = $viewer;
return $this;
}
/**
* @return Person[]
*/
public function getDirectViewers(): array {
return $this->directViewers;
}
/**
* @param Person[] $viewers
*
* @return StreamDetails
*/
public function setDirectViewers(array $viewers): self {
$this->directViewers = $viewers;
return $this;
}
/**
* @param Person $viewer
*
* @return StreamDetails
*/
public function addDirectViewer(Person $viewer): self {
$this->directViewers[] = $viewer;
return $this;
}
/**
* @return bool
*/
public function isPublic(): bool {
return $this->public;
}
/**
* @param bool $public
*
* @return StreamDetails
*/
public function setPublic(bool $public): self {
$this->public = $public;
return $this;
}
/**
* @return bool
*/
public function isFederated(): bool {
return $this->federated;
}
/**
* @param bool $federated
*
* @return StreamDetails
*/
public function setFederated(bool $federated): self {
$this->federated = $federated;
return $this;
}
/**
* @return array
*/
public function jsonSerialize(): array {
return [
'stream' => $this->getStream(),
'homeViewers' => $this->getHomeViewers(),
'directViewers' => $this->getDirectViewers(),
'public' => $this->isPublic(),
'federated' => $this->isFederated()
];
}
}