| Server IP : 54.94.228.101 / Your IP : 172.28.1.13 Web Server : Apache System : Linux ip-172-28-29-189 6.5.0-1014-aws #14~22.04.1-Ubuntu SMP Thu Feb 15 15:27:06 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.2.34-43+ubuntu22.04.1+deb.sury.org+1 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /var/www/html/vinumday2_0/app/Console/Commands/ |
Upload File : |
<?php
namespace App\Console\Commands;
use Symfony\Component\Console\Output\ConsoleOutput;
use Symfony\Component\Console\Helper\ProgressBar;
use Illuminate\Console\Command;
use App\Modules\Noticia\Models\Noticia;
use App\WpPost;
use App\Services\GeralService;
use Illuminate\Support\Facades\Log;
use DB;
class ImportaPosts extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'importa_posts';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Importa Posts Wordpress';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
$this->output = new ConsoleOutput;
}
/**
* Execute the console command.
*
* @return mixed
*/
public function handle()
{
$this->info(date('d/m/Y H:i:s') . " - START");
$posts = WpPost::where('post_type', 'post')->where('post_status', 'publish')->orderBy('ID', 'ASC')->get();
$progressBar = new ProgressBar($this->output, count($posts));
foreach ($posts as $post) {
$this->info(date('d/m/Y H:i:s') . " PostID: {$post->ID}" . "\n");
$Noticia = Noticia::where('nome', $post->post_title)->first();
if(!$Noticia){
$Noticia = new Noticia;
$Noticia->nome = $post->post_title;
$Noticia->descricao = $post->post_content;
$Noticia->slug = $post->post_name;
$Noticia->data = date('Y-m-d', strtotime($post->post_date));
$Noticia->data_completa = $post->post_date;
$Noticia->publicado = 1;
}else{
$Noticia->data_completa = $post->post_date;
}
$Noticia->save();
try {
//Busca Imagem Destaque
$postImage = WpPost::where('post_type', 'attachment')->where('post_parent', $post->ID)->whereRaw("post_mime_type LIKE '%image%'")->orderBy('ID', 'ASC')->first();
if($postImage && !empty($postImage->guid)){
$url_imagem = $postImage->guid;
$img = \Image::make($url_imagem);
$ext = explode("/", $url_imagem);
$filename = end($ext);
if($img->save(public_path() . '/uploads/noticia/' . $filename)){
$arquivo = GeralService::uploadFile(FALSE, 'noticia', ['filename' => $filename]);
if(!empty($arquivo->filename)){
$Noticia->thumbnail_principal = $arquivo->filename;
$Noticia->save();
}
}
}
} catch (\Intervention\Image\Exception\NotReadableException $ex) {
$progressBar->advance();
Log::info("PostID: {$post->ID} - " . $ex->getMessage());
Log::info("PostID: {$post->ID} - " . $postImage->guid);
$this->info(date('d/m/Y H:i:s') . " PostID: {$post->ID} - " . $ex->getMessage() . "\n");
continue;
} catch (Exception $e) {
$progressBar->advance();
Log::info("PostID: {$post->ID} - " . $e->getMessage());
Log::info("PostID: {$post->ID} - " . $postImage->guid);
$this->info(date('d/m/Y H:i:s') . " PostID: {$post->ID} - " . $ex->getMessage() . "\n");
continue;
}
$progressBar->advance();
}
$progressBar->finish();
$this->info(date('d/m/Y H:i:s') . " - DONE");
}
}