public function save() { $person = Person::where(Person::ATTR_NAME, $this->getName())->get()[0]; $person->slug = Util::createSlug($person->name); $person->biography = $this->getBiography(); $person->image = $this->getImage(); $person->save(); }
function getInfo($slug) { $person = Person::where(Person::ATTR_SLUG, $slug)->get()[0]; if (is_null($person->biography)) { abort(404); } $productions = $person->productions; $productions = Production::sortByState($productions); return view("frontend/contents/person/info")->with("person", $person)->with("productions", $productions); }
function getSearch($query) { $productions = Production::search($query); $persons = Person::search($query); foreach ($persons as $person) { $pros = $person->productions()->orderBy(Production::ATTR_STATE, "DESC")->get(); foreach ($pros as $pr) { $productions[] = $pr; } } $productions = Production::sortByState($productions); return view("frontend/contents/gen/search")->with("productions", $productions)->with("persons", $persons)->with("query", $query); }
private function cron() { \Event::listen('cron.collectJobs', function () { /** * CRON: Alimentación de cola de producciones * DESCRIPCION: Alimenta la cola de producciones que se van a procesar * EJECUCION: Cada 3 minutos */ \Cron::add(AutoProcess::CRON_PRODUCTIONS_FEED, '*/3 * * * *', function () { if (!AutoProcess::isActived(AutoProcess::CRON_PRODUCTIONS_FEED)) { return "Desactivado"; } $productionFeed = new ProductionFeed(); //Carga datos de producciones (peliculas) en el repositorio $productionFeed->loadRepository(); //Alimenta la cola de actualizaciones de peliculas $productionFeed->feedQueue(); return count($productionFeed->dataRepository) . " Producciones cargadas en cola"; }); /** * CRON: Seguimiento de produccion * DESCRIPCION: Toma las producciones en cola indicadas y las procesa obtienendo todos los datos de la produccion * EJECUCION: Cada minuto */ \Cron::add(AutoProcess::CRON_PRODUCTION_TRACK, '* * * * *', function () { if (!AutoProcess::isActived(AutoProcess::CRON_PRODUCTION_TRACK)) { return "Desactivado"; } $queue = QueueProductions::where(QueueProductions::ATTR_DATE_PROCESSED, null)->orderBy(QueueProductions::ATTR_ID, "ASC")->take(1)->get(); foreach ($queue as $production) { $provider = new ProductionProvider($production->name, $production->link); $production_id = $provider->save(); //Indica el registro como procesado. Esto ocasiona que la produccion ya no se vuelva a actualizar, hasta una nueva cola. $production->production_id = $production_id; $production->date_processed = DateUtil::getCurrentTime(); $production->save(); return $production->name . " Agregado"; } return "Sin cola"; }); /** * CRON: Seguimiento de persona * DESCRIPCION: Toma las personas indicadas y las procesa para obtener todos sus datos * EJECUCION: Cada minuto */ \Cron::add(AutoProcess::CRON_PERSON_TRACK, '* * * * *', function () { if (!AutoProcess::isActived(AutoProcess::CRON_PERSON_TRACK)) { return "Desactivado"; } $queue = QueuePersons::where(QueuePersons::ATTR_DATE_PROCESSED, null)->orderBy(QueuePersons::ATTR_ID, "DESC")->take(1)->get(); foreach ($queue as $person) { $provider = new PersonProvider($person->name, $person->link); $provider->save(); //Indica el registro como procesado. Esto ocasiona que la produccion ya no se vuelva a actualizar, hasta una nueva cola. $person->date_processed = DateUtil::getCurrentTime(); $person->save(); return $person->name . " Agregado"; } return "Sin cola"; }); /** * CRON: Envio de correo de notificacion de producciones disponibles * DESCRIPCION: Verifica todos las producciones en seguimientos por parte de los usuarios premium y cuando esten disponibles les envia un correo notificandoles * EJECUCION: Cada 12 horas */ \Cron::add(AutoProcess::CRON_USER_PRODUCTION_TRACK_SEND_MAIL, '0 */12 * * *', function () { if (!AutoProcess::isActived(AutoProcess::CRON_USER_PRODUCTION_TRACK_SEND_MAIL)) { return "Desactivado"; } //Obtiene todos los usuarios premium $users = User::where(User::ATTR_ROLE, User::ROLE_SUSCRIPTOR_PREMIUM)->get(); foreach ($users as $user) { //Obtiene las producciones que siguen que ya se encuentran disponibles y que no sean notificado por correo $productions = $user->tracks()->wherePivot(User::ATTR_TRACK_PIVOT_MAILED, 0)->where(Production::ATTR_STATE, Production::STATE_ACTIVE)->get(); if (count($productions) == 0) { continue; } if (count($productions) > 1) { $description_email = "<p>Este mensaje es para informate que varias producciones que te gustaria ver en nuestra plataforma ya se encuentran disponibles y las puedes ver cuando quieras.</p>" . "<div style='text-align:center;'>" . "<h2>Nuevas producciones disponibles para ti</h2>" . "</div>" . "<div style='text-align:center;'>"; } else { $description_email = "<p>Este mensaje es para informate que una producción que te gustaria ver en nuestra plataforma ya se encuentran disponible y la puede ver cuando quieras.</p>" . "<div style='text-align:center;'>" . "<h2>Nueva producción disponible para ti</h2>" . "</div>" . "<div style='text-align:center;'>"; } foreach ($productions as $production) { //Notifica las producciones disponibles asociadas $description_email .= "<a href='" . AutoProcess::URL_SITE . "production/" . $production->slug . "'><img width='192px' height='289px' style='margin: 0px 10px;' src='" . $production->image . "'></a>"; $production->pivot->mailed = 1; $production->pivot->save(); } $description_email .= "</div>"; //Envia el correo de notificacion del usuario $email = new Email(count($productions) > 1 ? "¡Hay varias producciones que te gustaria ver que ya estan disponible!" : "¡Una producción que te gustaria ver ya esta disponible!", $user[User::ATTR_EMAIL], [Email::VAR_NAME => $user->name, Email::VAR_DESCRIPTION => $description_email]); $email->queue(); } return "Notificaciones realizadas (Si aplican)"; }); /** * CRON: Genera el sitemap.xml del sitio * EJECUCION: Cada Semana */ \Cron::add(AutoProcess::CRON_GENERATE_SITEMAP, '0 0 * * 0', function () { //Url standards del sitio web $urls = array(AutoProcess::URL_SITE, AutoProcess::URL_SITE . "doc/terms", AutoProcess::URL_SITE . "doc/privacypolicy", AutoProcess::URL_SITE . "doc/cookies-policy", AutoProcess::URL_SITE . "doc/help", AutoProcess::URL_SITE . "catalogue"); $file = fopen(public_path("sitemap.xml"), "w"); fwrite($file, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" . PHP_EOL); fwrite($file, "<urlset xmlns=\"http://www.sitemaps.org/schemas/sitemap/0.9\"> " . PHP_EOL); for ($i = 0; $i < count($urls); $i++) { fwrite($file, "<url><loc>" . $urls[$i] . "</loc></url>" . PHP_EOL); } //Inserta las url de cada persona $persons = \App\System\Models\Person::whereNotNull(Person::ATTR_BIOGRAPHY)->get(); foreach ($persons as $person) { fwrite($file, "<url><loc>" . AutoProcess::URL_SITE . "person/" . $person->slug . "</loc></url>" . PHP_EOL); } //Inserta las url de todas las producciones $productions = Production::all(); foreach ($productions as $production) { fwrite($file, "<url><loc>" . AutoProcess::URL_SITE . "production/" . $production->slug . "</loc></url>" . PHP_EOL); } fwrite($file, "</urlset>" . PHP_EOL); fclose($file); return "Sitemap.xml generado (" . count($persons) . " Personas) (" . count($productions) . " Producciones)"; }); /** * CRON: Publica automaticamente una produccion programada * EJECUCION: Cada hora */ \Cron::add(AutoProcess::CRON_PRODUCTION_AUTO_PUBLISH, '0 */4 * * *', function () { $productions = Production::where(Production::ATTR_STATE, Production::STATE_PROGRAMMED)->orderBy(Production::ATTR_UPDATED_AT, "ASC")->take(1)->get(); foreach ($productions as $production) { $production->state = Production::STATE_ACTIVE; $production->save(); return $production->title . " Publicado"; } return "No hay producciones programadas"; }); }); }
public static function search($name, $take = 20) { return Person::where(self::ATTR_NAME, "LIKE", "%" . $name . "%")->whereNotNull(Person::ATTR_BIOGRAPHY)->take($take)->get(); }
function save() { if (!$this->validate()) { return null; } $production = new Production(); $production->title = $this->getTitle(); $production->title_original = $this->getTitle_original(); $production->year = $this->getYear(); $production->slug = $this->getSlug(); $production->description = $this->getDescription(); $production->state = is_null($this->getRating_rel()) ? Production::STATE_COMING_SOON : Production::STATE_IN_WAIT; $production->rating_rel = $this->getRating_rel(); $production->duration = $this->getDuration(); $production->image = $this->getImage(); $production->poster = $this->poster; $production->save(); //CATEGORIAS DE LA PRODUCCION $categories = $this->categories; foreach ($categories as $category) { //Verifica si ya existe la categoria, si no existe la crea y la asigna a la produccion $cat = Term::searchByName($category); if (is_null($term = $cat)) { $term = new Term(); $term->name = ucfirst(strtolower($category)); $term->taxonomy_id = Production::TAXONOMY_ID; $term->slug = Util::createSlug($category); $term->save(); } $production->terms()->attach($term->id); } //Relaciona un director con la producción a uno existente o lo crea sin o existe $director = $this->getDirector(); $staff_director = is_null($person = Person::searchByName($director[0])) ? new Person() : $person; $staff_director->name = $director[0]; $staff_director->slug = Util::createSlug($director[0]); $staff_director->save(); if (count(DB::select("SELECT * FROM staff WHERE production_id='" . $production->id . "' && person_id='" . $staff_director->id . "'")) == 0) { $staff_director->productions()->attach($production->id, array(Person::ATTR_PIVOT_ROLE => Person::ROLE_DIRECTOR)); } //Determina si el nombre del director se encuentra en cola para actualización, si no lo esta, lo agrega. if (is_null(QueuePersons::searchByNameInQueue($director[0]))) { $queue = new QueuePersons(); $queue->person_id = $staff_director->id; $queue->name = $director[0]; $queue->link = $director[1]; $queue->date_creation = DateUtil::getCurrentTime(); $queue->save(); } //Relaciona los actores con la produccion a uno existente o lo crea sino existe $actors = $this->actors; foreach ($actors as $actor) { if (is_null($actor[0]) || !isset($actor[0]) || strlen($actor[0]) == 0) { continue; } $staff_actor = is_null($person = Person::searchByName($actor[0])) ? new Person() : $person; $staff_actor->name = $actor[0]; $staff_actor->slug = Util::createSlug($actor[0]); $staff_actor->save(); if (count(DB::select("SELECT * FROM staff WHERE production_id='" . $production->id . "' && person_id='" . $staff_actor->id . "'")) == 0) { $staff_actor->productions()->attach($production->id, array(Person::ATTR_PIVOT_ROLE => Person::ROLE_ACTOR)); } //Determina si el nombre del actor/actriz se encuentra en cola para actualización, si no lo esta, lo agrega. if (is_null(QueuePersons::searchByNameInQueue($actor[0]))) { $queue = new QueuePersons(); $queue->person_id = $staff_actor->id; $queue->name = $actor[0]; $queue->link = $actor[1]; $queue->date_creation = DateUtil::getCurrentTime(); $queue->save(); } } return $production->id; }