Moved video files to public/videos directory, small refactoring.
This commit is contained in:
@@ -3,12 +3,11 @@
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Http\SymfonyCastDl\SymfonyCastDlService;
|
||||
use App\Models\Chapter;
|
||||
use App\Models\Course;
|
||||
|
||||
class ChapterController extends Controller
|
||||
{
|
||||
public function index(Course $course, int $chapter, SymfonyCastDlService $symfonyCastDlService)
|
||||
public function __invoke(Course $course, int $chapter, SymfonyCastDlService $symfonyCastDlService)
|
||||
{
|
||||
$chapter = $course->chapters->firstWhere('order', $chapter);
|
||||
|
||||
|
||||
18
app/Http/Controllers/Course/Sync.php
Normal file
18
app/Http/Controllers/Course/Sync.php
Normal file
@@ -0,0 +1,18 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Course;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Jobs\DownloadVideoFile;
|
||||
use App\Models\Course;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
|
||||
class Sync extends Controller
|
||||
{
|
||||
public function __invoke(Course $course): RedirectResponse
|
||||
{
|
||||
$course->chapters->each->update(['sync_offline' => 1]);
|
||||
$course->chapters->each(fn($chapter) => DownloadVideoFile::dispatch($chapter->id));
|
||||
return redirect()->back();
|
||||
}
|
||||
}
|
||||
@@ -11,16 +11,8 @@ use Illuminate\View\View;
|
||||
|
||||
class CourseController extends Controller
|
||||
{
|
||||
public function index(Course $course): View
|
||||
public function __invoke(Course $course): View
|
||||
{
|
||||
return view('course.index', compact('course'));
|
||||
}
|
||||
|
||||
public function sync(Course $course): \Illuminate\Http\RedirectResponse
|
||||
{
|
||||
$course->chapters->each->update(['sync_offline' => 1]);
|
||||
$course->chapters->each(fn($chapter) => DownloadVideoFile::dispatch($chapter->id));
|
||||
return redirect()->back();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -5,14 +5,19 @@ namespace App\Http\Controllers;
|
||||
use App\Http\SymfonyCastDl\HtmlParser;
|
||||
use App\Http\SymfonyCastDl\SymfonyCastDlService;
|
||||
use App\Models\Course;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class Index extends Controller
|
||||
{
|
||||
public function index(string $track = null)
|
||||
{
|
||||
$courses = Course::where('tracks', 'like', '%'.$track.'%')->with('chapters')->withCount('chapters')->get();
|
||||
|
||||
$courses = Course::where('tracks', 'like', '%' . $track . '%')->with('chapters')->withCount([
|
||||
'chapters',
|
||||
'chapters as chapters_to_sync' => function (Builder $query) {
|
||||
$query->where('sync_offline', 1);
|
||||
},
|
||||
])->get();
|
||||
return view('index', compact(['courses']));
|
||||
}
|
||||
|
||||
|
||||
@@ -18,11 +18,8 @@ class SymfonyCastDlService
|
||||
'base_uri' => config('symfonycast.base_url'),
|
||||
'cookies' => true
|
||||
]);
|
||||
|
||||
$response = $this->client->get('login');
|
||||
|
||||
$token = $htmlParser->getCsrfToken($response);
|
||||
|
||||
$this->client->post('login', [
|
||||
'form_params' => [
|
||||
'email' => config('symfonycast.login'),
|
||||
@@ -38,7 +35,6 @@ class SymfonyCastDlService
|
||||
public function getInfo(): void
|
||||
{
|
||||
$coursePage = $this->client->get('courses/filtering');
|
||||
|
||||
$courses = $this->htmlParser->getCourses($coursePage);
|
||||
$courses->each->save();
|
||||
/** @var Course $course */
|
||||
@@ -68,7 +64,7 @@ class SymfonyCastDlService
|
||||
return;
|
||||
}
|
||||
if (!is_dir($chapter->directory_path)) {
|
||||
mkdir($chapter->directory_path);
|
||||
mkdir(directory: $chapter->directory_path, recursive: true);
|
||||
}
|
||||
if (!$chapter->is_video_file) {
|
||||
$this->client->request(
|
||||
|
||||
Reference in New Issue
Block a user