]> git.immae.eu Git - github/wallabag/wallabag.git/blame - src/Wallabag/CoreBundle/Entity/Entry.php
Export dates from entries
[github/wallabag/wallabag.git] / src / Wallabag / CoreBundle / Entity / Entry.php
CommitLineData
9d50517c
NL
1<?php
2
ad4d1caa 3namespace Wallabag\CoreBundle\Entity;
9d50517c 4
0a018fe0 5use Doctrine\Common\Collections\ArrayCollection;
9d50517c 6use Doctrine\ORM\Mapping as ORM;
0f006880 7use Hateoas\Configuration\Annotation as Hateoas;
268e9e72 8use JMS\Serializer\Annotation\Groups;
0f006880 9use JMS\Serializer\Annotation\XmlRoot;
7d1fdab2
TC
10use JMS\Serializer\Annotation\Exclude;
11use JMS\Serializer\Annotation\VirtualProperty;
12use JMS\Serializer\Annotation\SerializedName;
619cc453 13use Symfony\Component\Validator\Constraints as Assert;
1210dae1 14use Wallabag\UserBundle\Entity\User;
4dc87223 15use Wallabag\AnnotationBundle\Entity\Annotation;
9d50517c
NL
16
17/**
4346a860 18 * Entry.
9d50517c 19 *
0f006880 20 * @XmlRoot("entry")
be463487 21 * @ORM\Entity(repositoryClass="Wallabag\CoreBundle\Repository\EntryRepository")
bd0f3d32 22 * @ORM\Table(name="`entry`")
34d15eb4 23 * @ORM\HasLifecycleCallbacks()
0f006880 24 * @Hateoas\Relation("self", href = "expr('/api/entries/' ~ object.getId())")
9d50517c 25 */
be463487 26class Entry
9d50517c 27{
0f006880 28 /** @Serializer\XmlAttribute */
9d50517c 29 /**
4346a860 30 * @var int
9d50517c 31 *
be463487 32 * @ORM\Column(name="id", type="integer")
9d50517c 33 * @ORM\Id
34d15eb4 34 * @ORM\GeneratedValue(strategy="AUTO")
5b7da076
TC
35 *
36 * @Groups({"entries_for_user", "export_all"})
9d50517c 37 */
be463487 38 private $id;
9d50517c 39
f3d0cb91 40 /**
78b3c31d 41 * @var string
f3d0cb91
NL
42 *
43 * @ORM\Column(name="uuid", type="text", nullable=true)
44 *
45 * @Groups({"entries_for_user", "export_all"})
46 */
47 private $uuid;
48
9d50517c
NL
49 /**
50 * @var string
51 *
52 * @ORM\Column(name="title", type="text", nullable=true)
5b7da076
TC
53 *
54 * @Groups({"entries_for_user", "export_all"})
9d50517c
NL
55 */
56 private $title;
57
58 /**
59 * @var string
60 *
b84a8055 61 * @Assert\NotBlank()
9d50517c 62 * @ORM\Column(name="url", type="text", nullable=true)
5b7da076
TC
63 *
64 * @Groups({"entries_for_user", "export_all"})
9d50517c
NL
65 */
66 private $url;
67
68 /**
4346a860 69 * @var bool
9d50517c 70 *
189ef634
TC
71 * @Exclude
72 *
be463487 73 * @ORM\Column(name="is_archived", type="boolean")
5b7da076
TC
74 *
75 * @Groups({"entries_for_user", "export_all"})
9d50517c 76 */
905ae369 77 private $isArchived = false;
9d50517c
NL
78
79 /**
4346a860 80 * @var bool
9d50517c 81 *
189ef634
TC
82 * @Exclude
83 *
be463487 84 * @ORM\Column(name="is_starred", type="boolean")
5b7da076
TC
85 *
86 * @Groups({"entries_for_user", "export_all"})
9d50517c 87 */
905ae369 88 private $isStarred = false;
9d50517c 89
9d50517c
NL
90 /**
91 * @var string
92 *
eacaf7f8 93 * @ORM\Column(name="content", type="text", nullable=true)
5b7da076
TC
94 *
95 * @Groups({"entries_for_user", "export_all"})
9d50517c 96 */
eacaf7f8 97 private $content;
9d50517c 98
34d15eb4
NL
99 /**
100 * @var date
101 *
be463487 102 * @ORM\Column(name="created_at", type="datetime")
5b7da076 103 *
9401696f 104 * @Groups({"entries_for_user", "export_all"})
34d15eb4
NL
105 */
106 private $createdAt;
107
108 /**
109 * @var date
110 *
be463487 111 * @ORM\Column(name="updated_at", type="datetime")
5b7da076 112 *
9401696f 113 * @Groups({"entries_for_user", "export_all"})
34d15eb4
NL
114 */
115 private $updatedAt;
116
34d15eb4 117 /**
4dc87223 118 * @ORM\OneToMany(targetEntity="Wallabag\AnnotationBundle\Entity\Annotation", mappedBy="entry", cascade={"persist", "remove"})
f38e03dc 119 * @ORM\JoinTable
5b7da076 120 *
f38e03dc 121 * @Groups({"entries_for_user", "export_all"})
34d15eb4 122 */
4dc87223 123 private $annotations;
34d15eb4
NL
124
125 /**
126 * @var string
127 *
128 * @ORM\Column(name="mimetype", type="text", nullable=true)
5b7da076
TC
129 *
130 * @Groups({"entries_for_user", "export_all"})
34d15eb4
NL
131 */
132 private $mimetype;
133
98f0929f
JB
134 /**
135 * @var string
136 *
137 * @ORM\Column(name="language", type="text", nullable=true)
5b7da076
TC
138 *
139 * @Groups({"entries_for_user", "export_all"})
98f0929f
JB
140 */
141 private $language;
142
34d15eb4 143 /**
4346a860 144 * @var int
34d15eb4 145 *
26864574 146 * @ORM\Column(name="reading_time", type="integer", nullable=true)
5b7da076
TC
147 *
148 * @Groups({"entries_for_user", "export_all"})
34d15eb4
NL
149 */
150 private $readingTime;
151
152 /**
153 * @var string
154 *
155 * @ORM\Column(name="domain_name", type="text", nullable=true)
5b7da076
TC
156 *
157 * @Groups({"entries_for_user", "export_all"})
34d15eb4
NL
158 */
159 private $domainName;
160
fad31615
JB
161 /**
162 * @var string
163 *
164 * @ORM\Column(name="preview_picture", type="text", nullable=true)
5b7da076
TC
165 *
166 * @Groups({"entries_for_user", "export_all"})
fad31615
JB
167 */
168 private $previewPicture;
169
34d15eb4 170 /**
4346a860 171 * @var bool
34d15eb4
NL
172 *
173 * @ORM\Column(name="is_public", type="boolean", nullable=true, options={"default" = false})
5b7da076
TC
174 *
175 * @Groups({"export_all"})
34d15eb4
NL
176 */
177 private $isPublic;
178
5f09650e 179 /**
7d1fdab2
TC
180 * @Exclude
181 *
1210dae1 182 * @ORM\ManyToOne(targetEntity="Wallabag\UserBundle\Entity\User", inversedBy="entries")
5b7da076
TC
183 *
184 * @Groups({"export_all"})
5f09650e
NL
185 */
186 private $user;
187
0a018fe0 188 /**
af95c09c 189 * @ORM\ManyToMany(targetEntity="Tag", inversedBy="entries", cascade={"persist"})
e42b13bc
JB
190 * @ORM\JoinTable(
191 * name="entry_tag",
192 * joinColumns={
193 * @ORM\JoinColumn(name="entry_id", referencedColumnName="id")
194 * },
195 * inverseJoinColumns={
196 * @ORM\JoinColumn(name="tag_id", referencedColumnName="id")
197 * }
198 * )
5b7da076
TC
199 *
200 * @Groups({"entries_for_user", "export_all"})
0a018fe0
NL
201 */
202 private $tags;
203
5f09650e
NL
204 /*
205 * @param User $user
206 */
5d6f6f56 207 public function __construct(User $user)
5f09650e
NL
208 {
209 $this->user = $user;
0a018fe0 210 $this->tags = new ArrayCollection();
5f09650e
NL
211 }
212
9d50517c 213 /**
4346a860 214 * Get id.
9d50517c 215 *
4346a860 216 * @return int
9d50517c
NL
217 */
218 public function getId()
219 {
220 return $this->id;
221 }
222
223 /**
4346a860
JB
224 * Set title.
225 *
226 * @param string $title
9d50517c 227 *
be463487 228 * @return Entry
9d50517c
NL
229 */
230 public function setTitle($title)
231 {
232 $this->title = $title;
233
234 return $this;
235 }
236
237 /**
4346a860 238 * Get title.
9d50517c 239 *
7df80cb3 240 * @return string
9d50517c
NL
241 */
242 public function getTitle()
243 {
244 return $this->title;
245 }
246
247 /**
4346a860
JB
248 * Set url.
249 *
250 * @param string $url
9d50517c 251 *
be463487 252 * @return Entry
9d50517c
NL
253 */
254 public function setUrl($url)
255 {
256 $this->url = $url;
257
258 return $this;
259 }
260
261 /**
4346a860 262 * Get url.
9d50517c 263 *
7df80cb3 264 * @return string
9d50517c
NL
265 */
266 public function getUrl()
267 {
268 return $this->url;
269 }
270
271 /**
4346a860
JB
272 * Set isArchived.
273 *
8eedc8cf 274 * @param bool $isArchived
9d50517c 275 *
be463487 276 * @return Entry
9d50517c 277 */
905ae369 278 public function setArchived($isArchived)
9d50517c 279 {
905ae369 280 $this->isArchived = $isArchived;
9d50517c
NL
281
282 return $this;
283 }
284
285 /**
4346a860 286 * Get isArchived.
9d50517c 287 *
8eedc8cf 288 * @return bool
9d50517c 289 */
905ae369 290 public function isArchived()
9d50517c 291 {
905ae369 292 return $this->isArchived;
9d50517c
NL
293 }
294
189ef634
TC
295 /**
296 * @VirtualProperty
297 * @SerializedName("is_archived")
298 * @Groups({"entries_for_user", "export_all"})
299 */
300 public function is_Archived()
301 {
302 return (int) $this->isArchived();
303 }
304
163eae0b
NL
305 public function toggleArchive()
306 {
905ae369 307 $this->isArchived = $this->isArchived() ^ 1;
7df80cb3 308
163eae0b
NL
309 return $this;
310 }
311
9d50517c 312 /**
4346a860
JB
313 * Set isStarred.
314 *
8eedc8cf 315 * @param bool $isStarred
9d50517c 316 *
be463487 317 * @return Entry
9d50517c 318 */
905ae369 319 public function setStarred($isStarred)
9d50517c 320 {
905ae369 321 $this->isStarred = $isStarred;
9d50517c
NL
322
323 return $this;
324 }
325
326 /**
4346a860 327 * Get isStarred.
9d50517c 328 *
8eedc8cf 329 * @return bool
9d50517c 330 */
905ae369 331 public function isStarred()
9d50517c 332 {
905ae369 333 return $this->isStarred;
9d50517c
NL
334 }
335
189ef634
TC
336 /**
337 * @VirtualProperty
338 * @SerializedName("is_starred")
339 * @Groups({"entries_for_user", "export_all"})
340 */
341 public function is_Starred()
342 {
343 return (int) $this->isStarred();
344 }
345
163eae0b
NL
346 public function toggleStar()
347 {
905ae369 348 $this->isStarred = $this->isStarred() ^ 1;
163eae0b
NL
349
350 return $this;
351 }
352
9d50517c 353 /**
4346a860
JB
354 * Set content.
355 *
356 * @param string $content
9d50517c 357 *
be463487 358 * @return Entry
9d50517c
NL
359 */
360 public function setContent($content)
361 {
362 $this->content = $content;
363
364 return $this;
365 }
366
367 /**
4346a860 368 * Get content.
9d50517c 369 *
7df80cb3 370 * @return string
9d50517c
NL
371 */
372 public function getContent()
373 {
374 return $this->content;
375 }
376
377 /**
5f09650e 378 * @return User
9d50517c 379 */
5f09650e 380 public function getUser()
9d50517c 381 {
5f09650e 382 return $this->user;
9d50517c 383 }
42a90646 384
7d1fdab2
TC
385 /**
386 * @VirtualProperty
387 * @SerializedName("user_name")
388 */
389 public function getUserName()
390 {
391 return $this->user->getUserName();
392 }
393
394 /**
395 * @VirtualProperty
396 * @SerializedName("user_email")
397 */
398 public function getUserEmail()
399 {
400 return $this->user->getEmail();
401 }
402
403 /**
404 * @VirtualProperty
405 * @SerializedName("user_id")
406 */
407 public function getUserId()
408 {
409 return $this->user->getId();
410 }
411
34d15eb4 412 /**
2f69eb4a 413 * @return string
34d15eb4
NL
414 */
415 public function getCreatedAt()
416 {
417 return $this->createdAt;
418 }
419
34d15eb4
NL
420 /**
421 * @return string
422 */
423 public function getUpdatedAt()
424 {
425 return $this->updatedAt;
426 }
427
428 /**
be463487 429 * @ORM\PrePersist
34d15eb4
NL
430 * @ORM\PreUpdate
431 */
be463487 432 public function timestamps()
34d15eb4 433 {
be463487
NL
434 if (is_null($this->createdAt)) {
435 $this->createdAt = new \DateTime();
436 }
437
34d15eb4
NL
438 $this->updatedAt = new \DateTime();
439 }
440
441 /**
4dc87223 442 * @return ArrayCollection<Annotation>
34d15eb4 443 */
4dc87223 444 public function getAnnotations()
34d15eb4 445 {
4dc87223 446 return $this->annotations;
34d15eb4
NL
447 }
448
449 /**
4dc87223 450 * @param Annotation $annotation
34d15eb4 451 */
4dc87223 452 public function setAnnotation(Annotation $annotation)
34d15eb4 453 {
4dc87223 454 $this->annotations[] = $annotation;
34d15eb4
NL
455 }
456
457 /**
458 * @return string
459 */
460 public function getMimetype()
461 {
462 return $this->mimetype;
463 }
464
465 /**
466 * @param string $mimetype
467 */
468 public function setMimetype($mimetype)
469 {
470 $this->mimetype = $mimetype;
471 }
472
473 /**
474 * @return int
475 */
476 public function getReadingTime()
477 {
478 return $this->readingTime;
479 }
480
481 /**
482 * @param int $readingTime
483 */
484 public function setReadingTime($readingTime)
485 {
486 $this->readingTime = $readingTime;
487 }
488
489 /**
490 * @return string
491 */
492 public function getDomainName()
493 {
494 return $this->domainName;
495 }
496
497 /**
498 * @param string $domainName
499 */
500 public function setDomainName($domainName)
501 {
502 $this->domainName = $domainName;
503 }
504
505 /**
4346a860 506 * @return bool
34d15eb4 507 */
2c093b03 508 public function isPublic()
34d15eb4
NL
509 {
510 return $this->isPublic;
511 }
512
513 /**
4346a860 514 * @param bool $isPublic
34d15eb4 515 */
82d6d9cb 516 public function setIsPublic($isPublic)
34d15eb4
NL
517 {
518 $this->isPublic = $isPublic;
519 }
0a018fe0
NL
520
521 /**
522 * @return ArrayCollection<Tag>
523 */
524 public function getTags()
525 {
526 return $this->tags;
527 }
528
529 /**
530 * @param Tag $tag
531 */
532 public function addTag(Tag $tag)
533 {
625acf33
KG
534 if ($this->tags->contains($tag)) {
535 return;
536 }
537
fc031e57
JB
538 // check if tag already exist but has not yet be persisted
539 // it seems that the previous condition with `contains()` doesn't check that case
540 foreach ($this->tags as $existingTag) {
fc732227 541 if ($existingTag->getLabel() === $tag->getLabel()) {
fc031e57
JB
542 return;
543 }
544 }
545
e42b13bc 546 $this->tags->add($tag);
46bbd8d3 547 $tag->addEntry($this);
0a018fe0 548 }
092ca707
NL
549
550 public function removeTag(Tag $tag)
551 {
e42b13bc
JB
552 if (!$this->tags->contains($tag)) {
553 return;
554 }
555
092ca707 556 $this->tags->removeElement($tag);
e42b13bc 557 $tag->removeEntry($this);
092ca707 558 }
fad31615
JB
559
560 /**
a1413a3d 561 * Set previewPicture.
fad31615
JB
562 *
563 * @param string $previewPicture
564 *
565 * @return Entry
566 */
567 public function setPreviewPicture($previewPicture)
568 {
569 $this->previewPicture = $previewPicture;
570
571 return $this;
572 }
573
574 /**
a1413a3d 575 * Get previewPicture.
fad31615
JB
576 *
577 * @return string
578 */
579 public function getPreviewPicture()
580 {
581 return $this->previewPicture;
582 }
98f0929f
JB
583
584 /**
585 * Set language.
586 *
587 * @param string $language
588 *
589 * @return Entry
590 */
591 public function setLanguage($language)
592 {
593 $this->language = $language;
594
595 return $this;
596 }
597
598 /**
599 * Get language.
600 *
601 * @return string
602 */
603 public function getLanguage()
604 {
605 return $this->language;
606 }
f3d0cb91
NL
607
608 /**
78b3c31d 609 * @return string
f3d0cb91
NL
610 */
611 public function getUuid()
612 {
613 return $this->uuid;
614 }
615
616 /**
78b3c31d 617 * @param string $uuid
f3d0cb91
NL
618 *
619 * @return Entry
620 */
621 public function setUuid($uuid)
622 {
623 $this->uuid = $uuid;
624
625 return $this;
626 }
627
628 public function generateUuid()
629 {
eddda878 630 if (null === $this->uuid) {
a7e2218e
NL
631 // @see http://blog.kevingomez.fr/til/2015/07/26/why-is-uniqid-slow/ for true parameter
632 $this->uuid = uniqid('', true);
f3d0cb91
NL
633 }
634 }
f1be7af4
NL
635
636 public function cleanUuid()
637 {
638 $this->uuid = null;
639 }
9d50517c 640}