Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- <?php
- if (!defined('RAPIDLEECH')) {
- require_once('index.html');
- exit;
- }
- class hitfile_net extends DownloadClass {
- private $link, $page, $cookie, $pA, $RDregexp, $DLregexp;
- public function Download($link) {
- global $premium_acc, $Referer;
- if (!preg_match('@^https?://(?:[^/]+\.)?hitfile\.net/(?:download/free/)?(\w+)@i', $link, $id)) html_error('Error: Invalid link entered.');
- $this->link = $Referer = 'http://hitfile.net/' . $id[1];
- $this->pA = (empty($_REQUEST['premium_user']) || empty($_REQUEST['premium_pass']) ? false : true);
- $this->cookie = array('user_lang' => 'en');
- $this->RDregexp = '@(https?://(?:[^/\"\'\t\r\n<>]+\.)?hitfile\.net(?:\:\d+)?)?//?download/redirect/[^\"\'\t\r\n<>]+@i';
- $this->DLregexp = '@https?://s\d+\.hitfile\.net(?:\:\d+)?/download\.php\?[^\"\'\t\r\n<>]+@i';
- if (empty($_POST['step'])) {
- $this->page = $this->GetPage($this->link);
- is_present($this->page, 'File was deleted or not found', 'File Not Found.'); // 404
- $this->cookie = GetCookiesArr($this->page, $this->cookie);
- }
- if (($_REQUEST['premium_acc'] == 'on' && ($this->pA || (!empty($premium_acc['hitfile_net']['user']) && !empty($premium_acc['hitfile_net']['pass']))))) {
- $user = ($this->pA ? $_REQUEST['premium_user'] : $premium_acc['hitfile_net']['user']);
- $pass = ($this->pA ? $_REQUEST['premium_pass'] : $premium_acc['hitfile_net']['pass']);
- if ($this->pA && !empty($_POST['pA_encrypted'])) {
- $user = decrypt(urldecode($user));
- $pass = decrypt(urldecode($pass));
- unset($_POST['pA_encrypted']);
- }
- return $this->CookieLogin($user, $pass);
- } else {
- $this->link = 'http://hitfile.net/download/free/' . $id[1];
- return $this->FreeDL();
- }
- }
- private function FreeDL() {
- $_POST['step'] = empty($_POST['step']) ? '' : $_POST['step'];
- switch ($_POST['step']) {
- case '1': { // Send Captcha && Get Countdown
- if (empty($_POST['captcha'])) html_error('You didn\'t enter the image-verification code.');
- $this->cookie = StrToCookies(decrypt(urldecode($_POST['cookie'])));
- $post = array();
- $post['captcha_response'] = urlencode($_POST['captcha']);
- $post['captcha_type'] = urlencode($_POST['c_type']);
- $post['captcha_subtype'] = (!empty($_POST['c_subtype']) ? urlencode($_POST['c_subtype']) : '');
- $page = $this->GetPage($this->link, $this->cookie, $post);
- is_present($page, 'Incorrect, try again!', 'Error: Wrong CAPTCHA entered.');
- is_present($page, 'Looks like your browser has disabled cookies.', 'Error: Invalid cookies.');
- if (!preg_match('@\W(?:min)?Limit[\s\t]*:[\s\t]*([\d\s\t\r\n\+\-\*/\(\)]+)[\s\t]*[\,\;]@i', $page, $count)) html_error('Countdown not found.');
- $data = $this->DefaultParamArr($this->link, encrypt(CookiesToStr($this->cookie)));
- $data['step'] = '2';
- $this->JSCountdown($count[1], $data);
- break;
- }
- case '2': { // Download
- $this->cookie = StrToCookies(decrypt(urldecode($_POST['cookie'])));
- $page = $this->GetPage(str_replace('/download/free/', '/download/getLinkTimeout/', $this->link), $this->cookie, 0, $this->link . "\r\nX-Requested-With: XMLHttpRequest");
- if (preg_match($this->RDregexp, $page, $redir)) {
- $redir = (empty($redir[1])) ? 'http://hitfile.net'.$redir[0] : $redir[0];
- $page = $this->GetPage($redir, $this->cookie, 0, $this->link);
- if (!preg_match($this->DLregexp, $page, $dllink)) html_error('Download-Link not Found.');
- } elseif (!preg_match($this->DLregexp, $page, $dllink)) html_error('Redirect-Link not Found.');
- $this->RedirectDownload(html_entity_decode($dllink[0]), 'hitfile_fr', $this->cookie);
- break;
- }
- default : { // Get Captcha
- $page = $this->GetPage($this->link, $this->cookie);
- if (preg_match('@\W(?:min)?Limit[\s\t]*:[\s\t]*([\d\s\t\r\n\+\-\*/\(\)]+)[\s\t]*[\,\;]@i', $page, $count)) {
- $data = $this->DefaultParamArr($this->link, encrypt(CookiesToStr($this->cookie)));
- $this->JSCountdown($count[1], $data, 'FreeDL limit reached');
- }
- if (!preg_match('@(https?://[^/\r\n\t\s\'\"<>]+)?/captcha/[^\r\n\t\s\'\"<>]+@i', $page, $imgurl)) html_error('Error: CAPTCHA not found.');
- $imgurl = (empty($imgurl[1])) ? 'http://hitfile.net'.$imgurl[0] : $imgurl[0];
- $imgurl = html_entity_decode($imgurl);
- if (!preg_match('@\Wvalue\s*=\s*[\'\"]([^\'\"\r\n<>]+)[\'\"]\s+name\s*=\s*[\'\"]captcha_type[\'\"]@i', $page, $c_type) || !preg_match('@\Wvalue\s*=\s*[\'\"]([^\'\"\r\n<>]*)[\'\"]\s+name\s*=\s*[\'\"]captcha_subtype[\'\"]@i', $page, $c_subtype)) html_error('CAPTCHA data not found');
- //Download captcha img.
- $capt_page = $this->GetPage($imgurl, $this->cookie);
- $capt_img = substr($capt_page, strpos($capt_page, "\r\n\r\n") + 4);
- $imgfile = DOWNLOAD_DIR . 'hitfile_captcha.png';
- if (file_exists($imgfile)) unlink($imgfile);
- if (!write_file($imgfile, $capt_img)) html_error('Error getting CAPTCHA image');
- unset($capt_page, $capt_img);
- $data = $this->DefaultParamArr($this->link, encrypt(CookiesToStr($this->cookie)));
- $data['step'] = '1';
- $data['c_type'] = urlencode($c_type[1]);
- $data['c_subtype'] = urlencode($c_subtype[1]);
- $this->EnterCaptcha($imgfile.'?'.time(), $data);
- exit;
- }
- }
- }
- private function PremiumDL() {
- $page = $this->GetPage($this->link, $this->cookie);
- if (preg_match($this->RDregexp, $page, $redir)) {
- $redir = (empty($redir[1])) ? 'http://hitfile.net'.$redir[0] : $redir[0];
- $page = $this->GetPage($redir, $this->cookie);
- if (!preg_match($this->DLregexp, $page, $dllink)) html_error('Download Link not Found.');
- } elseif (!preg_match($this->DLregexp, $page, $dllink)) html_error('Redirect Link not Found.');
- $this->RedirectDownload(html_entity_decode($dllink[0]), 'hitfile_pr', $this->cookie);
- }
- private function Login($user, $pass) {
- $purl = 'http://hitfile.net/';
- if (!empty($_POST['step']) && ($_POST['step'] == '1' || $_POST['step'] == '2')) {
- $this->cookie = StrToCookies(decrypt(urldecode($_POST['cookie'])));
- $post = array();
- $post['user%5Blogin%5D'] = urlencode($user);
- $post['user%5Bpass%5D'] = urlencode($pass);
- if ($_POST['step'] == '1') {
- if (empty($_POST['captcha'])) html_error('You didn\'t enter the image verification code.');
- $post['user%5Bcaptcha_response%5D'] = urlencode($_POST['captcha']);
- } else {
- if (empty($_POST['recaptcha_response_field'])) html_error('You didn\'t enter the image verification code.');
- $post['recaptcha_challenge_field'] = urlencode($_POST['recaptcha_challenge_field']);
- $post['recaptcha_response_field'] = urlencode($_POST['recaptcha_response_field']);
- }
- $post['user%5Bcaptcha_type%5D'] = urlencode($_POST['c_type']);
- $post['user%5Bcaptcha_subtype%5D'] = (!empty($_POST['c_subtype']) ? urlencode($_POST['c_subtype']) : '');
- $post['user%5Bmemory%5D'] = 'on';
- $post['user%5Bsubmit%5D'] = 'Login';
- $page = $this->GetPage($purl.'user/login', $this->cookie, $post, $purl.'login');
- $this->cookie = GetCookiesArr($page, $this->cookie);
- $x = 0;
- while ($x < 3 && stripos($page, "\nLocation: ") !== false && preg_match('@\nLocation: ((https?://[^/\r\n]+)?/[^\r\n]*)@i', $page, $redir)) {
- $redir = (empty($redir[2])) ? 'http://hitfile.net'.$redir[1] : $redir[1];
- $page = $this->GetPage($redir, $this->cookie);
- $this->cookie = GetCookiesArr($page, $this->cookie);
- $x++;
- }
- is_present($page, 'Incorrect login or password', 'Login Failed: Login/Password incorrect.');
- is_present($page, 'E-Mail address appears to be invalid.', 'Login Failed: Invalid E-Mail.');
- is_present($page, 'Username(Email) does not exist', 'Login Failed: E-Mail is not registered.');
- is_present($page, 'Incorrect verification code', 'Login Failed: Wrong CAPTCHA entered.');
- is_present($page, 'Incorrect captcha code', 'Login Failed: Wrong Recaptcha entered.');
- // is_present($page, 'Limit of login attempts exceeded for your account. It has been temporarily locked.', 'Login Failed: Account Temporally Locked.');
- if (empty($redir) || $redir != $purl) $page = $this->GetPage($purl, $this->cookie, 0, $purl);
- is_notpresent($page, '/user/logout">Logout<', 'Login Failed.');
- $this->SaveCookies($user, $pass); // Update cookies file
- is_present($page, 'Account: <b>free</b>', 'Login Failed: Account isn\'t premium.');
- return $this->PremiumDL();
- } else {
- $post = array();
- $post['user%5Blogin%5D'] = urlencode($user);
- $post['user%5Bpass%5D'] = urlencode($pass);
- $post['user%5Bmemory%5D'] = 'on';
- $post['user%5Bsubmit%5D'] = 'Login';
- $page = $this->GetPage($purl.'user/login', $this->cookie, $post, $purl.'login');
- $this->cookie = GetCookiesArr($page, $this->cookie);
- if (!empty($this->cookie['user_isloggedin']) && $this->cookie['user_isloggedin'] == '1') {
- $page = $this->GetPage($purl, $this->cookie, 0, $purl);
- $this->SaveCookies($user, $pass); // Update cookies file
- is_present($page, 'Account: <b>free</b>', 'Login Failed: Account isn\'t premium');
- return $this->PremiumDL();
- }
- $x = 0;
- while ($x < 3 && stripos($page, "\nLocation: ") !== false && preg_match('@\nLocation: ((https?://[^/\r\n]+)?/[^\r\n]*)@i', $page, $redir)) {
- $redir = (empty($redir[2])) ? 'http://hitfile.net'.$redir[1] : $redir[1];
- $page = $this->GetPage($redir, $this->cookie);
- $this->cookie = GetCookiesArr($page, $this->cookie);
- $x++;
- }
- if ($x < 1) html_error('Login redirect not found');
- is_present($page, 'Incorrect login or password', 'Login Failed: Login/Password incorrect');
- is_present($page, 'E-Mail address appears to be invalid.', 'Login Failed: Invalid E-Mail');
- is_present($page, 'Username(Email) does not exist', 'Login Failed: E-Mail is not registered.');
- // is_present($page, 'Limit of login attempts exceeded for your account. It has been temporarily locked.', 'Login Failed: Account Temporally Locked');
- if (preg_match('@(https?://[^/\r\n\t\s\'\"<>]+)?/captcha/[^\r\n\t\s\'\"<>]+@i', $page, $imgurl)) {
- $imgurl = (empty($imgurl[1])) ? 'http://hitfile.net'.$imgurl[0] : $imgurl[0];
- $imgurl = html_entity_decode($imgurl);
- if (!preg_match('@\Wvalue\s*=\s*[\'\"]([^\'\"\r\n<>]+)[\'\"]\s+name\s*=\s*[\'\"]user\[captcha_type\][\'\"]@i', $page, $c_type) || !preg_match('@\Wvalue\s*=\s*[\'\"]([^\'\"\r\n<>]*)[\'\"]\s+name\s*=\s*[\'\"]user\[captcha_subtype\][\'\"]@i', $page, $c_subtype)) html_error('CAPTCHA data not found.');
- //Download captcha img.
- $capt_page = $this->GetPage($imgurl, $this->cookie);
- $capt_img = substr($capt_page, strpos($capt_page, "\r\n\r\n") + 4);
- $imgfile = DOWNLOAD_DIR . 'hitfile_captcha.png';
- if (file_exists($imgfile)) unlink($imgfile);
- if (!write_file($imgfile, $capt_img)) html_error('Error getting CAPTCHA image.');
- unset($capt_page, $capt_img);
- $data = $this->DefaultParamArr($this->link, encrypt(CookiesToStr($this->cookie)));
- $data['step'] = '1';
- $data['c_type'] = urlencode($c_type[1]);
- $data['c_subtype'] = urlencode($c_subtype[1]);
- $data['premium_acc'] = 'on';
- if ($this->pA) {
- $data['pA_encrypted'] = 'true';
- $data['premium_user'] = urlencode(encrypt($user)); // encrypt() will keep this safe.
- $data['premium_pass'] = urlencode(encrypt($pass)); // And this too.
- }
- $this->EnterCaptcha($imgfile.'?'.time(), $data);
- exit;
- } elseif (preg_match('@https?://(?:[^/]+\.)?(?:(?:google\.com/recaptcha/api)|(?:recaptcha\.net))/(?:(?:challenge)|(?:noscript))\?k=([\w\.\-]+)@i', $page, $pid)) {
- $data = $this->DefaultParamArr($this->link, encrypt(CookiesToStr($this->cookie)));
- $data['step'] = '2';
- $data['c_type'] = 'recaptcha';
- $data['premium_acc'] = 'on';
- if ($this->pA) {
- $data['pA_encrypted'] = 'true';
- $data['premium_user'] = urlencode(encrypt($user)); // encrypt() will keep this safe.
- $data['premium_pass'] = urlencode(encrypt($pass)); // And this too.
- }
- $this->reCAPTCHA($pid[1], $data, 0, 'Login');
- exit;
- } elseif (stripos($page, '/user/logout">Logout<') !== false) {
- $this->SaveCookies($user, $pass); // Update cookies file
- is_present($page, 'Account: <b>free</b>', 'Login Failed: Account isn\'t premium');
- return $this->PremiumDL();
- } else html_error('CAPTCHA not found.');
- }
- }
- private function IWillNameItLater($cookie, $decrypt=true) {
- if (!is_array($cookie)) {
- if (!empty($cookie)) return $decrypt ? decrypt(urldecode($cookie)) : urlencode(encrypt($cookie));
- return '';
- }
- if (count($cookie) < 1) return $cookie;
- $keys = array_keys($cookie);
- $values = array_values($cookie);
- $keys = $decrypt ? array_map('decrypt', array_map('urldecode', $keys)) : array_map('urlencode', array_map('encrypt', $keys));
- $values = $decrypt ? array_map('decrypt', array_map('urldecode', $values)) : array_map('urlencode', array_map('encrypt', $values));
- return array_combine($keys, $values);
- }
- private function CookieLogin($user, $pass, $filename = 'hitfile_dl.php') {
- global $secretkey;
- if (empty($user) || empty($pass)) html_error('Login Failed: User or Password is empty.');
- $filename = DOWNLOAD_DIR . basename($filename);
- if (!file_exists($filename)) return $this->Login($user, $pass);
- $file = file($filename);
- $savedcookies = unserialize($file[1]);
- unset($file);
- $hash = hash('crc32b', $user.':'.$pass);
- if (array_key_exists($hash, $savedcookies)) {
- $_secretkey = $secretkey;
- $secretkey = sha1($user.':'.$pass);
- $testCookie = (decrypt(urldecode($savedcookies[$hash]['enc'])) == 'OK') ? $this->IWillNameItLater($savedcookies[$hash]['cookie']) : '';
- $secretkey = $_secretkey;
- if (empty($testCookie) || (is_array($testCookie) && count($testCookie) < 1)) return $this->Login($user, $pass);
- $page = $this->GetPage('http://hitfile.net/', $testCookie);
- if (stripos($page, '/user/logout">Logout<') === false) return $this->Login($user, $pass);
- $this->cookie = GetCookiesArr($page, $testCookie); // Update cookies
- $this->SaveCookies($user, $pass); // Update cookies file
- is_present($page, 'Account: <b>free</b>', 'Account isn\'t premium.');
- return $this->PremiumDL();
- }
- return $this->Login($user, $pass);
- }
- private function SaveCookies($user, $pass, $filename = 'hitfile_dl.php') {
- global $secretkey;
- $maxdays = 31; // Max days to keep cookies saved
- $filename = DOWNLOAD_DIR . basename($filename);
- if (file_exists($filename)) {
- $file = file($filename);
- $savedcookies = unserialize($file[1]);
- unset($file);
- // Remove old cookies
- foreach ($savedcookies as $k => $v) if (time() - $v['time'] >= ($maxdays * 24 * 60 * 60)) unset($savedcookies[$k]);
- } else $savedcookies = array();
- $hash = hash('crc32b', $user.':'.$pass);
- $_secretkey = $secretkey;
- $secretkey = sha1($user.':'.$pass);
- $savedcookies[$hash] = array('time' => time(), 'enc' => urlencode(encrypt('OK')), 'cookie' => $this->IWillNameItLater($this->cookie, false));
- $secretkey = $_secretkey;
- file_put_contents($filename, "<?php exit(); ?>\r\n" . serialize($savedcookies), LOCK_EX);
- }
- }
- //[09-1-2013] Written by Th3-822.
- //[07-6-2013] Added login recaptcha support. - Th3-822
- //[03-1-2016] Replaced 'turbobit' with 'hitfile' && small edits to make it work. - Th3-822
- ?>
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement