Пример #1
0
 /**
  * Regenerate a torrent's file list from its meta data,
  * update the database record and clear relevant cache keys
  *
  * @param int $TorrentID
  */
 public static function regenerate_filelist($TorrentID)
 {
     $QueryID = G::$DB->get_query_id();
     G::$DB->query("\n\t\t\tSELECT tg.ID,\n\t\t\t\ttf.File\n\t\t\tFROM torrents_files AS tf\n\t\t\t\tJOIN torrents AS t ON t.ID = tf.TorrentID\n\t\t\t\tJOIN torrents_group AS tg ON tg.ID = t.GroupID\n\t\t\tWHERE tf.TorrentID = {$TorrentID}");
     if (G::$DB->has_results()) {
         list($GroupID, $Contents) = G::$DB->next_record(MYSQLI_NUM, false);
         if (Misc::is_new_torrent($Contents)) {
             $Tor = new BencodeTorrent($Contents);
             $FilePath = isset($Tor->Dec['info']['files']) ? Format::make_utf8($Tor->get_name()) : '';
         } else {
             $Tor = new TORRENT(unserialize(base64_decode($Contents)), true);
             $FilePath = isset($Tor->Val['info']->Val['files']) ? Format::make_utf8($Tor->get_name()) : '';
         }
         list($TotalSize, $FileList) = $Tor->file_list();
         foreach ($FileList as $File) {
             $TmpFileList[] = self::filelist_format_file($File);
         }
         $FileString = implode("\n", $TmpFileList);
         G::$DB->query("\n\t\t\t\tUPDATE torrents\n\t\t\t\tSET Size = {$TotalSize}, FilePath = '" . db_string($FilePath) . "', FileList = '" . db_string($FileString) . "'\n\t\t\t\tWHERE ID = {$TorrentID}");
         G::$Cache->delete_value("torrents_details_{$GroupID}");
     }
     G::$DB->set_query_id($QueryID);
 }
Пример #2
0
 $Name = $ExtraTorrent['Name'];
 $ExtraTorrentsInsert[$Name] = $ExtraTorrent;
 $ThisInsert =& $ExtraTorrentsInsert[$Name];
 $ExtraTor = new BencodeTorrent($Name, true);
 if (isset($ExtraTor->Dec['encrypted_files'])) {
     $Err = 'At least one of the torrents contain an encrypted file list which is not supported here';
     break;
 }
 if (!$ExtraTor->is_private()) {
     $ExtraTor->make_private();
     // The torrent is now private.
     $PublicTorrent = true;
 }
 // File list and size
 list($ExtraTotalSize, $ExtraFileList) = $ExtraTor->file_list();
 $ExtraDirName = isset($ExtraTor->Dec['info']['files']) ? Format::make_utf8($ExtraTor->get_name()) : '';
 $ExtraTmpFileList = array();
 foreach ($ExtraFileList as $ExtraFile) {
     list($ExtraSize, $ExtraName) = $ExtraFile;
     check_file($Type, $ExtraName);
     // Make sure the file name is not too long
     if (mb_strlen($ExtraName, 'UTF-8') + mb_strlen($ExtraDirName, 'UTF-8') + 1 > MAX_FILENAME_LENGTH) {
         $Err = "The torrent contained one or more files with too long of a name: <br />{$ExtraDirName}/{$ExtraName}";
         break;
     }
     // Add file and size to array
     $ExtraTmpFileList[] = Torrents::filelist_format_file($ExtraFile);
 }
 // To be stored in the database
 $ThisInsert['FilePath'] = db_string($ExtraDirName);
 $ThisInsert['FileString'] = db_string(implode("\n", $ExtraTmpFileList));