AzuraCast/src/Entity/StationRequest.php
2019-09-29 02:50:24 -05:00

135 lines
2.4 KiB
PHP

<?php
namespace App\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
* @ORM\Table(name="station_requests")
* @ORM\Entity()
*/
class StationRequest
{
/**
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
* @var int
*/
protected $id;
/**
* @ORM\Column(name="station_id", type="integer")
* @var int
*/
protected $station_id;
/**
* @ORM\ManyToOne(targetEntity="Station", inversedBy="media")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="station_id", referencedColumnName="id", onDelete="CASCADE")
* })
* @var Station
*/
protected $station;
/**
* @ORM\Column(name="track_id", type="integer")
* @var int
*/
protected $track_id;
/**
* @ORM\ManyToOne(targetEntity="StationMedia")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="track_id", referencedColumnName="id", onDelete="CASCADE")
* })
* @var StationMedia
*/
protected $track;
/**
* @ORM\Column(name="timestamp", type="integer")
* @var int
*/
protected $timestamp;
/**
* @ORM\Column(name="played_at", type="integer")
* @var int
*/
protected $played_at;
/**
* @ORM\Column(name="ip", type="string", length=40)
* @var string
*/
protected $ip;
public function __construct(Station $station, StationMedia $track)
{
$this->station = $station;
$this->track = $track;
$this->timestamp = time();
$this->played_at = 0;
$this->ip = $_SERVER['REMOTE_ADDR'];
}
/**
* @return int
*/
public function getId(): int
{
return $this->id;
}
/**
* @return Station
*/
public function getStation(): Station
{
return $this->station;
}
/**
* @return StationMedia
*/
public function getTrack(): StationMedia
{
return $this->track;
}
/**
* @return int
*/
public function getTimestamp(): int
{
return $this->timestamp;
}
/**
* @return int
*/
public function getPlayedAt(): int
{
return $this->played_at;
}
/**
* @param int $played_at
*/
public function setPlayedAt(int $played_at)
{
$this->played_at = $played_at;
}
/**
* @return string
*/
public function getIp(): string
{
return $this->ip;
}
}