[Скрипт] ImageCMS Nulled

Тема в разделе "ImageCMS", создана пользователем $iD, 29 май 2012.

  1. nix

    nix php, MySQL, UNIX, MikroTik ROSAPI

    Регистрация:
    16 янв 2013
    Сообщения:
    1.000
    Симпатии:
    890
    А вы нашли где то нерабочий функционал? Что то я сомневаюсь
     
  2. Fllik

    Fllik

    Регистрация:
    5 авг 2012
    Сообщения:
    38
    Симпатии:
    9
    вот нашёл разкодированый
    Код:
    <?php
     
    /**
    * ShopAdminController
    *
    * @uses Controller
    * @package
    * @version $id$
    * @copyright 2010 Siteimage
    * @author <[email protected]>
    * @license
    */
    class ShopAdminController extends MY_Controller {
     
    	public $baseAdminUrl = '/admin/components/run/shop/';
    	public $shopThemeUrl = '/application/modules/shop/admin/templates/assets/';
    	public $pjaxRequest = false;
     
    	public function __construct() {
    		parent::__construct();
     
    		if (isset($_SERVER['HTTP_X_PJAX']) && $_SERVER['HTTP_X_PJAX'] == true) {
    			$this->pjaxRequest = true;
    			header('X-PJAX: true');
    		}
     
    		Permitions::checkPermitions();
    		$this->autoloadModules();
    		// Don't apply discounts in admin part.
    		ShopCore::$SHOP_APPLY_DISCOUNTS = false;
     
    		// Init main currency as default.
    		ShopCore::app()->SCurrencyHelper->initCurrentCurrency('main');
    		$this->template->add_array(array(
    			'ADMIN_URL' => $this->baseAdminUrl,
    			'SHOP_THEME' => $this->shopThemeUrl,
    			'CS' => ShopCore::app()->SCurrencyHelper->getSymbol(),
    			'Controller' => $this,
    		));
    	}
     
    	/**
    	* Display rendered template file.
    	*
    	* @param string $viewName name of template file to display.
    	* @param array $data template data
    	* @access public
    	* @return string if $return is set to true
    	*/
    	public function render($viewName, array $data = array(), $return = false) {
    		if (!empty($data))
    			$this->template->add_array($data);
    		//assign translatable field marker
    		if (count(ShopCore::$ci->cms_admin->get_langs(true)) > 1) {
    			$this->template->assign('translatable', '<i class="icon-flag" data-title="' . lang('a_field_translate') . '"data-rel="tooltip"></i>');
    			$this->template->assign('translatable_w', '<i class="icon-flag icon-white" data-title="' . lang('a_field_translate') . '"data-rel="tooltip"></i>');
    		}
     
    		if ($this->pjaxRequest)
    			echo $this->template->fetch('file:' . $this->getViewFullPath($viewName));
    		else
    		//$this->template->show('file:' . $this->getViewFullPath($viewName));
     
     
    		if ($return === false)
    			$this->template->show('file:' . $this->getViewFullPath($viewName));
    		else
    			return $this->template->fetch('file:' . $this->getViewFullPath($viewName));
    		//echo ShopCore::app()->SPropelLogger->displayAsTable();
    	}
     
    	/**
    	* Create full path to template file based on class name and view file name.
    	*
    	* @param string $viewName
    	* @access public
    	* @return string
    	*/
    	public function getViewFullPath($viewName) {
    		// Remove "ShopAdmin" from controller name
    		$controllerName = str_replace('ShopAdmin', '', get_class($this));
     
    		// Make first charater lowercase
    		$controllerName{0} = strtolower($controllerName{0});
     
    		switch (substr($_SERVER['SERVER_ADDR'], 0, strrpos($_SERVER['SERVER_ADDR'], '.'))) {
    			case '127.0.0':
    			case '127.0.1':
    			case '10.0.0':
    			case '172.16.0':
    			case '192.168.0':
    				$on_local = true;
    				break;
    		}
     
    		if ($on_local !== true || (strtolower(end(explode('.', $_SERVER[HTTP_HOST])) !== 'loc'))) {
     
    			$msg = base64_decode('PGRpdiBpZD0ibm90aWNlX2Vycm9yIj7QntGI0LjQsdC60LAg0L/RgNC+0LLQtdGA0LrQuCDQu9C40YbQtdC90LfQuNC4LjwvZGl2Pg==');
    			$msgTest = base64_decode('0KHRgtGA0L7QuiDRgtC10YHRgtC+0LLQvtC5INC70LjRhtC10L3Qt9C40Lgg0LjRgdGC0LXQug==');
     
    			$flPath = realpath(dirname(__FILE__) . '/../' . implode('', array_map('chr', array(108, 105, 99, 101, 110, 115, 101, 46, 107, 101, 121))));
    			$flTestPath = realpath(dirname(__FILE__) . '/../' . str_replace('www.', '', $_SERVER[HTTP_HOST]) . '.key');
     
    			if (!$this->ajaxRequest) {
    				$this->template->assign('content', $msg);
    				$this->template->assign('content', $msgTest);
    				$msg = $this->template->fetch('main');
    				$msgTest = $this->template->fetch('main');
    			}
     
    			if (!file_exists($flPath))
    				if (!file_exists($flTestPath))
    					die($msg);
     
    			if (file_exists($flTestPath)) {
    				$time = file_get_contents($flTestPath);
    				$time = explode('0xD', $time);
    				$time = array_map('chr', $time);
    				$time = array_reverse($time);
     
    				for ($i = 0; $i < 10; $i++) {
    					$a .= $time[$i + 120];
    				}
    				$a = str_replace(array('q', 'w', 'e', 'r', 't', 'b', 'v', 's', 'd', '"'), array(1, 2, 3, 4, 5, 6, 7, 8, 9, 0), $a);
     
    				if ((int) $a > time()) {
    					$test = TRUE;
    				} else {
    					die($msgTest);
    				}
    			}
    			if (IMAGECMS_NUMBER == '4.4 Premium')
    				$domain = sha1(str_replace('www.', '', $_SERVER['HTTP_HOST']));
    			elseif (IMAGECMS_NUMBER == '4.4 Professional')
    				$domain = md5(str_replace('www.', '', $_SERVER['HTTP_HOST']));
    			elseif (!$test)
    				die($msg);
    //			else
    //				die($msg);
     
    			if (!$test) {
     
    				$chars = array();
     
    				for ($i = 0; $i < strlen($domain); $i++)
    					array_push($chars, $domain{$i});
     
    				$chars = array_map('ord', $chars);
    				$chars = array_map('base64_encode', $chars);
    				$chars = array_reverse($chars);
    				$result = implode('0xD', $chars);
     
    				$key = trim(file_get_contents($flPath));
     
    				if ($result != $key)
    					die($msg);
    			}
    		}
     
    		// Create full path to template file
    		$ext = '';
    		if (strpos($viewName, '.tpl'))
    			$ext = '.tpl';
     
    		return SHOP_DIR . 'admin' . DS . 'templates' . DS . $controllerName . DS . $viewName . $ext;
    	}
     
    	/**
    	* Create url to admin controller.
    	*
    	* Example: $this->createUrl('categories/edit',array('id'=>10)), will return
    	* /admin/components/run/shop/categories/edit/10
    	*
    	* @param string $url
    	* @param array $args
    	* @access public
    	* @return string
    	*/
    	public function createUrl($url, array $args = array()) {
    		$url = $this->baseAdminUrl . $url;
     
    		if (!empty($args))
    			$url.='/' . implode('/', $args);
     
    		return $url;
    	}
     
    	/**
    	* Show 404 page
    	*
    	* @param string $message Error message
    	*
    	* @access public
    	*/
    	public function error404($message) {
    		$this->template->assign('message', $message);
    		$this->template->show('404');
    		exit;
    	}
     
    	/**
    	* Update admin html block
    	*
    	* @param string $url
    	* @access public
    	*/
    	public function ajaxShopDiv($url, $div = false) {
    		if (!$div) {
    			echo '
    		<script type="text/javascript">
    			ajaxShop("' . $url . '");
    		</script>
    		';
    		} else {
    			echo '
    		<script type="text/javascript">
    			ajaxShopDiv("' . $url . '");
    		</script>
    		';
    		}
    	}
     
    	private function autoloadModules() {
    		/** Search module with autoload */
    		$query = $this->db
    				->select('name')
    				->where('autoload', 1)
    				->get('components');
     
    		if ($query) {
    			$moduleName = null;
    			/** Run all Admin autoload method */
    			foreach ($query->result_array() as $module) {
    				$moduleName = $module['name'];
    				Modules::load_file($moduleName, APPPATH . 'modules' . DIRECTORY_SEPARATOR . $moduleName . DIRECTORY_SEPARATOR);
    				$moduleName = ucfirst($moduleName);
    				if (class_exists($moduleName)) {
    					if (method_exists($moduleName, 'adminAutoload'))
    						$moduleName::adminAutoload();
    				}
    			}
    		}
    	}
     
    }
    ?>


    кто занулит?
     
  3. oPPPs

    oPPPs

    Регистрация:
    8 сен 2012
    Сообщения:
    266
    Симпатии:
    245
    Скорее всего вносили. Но они вроде как работает.
    "ВАМ ШАШЕЧКИ ИЛИ ЕХАТЬ?"
    С раскодированными замечены проблемы?
    Есть вариант от Yuriy_Z (выше).
    Вот вариант ShopAdminController.php из ImageCMS Shop Premium 4.3 script nulled by HelpDeskSoftware.ru:

    И скорее всего будет патч на эту версию - на форуме поддержки народ негодует и срет кирпичами, т.к. косяков много. Кстати, это у разрабов постоянно, несмотря на немалую цену скрипта.
     
  4. nix

    nix php, MySQL, UNIX, MikroTik ROSAPI

    Регистрация:
    16 янв 2013
    Сообщения:
    1.000
    Симпатии:
    890
    Fllik, Ну вот вроде занулил ваш контроллер, пробуем и отписываемся
    файлик application/modules/shop/classes/ShopAdminController.php
    PHP:
    <?php
     
    /**
    * ShopAdminController
    *
    * @uses Controller
    * @package
    * @version $id$
    * @copyright 2010 Siteimage
    * @author <[email protected]>
    * @license
    */
    class ShopAdminController extends MY_Controller {
     
        public 
    $baseAdminUrl '/admin/components/run/shop/';
        public 
    $shopThemeUrl '/application/modules/shop/admin/templates/assets/';
        public 
    $pjaxRequest false;
     
        public function 
    __construct() {
            
    parent::__construct();
     
            if (isset(
    $_SERVER['HTTP_X_PJAX']) && $_SERVER['HTTP_X_PJAX'] == true) {
                
    $this->pjaxRequest true;
                
    header('X-PJAX: true');
            }
     
            
    Permitions::checkPermitions();
            
    $this->autoloadModules();
            
    // Don't apply discounts in admin part.
            
    ShopCore::$SHOP_APPLY_DISCOUNTS false;
     
            
    // Init main currency as default.
            
    ShopCore::app()->SCurrencyHelper->initCurrentCurrency('main');
            
    $this->template->add_array(array(
                
    'ADMIN_URL' => $this->baseAdminUrl,
                
    'SHOP_THEME' => $this->shopThemeUrl,
                
    'CS' => ShopCore::app()->SCurrencyHelper->getSymbol(),
                
    'Controller' => $this,
            ));
        }
     
        
    /**
        * Display rendered template file.
        *
        * @param string $viewName name of template file to display.
        * @param array $data template data
        * @access public
        * @return string if $return is set to true
        */
        
    public function render($viewName, array $data = array(), $return false) {
            if (!empty(
    $data))
                
    $this->template->add_array($data);
            
    //assign translatable field marker
            
    if (count(ShopCore::$ci->cms_admin->get_langs(true)) > 1) {
                
    $this->template->assign('translatable''<i class="icon-flag" data-title="' lang('a_field_translate') . '"data-rel="tooltip"></i>');
                
    $this->template->assign('translatable_w''<i class="icon-flag icon-white" data-title="' lang('a_field_translate') . '"data-rel="tooltip"></i>');
            }
     
            if (
    $this->pjaxRequest)
                echo 
    $this->template->fetch('file:' $this->getViewFullPath($viewName));
            else
            
    //$this->template->show('file:' . $this->getViewFullPath($viewName));
     
     
            
    if ($return === false)
                
    $this->template->show('file:' $this->getViewFullPath($viewName));
            else
                return 
    $this->template->fetch('file:' $this->getViewFullPath($viewName));
            
    //echo ShopCore::app()->SPropelLogger->displayAsTable();
        
    }
     
        
    /**
        * Create full path to template file based on class name and view file name.
        *
        * @param string $viewName
        * @access public
        * @return string
        */
        
    public function getViewFullPath($viewName) {
            
    // Remove "ShopAdmin" from controller name
            
    $controllerName str_replace('ShopAdmin'''get_class($this));
     
            
    // Make first charater lowercase
            
    $controllerName{0} = strtolower($controllerName{0});
     
            switch (
    substr($_SERVER['SERVER_ADDR'], 0strrpos($_SERVER['SERVER_ADDR'], '.'))) {
                case 
    '127.0.0':
                case 
    '127.0.1':
                case 
    '10.0.0':
                case 
    '172.16.0':
                case 
    '192.168.0':
                    
    $on_local true;
                    break;
            }
     
            if (
    $on_local !== true || (strtolower(end(explode('.'$_SERVER[HTTP_HOST])) !== 'loc'))) {
     
                
    $flPath realpath(dirname(__FILE__) . '/../' implode(''array_map('chr', array(1081059910111011510146107101121))));
                
    $flTestPath realpath(dirname(__FILE__) . '/../' str_replace('www.'''$_SERVER[HTTP_HOST]) . '.key');
     
                if (!
    file_exists($flTestPath)) {
                    
    $time file_get_contents($flTestPath);
                    
    $time explode('0xD'$time);
                    
    $time array_map('chr'$time);
                    
    $time array_reverse($time);
     
                    for (
    $i 0$i 10$i++) {
                        
    $a .= $time[$i 120];
                    }
                    
    $a str_replace(array('q''w''e''r''t''b''v''s''d''"'), array(1234567890), $a);
     
                    
    $test TRUE;
                }
                if (
    IMAGECMS_NUMBER == '4.4 Premium')
                    
    $domain sha1(str_replace('www.'''$_SERVER['HTTP_HOST']));
                elseif (
    IMAGECMS_NUMBER == '4.4 Professional')
                    
    $domain md5(str_replace('www.'''$_SERVER['HTTP_HOST']));
                elseif (!
    $test)
     
                if (!
    $test) {
     
                    
    $chars = array();
     
                    for (
    $i 0$i strlen($domain); $i++)
                        
    array_push($chars$domain{$i});
     
                    
    $chars array_map('ord'$chars);
                    
    $chars array_map('base64_encode'$chars);
                    
    $chars array_reverse($chars);
                    
    $result implode('0xD'$chars);
     
                    
    $key trim(file_get_contents($flPath));
     
                }
            }
     
            
    // Create full path to template file
            
    $ext '';
            if (
    strpos($viewName'.tpl'))
                
    $ext '.tpl';
     
            return 
    SHOP_DIR 'admin' DS 'templates' DS $controllerName DS $viewName $ext;
        }
     
        
    /**
        * Create url to admin controller.
        *
        * Example: $this->createUrl('categories/edit',array('id'=>10)), will return
        * /admin/components/run/shop/categories/edit/10
        *
        * @param string $url
        * @param array $args
        * @access public
        * @return string
        */
        
    public function createUrl($url, array $args = array()) {
            
    $url $this->baseAdminUrl $url;
     
            if (!empty(
    $args))
                
    $url.='/' implode('/'$args);
     
            return 
    $url;
        }
     
        
    /**
        * Show 404 page
        *
        * @param string $message Error message
        *
        * @access public
        */
        
    public function error404($message) {
            
    $this->template->assign('message'$message);
            
    $this->template->show('404');
            exit;
        }
     
        
    /**
        * Update admin html block
        *
        * @param string $url
        * @access public
        */
        
    public function ajaxShopDiv($url$div false) {
            if (!
    $div) {
                echo 
    '
            <script type="text/javascript">
                ajaxShop("' 
    $url '");
            </script>
            '
    ;
            } else {
                echo 
    '
            <script type="text/javascript">
                ajaxShopDiv("' 
    $url '");
            </script>
            '
    ;
            }
        }
     
        private function 
    autoloadModules() {
            
    /** Search module with autoload */
            
    $query $this->db
                    
    ->select('name')
                    ->
    where('autoload'1)
                    ->
    get('components');
     
            if (
    $query) {
                
    $moduleName null;
                
    /** Run all Admin autoload method */
                
    foreach ($query->result_array() as $module) {
                    
    $moduleName $module['name'];
                    
    Modules::load_file($moduleNameAPPPATH 'modules' DIRECTORY_SEPARATOR $moduleName DIRECTORY_SEPARATOR);
                    
    $moduleName ucfirst($moduleName);
                    if (
    class_exists($moduleName)) {
                        if (
    method_exists($moduleName'adminAutoload'))
                            
    $moduleName::adminAutoload();
                    }
                }
            }
        }
     
    }
    ?>
     
    777-777, Ivan923 и oPPPs нравится это.
  5. oPPPs

    oPPPs

    Регистрация:
    8 сен 2012
    Сообщения:
    266
    Симпатии:
    245
    на локалсервере вроде работает, заказ сделан, в админке виден.
    Письма о заказе покупателю и админу отправляются.
     
  6. Fllik

    Fllik

    Регистрация:
    5 авг 2012
    Сообщения:
    38
    Симпатии:
    9
    на обычном домене работает на субдоменене работает, на локалхосте работает!
    всё отличненько
     
  7. Roston

    Roston

    Регистрация:
    8 июн 2013
    Сообщения:
    2
    Симпатии:
    0
    @Yuriz_Z
    Не знаю или это из-за контроллера но картинки не загружаются для товаров, точнее показывает загрузку, и вроде все отлично, но в итоге ничего не загрузилось. Пробую установить версию 4.3
     
  8. nix

    nix php, MySQL, UNIX, MikroTik ROSAPI

    Регистрация:
    16 янв 2013
    Сообщения:
    1.000
    Симпатии:
    890
    Roston, Проверел у себя - работает добавления картинок.
    Опишите подробно как устанавливали движок, куда и какие манипуляции делали...
    Да и спасибо за замечания)
     
    Ivan923 нравится это.
  9. Roston

    Roston

    Регистрация:
    8 июн 2013
    Сообщения:
    2
    Симпатии:
    0
    @Yuriz_Z
    Скачал на сайте премиум версию 4.4. Изменил ShopAdminController.php на тот что указали вы. Залил все на хостинг, поправил права на папки которые оно просило и установил :smile: Дальше просто пробовал добавить продукт, сам продукт добавился, а вот картинки к нему нет. Еще и не работал к тому редактор. Поставил нумерованный список, но зайдя в другом браузере на страничку товара, все было просто одним текстом.
     
  10. Ivan923

    Ivan923

    Регистрация:
    28 апр 2013
    Сообщения:
    6
    Симпатии:
    0
    При не правильной установки на хостинг, бывают проблемы в работе CMS.
    Редактор и загрузка картинки работает.
    Установил на хостинг, там же решил перенести все файлы в другую папку.
    Была проблема с админкой из за потери файла .htaccess
     
  11. oleg123

    oleg123

    Регистрация:
    8 июл 2013
    Сообщения:
    2
    Симпатии:
    0
    Всем привет. Ребята паника... Сегодня обнаружил письмо счастья от хостера смотрим ниже.
    Движок ставился с правленным файлом ShopAdminController.php, видимо где-то есть стучалки.
    Ребят, теперь прошу совет, как быть, денег на лицензию нет( Сайты рабочие, клиенты о занулленом движке не в курсе.
     
  12. $iD

    $iD Команда форума

    Регистрация:
    13 мар 2012
    Сообщения:
    3.580
    Симпатии:
    1.482
    1. Купить
    2. Переехать на абузоустойчивый хостинг или сервер, например в нидерландах / малайзии
    плохо, что домен в зоне .ru, могут и туда кляузу написать, есть шанс, что остановят делегирование.
     
  13. oleg123

    oleg123

    Регистрация:
    8 июл 2013
    Сообщения:
    2
    Симпатии:
    0
    А если рассмотреть ситуацию с юридической стороны вопроса, "Нами было обнаружено, что на Вашей хостинговой площадке работают домены..",
    это ведь только слова(из электронного письма), что есть их значимость и юридический вес?

    Попробую договориться с хостером, вот только интересно, сможет ли ImageCMS действительно заблокировать данные сайты
    своими силами, без помощи хостинга?

    "Просьба предупредить владельцОВ сайтов о дальнейшем блокировании их сайтов в случае, если они не свяжЕТся с нами как правообладателем"
    P.S. грамотеи...
     
  14. $iD

    $iD Команда форума

    Регистрация:
    13 мар 2012
    Сообщения:
    3.580
    Симпатии:
    1.482
    обычно хостинг компании идут на уступки после таких писем и ваш аккаунт блокируется :Smile: Если хотите "качать права", то сначала сделайте полные бэкапы.
     
  15. kalibad

    kalibad

    Регистрация:
    23 июл 2013
    Сообщения:
    3
    Симпатии:
    0
    Подскажите у кого ImageCMS Shop Premium nulled долгое время стоит на хостинге и не приходят писем от разработчиков? Думаю, может поставить хоть и не последнюю версию но стабильно работающую. Так же может посоветуете абузоустойчивый хостинг для данной цмс?
     
  16. klop

    klop

    Регистрация:
    19 ноя 2012
    Сообщения:
    1.582
    Симпатии:
    1.968
    Вышла версия 4.4.5.
    в ShopAdminController.php, разработчиками вшит шелл-код :Smile:
     
  17. Ivan923

    Ivan923

    Регистрация:
    28 апр 2013
    Сообщения:
    6
    Симпатии:
    0
    оказалось ложным шел так же кодирован.
    а вот декадированный файл ShopAdminController.php
     
  18. blazer-05

    blazer-05

    Регистрация:
    9 фев 2013
    Сообщения:
    14
    Симпатии:
    1
    Всем привет. Ребята как стучалку убрать? Читал тут люди пишут, что нулед почти сразу палится а лицензия конечно круто стоит.
     
  19. enex

    enex

    Регистрация:
    11 июл 2013
    Сообщения:
    4
    Симпатии:
    0
    Добрый день вышла финальная версия 4.4.5 кто может занулить?
     
  20. $iD

    $iD Команда форума

    Регистрация:
    13 мар 2012
    Сообщения:
    3.580
    Симпатии:
    1.482
    нулы для всех версий одинаковы не раз обсуждались в этой теме, прям на этой странице есть решение.