wallabag/src/Wallabag/CoreBundle/Entity/Entry.php

599 lines
11 KiB
PHP
Raw Normal View History

2015-01-22 16:18:56 +00:00
<?php
namespace Wallabag\CoreBundle\Entity;
2015-01-22 16:18:56 +00:00
2015-02-20 19:29:33 +00:00
use Doctrine\Common\Collections\ArrayCollection;
2015-01-22 16:18:56 +00:00
use Doctrine\ORM\Mapping as ORM;
use Hateoas\Configuration\Annotation as Hateoas;
2015-10-19 19:17:30 +00:00
use JMS\Serializer\Annotation\Groups;
use JMS\Serializer\Annotation\XmlRoot;
2016-03-13 19:17:52 +00:00
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;
2015-01-22 16:18:56 +00:00
/**
2015-05-30 11:52:26 +00:00
* Entry.
2015-01-22 16:18:56 +00:00
*
* @XmlRoot("entry")
2015-02-06 06:45:32 +00:00
* @ORM\Entity(repositoryClass="Wallabag\CoreBundle\Repository\EntryRepository")
* @ORM\Table(name="`entry`")
2015-02-04 21:25:44 +00:00
* @ORM\HasLifecycleCallbacks()
* @Hateoas\Relation("self", href = "expr('/api/entries/' ~ object.getId())")
2015-01-22 16:18:56 +00:00
*/
2015-02-06 06:45:32 +00:00
class Entry
2015-01-22 16:18:56 +00:00
{
/** @Serializer\XmlAttribute */
2015-01-22 16:18:56 +00:00
/**
2015-05-30 11:52:26 +00:00
* @var int
2015-01-22 16:18:56 +00:00
*
2015-02-06 06:45:32 +00:00
* @ORM\Column(name="id", type="integer")
2015-01-22 16:18:56 +00:00
* @ORM\Id
2015-02-04 21:25:44 +00:00
* @ORM\GeneratedValue(strategy="AUTO")
*
* @Groups({"entries_for_user", "export_all"})
2015-01-22 16:18:56 +00:00
*/
2015-02-06 06:45:32 +00:00
private $id;
2015-01-22 16:18:56 +00:00
/**
* @var string
*
* @ORM\Column(name="title", type="text", nullable=true)
*
* @Groups({"entries_for_user", "export_all"})
2015-01-22 16:18:56 +00:00
*/
private $title;
/**
* @var string
*
2015-01-23 13:58:17 +00:00
* @Assert\NotBlank()
2015-01-22 16:18:56 +00:00
* @ORM\Column(name="url", type="text", nullable=true)
*
* @Groups({"entries_for_user", "export_all"})
2015-01-22 16:18:56 +00:00
*/
private $url;
/**
2015-05-30 11:52:26 +00:00
* @var bool
2015-01-22 16:18:56 +00:00
*
* @Exclude
*
2015-02-06 06:45:32 +00:00
* @ORM\Column(name="is_archived", type="boolean")
*
* @Groups({"entries_for_user", "export_all"})
2015-01-22 16:18:56 +00:00
*/
2015-02-05 21:33:36 +00:00
private $isArchived = false;
2015-01-22 16:18:56 +00:00
/**
2015-05-30 11:52:26 +00:00
* @var bool
2015-01-22 16:18:56 +00:00
*
* @Exclude
*
2015-02-06 06:45:32 +00:00
* @ORM\Column(name="is_starred", type="boolean")
*
* @Groups({"entries_for_user", "export_all"})
2015-01-22 16:18:56 +00:00
*/
2015-02-05 21:33:36 +00:00
private $isStarred = false;
2015-01-22 16:18:56 +00:00
/**
* @var string
*
* @ORM\Column(name="content", type="text", nullable=true)
*
* @Groups({"entries_for_user", "export_all"})
2015-01-22 16:18:56 +00:00
*/
private $content;
2015-01-22 16:18:56 +00:00
2015-02-04 21:25:44 +00:00
/**
* @var date
*
2015-02-06 06:45:32 +00:00
* @ORM\Column(name="created_at", type="datetime")
*
* @Groups({"export_all"})
2015-02-04 21:25:44 +00:00
*/
private $createdAt;
/**
* @var date
*
2015-02-06 06:45:32 +00:00
* @ORM\Column(name="updated_at", type="datetime")
*
* @Groups({"export_all"})
2015-02-04 21:25:44 +00:00
*/
private $updatedAt;
/**
* @ORM\OneToMany(targetEntity="Wallabag\AnnotationBundle\Entity\Annotation", mappedBy="entry", cascade={"persist", "remove"})
* @ORM\JoinTable
*
* @Groups({"entries_for_user", "export_all"})
2015-02-04 21:25:44 +00:00
*/
private $annotations;
2015-02-04 21:25:44 +00:00
/**
* @var string
*
* @ORM\Column(name="mimetype", type="text", nullable=true)
*
* @Groups({"entries_for_user", "export_all"})
2015-02-04 21:25:44 +00:00
*/
private $mimetype;
2015-09-20 20:37:27 +00:00
/**
* @var string
*
* @ORM\Column(name="language", type="text", nullable=true)
*
* @Groups({"entries_for_user", "export_all"})
2015-09-20 20:37:27 +00:00
*/
private $language;
2015-02-04 21:25:44 +00:00
/**
2015-05-30 11:52:26 +00:00
* @var int
2015-02-04 21:25:44 +00:00
*
* @ORM\Column(name="reading_time", type="integer", nullable=true)
*
* @Groups({"entries_for_user", "export_all"})
2015-02-04 21:25:44 +00:00
*/
private $readingTime;
/**
* @var string
*
* @ORM\Column(name="domain_name", type="text", nullable=true)
*
* @Groups({"entries_for_user", "export_all"})
2015-02-04 21:25:44 +00:00
*/
private $domainName;
2015-08-24 10:27:17 +00:00
/**
* @var string
*
* @ORM\Column(name="preview_picture", type="text", nullable=true)
*
* @Groups({"entries_for_user", "export_all"})
2015-08-24 10:27:17 +00:00
*/
private $previewPicture;
2015-02-04 21:25:44 +00:00
/**
2015-05-30 11:52:26 +00:00
* @var bool
2015-02-04 21:25:44 +00:00
*
* @ORM\Column(name="is_public", type="boolean", nullable=true, options={"default" = false})
*
* @Groups({"export_all"})
2015-02-04 21:25:44 +00:00
*/
private $isPublic;
/**
2016-03-13 19:17:52 +00:00
* @Exclude
*
* @ORM\ManyToOne(targetEntity="Wallabag\UserBundle\Entity\User", inversedBy="entries")
*
* @Groups({"export_all"})
*/
private $user;
2015-02-20 19:29:33 +00:00
/**
* @ORM\ManyToMany(targetEntity="Tag", inversedBy="entries", cascade={"persist"})
* @ORM\JoinTable(
* name="entry_tag",
* joinColumns={
* @ORM\JoinColumn(name="entry_id", referencedColumnName="id")
* },
* inverseJoinColumns={
* @ORM\JoinColumn(name="tag_id", referencedColumnName="id")
* }
* )
*
* @Groups({"entries_for_user", "export_all"})
2015-02-20 19:29:33 +00:00
*/
private $tags;
/*
* @param User $user
*/
public function __construct(User $user)
{
$this->user = $user;
2015-02-20 19:29:33 +00:00
$this->tags = new ArrayCollection();
}
2015-01-22 16:18:56 +00:00
/**
2015-05-30 11:52:26 +00:00
* Get id.
2015-01-22 16:18:56 +00:00
*
2015-05-30 11:52:26 +00:00
* @return int
2015-01-22 16:18:56 +00:00
*/
public function getId()
{
return $this->id;
}
/**
2015-05-30 11:52:26 +00:00
* Set title.
*
* @param string $title
2015-01-22 16:18:56 +00:00
*
2015-02-06 06:45:32 +00:00
* @return Entry
2015-01-22 16:18:56 +00:00
*/
public function setTitle($title)
{
$this->title = $title;
return $this;
}
/**
2015-05-30 11:52:26 +00:00
* Get title.
2015-01-22 16:18:56 +00:00
*
2015-01-31 18:09:34 +00:00
* @return string
2015-01-22 16:18:56 +00:00
*/
public function getTitle()
{
return $this->title;
}
/**
2015-05-30 11:52:26 +00:00
* Set url.
*
* @param string $url
2015-01-22 16:18:56 +00:00
*
2015-02-06 06:45:32 +00:00
* @return Entry
2015-01-22 16:18:56 +00:00
*/
public function setUrl($url)
{
$this->url = $url;
return $this;
}
/**
2015-05-30 11:52:26 +00:00
* Get url.
2015-01-22 16:18:56 +00:00
*
2015-01-31 18:09:34 +00:00
* @return string
2015-01-22 16:18:56 +00:00
*/
public function getUrl()
{
return $this->url;
}
/**
2015-05-30 11:52:26 +00:00
* Set isArchived.
*
* @param bool $isArchived
2015-01-22 16:18:56 +00:00
*
2015-02-06 06:45:32 +00:00
* @return Entry
2015-01-22 16:18:56 +00:00
*/
2015-02-05 21:33:36 +00:00
public function setArchived($isArchived)
2015-01-22 16:18:56 +00:00
{
2015-02-05 21:33:36 +00:00
$this->isArchived = $isArchived;
2015-01-22 16:18:56 +00:00
return $this;
}
/**
2015-05-30 11:52:26 +00:00
* Get isArchived.
2015-01-22 16:18:56 +00:00
*
* @return bool
2015-01-22 16:18:56 +00:00
*/
2015-02-05 21:33:36 +00:00
public function isArchived()
2015-01-22 16:18:56 +00:00
{
2015-02-05 21:33:36 +00:00
return $this->isArchived;
2015-01-22 16:18:56 +00:00
}
/**
* @VirtualProperty
* @SerializedName("is_archived")
* @Groups({"entries_for_user", "export_all"})
*/
public function is_Archived()
{
return (int) $this->isArchived();
}
2015-01-23 11:45:24 +00:00
public function toggleArchive()
{
2015-02-05 21:33:36 +00:00
$this->isArchived = $this->isArchived() ^ 1;
2015-01-31 18:09:34 +00:00
2015-01-23 11:45:24 +00:00
return $this;
}
2015-01-22 16:18:56 +00:00
/**
2015-05-30 11:52:26 +00:00
* Set isStarred.
*
* @param bool $isStarred
2015-01-22 16:18:56 +00:00
*
2015-02-06 06:45:32 +00:00
* @return Entry
2015-01-22 16:18:56 +00:00
*/
2015-02-05 21:33:36 +00:00
public function setStarred($isStarred)
2015-01-22 16:18:56 +00:00
{
2015-02-05 21:33:36 +00:00
$this->isStarred = $isStarred;
2015-01-22 16:18:56 +00:00
return $this;
}
/**
2015-05-30 11:52:26 +00:00
* Get isStarred.
2015-01-22 16:18:56 +00:00
*
* @return bool
2015-01-22 16:18:56 +00:00
*/
2015-02-05 21:33:36 +00:00
public function isStarred()
2015-01-22 16:18:56 +00:00
{
2015-02-05 21:33:36 +00:00
return $this->isStarred;
2015-01-22 16:18:56 +00:00
}
/**
* @VirtualProperty
* @SerializedName("is_starred")
* @Groups({"entries_for_user", "export_all"})
*/
public function is_Starred()
{
return (int) $this->isStarred();
}
2015-01-23 11:45:24 +00:00
public function toggleStar()
{
2015-02-05 21:33:36 +00:00
$this->isStarred = $this->isStarred() ^ 1;
2015-01-23 11:45:24 +00:00
return $this;
}
2015-01-22 16:18:56 +00:00
/**
2015-05-30 11:52:26 +00:00
* Set content.
*
* @param string $content
2015-01-22 16:18:56 +00:00
*
2015-02-06 06:45:32 +00:00
* @return Entry
2015-01-22 16:18:56 +00:00
*/
public function setContent($content)
{
$this->content = $content;
return $this;
}
/**
2015-05-30 11:52:26 +00:00
* Get content.
2015-01-22 16:18:56 +00:00
*
2015-01-31 18:09:34 +00:00
* @return string
2015-01-22 16:18:56 +00:00
*/
public function getContent()
{
return $this->content;
}
/**
* @return User
2015-01-22 16:18:56 +00:00
*/
public function getUser()
2015-01-22 16:18:56 +00:00
{
return $this->user;
2015-01-22 16:18:56 +00:00
}
2015-02-04 16:54:23 +00:00
2016-03-13 19:17:52 +00:00
/**
* @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();
}
2015-02-04 21:25:44 +00:00
/**
2015-02-06 13:18:01 +00:00
* @return string
2015-02-04 21:25:44 +00:00
*/
public function getCreatedAt()
{
return $this->createdAt;
}
/**
* @return string
*/
public function getUpdatedAt()
{
return $this->updatedAt;
}
/**
2015-02-06 06:45:32 +00:00
* @ORM\PrePersist
2015-02-04 21:25:44 +00:00
* @ORM\PreUpdate
*/
2015-02-06 06:45:32 +00:00
public function timestamps()
2015-02-04 21:25:44 +00:00
{
2015-02-06 06:45:32 +00:00
if (is_null($this->createdAt)) {
$this->createdAt = new \DateTime();
}
2015-02-04 21:25:44 +00:00
$this->updatedAt = new \DateTime();
}
/**
* @return ArrayCollection<Annotation>
2015-02-04 21:25:44 +00:00
*/
public function getAnnotations()
2015-02-04 21:25:44 +00:00
{
return $this->annotations;
2015-02-04 21:25:44 +00:00
}
/**
* @param Annotation $annotation
2015-02-04 21:25:44 +00:00
*/
public function setAnnotation(Annotation $annotation)
2015-02-04 21:25:44 +00:00
{
$this->annotations[] = $annotation;
2015-02-04 21:25:44 +00:00
}
/**
* @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;
}
/**
2015-05-30 11:52:26 +00:00
* @return bool
2015-02-04 21:25:44 +00:00
*/
public function isPublic()
2015-02-04 21:25:44 +00:00
{
return $this->isPublic;
}
/**
2015-05-30 11:52:26 +00:00
* @param bool $isPublic
2015-02-04 21:25:44 +00:00
*/
public function setIsPublic($isPublic)
2015-02-04 21:25:44 +00:00
{
$this->isPublic = $isPublic;
}
2015-02-20 19:29:33 +00:00
/**
* @return ArrayCollection<Tag>
*/
public function getTags()
{
return $this->tags;
}
/**
* @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) {
2015-12-29 13:50:52 +00:00
if ($existingTag->getLabel() === $tag->getLabel()) {
return;
}
}
$this->tags->add($tag);
2015-02-24 06:42:09 +00:00
$tag->addEntry($this);
2015-02-20 19:29:33 +00:00
}
public function removeTag(Tag $tag)
{
if (!$this->tags->contains($tag)) {
return;
}
$this->tags->removeElement($tag);
$tag->removeEntry($this);
}
2015-08-24 10:27:17 +00:00
/**
2015-08-24 10:35:02 +00:00
* Set previewPicture.
2015-08-24 10:27:17 +00:00
*
* @param string $previewPicture
*
* @return Entry
*/
public function setPreviewPicture($previewPicture)
{
$this->previewPicture = $previewPicture;
return $this;
}
/**
2015-08-24 10:35:02 +00:00
* Get previewPicture.
2015-08-24 10:27:17 +00:00
*
* @return string
*/
public function getPreviewPicture()
{
return $this->previewPicture;
}
2015-09-20 20:37:27 +00:00
/**
* 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;
}
2015-01-22 16:18:56 +00:00
}