-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMediaResource.php
139 lines (119 loc) · 2.58 KB
/
MediaResource.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
<?php
namespace Perform\MediaBundle;
use Perform\UserBundle\Entity\User;
use Perform\MediaBundle\File\ParseResult;
/**
* A resource to be imported into the media library.
*
* @author Glynn Forrest <me@glynnforrest.com>
**/
class MediaResource
{
protected $path;
protected $isFile = false;
protected $name;
protected $owner;
protected $deleteAfterProcess = false;
protected $parseResult;
public function __construct($path, $name = null, User $owner = null)
{
$this->path = $path;
$this->name = $name ?: basename($path);
$this->owner = $owner;
}
/**
* Create a new resource, marking it as a file.
*/
public static function file($path, $name = null, User $owner = null)
{
$resource = new self($path, $name, $owner);
$resource->setFile(true);
return $resource;
}
/**
* @var string $path
*
* @return static
*/
public function setPath($path)
{
$this->path = $path;
return $this;
}
/**
* @return string
*/
public function getPath()
{
return $this->path;
}
/**
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* @return User|null
*/
public function getOwner()
{
return $this->owner;
}
/**
* Mark this resource as a file.
*
* @param bool $isFile
*
* @return static
*/
public function setFile($isFile)
{
$this->isFile = (bool) $isFile;
return $this;
}
/**
* @return bool
*/
public function isFile()
{
return $this->isFile;
}
public function deleteAfterProcess($delete = true)
{
$this->deleteAfterProcess = $delete;
}
/**
* Delete this resource, but only if it has been marked to be
* deleted after processing.
*
* Use deleteAfterProcess() to mark this resource for deletion.
*
* Nothing will happen if the resource is not a file.
*/
public function delete()
{
if (!$this->deleteAfterProcess || !$this->isFile()) {
return;
}
@unlink($this->path);
}
/**
* @param ParseResult $parseResult
*
* @return MediaResource
*/
public function setParseResult(ParseResult $parseResult)
{
$this->parseResult = $parseResult;
return $this;
}
/**
* @return ParseResult
*/
public function getParseResult()
{
return $this->parseResult ?: new ParseResult('', '', '');
}
}