ABTrack ported to nuke...

  Post new topicReply to topicPrintable Version
<< View previous topic View next topic >>
Share: Del.icio.us  Digg  Google  Spurl  Blink  Furl  Y! MyWeb  
#1   ABTrack ported to nuke...
KaZuyA
CZ Newbie
KaZuyA has been a member for over 17 year's 17 Year Member
Gender: Male
Status: Offline
Joined: Dec 29, 2006
0.00 posts per day
Posts: 2
Points: 25
   
Hey! I am trying for some time to port a phpbb mod to bbtonuke, but i have a small problem...Wish the experts can help me fix it..

The mod is called AB Track or Torrent Pier and is a torrent tracker for phpbb. I ported databases and configurations successfully to nuke.
First of all, i installed the mod in my original webpage. It is working fine but with this problem. Because i thought that the other mods and/or my theme may causing the problem i tried a fresh Forum module.

This mod requires the famous attach mod and the template.php of the eXtreme Styles mod, which caches the theme + some new "functions" you can use in the tpl theme files.

All the mod is working fine. When you attach a torrent file into your post it automatically register the torrent into the site's tracker+some ip and hash "checks"(private torrent explains what it does). if it fails you can manual register it after clicking a link that appears in the torrent attachment of your post.

The link is: mysite.com/modules.php?name=Forums&file=torrent&mode=reg&id=2&sid=17fa5bdd7388906abd91172064914285

What's the problem? Blank page!

Here's is the torrent.php

<?php

define('IN_PHPBB', true);
$phpbb_root_path = './';
include($phpbb_root_path .'extension.inc');
include($phpbb_root_path .'common.'.$phpEx);
include_once($phpbb_root_path .'includes/functions_torrent.'.$phpEx);

// Start session management
$userdata = session_pagestart($user_ip, PAGE_INDEX);
init_userprefs($userdata);

$user_id = $userdata['user_id'];

// Check if user logged in
if (!$userdata['session_logged_in'])
{
   redirect(append_sid("login.$phpEx?redirect=index.$phpEx", TRUE));
}

$sid = (isset($_REQUEST['sid'])) ? $_REQUEST['sid'] : '';
$confirm = (isset($HTTP_POST_VARS['confirm'])) ? TRUE : FALSE;

// Set received variables
// Strings
$input_vars_str  = array(
   'mode' => 'mode'
);

// Numeric
$input_vars_num = array(
   'attach_id' => 'id',
   'req_uid' => 'u'
);

// Strings
foreach ($input_vars_str as $var => $param)
{
   $$var = (isset($_REQUEST[$param])) ? $_REQUEST[$param] : '';
}
// Numeric
foreach ($input_vars_num as $var => $param)
{
   $$var = (isset($_REQUEST[$param])) ? intval($_REQUEST[$param]) : '';
}

if (isset($HTTP_POST_VARS['del_torrent']))
{
   $mode = 'del';
}
else if (isset($HTTP_POST_VARS['del_torrent_move_topic']))
{
   $mode = 'del_move';
}

if (($mode == 'reg' || $mode == 'unreg' || $mode == 'del' || $mode == 'del_move') && !$attach_id)
{
   message_die(GENERAL_ERROR, 'Invalid attach_id');
}

// Show users torrent-profile
if ($mode == 'userprofile')
{
   redirect(append_sid("profile.$phpEx?mode=viewprofile&u=$req_uid"), TRUE);
}

// check SID
if ($sid == '' || $sid !== $userdata['session_id'])
{
   message_die(GENERAL_ERROR, 'Invalid_session');
}

// Register torrent on tracker
if ($mode == 'reg')
{
   tracker_register($attach_id, 'request');
   exit;
}

// Unregister torrent from tracker
if ($mode == 'unreg')
{
   tracker_unregister($attach_id, 'request');
   exit;
}

// Delete torrent
if ($mode == 'del' && $confirm)
{
   delete_torrent($attach_id, 'request');
   $redirect_url = append_sid("viewtopic.$phpEx?".POST_TOPIC_URL."=$topic_id");
   redirect($redirect_url);
}

// Delete torrent and move topic
if ($mode == 'del_move' && $confirm)
{
   delete_torrent($attach_id, 'request');

   $redirect_url = "modcp.$phpEx?".POST_TOPIC_URL."=$topic_id&mode=move&sid=". $userdata['session_id'];
   redirect($redirect_url);
}

message_die(GENERAL_ERROR, 'Not confirmed or invalid mode');

?>


Notice that the file is sometype of "independent". Common.php that is included hasn't got any changes the function_torrent.php is included in the mod pkg and here it is:


<?php

function get_torrent_info ($attach_id)
{
   global $db;

   $attach_id = intval($attach_id);

   $sql = 'SELECT a.post_id, a.privmsgs_id, d.physical_filename, d.extension, d.tracker_status, t.topic_first_post_id, p.poster_id, p.topic_id, p.forum_id, f.allow_reg_tracker
      FROM '. ATTACHMENTS_TABLE .' a, '. ATTACHMENTS_DESC_TABLE .' d, '. POSTS_TABLE .' p, '. TOPICS_TABLE .' t, '. FORUMS_TABLE ." f
      WHERE a.attach_id = $attach_id
         AND d.attach_id = $attach_id
         AND p.post_id = a.post_id
         AND t.topic_id = p.topic_id
         AND f.forum_id = p.forum_id
      LIMIT 1";

   if (!$result = $db->sql_query($sql))
   {
      message_die(GENERAL_ERROR, 'Could not query torrent information', '', __LINE__, __FILE__, $sql);
   }

   if (!$torrent = $db->sql_fetchrow($result))
   {
      message_die(GENERAL_ERROR, 'Invalid attach_id');
   }

   $db->sql_freeresult($result);

   return $torrent;
}

function torrent_auth_check ($forum_id, $poster_id)
{
   global $userdata, $lang, $attach_config;

   if ($userdata['user_level'] == ADMIN)
   {
      return TRUE;
   }
   else
   {
      $is_auth = auth(AUTH_ALL, $forum_id, $userdata);

      if ($poster_id != $userdata['user_id'] && !$is_auth['auth_mod'])
      {
         message_die(GENERAL_MESSAGE, $lang['Not_Moderator'], $lang['Not_Authorised']);
      }
      else if (!$is_auth['auth_view'] || !$is_auth['auth_attachments'] || $attach_config['disable_mod'])
      {
         $message = sprintf($lang['Sorry_auth_read'], $is_auth['auth_read_type']);
         message_die(GENERAL_MESSAGE, $message);
      }

      return $is_auth;
   }
}

function tracker_unregister ($attach_id, $mode = '')
{
   global $db, $lang, $board_config;

   $attach_id = intval($attach_id);
   $torrent = array();
   $post_id = $topic_id = $forum_id = '';


   if ($torrent = get_torrent_info($attach_id))
   {
      $post_id  = $torrent['post_id'];
      $topic_id = $torrent['topic_id'];
      $forum_id = $torrent['forum_id'];
   }

   if ($mode == 'request')
   {
      if (!$torrent)
      {
         message_die(GENERAL_ERROR, 'Torrent not found');
      }

      if (!$torrent['tracker_status'])
      {
         message_die(GENERAL_ERROR, 'Torrent already unregistered');
      }

      torrent_auth_check($forum_id, $torrent['poster_id']);
   }

   // Unset DL-Type for topic
   if ($board_config['bt_unset_dltype_on_tor_unreg'])
   {
      if (!$topic_id)
      {
         $sql = 'SELECT topic_id
            FROM '. BT_TORRENTS_TABLE ."
            WHERE attach_id = $attach_id";

         if (!$result = $db->sql_query($sql))
         {
            message_die(GENERAL_ERROR, 'Could not query torrent information', '', __LINE__, __FILE__, $sql);
         }

         if ($row = $db->sql_fetchrow($result))
         {
            $topic_id = $row['topic_id'];
         }
      }

      if ($topic_id)
      {
         $sql = 'UPDATE '. TOPICS_TABLE .' SET
               topic_dl_type = '. TOPIC_DL_TYPE_NORMAL ."
            WHERE topic_id = $topic_id
            LIMIT 1";

         if (!$result = $db->sql_query($sql))
         {
            message_die(GENERAL_ERROR, 'Could not update topics table', '', __LINE__, __FILE__, $sql);
         }
      }
   }

   $sql = 'DELETE FROM '. BT_TORRENTS_TABLE ."
      WHERE attach_id = $attach_id";

   if (!$db->sql_query($sql))
   {
      message_die(GENERAL_ERROR, 'Could not delete torrent from torrents table', '', __LINE__, __FILE__, $sql);
   }

   $sql = 'DELETE FROM '. BT_TOR_DL_STAT_TABLE ."
      WHERE attach_id = $attach_id";

   if (!$db->sql_query($sql))
   {
      message_die(GENERAL_ERROR, 'Could not delete torrent dl-stat', '', __LINE__, __FILE__, $sql);
   }

   $sql = 'UPDATE '. ATTACHMENTS_DESC_TABLE ." SET
         tracker_status = 0
      WHERE attach_id = $attach_id";

   if (!$db->sql_query($sql))
   {
      message_die(GENERAL_ERROR, 'Could not update torrent status', '', __LINE__, __FILE__, $sql);
   }

   if ($mode == 'request')
   {
      exit_redirect($lang['Bt_Deleted'], $post_id, $forum_id);
   }
}

function delete_torrent ($attach_id, $mode = '')
{
   global $phpEx, $lang, $userdata;
   global $reg_mode, $topic_id;

   $attach_id = intval($attach_id);
   $reg_mode = $mode;

   if (!$torrent = get_torrent_info($attach_id))
   {
      message_die(GENERAL_ERROR, 'Torrent not found');
   }

   $post_id   = $torrent['post_id'];
   $topic_id  = $torrent['topic_id'];
   $forum_id  = $torrent['forum_id'];
   $poster_id = $torrent['poster_id'];

   if ($torrent['extension'] !== TORRENT_EXT)
   {
      message_die(GENERAL_ERROR, $lang['Not_torrent']);
   }

   torrent_auth_check($forum_id, $torrent['poster_id']);
   tracker_unregister($attach_id);
   delete_attachment(0, $attach_id);

   return;
}

function tracker_register ($attach_id, $mode = '')
{
   global $phpEx, $db, $template, $attach_config, $board_config, $phpbb_root_path, $lang, $return_message;
   global $reg_mode;

   $template->assign_vars(array('META' => ''));
   $attach_id = intval($attach_id);
   $reg_mode = $mode;

   if (!$torrent = get_torrent_info($attach_id))
   {
      message_die(GENERAL_ERROR, 'Torrent not found');
   }

   $post_id   = $torrent['post_id'];
   $topic_id  = $torrent['topic_id'];
   $forum_id  = $torrent['forum_id'];
   $poster_id = $torrent['poster_id'];

   if ($torrent['extension'] !== TORRENT_EXT)
   {
      torrent_error_exit($lang['Not_torrent']);
   }

   if ($torrent['privmsgs_id'])
   {
      torrent_error_exit('Not allowed in PM');
   }

   if (!$torrent['allow_reg_tracker'])
   {
      torrent_error_exit($lang['Reg_not_allowed_in_this_forum']);
   }

   if ($post_id != $torrent['topic_first_post_id'])
   {
      torrent_error_exit($lang['Allowed_only_1st_post_reg']);
   }

   if ($torrent['tracker_status'])
   {
      torrent_error_exit($lang['Already_reg']);
   }

   if ($this_topic_torrents = get_registered_torrents($topic_id, 'topic'))
   {
      torrent_error_exit($lang['Only_1_tor_per_topic']);
   }

   torrent_auth_check($forum_id, $torrent['poster_id']);

   $filename = $phpbb_root_path . $attach_config['upload_dir'] .'/'. $torrent['physical_filename'];

   if (!is_file($filename))
   {
      torrent_error_exit('File name error');
   }

   if (!file_exists($filename))
   {
      torrent_error_exit('File not exists');
   }

   if (!$tor = bdecode_file($filename))
   {
      torrent_error_exit('This is not a bencoded file');
   }

   if ($board_config['bt_check_announce_url'])
   {
      include_once($phpbb_root_path .'includes/torrent_announce_urls.'.$phpEx);

      $ann = (@$tor['announce']) ? $tor['announce'] : '';
      $announce_urls['main_url'] = $board_config['bt_announce_url'];

      if (!$ann || !in_array($ann, $announce_urls))
      {
         $mess = sprintf($lang['Invalid_ann_url'], htmlspecialchars($ann), $announce_urls['main_url']);
         torrent_error_exit($mess);
      }
   }

   $info = (@$tor['info']) ? $tor['info'] : array();

   if (!@$info['name'] || !@$info['piece length'] || !@$info['pieces'] || strlen($info['pieces']) % 20 != 0)
   {
      torrent_error_exit('Invalid torrent file');
   }

   $totallen = floatval(0);

   if (@$info['length'])
   {
      $totallen += $info['length'];
   }
   else if (@$info['files'] && is_array($info['files']))
   {
      foreach ($info['files'] as $fn => $f)
      {
         $totallen += $f['length'];
      }
   }
   else
   {
      torrent_error_exit('Invalid torrent file');
   }

   $size = sprintf('%.0f', $totallen);
   $piece_length = sprintf('%.0f', floatval($info['piece length']));

   $reg_time = time();

   $info_hash     = pack("H*", sha1(bencode($info)));
   $info_hash_md5 = strtolower(md5($info_hash));
   $info_hash_sql = rtrim(bt_sql_esc($info_hash), ' ');

   $columns = ' info_hash,       post_id,  poster_id,  topic_id,  attach_id,   size,    piece_length,   reg_time';
   $values = "'$info_hash_sql', $post_id, $poster_id, $topic_id, $attach_id, '$size', '$piece_length', $reg_time";

   $sql = 'INSERT INTO '. BT_TORRENTS_TABLE ." ($columns) VALUES ($values)";

   if (!$db->sql_query($sql))
   {
      $sql_error = $db->sql_error();

      if ($sql_error['code'] == 1062) // Duplicate entry
      {
         torrent_error_exit($lang['Bt_Reg_fail_same_hash']);
      }

      message_die(GENERAL_ERROR, 'Could not register torrent on tracker', '', __LINE__, __FILE__, $sql);
   }

/*
   // Insert empty up/down "statistic record" for guests
   $torrent_id = $db->sql_nextid();
   $guest_uid  = ANONYMOUS;

   $columns = 'torrent_id,  user_id,    attach_id, t_up_total, t_down_total';
   $values = "$torrent_id, $guest_uid, $attach_id, 0,          0";

   $sql = 'INSERT INTO '. BT_TOR_DL_STAT_TABLE ." ($columns) VALUES ($values)";

   if (!$db->sql_query($sql))
   {
      message_die(GENERAL_ERROR, 'Could not insert empty statistic record for guests', '', __LINE__, __FILE__, $sql);
   }
*/

   // update tracker status for this attachment
   $sql = 'UPDATE '. ATTACHMENTS_DESC_TABLE ." SET
         tracker_status = 1
      WHERE attach_id = $attach_id
      LIMIT 1";

   if (!$db->sql_query($sql))
   {
      message_die(GENERAL_ERROR, 'Could not update torrent status', '', __LINE__, __FILE__, $sql);
   }

   // set DL-Type for topic
   if ($board_config['bt_set_dltype_on_tor_reg'])
   {
      $sql = 'UPDATE '. TOPICS_TABLE .' SET
            topic_dl_type = '. TOPIC_DL_TYPE_DL ."
         WHERE topic_id = $topic_id
         LIMIT 1";

      if (!$result = $db->sql_query($sql))
      {
         message_die(GENERAL_ERROR, 'Could not update topics table', '', __LINE__, __FILE__, $sql);
      }
   }

   if ($reg_mode == 'request' || $reg_mode == 'newtopic')
   {
      $mess = sprintf($lang['Bt_Registered'], append_sid("download.$phpEx?id=$attach_id"));
      exit_redirect($mess, $post_id, $forum_id);
   }

   return;
}

function send_torrent_with_passkey ($filename)
{
   global $attachment, $auth_pages, $db, $userdata, $board_config, $phpEx, $lang, $HTTP_GET_VARS;

   if ($attachment['extension'] !== TORRENT_EXT || !$size = @filesize($filename))
   {
      return;
   }

   $post_id   = '';
   $user_id   = $userdata['user_id'];
   $attach_id = $attachment['attach_id'];

   // Get tracker config
   $sql = 'SELECT *
      FROM '. BT_CONFIG_TABLE ."
      WHERE config_name = 'allow_guest_dl'";

   if (!$rowset = @$db->sql_fetchrowset($db->sql_query($sql)))
   {
      message_die(GENERAL_ERROR, 'Could not query tracker config', '', __LINE__, __FILE__, $sql);
   }

   foreach ($rowset as $rid => $row)
   {
      $tr_cfg[$row['config_name']] = $row['config_value'];
   }

   // Get post_id
   foreach ($auth_pages as $rid => $row)
   {
      if ($row['attach_id'] == $attach_id)
      {
         $post_id = $row['post_id'];
         break;
      }
   }

   // Redirect guests to login page
   if (!$userdata['session_logged_in'] && !$tr_cfg['allow_guest_dl'])
   {
      if ($post_id)
      {
         redirect(append_sid("login.$phpEx?redirect=viewtopic.$phpEx&". POST_POST_URL ."=$post_id", TRUE));
      }
      else
      {
         redirect(append_sid("login.$phpEx?redirect=index.$phpEx", TRUE));
      }
   }

   // Get torrent tracker status
   $sql = 'SELECT d.tracker_status, u.user_allow_passkey
      FROM '. ATTACHMENTS_DESC_TABLE .' d, '. USERS_TABLE ." u
      WHERE d.attach_id = $attach_id
         AND u.user_id = $user_id
      LIMIT 1";

   if (!$result = $db->sql_query($sql))
   {
      message_die(GENERAL_ERROR, 'Could not query information for this torrent', '', __LINE__, __FILE__, $sql);
   }

   $row = $db->sql_fetchrow($result);

   if (!$row['tracker_status'])
   {
      message_die(GENERAL_ERROR, $lang['Passkey_err_tor_not_reg']);
   }

   if (!$row['user_allow_passkey'])
   {
      message_die(GENERAL_ERROR, 'Could not generate torrent<br /><br />You are not authorized to download this torrent');
   }

   $ann_url = $board_config['bt_announce_url'];

   if (!$tor = bdecode_file($filename))
   {
      message_die(GENERAL_ERROR, 'This is not a bencoded file');
   }

   // replace original announce url with tracker default
   if ($board_config['bt_replace_ann_url'] || !@$tor['announce'])
   {
      $tor['announce'] = strval($ann_url);
   }

   // delete all additional urls
   if ($board_config['bt_del_addit_ann_urls'])
   {
     unset($tor['announce-list']);
   }

   // add publisher & topic url
   $publisher = $board_config['bt_add_publisher'];
   $publisher_url = ($post_id) ? make_url("viewtopic.$phpEx?". POST_POST_URL ."=$post_id") : '';

   if ($publisher)
   {
      $tor['publisher'] = strval($publisher);
      unset($tor['publisher.utf-8']);

      if ($publisher_url)
      {
         $tor['publisher-url'] = strval($publisher_url);
         unset($tor['publisher-url.utf-8']);
      }
   }

   // add comment
   $comment = '';

   $orig_com = (@$tor['comment']) ? $tor['comment'] : '';

   if ($board_config['bt_add_comment'])
   {
      $comment = $board_config['bt_add_comment'];
   }
   else
   {
      $comment = ($publisher_url) ? $publisher_url : '';
   }

   if ($comment = trim($comment))
   {
      $tor['comment'] = strval($comment);
      unset($tor['comment.utf-8']);
   }

   // DHT
   $board_config['bt_disable_dht'] = 1;

   if ($board_config['bt_disable_dht'])
   {
      $tor['private'] = intval(1);
      unset($tor['nodes']);

      $tor['azureus_properties'] = array('dht_backup_enable' => intval(0));
   }

   // Send torrent
   $output = bencode($tor);
   $output_size = strlen($output);

   header("Content-length: $output_size");
   header('Content-Type: application/x-bittorrent');
   header('Content-Disposition: attachment; filename="'. clean_filename($attachment['real_filename']) .'"');

   echo $output;

   exit;
}

function get_registered_torrents ($id, $mode)
{
   global $db;

   $field = ($mode == 'topic') ? 'topic_id' : 'post_id';

   $sql = 'SELECT torrent_id
      FROM '. BT_TORRENTS_TABLE ."
      WHERE $field = $id";

   if (!$result = $db->sql_query($sql))
   {
      message_die(GENERAL_ERROR, 'Could not query torrent id', '', __LINE__, __FILE__, $sql);
   }

   if ($rowset = @$db->sql_fetchrowset($result))
   {
      return $rowset;
   }
   else
   {
      return FALSE;
   }
}

function exit_redirect ($message, $post_id, $forum_id)
{
   global $template, $lang, $phpEx;

   $exit_meta = '<meta http-equiv="refresh" content="300;url='. append_sid("viewtopic.$phpEx?". POST_POST_URL ."=". $post_id) .'#'. $post_id .'">';
   $exit_message = $message .'<br /><br />'. sprintf($lang['Click_return_topic'], '<a href="'. append_sid("viewtopic.$phpEx?". POST_POST_URL ."=". $post_id) .'#'. $post_id .'">', '</a>') .'<br /><br />'. sprintf($lang['Click_return_forum'], '<a href="'. append_sid("viewforum.$phpEx?". POST_FORUM_URL ."=$forum_id") .'">', '</a>');
   $template->assign_vars(array('META' => $exit_meta));
   message_die(GENERAL_MESSAGE, $exit_message);
}

function torrent_error_exit ($message)
{
   global $reg_mode, $return_message, $lang;

   $err_code = GENERAL_ERROR;
   $msg = '';

   if (isset($reg_mode) && ($reg_mode == 'request' || $reg_mode == 'newtopic'))
   {
      if (isset($return_message))
      {
         $msg .= $return_message .'<br /><br /><hr /><br />';
      }
      $msg .= '<b>'. $lang['Bt_Reg_fail'] .'</b><br /><br />';

      $err_code = GENERAL_MESSAGE;
   }

   $msg .= $message;
   message_die($err_code, $msg);
}

// based on function from PHPBuddy.com
function make_rand_str ($len = 10)
{
   $rnd = crypt(uniqid(rand(), 1));
   $rnd = strip_tags(stripslashes($rnd));
   $rnd = str_replace('.', '', $rnd);
   $rnd = strrev(str_replace('/', '', $rnd));
   $rnd = substr($rnd, 0, $len);
   return $rnd;
}

// bdecode/bencode (based on functions from OpenTracker - http://whitsoftdev.com/opentracker/)
function bdecode_file ($filename)
{
   if (!$fp = fopen($filename, 'rb'))
   {
      return NULL;
   }
   $fc = fread($fp, @filesize($filename));
   fclose($fp);

   return bdecode($fc);
}

function bdecode($str)
{
   $pos = 0;
   return bdecode_r($str, $pos);
}

function bdecode_r($str, &$pos)
{
   $strlen = strlen($str);

   if (($pos < 0) || ($pos >= $strlen))
   {
      return NULL;
   }
   else if ($str{$pos} == 'i')
   {
      $pos++;
      $numlen = strspn($str, '-0123456789', $pos);
      $spos = $pos;
      $pos += $numlen;

      if (($pos >= $strlen) || ($str{$pos} != 'e'))
      {
         return NULL;
      }
      else
      {
         $pos++;
         return floatval(substr($str, $spos, $numlen));
      }
   }
   else if ($str{$pos} == 'd')
   {
      $pos++;
      $ret = array();

      while ($pos < $strlen)
      {
         if ($str{$pos} == 'e')
         {
            $pos++;
            return $ret;
         }
         else
         {
            $key = bdecode_r($str, $pos);

            if ($key === NULL)
            {
               return NULL;
            }
            else
            {
               $val = bdecode_r($str, $pos);

               if ($val === NULL)
               {
                  return NULL;
               }
               else if (!is_array($key))
               {
                  $ret[$key] = $val;
               }
            }
         }
      }
      return NULL;
   }
   else if ($str{$pos} == 'l')
   {
      $pos++;
      $ret = array();

      while ($pos < $strlen)
      {
         if ($str{$pos} == 'e')
         {
            $pos++;
            return $ret;
         }
         else
         {
            $val = bdecode_r($str, $pos);

            if ($val === NULL)
            {
               return NULL;
            }
            else
            {
               $ret[] = $val;
            }
         }
      }
      return NULL;
   }
   else
   {
      $numlen = strspn($str, '0123456789', $pos);
      $spos = $pos;
      $pos += $numlen;

      if (($pos >= $strlen) || ($str{$pos} != ':'))
      {
         return NULL;
      }
      else
      {
         $vallen = intval(substr($str, $spos, $numlen));
         $pos++;
         $val = substr($str, $pos, $vallen);

         if (strlen($val) != $vallen)
         {
            return NULL;
         }
         else
         {
            $pos += $vallen;
            return $val;
         }
      }
   }
}

function bencode($var)
{
   if (is_int($var))
   {
      return 'i'. $var .'e';
   }
   else if (is_float($var))
   {
      return 'i'. sprintf('%.0f', $var) .'e';
   }
   else if (is_array($var))
   {
      if (count($var) == 0)
      {
         return 'de';
      }
      else
      {
         $assoc = false;

         foreach ($var as $key => $val)
         {
            if (!is_int($key) && !is_float($var))
            {
               $assoc = true;
               break;
            }
         }

         if ($assoc)
         {
            ksort($var, SORT_REGULAR);
            $ret = 'd';

            foreach ($var as $key => $val)
            {
               $ret .= bencode($key) . bencode($val);
            }
            return $ret .'e';
         }
         else
         {
            $ret = 'l';

            foreach ($var as $val)
            {
               $ret .= bencode($val);
            }
            return $ret .'e';
         }
      }
   }
   else
   {
      return strlen($var) .':'. $var;
   }
}

?>


The ab track can be found here(and at sourceforge, but no official support the creator abandon the project): [ Register or login to view links on this board. ]
And if i misunderstood please be free to ask.

Thanks, KaZuyA


Back to top Reply with quote
#2   
KaZuyA
CZ Newbie
KaZuyA has been a member for over 17 year's 17 Year Member
Gender: Male
Status: Offline
Joined: Dec 29, 2006
0.00 posts per day
Posts: 2
Points: 25
   
Hi! It's fixed! All thanks to echo!
I used echo $filename; to see in what directory was checking about the file. And i got /modules/Forums/modules/Forums/files/xxxxx.torrent

To fix it open the includes/functions_torrent.php
find
[code[$filename = $phpbb_root_path . $attach_config['upload_dir'] .'/'. $torrent['physical_filename'];[/code]

and rename it to
$filename = $phpbb_root_path .'/files/'. $torrent['physical_filename'];


a single line fix! I am impressed by myself!


Back to top Reply with quote
#3   
Telli
Site Admin
Occupation: Self Employed
Age: 46
Gender: Male
Fav. Sports Team: Detroit Red Wings
Website:
Status: Offline
Joined: May 26, 2003
1.03 posts per day
Posts: 8089
Points: 494,475
   
Nice job. Hopefully someone else finds it helpful icon_smile.gif




_________________
The path of the righteous man is beset on all sides by the inequities of the selfish and the tyranny of evil men. Blessed is he, who in the name of charity and good will, shepherds the weak through the valley of darkness, for he is truly his brother's keeper and the finder of lost children. And I will strike down upon thee with great vengeance and furious anger those who would attempt to poison and destroy my brothers. And you will know my name is the Lord when I lay my vengeance upon thee. Ezekiel 25:17
Back to top Reply with quote
Display posts from previous:      
Add To: Del.icio.us  Digg  Google  Spurl  Blink  Furl  Y! MyWeb  
<< View previous topic View next topic >>
Post new topicReply to topic

Jump to 
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum
You cannot attach files in this forum
You cannot download files in this forum