-
-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathMigrator.php
206 lines (179 loc) · 4.43 KB
/
Migrator.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
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
<?php
namespace Statamic\Migrator;
use Illuminate\Filesystem\Filesystem;
use Statamic\Facades\Path;
use Statamic\Migrator\Exceptions\AlreadyExistsException;
use Statamic\Support\Str;
abstract class Migrator
{
protected $handle;
protected $newPath;
protected $overwrite = false;
/**
* Instantiate migrator.
*
* @param string $handle
*/
public function __construct($handle)
{
$this->handle = $handle;
$this->files = app(Filesystem::class);
}
/**
* Instantiate migrator on handle.
*
* @param string $handle
* @return static
*/
public static function handle($handle)
{
return new static($handle);
}
/**
* Instantiate migrator without handle.
*
* @return static
*/
public static function withoutHandle()
{
return new static(null);
}
/**
* Get descriptor for use in command output.
*
* @return string
*/
public static function descriptor()
{
$extractedFromClassName = preg_replace('/.*\\\(\w+)Migrator$/', '$1', get_called_class());
return Str::modifyMultiple($extractedFromClassName, ['studlyToWords', 'ucfirst']);
}
/**
* Set whether files should be overwritten.
*
* @param bool $overwrite
* @return $this
*/
public function overwrite($overwrite)
{
$this->overwrite = $overwrite;
return $this;
}
/**
* Perform migration.
*/
abstract public function migrate();
/**
* Set new path.
*
* @param string $path
* @return $this
*/
protected function setNewPath($path)
{
$this->newPath = $path;
return $this;
}
/**
* Get site path.
*
* @param string|null $append
* @return string
*/
protected function sitePath($append = null)
{
return $this->normalizePath(collect([base_path('site'), $append])->filter()->implode('/'));
}
/**
* Get new path.
*
* @param string|null $append
* @return string
*/
protected function newPath($append = null)
{
return $this->normalizePath(collect([$this->newPath, $append])->filter()->implode('/'));
}
/**
* Normalize path to help prevent errors in Windows.
*
* @param string $path
* @return string
*/
protected function normalizePath($path)
{
return Path::resolve($path);
}
/**
* Validate unique.
*
* @return $this
*
* @throws AlreadyExistsException
*/
protected function validateUnique()
{
if ($this->overwrite) {
return $this;
}
$descriptor = static::descriptor();
collect($this->uniquePaths())
->map(function ($path) {
return Path::resolve($path);
})
->filter(function ($path) {
return $this->pathExists($path);
})
->each(function ($path) use ($descriptor) {
throw new AlreadyExistsException("{$descriptor} already exists at [path].", $path);
});
return $this;
}
/**
* Check if path exists (with files, if directory).
*
* @param mixed $path
*/
protected function pathExists($path)
{
$pathExists = $this->files->exists($path);
return $this->files->isDirectory($path)
? $pathExists && $this->files->files($path)
: $pathExists;
}
/**
* Specify unique paths that shouldn't be overwritten.
*
* @return array
*/
protected function uniquePaths()
{
return [
$this->newPath,
];
}
/**
* Copy directory from site path to new path.
*
* @param string $sitePath
* @param string|null $newPath
* @return $this
*/
protected function copyDirectoryFromSiteToNewPath($sitePath, $newPath = null)
{
$this->files->copyDirectory($this->sitePath($sitePath), $this->newPath($newPath));
return $this;
}
// /**
// * Copy file from site path to new path.
// *
// * @param string $sitePath
// * @param string|null $newPath
// * @return $this
// */
// protected function copyFileFromSiteToNewPath($sitePath, $newPath = null)
// {
// $this->files->copy($this->sitePath($sitePath), $this->newPath($newPath));
// return $this;
// }
}