00001 <?php 00002 /** 00003 * Magento 00004 * 00005 * NOTICE OF LICENSE 00006 * 00007 * This source file is subject to the Open Software License (OSL 3.0) 00008 * that is bundled with this package in the file LICENSE.txt. 00009 * It is also available through the world-wide-web at this URL: 00010 * http://opensource.org/licenses/osl-3.0.php 00011 * If you did not receive a copy of the license and are unable to 00012 * obtain it through the world-wide-web, please send an email 00013 * to license@magentocommerce.com so we can send you a copy immediately. 00014 * 00015 * DISCLAIMER 00016 * 00017 * Do not edit or add to this file if you wish to upgrade Magento to newer 00018 * versions in the future. If you wish to customize Magento for your 00019 * needs please refer to http://www.magentocommerce.com for more information. 00020 * 00021 * @category Mage 00022 * @package Mage_Downloadable 00023 * @copyright Copyright (c) 2008 Irubin Consulting Inc. DBA Varien (http://www.varien.com) 00024 * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) 00025 */ 00026 00027 /** 00028 * Downloadable File upload controller 00029 * 00030 * @category Mage 00031 * @package Mage_Downloadable 00032 * @author Magento Core Team <core@magentocommerce.com> 00033 */ 00034 class Mage_Downloadable_FileController extends Mage_Adminhtml_Controller_Action 00035 { 00036 00037 /** 00038 * Upload file controller action 00039 */ 00040 public function uploadAction() 00041 { 00042 $type = $this->getRequest()->getParam('type'); 00043 $tmpPath = ''; 00044 if ($type == 'samples') { 00045 $tmpPath = Mage_Downloadable_Model_Sample::getBaseTmpPath(); 00046 } elseif ($type == 'links') { 00047 $tmpPath = Mage_Downloadable_Model_Link::getBaseTmpPath(); 00048 } elseif ($type == 'link_samples') { 00049 $tmpPath = Mage_Downloadable_Model_Link::getBaseSampleTmpPath(); 00050 } 00051 $result = array(); 00052 try { 00053 $uploader = new Varien_File_Uploader($type); 00054 $uploader->setAllowRenameFiles(true); 00055 $uploader->setFilesDispersion(true); 00056 $result = $uploader->save($tmpPath); 00057 $result['cookie'] = array( 00058 'name' => session_name(), 00059 'value' => $this->_getSession()->getSessionId(), 00060 'lifetime' => $this->_getSession()->getCookieLifetime(), 00061 'path' => $this->_getSession()->getCookiePath(), 00062 'domain' => $this->_getSession()->getCookieDomain() 00063 ); 00064 } catch (Exception $e) { 00065 $result = array('error'=>$e->getMessage(), 'errorcode'=>$e->getCode()); 00066 } 00067 00068 $this->getResponse()->setBody(Zend_Json::encode($result)); 00069 } 00070 00071 /** 00072 * Check admin permissions for this controller 00073 * 00074 * @return boolean 00075 */ 00076 protected function _isAllowed() 00077 { 00078 return Mage::getSingleton('admin/session')->isAllowed('catalog/products'); 00079 } 00080 00081 }