mirror of
https://github.com/wallabag/wallabag.git
synced 2025-04-27 12:14:42 +00:00
704 lines
13 KiB
PHP
704 lines
13 KiB
PHP
<?php
|
|
|
|
namespace Wallabag\CoreBundle\Entity;
|
|
|
|
use Doctrine\Common\Collections\ArrayCollection;
|
|
use Doctrine\ORM\Mapping as ORM;
|
|
use Hateoas\Configuration\Annotation as Hateoas;
|
|
use JMS\Serializer\Annotation\Groups;
|
|
use JMS\Serializer\Annotation\XmlRoot;
|
|
use JMS\Serializer\Annotation\Exclude;
|
|
use JMS\Serializer\Annotation\VirtualProperty;
|
|
use JMS\Serializer\Annotation\SerializedName;
|
|
use Symfony\Component\Validator\Constraints as Assert;
|
|
use Wallabag\UserBundle\Entity\User;
|
|
use Wallabag\AnnotationBundle\Entity\Annotation;
|
|
|
|
/**
|
|
* Entry.
|
|
*
|
|
* @XmlRoot("entry")
|
|
* @ORM\Entity(repositoryClass="Wallabag\CoreBundle\Repository\EntryRepository")
|
|
* @ORM\Table(
|
|
* name="`entry`",
|
|
* options={"collate"="utf8mb4_unicode_ci", "charset"="utf8mb4"},
|
|
* indexes={
|
|
* @ORM\Index(name="created_at", columns={"created_at"}),
|
|
* @ORM\Index(name="uid", columns={"uid"})
|
|
* }
|
|
* )
|
|
* @ORM\HasLifecycleCallbacks()
|
|
* @Hateoas\Relation("self", href = "expr('/api/entries/' ~ object.getId())")
|
|
*/
|
|
class Entry
|
|
{
|
|
/** @Serializer\XmlAttribute */
|
|
/**
|
|
* @var int
|
|
*
|
|
* @ORM\Column(name="id", type="integer")
|
|
* @ORM\Id
|
|
* @ORM\GeneratedValue(strategy="AUTO")
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $id;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @ORM\Column(name="uid", type="string", length=23, nullable=true)
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $uid;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @ORM\Column(name="title", type="text", nullable=true)
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $title;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @Assert\NotBlank()
|
|
* @ORM\Column(name="url", type="text", nullable=true)
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $url;
|
|
|
|
/**
|
|
* @var bool
|
|
*
|
|
* @Exclude
|
|
*
|
|
* @ORM\Column(name="is_archived", type="boolean")
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $isArchived = false;
|
|
|
|
/**
|
|
* @var bool
|
|
*
|
|
* @Exclude
|
|
*
|
|
* @ORM\Column(name="is_starred", type="boolean")
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $isStarred = false;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @ORM\Column(name="content", type="text", nullable=true)
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $content;
|
|
|
|
/**
|
|
* @var \DateTime
|
|
*
|
|
* @ORM\Column(name="created_at", type="datetime")
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $createdAt;
|
|
|
|
/**
|
|
* @var \DateTime
|
|
*
|
|
* @ORM\Column(name="updated_at", type="datetime")
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $updatedAt;
|
|
|
|
/**
|
|
* @ORM\OneToMany(targetEntity="Wallabag\AnnotationBundle\Entity\Annotation", mappedBy="entry", cascade={"persist", "remove"})
|
|
* @ORM\JoinTable
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $annotations;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @ORM\Column(name="mimetype", type="text", nullable=true)
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $mimetype;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @ORM\Column(name="language", type="text", nullable=true)
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $language;
|
|
|
|
/**
|
|
* @var int
|
|
*
|
|
* @ORM\Column(name="reading_time", type="integer", nullable=true)
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $readingTime;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @ORM\Column(name="domain_name", type="text", nullable=true)
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $domainName;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @ORM\Column(name="preview_picture", type="text", nullable=true)
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $previewPicture;
|
|
|
|
/**
|
|
* @var bool
|
|
*
|
|
* @ORM\Column(name="is_public", type="boolean", nullable=true, options={"default" = false})
|
|
*
|
|
* @Groups({"export_all"})
|
|
*/
|
|
private $isPublic;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @ORM\Column(name="http_status", type="string", length=3, nullable=true)
|
|
*
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
private $httpStatus;
|
|
|
|
/**
|
|
* @Exclude
|
|
*
|
|
* @ORM\ManyToOne(targetEntity="Wallabag\UserBundle\Entity\User", inversedBy="entries")
|
|
*
|
|
* @Groups({"export_all"})
|
|
*/
|
|
private $user;
|
|
|
|
/**
|
|
* @ORM\ManyToMany(targetEntity="Tag", inversedBy="entries", cascade={"persist"})
|
|
* @ORM\JoinTable(
|
|
* name="entry_tag",
|
|
* joinColumns={
|
|
* @ORM\JoinColumn(name="entry_id", referencedColumnName="id", onDelete="cascade")
|
|
* },
|
|
* inverseJoinColumns={
|
|
* @ORM\JoinColumn(name="tag_id", referencedColumnName="id", onDelete="cascade")
|
|
* }
|
|
* )
|
|
*/
|
|
private $tags;
|
|
|
|
/*
|
|
* @param User $user
|
|
*/
|
|
public function __construct(User $user)
|
|
{
|
|
$this->user = $user;
|
|
$this->tags = new ArrayCollection();
|
|
}
|
|
|
|
/**
|
|
* Get id.
|
|
*
|
|
* @return int
|
|
*/
|
|
public function getId()
|
|
{
|
|
return $this->id;
|
|
}
|
|
|
|
/**
|
|
* Set title.
|
|
*
|
|
* @param string $title
|
|
*
|
|
* @return Entry
|
|
*/
|
|
public function setTitle($title)
|
|
{
|
|
$this->title = $title;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get title.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getTitle()
|
|
{
|
|
return $this->title;
|
|
}
|
|
|
|
/**
|
|
* Set url.
|
|
*
|
|
* @param string $url
|
|
*
|
|
* @return Entry
|
|
*/
|
|
public function setUrl($url)
|
|
{
|
|
$this->url = $url;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get url.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getUrl()
|
|
{
|
|
return $this->url;
|
|
}
|
|
|
|
/**
|
|
* Set isArchived.
|
|
*
|
|
* @param bool $isArchived
|
|
*
|
|
* @return Entry
|
|
*/
|
|
public function setArchived($isArchived)
|
|
{
|
|
$this->isArchived = $isArchived;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get isArchived.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isArchived()
|
|
{
|
|
return $this->isArchived;
|
|
}
|
|
|
|
/**
|
|
* @VirtualProperty
|
|
* @SerializedName("is_archived")
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
public function is_Archived()
|
|
{
|
|
return (int) $this->isArchived();
|
|
}
|
|
|
|
public function toggleArchive()
|
|
{
|
|
$this->isArchived = $this->isArchived() ^ 1;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set isStarred.
|
|
*
|
|
* @param bool $isStarred
|
|
*
|
|
* @return Entry
|
|
*/
|
|
public function setStarred($isStarred)
|
|
{
|
|
$this->isStarred = $isStarred;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get isStarred.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isStarred()
|
|
{
|
|
return $this->isStarred;
|
|
}
|
|
|
|
/**
|
|
* @VirtualProperty
|
|
* @SerializedName("is_starred")
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
public function is_Starred()
|
|
{
|
|
return (int) $this->isStarred();
|
|
}
|
|
|
|
public function toggleStar()
|
|
{
|
|
$this->isStarred = $this->isStarred() ^ 1;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set content.
|
|
*
|
|
* @param string $content
|
|
*
|
|
* @return Entry
|
|
*/
|
|
public function setContent($content)
|
|
{
|
|
$this->content = $content;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get content.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getContent()
|
|
{
|
|
return $this->content;
|
|
}
|
|
|
|
/**
|
|
* @return User
|
|
*/
|
|
public function getUser()
|
|
{
|
|
return $this->user;
|
|
}
|
|
|
|
/**
|
|
* @VirtualProperty
|
|
* @SerializedName("user_name")
|
|
*/
|
|
public function getUserName()
|
|
{
|
|
return $this->user->getUserName();
|
|
}
|
|
|
|
/**
|
|
* @VirtualProperty
|
|
* @SerializedName("user_email")
|
|
*/
|
|
public function getUserEmail()
|
|
{
|
|
return $this->user->getEmail();
|
|
}
|
|
|
|
/**
|
|
* @VirtualProperty
|
|
* @SerializedName("user_id")
|
|
*/
|
|
public function getUserId()
|
|
{
|
|
return $this->user->getId();
|
|
}
|
|
|
|
/**
|
|
* Set created_at.
|
|
* Only used when importing data from an other service.
|
|
*
|
|
* @param \DateTime $createdAt
|
|
*
|
|
* @return Entry
|
|
*/
|
|
public function setCreatedAt(\DateTime $createdAt)
|
|
{
|
|
$this->createdAt = $createdAt;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* @return \DateTime
|
|
*/
|
|
public function getCreatedAt()
|
|
{
|
|
return $this->createdAt;
|
|
}
|
|
|
|
/**
|
|
* @return \DateTime
|
|
*/
|
|
public function getUpdatedAt()
|
|
{
|
|
return $this->updatedAt;
|
|
}
|
|
|
|
/**
|
|
* @ORM\PrePersist
|
|
* @ORM\PreUpdate
|
|
*/
|
|
public function timestamps()
|
|
{
|
|
if (is_null($this->createdAt)) {
|
|
$this->createdAt = new \DateTime();
|
|
}
|
|
|
|
$this->updatedAt = new \DateTime();
|
|
}
|
|
|
|
/**
|
|
* @return ArrayCollection<Annotation>
|
|
*/
|
|
public function getAnnotations()
|
|
{
|
|
return $this->annotations;
|
|
}
|
|
|
|
/**
|
|
* @param Annotation $annotation
|
|
*/
|
|
public function setAnnotation(Annotation $annotation)
|
|
{
|
|
$this->annotations[] = $annotation;
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
public function getMimetype()
|
|
{
|
|
return $this->mimetype;
|
|
}
|
|
|
|
/**
|
|
* @param string $mimetype
|
|
*/
|
|
public function setMimetype($mimetype)
|
|
{
|
|
$this->mimetype = $mimetype;
|
|
}
|
|
|
|
/**
|
|
* @return int
|
|
*/
|
|
public function getReadingTime()
|
|
{
|
|
return $this->readingTime;
|
|
}
|
|
|
|
/**
|
|
* @param int $readingTime
|
|
*/
|
|
public function setReadingTime($readingTime)
|
|
{
|
|
$this->readingTime = $readingTime;
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
public function getDomainName()
|
|
{
|
|
return $this->domainName;
|
|
}
|
|
|
|
/**
|
|
* @param string $domainName
|
|
*/
|
|
public function setDomainName($domainName)
|
|
{
|
|
$this->domainName = $domainName;
|
|
}
|
|
|
|
/**
|
|
* @return bool
|
|
*/
|
|
public function isPublic()
|
|
{
|
|
return $this->isPublic;
|
|
}
|
|
|
|
/**
|
|
* @param bool $isPublic
|
|
*/
|
|
public function setIsPublic($isPublic)
|
|
{
|
|
$this->isPublic = $isPublic;
|
|
}
|
|
|
|
/**
|
|
* @return ArrayCollection<Tag>
|
|
*/
|
|
public function getTags()
|
|
{
|
|
return $this->tags;
|
|
}
|
|
|
|
/**
|
|
* @VirtualProperty
|
|
* @SerializedName("tags")
|
|
* @Groups({"entries_for_user", "export_all"})
|
|
*/
|
|
public function getSerializedTags()
|
|
{
|
|
$data = [];
|
|
foreach ($this->tags as $tag) {
|
|
$data[] = $tag->getLabel();
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
/**
|
|
* @param Tag $tag
|
|
*/
|
|
public function addTag(Tag $tag)
|
|
{
|
|
if ($this->tags->contains($tag)) {
|
|
return;
|
|
}
|
|
|
|
// check if tag already exist but has not yet be persisted
|
|
// it seems that the previous condition with `contains()` doesn't check that case
|
|
foreach ($this->tags as $existingTag) {
|
|
if ($existingTag->getLabel() === $tag->getLabel()) {
|
|
return;
|
|
}
|
|
}
|
|
|
|
$this->tags->add($tag);
|
|
$tag->addEntry($this);
|
|
}
|
|
|
|
public function removeTag(Tag $tag)
|
|
{
|
|
if (!$this->tags->contains($tag)) {
|
|
return;
|
|
}
|
|
|
|
$this->tags->removeElement($tag);
|
|
$tag->removeEntry($this);
|
|
}
|
|
|
|
/**
|
|
* Set previewPicture.
|
|
*
|
|
* @param string $previewPicture
|
|
*
|
|
* @return Entry
|
|
*/
|
|
public function setPreviewPicture($previewPicture)
|
|
{
|
|
$this->previewPicture = $previewPicture;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get previewPicture.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getPreviewPicture()
|
|
{
|
|
return $this->previewPicture;
|
|
}
|
|
|
|
/**
|
|
* Set language.
|
|
*
|
|
* @param string $language
|
|
*
|
|
* @return Entry
|
|
*/
|
|
public function setLanguage($language)
|
|
{
|
|
$this->language = $language;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get language.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getLanguage()
|
|
{
|
|
return $this->language;
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
public function getUid()
|
|
{
|
|
return $this->uid;
|
|
}
|
|
|
|
/**
|
|
* @param string $uid
|
|
*
|
|
* @return Entry
|
|
*/
|
|
public function setUid($uid)
|
|
{
|
|
$this->uid = $uid;
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function generateUid()
|
|
{
|
|
if (null === $this->uid) {
|
|
// @see http://blog.kevingomez.fr/til/2015/07/26/why-is-uniqid-slow/ for true parameter
|
|
$this->uid = uniqid('', true);
|
|
}
|
|
}
|
|
|
|
public function cleanUid()
|
|
{
|
|
$this->uid = null;
|
|
}
|
|
|
|
/**
|
|
* @return int
|
|
*/
|
|
public function getHttpStatus()
|
|
{
|
|
return $this->httpStatus;
|
|
}
|
|
|
|
/**
|
|
* @param int $httpStatus
|
|
*
|
|
* @return Entry
|
|
*/
|
|
public function setHttpStatus($httpStatus)
|
|
{
|
|
$this->httpStatus = $httpStatus;
|
|
|
|
return $this;
|
|
}
|
|
}
|