コード例 #1
0
 /**
  * Currently only works for products containing one single download
  *
  * @param IsotopeProduct $objProduct
  * @param array          $arrConfig
  */
 public function downloadSingleProduct(IsotopeProduct $objProduct, array $arrConfig = array())
 {
     if (($objDownload = Download::findByPid($objProduct->getProductId())) !== null && ($strPath = Files::getPathFromUuid($objDownload->singleSRC))) {
         // TODO count downloads
         // start downloading the file (protected folders also supported)
         \Controller::redirect(Environment::getUrl() . '?file=' . $strPath);
     }
 }
コード例 #2
0
 /**
  * Find prices for a given product and collection
  *
  * @param IsotopeProduct|Standard                    $objProduct
  * @param IsotopeProductCollection|ProductCollection $objCollection
  * @param array                                      $arrOptions
  *
  * @return IsotopePrice
  */
 public static function findByProductAndCollection(IsotopeProduct $objProduct, IsotopeProductCollection $objCollection, array $arrOptions = array())
 {
     $t = static::$strTable;
     $arrOptions['column'] = array();
     $arrOptions['value'] = array();
     if ($objProduct->hasAdvancedPrices()) {
         $time = \Date::floorToMinute($objCollection->getLastModification());
         $arrGroups = static::getMemberGroups($objCollection->getRelated('member'));
         $arrOptions['column'][] = "{$t}.config_id IN (" . (int) $objCollection->config_id . ",0)";
         $arrOptions['column'][] = "{$t}.member_group IN(" . implode(',', $arrGroups) . ")";
         $arrOptions['column'][] = "({$t}.start='' OR {$t}.start<'{$time}')";
         $arrOptions['column'][] = "({$t}.stop='' OR {$t}.stop>'" . ($time + 60) . "')";
         $arrOptions['order'] = "{$t}.config_id DESC, " . \Database::getInstance()->findInSet('member_group', $arrGroups) . ", {$t}.start DESC, {$t}.stop DESC";
     } else {
         $arrOptions['column'][] = "{$t}.config_id=0";
         $arrOptions['column'][] = "{$t}.member_group=0";
         $arrOptions['column'][] = "{$t}.start=''";
         $arrOptions['column'][] = "{$t}.stop=''";
     }
     if ($objProduct->hasVariantPrices() && !$objProduct->isVariant()) {
         $arrIds = $objProduct->getVariantIds() ?: array(0);
         $arrOptions['column'][] = "{$t}.pid IN (" . implode(',', $arrIds) . ")";
     } else {
         $arrOptions['column'][] = "{$t}.pid=" . ($objProduct->hasVariantPrices() ? $objProduct->id : $objProduct->getProductId());
     }
     $objResult = static::find($arrOptions);
     return null === $objResult ? null : $objResult->filterDuplicatesBy('pid');
 }
コード例 #3
0
 /**
  * Find related products of a product
  * @param   IsotopeProduct
  * @param   array
  * @param   array
  * @return  \Model\Collection|null
  */
 public static function findByProductAndCategories(IsotopeProduct $objProduct, array $arrCategories, array $arrOptions = array())
 {
     $t = static::$strTable;
     $arrOptions = array_merge(array('column' => array("{$t}.pid=?", "{$t}.category IN (" . implode(',', $arrCategories) . ")"), 'value' => array($objProduct->getProductId()), 'order' => \Database::getInstance()->findInSet("{$t}.category", $arrCategories), 'return' => 'Collection'), $arrOptions);
     return static::find($arrOptions);
 }