1 public function getAdsByGPSAndUserIdAndLanguageId(array $parameters, $userId, $languageId)
3 $longitude = $parameters['longitude'];
4 $latitude = $parameters['latitude'];
5 $radius = sfConfig::get('app_radius', '100');
6 $adIds = Doctrine_Manager::getInstance()->getCurrentConnection()->fetchColumn(
7 SELECT ad_id FROM office INNER JOIN office_ads ON (office_ads.office_id=office.id)
8 WHERE ST_DWithin(office_gps, ST_GeographyFromText(SRID=4326;POINT($longitude $latitude)), $radius));
9 foreach ($adIds as $adId) {
10 $adIds[] = Doctrine_Manager::getInstance()->getCurrentConnection()->fetchOne(
11 SELECT ad.id FROM ad INNER JOIN company_category ON (ad.company_categ_id=company_category.id)
12 INNER JOIN general_category ON (company_category.general_categ_id=general_category.id)
13 INNER JOIN user_basket ON (user_basket.general_categ_id=general_category.id)
14 WHERE user_id=$userId AND ad.id=$adId);
17 foreach($adIds as $adId)
18 $ads[] = $this->findOneByAdIdAndLanguageId($adId, $languageId);