Последняя версия с сервера прошлого разработчика
This commit is contained in:
52
app/Domain/Videos/Action/CreateVideoAction.php
Executable file
52
app/Domain/Videos/Action/CreateVideoAction.php
Executable file
@@ -0,0 +1,52 @@
|
||||
<?php
|
||||
namespace App\Domain\Videos\Action;
|
||||
|
||||
use App\Domain\Feeds\Models\Feed;
|
||||
use DB;
|
||||
use App\Domain\Feeds\ToFeedAction;
|
||||
use App\Domain\Videos\DataTransferObjects\VideoData;
|
||||
|
||||
class CreateVideoAction implements ToFeedAction
|
||||
{
|
||||
public function __invoke(VideoData $videoData)
|
||||
{
|
||||
DB::beginTransaction();
|
||||
|
||||
//$youtube_code = $videoData->youtube ? $this->getCodeYoutube($videoData->youtube) : '';
|
||||
|
||||
$videoFeed = Feed::create([
|
||||
'title' => $videoData->title,
|
||||
'body' => $videoData->body,
|
||||
'price' => $videoData->price,
|
||||
'is_paid' => $videoData->is_paid,
|
||||
'user_id' => $videoData->user->id,
|
||||
'type' => 'videos',
|
||||
'is_ads' => false,
|
||||
//'iframe_code' => $youtube_code,
|
||||
]);
|
||||
|
||||
foreach ($videoData->videos as $video) {
|
||||
$videoFeed->addMedia($video)->toMediaCollection('common');
|
||||
}
|
||||
if($videoData->is_loaded_preview){
|
||||
$videoFeed->addMedia($videoData->preview)->toMediaCollection('preview');
|
||||
}
|
||||
if($videoData->is_loaded_videos_paid){
|
||||
foreach ($videoData->videos_paid as $video) {
|
||||
$videoFeed->addMedia($video)->toMediaCollection('paid');
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
DB::commit();
|
||||
|
||||
return $videoFeed;
|
||||
}
|
||||
|
||||
private function getCodeYoutube($video)
|
||||
{
|
||||
$youtuberegexp = '/(?:youtube\.com\/(?:[^\/]+\/.+\/|(?:v|e(?:mbed)?)\/|.*[?&]v=)|youtu\.be\/)([^"&?\/\s]{11})/i';
|
||||
preg_match($youtuberegexp, $video, $matches);
|
||||
return @$matches[1];
|
||||
}
|
||||
}
|
||||
74
app/Domain/Videos/Action/UpdateVideoAction.php
Executable file
74
app/Domain/Videos/Action/UpdateVideoAction.php
Executable file
@@ -0,0 +1,74 @@
|
||||
<?php
|
||||
namespace App\Domain\Videos\Action;
|
||||
|
||||
use DB;
|
||||
use App\Domain\Feeds\Models\Feed;
|
||||
use App\Domain\Feeds\ToFeedAction;
|
||||
use App\Domain\Feeds\Enums\StatusEnum;
|
||||
use App\Domain\Videos\DataTransferObjects\VideoData;
|
||||
use Spatie\MediaLibrary\MediaCollections\Models\Media;
|
||||
|
||||
class UpdateVideoAction implements ToFeedAction
|
||||
{
|
||||
|
||||
public $videoFeed;
|
||||
|
||||
public function __construct(Feed $videoFeed)
|
||||
{
|
||||
$this->videoFeed = $videoFeed;
|
||||
}
|
||||
|
||||
public function __invoke(VideoData $videoData)
|
||||
{
|
||||
|
||||
$status = $this->videoFeed->status;
|
||||
if($status === StatusEnum::BANNED()){
|
||||
$status = StatusEnum::EDITABLE();
|
||||
}
|
||||
if($status === StatusEnum::APPROVED()){
|
||||
$status = StatusEnum::EDITABLE();
|
||||
}
|
||||
|
||||
DB::beginTransaction();
|
||||
$this->videoFeed->fill([
|
||||
'title' => $videoData->title,
|
||||
'body' => $videoData->body,
|
||||
'price' => $videoData->price,
|
||||
'is_paid' => $videoData->is_paid,
|
||||
'status' => $status,
|
||||
'is_ads' => false,
|
||||
])->save();
|
||||
|
||||
if($videoData->is_loaded_video){
|
||||
foreach ($videoData->videos as $video) {
|
||||
$this->videoFeed->addMedia($video)->toMediaCollection('common');
|
||||
}
|
||||
}
|
||||
|
||||
if($videoData->is_loaded_preview){
|
||||
if($existPreview = $this->videoFeed->getMedia('preview')->first()){
|
||||
$existPreview->delete();
|
||||
}
|
||||
$this->videoFeed->addMedia($videoData->preview)->toMediaCollection('preview');
|
||||
}
|
||||
if($videoData->is_loaded_videos_paid){
|
||||
foreach ($videoData->videos_paid as $video) {
|
||||
$this->videoFeed->addMedia($video)->toMediaCollection('paid');
|
||||
}
|
||||
}
|
||||
|
||||
if(count($videoData->removedItems)){
|
||||
foreach ($videoData->removedItems as $removedItem) {
|
||||
if($media = Media::find($removedItem)){
|
||||
$media->delete();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
DB::commit();
|
||||
|
||||
return $this->videoFeed->refresh();
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user