コード例 #1
0
ファイル: Choice.php プロジェクト: emilymwang8/ajk-broker
 /**
  * 二手房-精选房源管理页面
  *返回值 为页面参数,所以必须是数组
  *
  * @param int $broker_id
  * @param int $city_id
  * @param array $extraData $request->get_parameters();
  * @return array
  */
 public static function esf_init_manage($brokerId, $cityId, $extraData = array())
 {
     $attr = array();
     //$attr['bidChoiceIsFull'] = self::checkEsfBidChoiceFull($brokerId,$cityId);
     $houseId = $attr = array();
     //获取经纪人竞价计划
     self::setEsfBrokerAllPlanInfo($brokerId, $cityId);
     $attr['planInfos'] = self::$esfBrokerAllPlanInfo[$brokerId];
     if (empty($attr['planInfos'])) {
         return array();
     }
     $onQueueNumArray = array();
     foreach ($attr['planInfos'] as $key => $value) {
         //转换key
         unset($attr['planInfos'][$key]);
         //剔除非精选推广计划
         if ($value->bidVersion != Model_Plan_EsfAjkPropSpread::CHOICEVERSION) {
             continue;
         }
         $attr['planInfos'][$value->propId] = $value;
         $houseId[] = $value->propId;
         if ($value->model == Model_Plan_EsfAjkPropSpread::BLOCK_CHOICE) {
             $attr['planInfoUrl'][$value->propId]['urlChoice'] = "/ajkbroker/user/ajax/blockchoice";
         } else {
             $attr['planInfoUrl'][$value->propId]['urlChoice'] = "/ajkbroker/user/ajax/choice";
         }
         if ($value->status == Model_Plan_EsfAjkPropSpread::ONQUEUE) {
             //计算排名
             //$onQueueNumArray[$value->id] = sprintf("当前排第%d位",self::getEsfOnQueueNum($value->id,$value->commId,$value->smallprice,$value->bigprice));
             if ($value->model == Model_Plan_EsfAjkPropSpread::BLOCK_CHOICE) {
                 //板块精选
                 $onQueueNumArray[$value->id] = Bll_Plan_Bid_BlockChoice::getEsfOnQueueNum($value->id, $value->areacode, $value->smallprice, $value->bigprice);
             } else {
                 //小区精选
                 $onQueueNumArray[$value->id] = self::getEsfOnQueueNum($value->id, $value->commId, $value->smallprice, $value->bigprice);
             }
         }
     }
     //排队中名词列表
     $attr['onQueueNumArray'] = $onQueueNumArray;
     //判断计划是否已满
     $attr['bidChoiceIsFull'] = self::checkEsfBidChoiceFull($brokerId, $cityId);
     //获取房源信息
     //$houseId = array('168783719','168783720');
     $onLinceHouseInfo = $onQueueHouseInfo = $historyHouseInfo = array();
     $allHouseInfo = Bll_House_EsfHouse::getHouseBaseInfo($houseId, $cityId);
     foreach ($allHouseInfo as $row) {
         $block = Bll_Commtype_Api::getInfoByTypeCode($attr['planInfos'][$row->proId]->areacode);
         $area = Bll_Commtype_Api::getInfoByTypeId($block['parentId']);
         $attr['AreaBlock'][$row->proId]['areaName'] = $area['typeName'];
         $attr['AreaBlock'][$row->proId]['blockName'] = $block['typeName'];
         if ($attr['planInfos'][$row->proId]->status == Model_Plan_EsfAjkPropSpread::ONLINE) {
             $onLinceHouseInfo[] = $row;
         } elseif ($attr['planInfos'][$row->proId]->status == Model_Plan_EsfAjkPropSpread::ONQUEUE) {
             $onQueueHouseInfo[] = $row;
         } else {
             $historyHouseInfo[] = $row;
         }
     }
     $attr['housesInfo'] = array_merge($onLinceHouseInfo, $onQueueHouseInfo, $historyHouseInfo);
     //获取房源所在城市拼音
     $attr['citySet'] = APF::get_instance()->get_config("city_set", "multicity");
     $attr['baseDomain'] = APF::get_instance()->get_config("base_domain");
     return $attr;
 }
コード例 #2
0
ファイル: BlockSet.php プロジェクト: emilymwang8/ajk-broker
 public function handle_request_internal()
 {
     /**
      * @var $request AJKRequest
      */
     $request = APF::get_instance()->get_request();
     $response = APF::get_instance()->get_response();
     $params = $this->getParameters();
     $route_matches = $request->get_router_matches();
     $brokerId = $request->getBrokerId();
     $cityId = $request->getBrokerCityId();
     $userId = $request->getUserId();
     $business = trim($route_matches[1]);
     $prop_id = $route_matches[2];
     if (empty($brokerId)) {
         $response->redirect(Util_Url::buildChoiceResultUrl(http_build_query(array('err_no' => Bll_Plan_Bid_BlockChoice::BID_FAIL_OTHER, 'err_msg' => '请登陆操作', 'from' => 'bid_blockset'))));
         return false;
     }
     $isChoiceCity = false;
     $isChoiceCityTwo = false;
     switch ($business) {
         case 'ajk':
             $isChoiceCity = Bll_City::isBlockChoice($cityId, Const_Site::ANJUKE);
             //修改表city_biz_types 的type还有配置
             $isChoiceCityTwo = Bll_City::isChoiceCity($cityId, Const_Site::ANJUKE);
             break;
     }
     if (!$isChoiceCity) {
         $response->redirect('/user/combo/brokerhome?from=not_choice_city');
         return false;
     }
     //return 'Choice_BlockSet';
     //验证choice城市
     $config = Model_Config_CommonCity::getConfig(Model_Config_CommonCity::CHOICENAME, $cityId);
     /** 判断精选计划开启时间是否到了 */
     //$request->set_attribute('choiceStarted', time()<$config['startTime']);
     $request->set_attribute('choiceStarted', !$this->getCityOpenTimeBegin($config['startTime']));
     $request->set_attribute('choiceStartTimeMsg', sprintf('%d点准时开放', date('H', $config['startTime'])));
     /*if(time()<$config['startTime']){
           $response->redirect(Util_Url::buildChoiceResultUrl(http_build_query(array('err_no'=>Bll_Plan_Bid_Choice::BID_FAIL_OTHER, 'err_msg'=>'还未到精选房源开始时间。', 'from'=>'bid_blockset'))));
           return false;
       }*/
     if (empty($route_matches) || count($route_matches) < 3) {
         $response->redirect(Util_Url::buildChoiceResultUrl(http_build_query(array('err_no' => Bll_Plan_Bid_BlockChoice::BID_FAIL_OTHER, 'err_msg' => '请从精选房源管理页设置精选房源计划', 'from' => 'bid_blockset'))));
         return false;
     }
     if (!is_numeric($route_matches[2])) {
         $response->redirect(Util_Url::buildChoiceResultUrl(http_build_query(array('err_no' => Bll_Plan_Bid_BlockChoice::BID_FAIL_OTHER, 'err_msg' => '房源ID必须是数字', 'from' => 'bid_blockset'))));
         return false;
     }
     $params['ip'] = $request->get_client_ip();
     //        var_dump($business);exit;
     if ($request->is_post_method()) {
         switch ($business) {
             case 'ajk':
                 try {
                     $result = Bll_Plan_Bid_BlockChoice::esf_setting_post($brokerId, $cityId, $prop_id, $userId, $params);
                 } catch (Exception $e) {
                     $result = array('err_no' => Bll_Plan_Bid_BlockChoice::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试');
                 }
                 break;
             default:
                 $result = http_build_query(array('err_no' => Bll_Plan_Bid_BlockChoice::BID_FAIL_OTHER, 'err_msg' => '参数错误。', 'from' => 'bid_blockset'));
                 break;
         }
         $result = array_merge($result, array('act' => $business, 'propId' => $prop_id));
         $response->redirect(Util_Url::buildChoiceResultUrl(http_build_query($result)));
         return false;
     }
     switch ($business) {
         case 'ajk':
             try {
                 $pageAttributes = Bll_Plan_Bid_BlockChoice::esf_setting($brokerId, $cityId, $prop_id, $userId, $params);
             } catch (Exception $e) {
                 $pageAttributes = array('err_no' => Bll_Plan_Bid_BlockChoice::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试');
             }
             break;
         default:
             $response->redirect(Util_Url::buildChoiceResultUrl(http_build_query(array('err_no' => Bll_Plan_Bid_BlockChoice::BID_FAIL_OTHER, 'err_msg' => '参数错误。', 'from' => 'bid_blockset'))));
             break;
     }
     if (isset($pageAttributes['err_no'])) {
         $result = array('err_no' => Bll_Plan_Bid_BlockChoice::BID_FAIL_OTHER, 'err_msg' => $pageAttributes['err_msg'], 'from' => 'bid_blockset');
         $result = array_merge($result, array('act' => $business, 'propId' => $prop_id));
         $response->redirect(Util_Url::buildChoiceResultUrl(http_build_query($result)));
         return false;
     }
     $request->set_attribute('isChoiceCityTwo', $isChoiceCityTwo);
     $request->set_attribute('isChoiceCity', $isChoiceCity);
     $request->set_attribute('business', $business);
     $request->set_attribute('prop_id', $prop_id);
     $this->set_attributes($pageAttributes);
     /**
      * 2015 年关精选打折 预计时间2.1 ~ 3.5
      * TODO 2015.4.1 删除这部分代码
      */
     $isChoiceRebate = Bll_Onoff_Choice::getChoiceRebateByBroekrId($brokerId);
     $this->setAttribute('isChoiceRebate', $isChoiceRebate);
     switch ($business) {
         case 'jp':
             return 'Choice_BlockSetJP';
             break;
         default:
             return 'Choice_BlockSet';
     }
 }
コード例 #3
0
 /**
  * 二手房精选推广设置页面
  *
  * @param $brokerId
  * @param $cityId
  * @param $houseId
  * @param $userId
  * @param array $params
  * @return array
  */
 public static function esf_setting_post($brokerId, $cityId, $houseId, $userId, $params = array())
 {
     $result = array();
     //获取精选推广预算
     $brokerInfo = Bll_BrokerBaseBll::get_instance()->get_broker_info($brokerId);
     $brokerCompanyId = $brokerInfo['BaseInfo']['COMPANYID'];
     $choiceSet = APF::get_instance()->get_config('block_choice_set');
     if (isset($choiceSet[$brokerCompanyId]) && !empty($choiceSet[$brokerCompanyId])) {
         $min_budget = $choiceSet[$brokerCompanyId]['ajk']['ESF_CHOICE_MIN_BUDGET'];
         $max_budget = $choiceSet[$brokerCompanyId]['ajk']['ESF_CHOICE_MAX_BUDGET'];
     } else {
         $min_budget = $choiceSet['default']['ajk']['ESF_CHOICE_MIN_BUDGET'];
         $max_budget = $choiceSet['default']['ajk']['ESF_CHOICE_MAX_BUDGET'];
     }
     //判断预算的合法性
     if ($params['budget'] < $min_budget || $params['budget'] > $max_budget) {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '预算价格范围非法');
     }
     //获取房源信息
     $pageAttribute['housesInfo'] = Bll_House_EsfHouse::getHouseBaseInfo($houseId, $cityId);
     if (empty($pageAttribute['housesInfo'])) {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '房源不存在');
     }
     $houseInfo = $pageAttribute['housesInfo'][0];
     if ($houseInfo->userId != $userId) {
         return array('err_no' => self::BID_FAIL_QUALITY_OR_NEW, 'err_msg' => '房源不属于当前操作人');
     }
     if ($houseInfo->isVisible != 1) {
         return array('err_no' => self::BID_FAIL_QUALITY_OR_NEW, 'err_msg' => '房源是违规房源,不可以参加精选房源推广');
     }
     if ($houseInfo->isHighQulity == 0) {
         return array('err_no' => self::BID_FAIL_QUALITY_OR_NEW, 'err_msg' => '多图、新发15天房源才能参与精选推广');
     }
     if (date('Ymd', strtotime('-15 days')) > date('Ymd', $houseInfo->postDate)) {
         return array('err_no' => self::BID_FAIL_QUALITY_OR_NEW, 'err_msg' => '只能精选推广15天内发布的房源');
     }
     self::setChoiceNum($cityId);
     //判断当前经纪人已经精选推广的房源数
     if (isset($params['act']) && isset($params['rebid'])) {
         if (self::checkEsfBidChoiceFull($brokerId, $cityId, 1)) {
             return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '最多精选推广' . self::$all_esf_plan_num . '套房源');
         }
     } else {
         if (self::checkEsfBidChoiceFull($brokerId, $cityId)) {
             return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '最多精选推广' . self::$all_esf_plan_num . '套房源');
         }
     }
     /** 判断是否是精选开放城市 */
     if (!Bll_City::isChoiceIndependentCity($cityId, Const_Site::ANJUKE)) {
         /** 判断是在套餐推广中 */
         $houseState = Bll_Combo_HouseRelation::getOnlineRelationByHouseId($houseId, Bll_Combo_HouseRelation::SITE_TYPE_AJK);
         if (empty($houseState)) {
             return array('err_no' => self::BID_FAIL_QUALITY_OR_NEW, 'err_msg' => '该房源不在推广中');
         }
     }
     //判断是否已在竞价计划中
     $planInfo = Model_Plan_EsfAjkPropSpread::getChoicePlanInfoByHouseid($houseId);
     if (!empty($planInfo) && !isset($params['rebid'])) {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '房源已经精选');
     }
     /** 防并发 */
     if (false === self::rejectSameRequest(Bll_Plan_Bid_BlockChoice::SITE_AJK, $brokerId, $houseId)) {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '系统繁忙(code:-906)');
     }
     //重新推广,判断结算状态
     if (isset($params['act']) && isset($params['rebid'])) {
         //获取计划信息
         if (!isset($planInfo)) {
             $planInfo = Model_Plan_EsfAjkPropSpread::getChoicePlanInfoByHouseid($houseId);
         }
         if ($planInfo->status == Model_Plan_EsfAjkPropSpread::ONLINE || $planInfo->status == Model_Plan_EsfAjkPropSpread::ONQUEUE) {
             return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '房源已经精选');
         }
         if ($planInfo->tradestatus != Model_Plan_EsfAjkPropSpread::COMPLETETTRADESTATU) {
             return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '房源还未结算完成');
         }
     }
     $housePrice = intval($houseInfo->proPrice * 10000);
     $priceIntervalInfo = Model_House_EsfPrice::get_price($cityId, $housePrice);
     if (empty($priceIntervalInfo)) {
         return array('err_no' => self::BID_FAIL_QUALITY_OR_NEW, 'err_msg' => '房源价格未知');
     }
     $priceId = $priceIntervalInfo['id'];
     $minPrice = $priceIntervalInfo['minPrice'];
     $maxPrice = $priceIntervalInfo['maxPrice'];
     $block = Bll_Commtype_Api::getInfoByTypeCode($houseInfo->areaCode);
     /** 获取点击单价 最低预算不能小于点击单价 */
     try {
         /**
          * @var Bll_Service_Client_HttpResponse $clickPrice
          */
         for ($i = 0; $i < 3; $i++) {
             $clickPrice = Bll_Service_BlockChoice::ajkBlockClickPrice(array('brokerId' => $brokerId, 'cityId' => $cityId, 'price' => $housePrice, 'blockId' => $block['typeId']));
             if ($clickPrice->isSucceeded()) {
                 break;
             }
         }
         if (!$clickPrice->isSucceeded() || $clickPrice['status'] == 'error') {
             return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
         }
         if ($params['budget'] * 100 < $clickPrice['realTradeAmount']) {
             return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '推广预算不能小于点击单价');
         }
         if (isset($params['fromApi']) && $params['fromApi']) {
             /** 来自API 的精选创建计划 */
             $params['price'] = $clickPrice['realTradeAmount'] / 100;
         } else {
             /** 点击单价不能小于当前系统内的单价 防止恶意操作 */
             if ($params['price'] < $clickPrice['realTradeAmount'] / 100) {
                 return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '点击单价错误');
             }
         }
     } catch (Exception $e) {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
     }
     //查询坑情况
     $bucketInfo = Model_Choice_EsfBlockBidBucket::get_bucket_info($houseInfo->areaCode, $priceId);
     if (empty($bucketInfo)) {
         if (Model_Choice_EsfBlockBidBucket::init_bucket_info($houseInfo->areaCode, $priceId, $cityId)) {
             $bucketInfo = array('typeCode' => $houseInfo->areaCode, 'priceId' => $priceId, 'totalNum' => Model_Choice_EsfBidBucket::TOTALNUM, 'usedNum' => 0, 'maxOnlineNum' => Model_Choice_EsfBidBucket::MAXONLINENUM);
         } else {
             return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
         }
     }
     //坑位表维护
     if ($params['show'] == 1) {
         //预判断坑位
         if ($bucketInfo['usedNum'] >= $bucketInfo['maxOnlineNum']) {
             return array('err_no' => self::BID_SHOW_FAIL, 'err_msg' => '推广位置已满,请重新推广!');
         }
         //按照最大在线数目更新坑位表
         if (!Model_Choice_EsfBlockBidBucket::increment_used_num($houseInfo->areaCode, $priceId, 1)) {
             return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
         }
     } else {
         //预判断坑位
         if ($bucketInfo['usedNum'] >= $bucketInfo['totalNum']) {
             return array('err_no' => self::BID_WAIT_FAIL, 'err_msg' => '排队位置已满,请重新推广!');
         }
         //按照最大坑位数目更新
         if (!Model_Choice_EsfBlockBidBucket::increment_used_num($houseInfo->areaCode, $priceId, 0)) {
             return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
         }
     }
     //获取reuqestid
     $year = date('Y');
     $bll = new Bll_Plan_BidFreezeOrderNum($year);
     $requestId = $bll->getRequestId(Bll_Plan_BidFreezeOrderNum::ESF, $userId, $year, 0, $houseId);
     //冻结金额
     $amount = $params['budget'] * 100;
     $note = sprintf("二手房精选房源冻结,propId: %d", $houseId);
     if (($freezeResult = self::bid_freeze($brokerId, $amount, $requestId, $note, Const_PaymentApp::AJK_CHOICE)) === false) {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
     }
     if (!$freezeResult->isSucceeded()) {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
     }
     if ($freezeResult['status'] == 'error') {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '冻结失败!');
     }
     $snNum = $freezeResult['data']['sn'];
     //重新推广,将原来的推广计划置为删除状态
     if (isset($params['act']) && $params['rebid']) {
         $planInfo->status = Model_Plan_EsfAjkPropSpread::DELETE;
         if (!$planInfo->save()) {
             return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
         }
     }
     //新建计划
     $time = time();
     $offer = $params['price'] * 100;
     $stopTime = $time + self::ESF_AUTO_STOP_TIME;
     $endTime = time() + Model_Plan_EsfAjkPropSpread::CHOICELASTINGTIME;
     $arrAddInfo['serialnumber'] = $snNum;
     $arrAddInfo['propId'] = $houseId;
     $arrAddInfo['cityId'] = $cityId;
     $arrAddInfo['commId'] = $houseInfo->commId;
     $arrAddInfo['brokerId'] = $brokerId;
     $arrAddInfo['userId'] = $userId;
     $arrAddInfo['budget'] = $amount;
     $arrAddInfo['balance'] = $amount;
     $arrAddInfo['spreadstartdate'] = $time;
     $arrAddInfo['spreadenddate'] = $endTime;
     $arrAddInfo['bigprice'] = $maxPrice;
     $arrAddInfo['smallprice'] = $minPrice;
     $arrAddInfo['propriceint'] = $housePrice;
     $arrAddInfo['status'] = Model_Plan_EsfAjkPropSpread::ONQUEUE;
     $arrAddInfo['isreserve'] = Model_Plan_EsfAjkPropSpread::RESERVE;
     $arrAddInfo['bidVersion'] = Model_Plan_EsfAjkPropSpread::CHOICEVERSION;
     $arrAddInfo['areacode'] = $houseInfo->areaCode;
     $arrAddInfo['stoptime'] = $stopTime;
     $arrAddInfo['createtime'] = $time;
     $arrAddInfo['offer'] = $offer;
     $arrAddInfo['model'] = Model_Plan_EsfAjkPropSpread::BLOCK_CHOICE;
     //排名系数,请直接绕过 +_+
     $hpratioABll = new Bll_Plan_Bid_EsfHpratioA();
     $arrAddInfo['qulityScore'] = $hpratioABll->getHouseMass($houseId, $brokerId, $cityId, $houseInfo->commId, $houseInfo->hasRoomPic, $houseInfo->isHighQulity, $houseInfo->postDate, $houseInfo->unitPrice);
     $commScore = round($hpratioABll->getCommScore($houseInfo->commId), 5);
     $arrAddInfo['commScore'] = $commScore;
     $userActionScore = $hpratioABll->getUserActionScore($houseId, $cityId);
     $arrAddInfo['behaviorScore'] = $userActionScore;
     $arrAddInfo['hpratioA'] = $hpratioABll->getHpraio($offer, $arrAddInfo['qulityScore'], $userActionScore);
     $hpratioNorm = $hpratioABll->getPpcNormHpratio($arrAddInfo['hpratioA'], $houseInfo->commId, false, $minPrice, $maxPrice, $houseInfo->areaCode);
     $arrAddInfo['commsHpratioA'] = round($commScore * $hpratioNorm, 5);
     if (($planId = Model_Plan_EsfAjkPropSpread::insertLayer($arrAddInfo)) === false) {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
     }
     //新精选队列插入记录
     if (!Bll_Plan_Bid_EsfChoiceQueue::insert($brokerId, $planId, Model_Choice_ActionQueue::ENUM_BEGIN_BY_HAND, date('m'), $brokerId, '经纪人手动开始推广', APF::get_instance()->get_request()->get_client_ip(), $houseId)) {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
     }
     //插入自动停止队列
     $stopType = Model_Plan_EsfAjkPropspreadQueue::AUTOSTOP;
     Model_Plan_EsfAjkPropspreadQueue::insertOne($planId, $stopTime, $stopType);
     //记录log表
     $remark = sprintf("PROP_ID:null=>%d;CITY_ID:null=>%d;AREA_CODE:null=>%d;BROKER_ID:null=>%d;USER_ID:null=>%d;BUDGET:null=>%d;SPREADSTARTDATE:null=>%d;SPREADENDDATE:null=>%d;STATUS:null=>%d;ISRESERVE:null=>%d;SERIALNUMBER:null=>%d;TRADETYPE:0=>1;BALANCE:0=>%d;PROPRICEINT:0=>%d;BIGPRICE:0=>%d;SMALLPRICE:0=>%d", $houseId, $cityId, $houseInfo->areaCode, $brokerId, $userId, $amount, $time, $endTime, Model_Plan_EsfAjkPropSpread::ONQUEUE, Model_Plan_EsfAjkPropSpread::RESERVE, $snNum, $amount, $housePrice, $maxPrice, $minPrice);
     Model_Plan_LogAjkPropspread::addNewLog($planId, $brokerId, Model_Plan_LogAjkPropspread::ADD, $remark);
     //更新reuqest id完成
     if (!$bll->updateRequestComplete($requestId, $snNum, $planId)) {
         return array('err_no' => self::BID_FAIL_OTHER, 'err_msg' => '服务器繁忙,请重试(code: -' . __LINE__ . ')');
     }
     if ($params['show'] == 1) {
         return array('err_no' => self::BID_SHOW_SUCCESS);
     } else {
         $rank = Bll_Plan_Bid_BlockChoice::getEsfOnQueueNum($planId, $houseInfo->areaCode, $minPrice, $maxPrice);
         return array('err_no' => self::BID_WAIT_SUCCESS, 'rank' => $rank);
     }
 }