/**
  * Page のプロセス.
  *
  * @return void
  */
 function process($mode)
 {
     $objLog = new LC_Upgrade_Helper_Log();
     $objJson = new LC_Upgrade_Helper_Json();
     $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' => SITE_URL, 'public_key' => sha1($public_key . $sha1_key), 'sha1_key' => $sha1_key);
     $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 SC_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_PATH . '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;
     }
 }