|
5 | 5 | use Carbon\CarbonImmutable; |
6 | 6 | use Illuminate\Http\Response; |
7 | 7 | use Pterodactyl\Models\Server; |
| 8 | +use Illuminate\Http\JsonResponse; |
8 | 9 | use GuzzleHttp\Exception\TransferException; |
9 | 10 | use Pterodactyl\Services\Nodes\NodeJWTService; |
10 | 11 | use Illuminate\Contracts\Routing\ResponseFactory; |
|
17 | 18 | use Pterodactyl\Http\Requests\Api\Client\Servers\Files\DeleteFileRequest; |
18 | 19 | use Pterodactyl\Http\Requests\Api\Client\Servers\Files\RenameFileRequest; |
19 | 20 | use Pterodactyl\Http\Requests\Api\Client\Servers\Files\CreateFolderRequest; |
| 21 | +use Pterodactyl\Http\Requests\Api\Client\Servers\Files\CompressFilesRequest; |
20 | 22 | use Pterodactyl\Http\Requests\Api\Client\Servers\Files\GetFileContentsRequest; |
21 | 23 | use Pterodactyl\Http\Requests\Api\Client\Servers\Files\WriteFileContentRequest; |
22 | 24 |
|
@@ -90,7 +92,7 @@ public function listDirectory(ListFilesRequest $request, Server $server): array |
90 | 92 | */ |
91 | 93 | public function getFileContents(GetFileContentsRequest $request, Server $server): Response |
92 | 94 | { |
93 | | - return Response::create( |
| 95 | + return new Response( |
94 | 96 | $this->fileRepository->setServer($server)->getContent( |
95 | 97 | $request->get('file'), config('pterodactyl.files.max_edit_size') |
96 | 98 | ), |
@@ -136,79 +138,96 @@ public function download(GetFileContentsRequest $request, Server $server) |
136 | 138 | * |
137 | 139 | * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\WriteFileContentRequest $request |
138 | 140 | * @param \Pterodactyl\Models\Server $server |
139 | | - * @return \Illuminate\Http\Response |
| 141 | + * @return \Illuminate\Http\JsonResponse |
140 | 142 | */ |
141 | | - public function writeFileContents(WriteFileContentRequest $request, Server $server): Response |
| 143 | + public function writeFileContents(WriteFileContentRequest $request, Server $server): JsonResponse |
142 | 144 | { |
143 | 145 | $this->fileRepository->setServer($server)->putContent( |
144 | 146 | $request->get('file'), |
145 | 147 | $request->getContent() |
146 | 148 | ); |
147 | 149 |
|
148 | | - return Response::create('', Response::HTTP_NO_CONTENT); |
| 150 | + return new JsonResponse([], Response::HTTP_NO_CONTENT); |
149 | 151 | } |
150 | 152 |
|
151 | 153 | /** |
152 | 154 | * Creates a new folder on the server. |
153 | 155 | * |
154 | 156 | * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\CreateFolderRequest $request |
155 | 157 | * @param \Pterodactyl\Models\Server $server |
156 | | - * @return \Illuminate\Http\Response |
| 158 | + * @return \Illuminate\Http\JsonResponse |
157 | 159 | */ |
158 | | - public function createFolder(CreateFolderRequest $request, Server $server): Response |
| 160 | + public function createFolder(CreateFolderRequest $request, Server $server): JsonResponse |
159 | 161 | { |
160 | 162 | $this->fileRepository |
161 | 163 | ->setServer($server) |
162 | 164 | ->createDirectory($request->input('name'), $request->input('root', '/')); |
163 | 165 |
|
164 | | - return Response::create('', Response::HTTP_NO_CONTENT); |
| 166 | + return new JsonResponse([], Response::HTTP_NO_CONTENT); |
165 | 167 | } |
166 | 168 |
|
167 | 169 | /** |
168 | 170 | * Renames a file on the remote machine. |
169 | 171 | * |
170 | 172 | * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\RenameFileRequest $request |
171 | 173 | * @param \Pterodactyl\Models\Server $server |
172 | | - * @return \Illuminate\Http\Response |
| 174 | + * @return \Illuminate\Http\JsonResponse |
173 | 175 | */ |
174 | | - public function renameFile(RenameFileRequest $request, Server $server): Response |
| 176 | + public function renameFile(RenameFileRequest $request, Server $server): JsonResponse |
175 | 177 | { |
176 | 178 | $this->fileRepository |
177 | 179 | ->setServer($server) |
178 | 180 | ->renameFile($request->input('rename_from'), $request->input('rename_to')); |
179 | 181 |
|
180 | | - return Response::create('', Response::HTTP_NO_CONTENT); |
| 182 | + return new JsonResponse([], Response::HTTP_NO_CONTENT); |
181 | 183 | } |
182 | 184 |
|
183 | 185 | /** |
184 | 186 | * Copies a file on the server. |
185 | 187 | * |
186 | 188 | * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\CopyFileRequest $request |
187 | 189 | * @param \Pterodactyl\Models\Server $server |
188 | | - * @return \Illuminate\Http\Response |
| 190 | + * @return \Illuminate\Http\JsonResponse |
189 | 191 | */ |
190 | | - public function copyFile(CopyFileRequest $request, Server $server): Response |
| 192 | + public function copyFile(CopyFileRequest $request, Server $server): JsonResponse |
191 | 193 | { |
192 | 194 | $this->fileRepository |
193 | 195 | ->setServer($server) |
194 | 196 | ->copyFile($request->input('location')); |
195 | 197 |
|
196 | | - return Response::create('', Response::HTTP_NO_CONTENT); |
| 198 | + return new JsonResponse([], Response::HTTP_NO_CONTENT); |
| 199 | + } |
| 200 | + |
| 201 | + /** |
| 202 | + * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\CompressFilesRequest $request |
| 203 | + * @param \Pterodactyl\Models\Server $server |
| 204 | + * @return array |
| 205 | + */ |
| 206 | + public function compressFiles(CompressFilesRequest $request, Server $server): array |
| 207 | + { |
| 208 | + $file = $this->fileRepository->setServer($server) |
| 209 | + ->compressFiles( |
| 210 | + $request->input('root'), $request->input('files') |
| 211 | + ); |
| 212 | + |
| 213 | + return $this->fractal->item($file) |
| 214 | + ->transformWith($this->getTransformer(FileObjectTransformer::class)) |
| 215 | + ->toArray(); |
197 | 216 | } |
198 | 217 |
|
199 | 218 | /** |
200 | 219 | * Deletes a file or folder from the server. |
201 | 220 | * |
202 | 221 | * @param \Pterodactyl\Http\Requests\Api\Client\Servers\Files\DeleteFileRequest $request |
203 | 222 | * @param \Pterodactyl\Models\Server $server |
204 | | - * @return \Illuminate\Http\Response |
| 223 | + * @return \Illuminate\Http\JsonResponse |
205 | 224 | */ |
206 | | - public function delete(DeleteFileRequest $request, Server $server): Response |
| 225 | + public function delete(DeleteFileRequest $request, Server $server): JsonResponse |
207 | 226 | { |
208 | 227 | $this->fileRepository |
209 | 228 | ->setServer($server) |
210 | 229 | ->deleteFile($request->input('location')); |
211 | 230 |
|
212 | | - return Response::create('', Response::HTTP_NO_CONTENT); |
| 231 | + return new JsonResponse([], Response::HTTP_NO_CONTENT); |
213 | 232 | } |
214 | 233 | } |
0 commit comments