Example #1
0
 /**
  * Page のプロセス.
  *
  * @return void
  */
 public function process($mode)
 {
     $objLog = new LogHelper();
     $objJson = new JsonHelper();
     $objLog->start($mode);
     $dbFactory = Application::alias('eccube.db.factory');
     $arrSystemInfo = array('eccube_version' => ECCUBE_VERSION, 'php_version' => phpversion(), 'db_version' => $dbFactory->sfGetDBVersion());
     $objJson->setSuccess($arrSystemInfo);
     $objJson->display();
     $objLog->end();
 }
Example #2
0
 /**
  * アクセスチェック
  *
  * @return boolean
  */
 public function isValidAccess($mode)
 {
     $objLog = new LogHelper();
     switch ($mode) {
         // モジュールダウンロード
         case 'download':
             if ($this->isLoggedInAdminPage() === true) {
                 $objLog->log('* admin login ok');
                 return true;
             }
             break;
             // 自動アップロード最新ファイル取得
         // 自動アップロード最新ファイル取得
         case 'patch_download':
             // モジュール自動アップロード
         // モジュール自動アップロード
         case 'auto_update':
             $objForm = Application::alias('eccube.form_param');
             $objForm->addParam('public_key', 'public_key', MTEXT_LEN, '', array('EXIST_CHECK', 'ALNUM_CHECK', 'MAX_LENGTH_CHECK'));
             $objForm->addParam('sha1_key', 'sha1_key', MTEXT_LEN, '', array('EXIST_CHECK', 'ALNUM_CHECK', 'MAX_LENGTH_CHECK'));
             $objForm->setParam($_POST);
             $objLog->log('* param check start');
             $arrErr = $objForm->checkError();
             if ($arrErr) {
                 $objLog->log('* invalid param ' . print_r($arrErr, true));
                 return false;
             }
             $objLog->log('* public_key check start');
             $public_key = $this->getPublicKey();
             if (empty($public_key)) {
                 $objLog->log('* public_key not found');
                 return false;
             }
             $sha1_key = $objForm->getValue('sha1_key');
             $public_key_sha1 = $objForm->getValue('public_key');
             $objLog->log('* ip check start');
             if ($public_key_sha1 === sha1($public_key . $sha1_key)) {
                 $objLog->log('* auto update login ok');
                 return true;
             }
             break;
         default:
             $objLog->log('* mode invalid ' . $mode);
             return false;
     }
     return false;
 }
Example #3
0
 /**
  * Page のプロセス.
  *
  * @return void
  */
 public function process($mode)
 {
     $objLog = new LogHelper();
     $objJson = new JsonHelper();
     $objLog->start($mode);
     // 管理画面ログインチェック
     $objLog->log('* admin auth start');
     if ($this->isLoggedInAdminPage() !== true) {
         $objJson->setError(OSTORE_E_C_ADMIN_AUTH);
         $objJson->display();
         $objLog->error(OSTORE_E_C_ADMIN_AUTH);
         return;
     }
     // 認証キーの取得
     $public_key = $this->getPublicKey();
     $sha1_key = $this->createSeed();
     $objLog->log('* public key check start');
     if (empty($public_key)) {
         $objJson->setError(OSTORE_E_C_NO_KEY);
         $objJson->display();
         $objLog->error(OSTORE_E_C_NO_KEY);
         return;
     }
     // リクエストを開始
     $objLog->log('* http request start');
     $arrPostData = array('eccube_url' => HTTP_URL, 'public_key' => sha1($public_key . $sha1_key), 'sha1_key' => $sha1_key, 'ver' => ECCUBE_VERSION);
     $objReq = $this->request('products_list', $arrPostData);
     // リクエストチェック
     $objLog->log('* http request check start');
     if (\PEAR::isError($objReq)) {
         $objJson->setError(OSTORE_E_C_HTTP_REQ);
         $objJson->display();
         $objLog->error(OSTORE_E_C_HTTP_REQ, $objReq);
         return;
     }
     // レスポンスチェック
     $objLog->log('* http response check start');
     if ($objReq->getResponseCode() !== 200) {
         $objJson->setError(OSTORE_E_C_HTTP_RESP);
         $objJson->display();
         $objLog->error(OSTORE_E_C_HTTP_RESP, $objReq);
         return;
     }
     $body = $objReq->getResponseBody();
     $objRet = $objJson->decode($body);
     // JSONデータのチェック
     $objLog->log('* json deta check start');
     if (empty($objRet)) {
         $objJson->setError(OSTORE_E_C_FAILED_JSON_PARSE);
         $objJson->display();
         $objLog->error(OSTORE_E_C_FAILED_JSON_PARSE, $objReq);
         return;
     }
     // ステータスチェック
     $objLog->log('* json status check start');
     if ($objRet->status === OSTORE_STATUS_SUCCESS) {
         $objLog->log('* get products list ok');
         $arrProducts = array();
         foreach ($objRet->data as $product) {
             $arrProducts[] = get_object_vars($product);
         }
         $objView = new AdminView();
         $objView->assign('arrProducts', $arrProducts);
         $template = 'ownersstore/products_list.tpl';
         if (!$objView->_smarty->template_exists($template)) {
             $objLog->log('* template not exist, use default template');
             // デフォルトテンプレートを使用
             $template = DATA_REALDIR . 'Smarty/templates/default/admin/' . $template;
         }
         $html = $objView->fetch('ownersstore/products_list.tpl');
         $objJson->setSuccess(array(), $html);
         $objJson->display();
         $objLog->end();
         return;
     } else {
         // 配信サーバー側でエラーを補足
         echo $body;
         $objLog->error($objRet->errcode, $objReq);
         return;
     }
 }