Ejemplo n.º 1
0
 function send($keyconnexion = null)
 {
     \model\simple\Utilisateur::authentificationPourRtorrent($keyconnexion);
     if (!\config\Conf::$user["user"]) {
         throw new \Exception("Non User");
     }
     $erreur = 1;
     $torrents = null;
     $clefunique = null;
     $typemedias = null;
     $status = "ok";
     /*
      * =================================================
      * Traitement Mediastorrent !!!!
      * =================================================
      */
     if (isset($_REQUEST["mediastorrent"])) {
         $tmpclefunique = null;
         for ($idtorrent = 0; $idtorrent < $_REQUEST["nbtorrents"]; $idtorrent++) {
             if (isset($_REQUEST["torrent" . $idtorrent . "addbibli"])) {
                 $typemedias[$_REQUEST["torrent" . $idtorrent . "hash"]] = $_REQUEST["torrent" . $idtorrent . "type"];
                 switch ($_REQUEST["torrent" . $idtorrent . "type"]) {
                     case 'film':
                         $clef = \model\mysql\Torrentfilm::getClefUnique();
                         $clefunique[$_REQUEST["torrent" . $idtorrent . "hash"]] = $clef;
                         for ($idfile = 0; $idfile < $_REQUEST["torrent" . $idtorrent . "nbfiles"]; $idfile++) {
                             if (isset($_REQUEST["torrent" . $idtorrent . "ajoutecheckfile" . $idfile]) && isset($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "recherche"])) {
                                 if ($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "recherche"] === "manuel") {
                                     //Manuel
                                     $titre = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "titre"]);
                                     $otitre = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "titreoriginal"]);
                                     $synopsis = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "synopsis"]);
                                     $genre = explode(",", $_REQUEST["torrent" . $idtorrent . "file" . $idfile . "genre"]);
                                     array_walk($genre, create_function('&$val', '$val = trim($val);'));
                                     array_walk($genre, create_function('&$val', '$val = strtolower($val);'));
                                     array_walk($genre, create_function('&$val', '$val = ucfirst($val);'));
                                     $acteurs = explode(",", $_REQUEST["torrent" . $idtorrent . "file" . $idfile . "acteur"]);
                                     array_walk($acteurs, create_function('&$val', '$val = trim($val);'));
                                     array_walk($acteurs, create_function('&$val', '$val = strtolower($val);'));
                                     array_walk($acteurs, create_function('&$val', '$val = ucwords($val);'));
                                     $acteurs = implode(", ", $acteurs);
                                     $realisateurs = explode(",", $_REQUEST["torrent" . $idtorrent . "file" . $idfile . "realisateur"]);
                                     array_walk($realisateurs, create_function('&$val', '$val = trim($val);'));
                                     array_walk($realisateurs, create_function('&$val', '$val = strtolower($val);'));
                                     array_walk($realisateurs, create_function('&$val', '$val = ucwords($val);'));
                                     $realisateurs = implode(", ", $realisateurs);
                                     $anneeprod = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "anneeprod"]);
                                     $urlposter = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "poster"]);
                                     $urlbackdrop = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "backdrop"]);
                                     $infos["Titre"] = $titre;
                                     $infos["Titre original"] = $otitre;
                                     $infos["Genre"] = implode(", ", $genre);
                                     $infos["Réalisateur(s)"] = $realisateurs;
                                     $infos["Acteur(s)"] = $acteurs;
                                     $infos["Année de production"] = $anneeprod;
                                     $infos["Synopsis"] = $synopsis;
                                     $film = \model\mysql\Film::ajouteFilm($titre, $otitre, json_encode($infos), $urlposter, $urlbackdrop, $anneeprod, $acteurs, $realisateurs);
                                     $idfilm = $film->id;
                                     $film->addGenre($genre);
                                 } else {
                                     //Auto
                                     if ($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "typerecherche"] === "local") {
                                         //Local
                                         $idfilm = $_REQUEST["torrent" . $idtorrent . "file" . $idfile . "code"];
                                     } else {
                                         //Allo
                                         $o["typesearch"] = "movie";
                                         $allo = new \model\simple\Allocine($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "code"], $o);
                                         $infos = $allo->retourneResMovieFormatForBD();
                                         $genre = $infos["Genre"];
                                         $infos["Genre"] = implode(", ", $genre);
                                         $titre = isset($infos["Titre"]) ? $infos["Titre"] : $infos["Titre original"];
                                         $otitre = $infos["Titre original"];
                                         $urlposter = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "poster"]);
                                         $urlbackdrop = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "backdrop"]);
                                         $realisateurs = $infos["Réalisateur(s)"];
                                         $acteurs = "";
                                         if (isset($infos["Acteur(s)"])) {
                                             $acteurs = $infos["Acteur(s)"];
                                         }
                                         $anneeprod = $infos["Année de production"];
                                         $film = \model\mysql\Film::ajouteFilm($titre, $otitre, json_encode($infos), $urlposter, $urlbackdrop, $anneeprod, $acteurs, $realisateurs, $_REQUEST["torrent" . $idtorrent . "file" . $idfile . "code"]);
                                         $idfilm = $film->id;
                                         $film->addGenre($genre);
                                     }
                                 }
                                 \model\mysql\Torrentfilm::addTorrentFilm($idfilm, $_REQUEST["torrent" . $idtorrent . "numfile" . $idfile], $_REQUEST["torrent" . $idtorrent . "filecomplement" . $idfile], \config\Conf::$user["user"]->login, \config\Conf::$nomrtorrent, $_REQUEST["torrent" . $idtorrent . "hash"], $clef, isset($_REQUEST["torrent" . $idtorrent . "partagecheckfile" . $idfile]));
                             }
                         }
                         break;
                     case 'serie':
                         $clef = \model\mysql\Torrentserie::getClefUnique();
                         $clefunique[$_REQUEST["torrent" . $idtorrent . "hash"]] = $clef;
                         for ($idfile = 0; $idfile < $_REQUEST["torrent" . $idtorrent . "nbfiles"]; $idfile++) {
                             if (isset($_REQUEST["torrent" . $idtorrent . "ajoutecheckfile" . $idfile]) && isset($_REQUEST["torrent" . $idtorrent . "filerecherche"])) {
                                 if ($_REQUEST["torrent" . $idtorrent . "filerecherche"] === "manuel") {
                                     //Manuel
                                     /**
                                      * Todo check $idfile, une série == un torrent, pareil pour les différents fichier le contenant différent du film
                                      */
                                     $titre = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "titre"]);
                                     $otitre = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "titreoriginal"]);
                                     $synopsis = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "synopsis"]);
                                     $genre = explode(",", $_REQUEST["torrent" . $idtorrent . "file" . $idfile . "genre"]);
                                     array_walk($genre, create_function('&$val', '$val = trim($val);'));
                                     array_walk($genre, create_function('&$val', '$val = strtolower($val);'));
                                     array_walk($genre, create_function('&$val', '$val = ucfirst($val);'));
                                     $acteurs = explode(",", $_REQUEST["torrent" . $idtorrent . "file" . $idfile . "acteur"]);
                                     array_walk($acteurs, create_function('&$val', '$val = trim($val);'));
                                     array_walk($acteurs, create_function('&$val', '$val = strtolower($val);'));
                                     array_walk($acteurs, create_function('&$val', '$val = ucwords($val);'));
                                     $acteurs = implode(", ", $acteurs);
                                     $realisateurs = explode(",", $_REQUEST["torrent" . $idtorrent . "file" . $idfile . "realisateur"]);
                                     array_walk($realisateurs, create_function('&$val', '$val = trim($val);'));
                                     array_walk($realisateurs, create_function('&$val', '$val = strtolower($val);'));
                                     array_walk($realisateurs, create_function('&$val', '$val = ucwords($val);'));
                                     $realisateurs = implode(", ", $realisateurs);
                                     $anneeprod = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "anneeprod"]);
                                     $urlposter = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "poster"]);
                                     $urlbackdrop = trim($_REQUEST["torrent" . $idtorrent . "file" . $idfile . "backdrop"]);
                                     $infos["Titre"] = $titre;
                                     $infos["Titre original"] = $otitre;
                                     $infos["Genre"] = implode(", ", $genre);
                                     $infos["Réalisateur(s)"] = $realisateurs;
                                     $infos["Acteur(s)"] = $acteurs;
                                     $infos["Année de production"] = $anneeprod;
                                     $infos["Synopsis"] = $synopsis;
                                     $serie = \model\mysql\Serie::ajouteSerie($titre, $otitre, json_encode($infos), $urlposter, $urlbackdrop, $anneeprod, $acteurs, $realisateurs);
                                     $idserie = $serie->id;
                                     $serie->addGenre($genre);
                                 } else {
                                     //Auto
                                     if ($_REQUEST["torrent" . $idtorrent . "filetyperecherche"] === "local") {
                                         //Local
                                         $idserie = $_REQUEST["torrent" . $idtorrent . "filecode"];
                                     } else {
                                         //Allo
                                         $o["typesearch"] = "tvseries";
                                         $allo = new \model\simple\Allocine($_REQUEST["torrent" . $idtorrent . "filecode"], $o);
                                         $infos = $allo->retourneResSerieFormatForBD();
                                         $genre = $infos["Genre"];
                                         $infos["Genre"] = implode(", ", $genre);
                                         $titre = isset($infos["Titre"]) ? $infos["Titre"] : $infos["Titre original"];
                                         $otitre = $infos["Titre original"];
                                         $urlposter = trim($_REQUEST["torrent" . $idtorrent . "fileposter"]);
                                         $urlbackdrop = trim($_REQUEST["torrent" . $idtorrent . "filebackdrop"]);
                                         $realisateurs = $infos["Réalisateur(s)"];
                                         $acteurs = "";
                                         if (isset($infos["Acteur(s)"])) {
                                             $acteurs = $infos["Acteur(s)"];
                                         }
                                         $anneeprod = $infos["Lancement"];
                                         $this->set("ICI", "Ok");
                                         $serie = \model\mysql\Serie::ajouteSerie($titre, $otitre, json_encode($infos), $urlposter, $urlbackdrop, $anneeprod, $acteurs, $realisateurs, $_REQUEST["torrent" . $idtorrent . "filecode"]);
                                         $idserie = $serie->id;
                                         $serie->addGenre($genre);
                                     }
                                 }
                                 \model\mysql\Torrentserie::addTorrentSerie($idserie, $_REQUEST["torrent" . $idtorrent . "numfile" . $idfile], $_REQUEST["torrent" . $idtorrent . "filecomplement" . $idfile], \config\Conf::$user["user"]->login, $_REQUEST["torrent" . $idtorrent . "filesaison" . $idfile], $_REQUEST["torrent" . $idtorrent . "fileepisode" . $idfile], \config\Conf::$nomrtorrent, $_REQUEST["torrent" . $idtorrent . "hash"], $clef, isset($_REQUEST["torrent" . $idtorrent . "partagecheckfile" . $idfile]));
                             }
                         }
                         break;
                 }
             }
         }
     }
     if (isset($_FILES['torrentfile']) && !(count($_FILES['torrentfile']) == 1 && $_FILES['torrentfile']['error'][0] != 4)) {
         if (is_array($_FILES['torrentfile']['name'])) {
             for ($i = 0; $i < count($_FILES['torrentfile']['name']); ++$i) {
                 $files[] = array('name' => $_FILES['torrentfile']['name'][$i], 'tmp_name' => $_FILES['torrentfile']['tmp_name'][$i], 'error' => $_FILES['torrentfile']['error'][$i]);
             }
         } else {
             $files[] = $_FILES['torrentfile'];
         }
         foreach ($files as $file) {
             $erreur = 0;
             $torrent = null;
             $torrent['erreur'] = 1;
             $torrent['nom'] = $file["name"];
             if (pathinfo($file["name"], PATHINFO_EXTENSION) != "torrent") {
                 $file["name"] .= ".torrent";
             }
             $des = DS . "tmp" . DS . $file["name"];
             $torrent['nom'] = $file["name"];
             $ok = move_uploaded_file($file['tmp_name'], $des);
             if ($ok) {
                 $to = new \model\simple\Torrent($des);
                 //$torrents[]= array($to->getFileName(),$to->info["name"]);
                 if ($to->errors()) {
                     $torrent['status'] = "Erreur du fichier torrent";
                 } else {
                     $torrent["status"] = \model\xmlrpc\rTorrent::sendTorrent($to, !isset($_REQUEST['autostart']), $_REQUEST['repertoire']);
                     $torrent["clefunique"] = \model\simple\String::random(10);
                     usleep(40000);
                     if ($torrent['status'][0] === '0') {
                         $req = new \model\xmlrpc\rXMLRPCRequest(\config\Conf::$userscgi, array(new \model\xmlrpc\rXMLRPCCommand(\config\Conf::$userscgi, "d.custom.set", array($to->hash_info(), "clefunique", $clefunique[$to->hash_info()])), new \model\xmlrpc\rXMLRPCCommand(\config\Conf::$userscgi, "d.custom.set", array($to->hash_info(), "typemedias", isset($typemedias[$to->hash_info()]) ? $typemedias[$to->hash_info()] : "aucun"))));
                         $torrent["clefuniqueres"] = $req->success() ? $req->val : $req->val;
                         if ($torrent["clefuniqueres"][0] === "0" && $torrent["clefuniqueres"][1] === "0") {
                             $torrent['erreur'] = 0;
                         }
                     }
                 }
                 unlink($des);
             } else {
                 $torrent['status'] = "Erreur lors de l'upload | Code d'erreur => " . $file["error"];
             }
             $torrents[] = $torrent;
         }
     } else {
         $status = "Pas de fichier envoyer";
     }
     $this->set(array("torrents" => $torrents, "erreur" => $erreur, "status" => $status, "seedbox" => \model\mysql\Rtorrent::getRtorrentsDeUtilisateur(\config\Conf::$user["user"]->login)));
 }
Ejemplo n.º 2
0
 function addFilm($id)
 {
     $o["typesearch"] = "movie";
     $allo = new \model\simple\Allocine($id, $o);
     $infos = $allo->retourneResMovieFormatForBD();
     $genre = $infos["Genre"];
     $infos["Genre"] = implode(", ", $genre);
     $titre = isset($infos["Titre"]) ? $infos["Titre"] : $infos["Titre original"];
     $otitre = $infos["Titre original"];
     $urlposter = "";
     $urlbackdrop = "";
     $realisateurs = $infos["Réalisateur(s)"];
     $acteurs = "";
     if (isset($infos["Acteur(s)"])) {
         $acteurs = $infos["Acteur(s)"];
     }
     $anneeprod = $infos["Année de production"];
     $film = \model\mysql\Film::ajouteFilm($titre, $otitre, json_encode($infos), $urlposter, $urlbackdrop, $anneeprod, $acteurs, $realisateurs, $id);
     $film->addGenre($genre);
     $film->addGenre("Comédiatation");
 }