public function moveTmpFileToFile($userId, $insertToken, $articleId)
 {
     $valid = false;
     if ($userId && $insertToken) {
         $uploadTmpTbl = new VC_DbTable_Common("upload_tmp", "id");
         $listTmpUploadFiles = $uploadTmpTbl->fetchAll("user_id = " . $userId . " AND insert_token = '" . $insertToken . "'");
         $fileTbl = new VC_DbTable_Common("store_file", "id");
         $articleFileTbl = new VC_DbTable_Common("store_article_file", "article_id");
         foreach ($listTmpUploadFiles as $tmpFile) {
             $fileData = array();
             $fileData['name'] = $tmpFile['file_name'];
             $fileData['file_name'] = $tmpFile['file_name'];
             $fileData['user_id'] = $userId;
             $fileData['file_path'] = $tmpFile['file_path'];
             $fileData['icon_path'] = $tmpFile['icon_path'];
             $fileData['upload_date'] = $tmpFile['upload_date'];
             $fileId = $fileTbl->insert($fileData);
             //Insert into article_file
             $articleFileTbl->insert(array('article_id' => $articleId, 'file_id' => $fileId, "user_id" => $userId));
         }
         //Remove old file
         $oldFileSql = "CURDATE() - INTERVAL 2 DAY >= upload_date";
         $allOldFile = $uploadTmpTbl->fetchAll($oldFileSql);
         foreach ($allOldFile as $oldFile) {
             @unlink(ROOT_PATH . '/Sources/store/public' . $oldFile->file_path);
         }
         //Remove all file by token and post time
         $delSql = "(user_id = " . $userId . " AND insert_token = '" . $insertToken . "') ";
         $delSql .= " OR CURDATE() - INTERVAL 2 DAY >= upload_date";
         $uploadTmpTbl->delete($delSql);
         //delete file in hdd
         $valid = true;
     }
     return $valid;
 }
 public function editAction()
 {
     $articleId = (int) $this->_getParam('id');
     if ($articleId == 0) {
         throw new VC_Exception("Invalid article delete information");
     }
     $insertTokenNamespace = new Zend_Session_Namespace("INSERT_TOKEN");
     $message = "";
     //Check if this article belong with this user
     $articleTbl = new VC_DbTable_Store_Article();
     $article = $articleTbl->findByIdAndUserId($articleId, $this->userId);
     if ($article) {
         if ($this->_getParam('submit')) {
             if ($this->_getParam('title') && $this->_getParam('content') && $this->_getParam('tpid')) {
                 $updateData = array();
                 $updateData['title'] = $this->_getParam('title');
                 $updateData['content'] = $this->_getParam('content');
                 $updateData['root_link'] = $this->_getParam('root_link');
                 $updateData['topic_id'] = $this->_getParam('tpid');
                 $articleTbl->update($updateData, "id = " . $articleId);
                 $this->_redirect("article/view/?tpid=" . $article->topic_id . "&id=" . $articleId);
             } else {
                 $message = "Bạn phải nhập đầy đủ các phần có dấu  sao (*)";
             }
         }
         $menuObj = new VC_Business_MenuFactory();
         $groupAndTopic = $menuObj->getGroupsAndTopicsOfUser($this->userId);
         //echo "<pre>"; var_dump($groupAndTopic); echo "</pre>"; die;
         $this->view->groupAndTopic = $groupAndTopic;
         $this->view->message = $message;
         $this->view->article = $article;
         $this->view->insertToken = $insertTokenNamespace->insertToken;
         //Get all temp file uploaded of this article
         $uploadTmpTbl = new VC_DbTable_Common("upload_tmp", "id");
         $this->view->listUploadFiles = $uploadTmpTbl->fetchAll("user_id = " . $this->userId . " AND insert_token = '" . $insertTokenNamespace->insertToken . "'");
     } else {
         throw new VC_Exception("This article not belong with you");
     }
 }
 public function indexAction()
 {
     if ($this->userId == 0) {
         throw new VC_Exception("You have not permission");
     }
     $invidualDir = 'u_' . $this->userId;
     $this->_helper->viewRenderer->setNoRender();
     $this->_helper->getHelper('layout')->disableLayout();
     $uploadRootDir = ROOT_PATH . '/Sources/store/public/uploads';
     $uploadDir = $uploadRootDir . '/' . $invidualDir;
     if (!is_dir($uploadDir)) {
         mkdir($uploadDir, 0777);
         copy($uploadRootDir . "/index.html", $uploadDir . "/index.html");
     }
     $error = "";
     $msg = "";
     $config = VC_Config::getConfig();
     $maxFileSize = 0;
     $valid = false;
     if (isset($config['file']['upload']['size'])) {
         $maxFileSize = $config['file']['upload']['size'];
     } else {
         $error = "System error, please contact to administrator to resolve this problem, thank you very much";
     }
     $fileElementName = 'fileToUpload';
     $upload = new Zend_File_Transfer_Adapter_Http("http");
     $allowExt = explode(",", str_replace(" ", "", $config['file']['upload']['ext']));
     $upload->addValidator('Extension', true, $allowExt);
     $upload->addValidator('FilesSize', true, array('min' => '10B', 'max' => $maxFileSize));
     $upload->addValidator('Count', true, array('min' => 1, 'max' => 1));
     $messages = array();
     $files = $upload->getFileInfo();
     if ($upload->isValid() && $upload->isUploaded()) {
         reset($files);
         $fileInputName = key($files);
         //Get file extension
         $fileName = $files[$fileInputName]['name'];
         $ext = substr($fileName, strrpos($fileName, "."));
         $fileName = preg_replace("/[^a-z.0-9]/i", "", $_FILES[$fileInputName]['name']);
         $tempPath = $files[$fileInputName]['tmp_name'];
         $baseName = str_replace($ext, "", $fileName);
         //Name no ext
         if ("" == $fileName) {
             $fileName = time() . $ext;
         }
         if (file_exists($uploadDir . "/" . $fileName)) {
             $fileName = $baseName . "_" . time() . $ext;
         }
         if (move_uploaded_file($tempPath, $uploadDir . "/" . $fileName)) {
             $valid = true;
         } else {
             $error = "Could not upload file, please try again.";
         }
     }
     if ($valid) {
         //Save to upload_tmp in DB
         $uploadTmpTbl = new VC_DbTable_Common("upload_tmp", "id");
         $uploadTmpData = array();
         $uploadTmpData['file_name'] = $this->_getParam("file_name", $fileName);
         $uploadTmpData['user_id'] = $this->userId;
         $uploadTmpData['upload_date'] = date("Y-m-d");
         $insertTokenNamespace = new Zend_Session_Namespace("INSERT_TOKEN");
         $uploadTmpData['insert_token'] = $insertTokenNamespace->insertToken;
         $iconPath = VC_Business_File::getFileIcon($ext, '/uploads/' . $invidualDir . '/' . $fileName);
         $filePath = '/uploads/' . $invidualDir . '/' . $fileName;
         $uploadTmpData['icon_path'] = $iconPath;
         $uploadTmpData['file_path'] = $filePath;
         $uploadTmpTbl->insert($uploadTmpData);
         $result = array('error' => '', 'icon' => $iconPath, 'file' => $filePath, 'name' => $uploadTmpData['file_name']);
         echo Zend_Json_Encoder::encode($result, true);
     } else {
         $messages = $upload->getMessages();
         $result = array('error' => implode("\n", $messages) . "\n" . $error, 'file' => '');
         echo Zend_Json_Encoder::encode($result);
     }
 }