Пример #1
0
FeedContentPtr FeedMemcContentI::GetFeed(Ice::Long id, const Ice::Current&) {
  // for UserProfileClient test only
  vector<Ice::Long> feedids;
  feedids.push_back(8373921129);
  FeedContentDict dict = FeedMemcClient::instance().GetFeedDict(feedids);
  FeedContentPtr content;
  content = dict[8373921129];
  content->data->xml = "<f v=\"1.0\" type=\"blogPublish\"><time>1300185966866</time><type>601</type><from><id>257876975</id><name>远非</name><tinyimg>0/0/men_tiny.gif</tinyimg></from><blog><id>716684593</id><title>ooxxxwwoo</title><digest>&amp;#23002;&amp;#23452;&amp;#19996;&amp;#20998;&amp;#20139;&amp;#26446;&amp;#22025;&amp;#27427;&amp;#30340;&amp;#26085;&amp;#24535;&amp;#36716;&amp;#65306;&amp;#20854;&amp;#23454;&amp;#22823;&amp;#23478;&amp;#37117;&amp;#34987;&amp;#26085;&amp;#26412;&amp;#22320;&amp;#38663;&amp;#21560;&amp;#24341;&amp;#20102;&amp;#30524;&amp;#29699; &amp;#30495;&amp;#27491;&amp;#26368;&amp;#21361;&amp;#38505;&amp;#30340;&amp;#26159;&amp;#21152;&amp;#24030; &amp;#65288;&amp;#20197;&amp;#19979;&amp;#20026;&amp;#36716;&amp;#36733;&amp;#65289;&amp;#26085;&amp;#26412;&amp;#36825;&amp;#27425;&amp;#29378;&amp;#26292;&amp;#30340;&amp;#22320;&amp;#38663;&amp;#30495;&amp;#30340;&amp;#21560;&amp;#24341;&amp;#20102;&amp;#22823;&amp;#23478;&amp;#30340;&amp;#30524;&amp;#29699;&amp;#65292;&amp;#25105;&amp;#22269;&amp;#30005;&amp;#35270;&amp;#21488;&amp;#26356;&amp;#26159;&amp;#36830;&amp;#31687;&amp;#32047;&amp;#29261;&amp;#30340;&amp;#25253;&amp;#36947;&amp;#20197;&amp;#26399;&amp;#36716;&amp;#31227;&amp;#22823;&amp;#23478;&amp;#23545;&amp;#22269;&amp;#20869;&amp;#29616;&amp;#29366;&amp;#30340;&amp;#19981;&amp;#28385;&amp;#12290;&amp;#20854;&amp;#23454;&amp;#65292;&amp;#22823;&amp;#23478;&amp;#38590;&amp;#36947;&amp;#24536;&amp;#35760;&amp;#20102;&amp;#32654;&amp;#22269;&amp;#21152;&amp;#24030;&amp;#37027;&amp;#22855;&amp;#24618;&amp;#27515;&amp;#20129;&amp;#30340;500&amp;#19975;&amp;#26465;&amp;#40060;&amp;#20102;&amp;#21527;&amp;#65311;&amp;#25105;&amp;#35748;&amp;#20026;&amp;#19981;&amp;#36229;&amp;#36807;&amp;#19968;&amp;#20010;&amp;#26376;&amp;#65292;&amp;#21152;&amp;#24030;&amp;#23558;&amp;#21457;&amp;#29983;&amp;#24046;&amp;#19981;&amp;#22810;9&amp;#32423;&amp;#30340;&amp;#22320;&amp;#38663;&amp;#12290;&amp;#20026;&amp;#37027;&amp;#20123;&amp;#21363;&amp;#23558;&amp;#32633;&amp;#38590;&amp;#30340;&amp;#20154;&amp;#31048;&amp;#31095;&amp;#21543;&amp;#65281;&amp;#65281;&amp;#65281;&amp;#65281; &amp;#27425;&amp;#22768;&amp;#27874;&amp;#12290;&amp;#12290;&amp;#12290;&amp;#36807;&amp;#24378;&amp;#30340;&amp;#27425;&amp;#22768;&amp;#27874;...</digest><url>http://blog.renren.com/GetEntry.do?id=716684593&amp;owner=257876975</url></blog></f>"; 
  content->reply->oldReply = "<f><reply><id>1692426042</id><type>0</type><time>2011-03-15 18:51</time><body>&quot;test1&quot;</body><im><body>test1</body></im><from><id>238489851</id><name>袁飞</name><tinyimg>http://hdn.xnimg.cn/photos/hdn221/20110220/1735/tiny_2kcu_195010p019116.jpg</tinyimg><icon></icon></from></reply></f>";
  content->reply->newReply = "<f><reply><id>1692426042</id><type>0</type><time>2011-03-15 18:51</time><body>&quot;test2&quot;</body><im><body>test2</body></im><from><id>238489851</id><name>袁飞</name><tinyimg>http://hdn.xnimg.cn/photos/hdn221/20110220/1735/tiny_2kcu_195010p019116.jpg</tinyimg><icon></icon></from></reply></f>";
  FeedMemcClient::instance().SetFeed(content);
  return NULL; 
  UserProfile profile;
  MCE_INFO("get profile : " << id );
  bool b = UserProfileClient::instance().Get(id, &profile);
  if (b) {
  MCE_INFO("profile fields : " 
      << " id " << profile.id()
      << " stage " << profile.stage()
      << " gender " << profile.gender()
      << " age " << profile.age()
      << " school " << profile.school()
      << " major " << profile.major()
      << " grade " << profile.grade()
      << " home_area " << profile.home_area() << "@" << profile.home_area().size()
      << " current_area " << profile.current_area() << "@" << profile.current_area().size()
      << " ip " << profile.ip()
      << " ip_area " << profile.ip_area() << "@" << profile.ip_area().size() );
  } else {
    MCE_INFO("profile not found. id=" << id); 
  }

  return FeedMemcClient::instance().GetFeed(id);
};
Пример #2
0
FeedContentPtr MemcFeedTestI::GetFeed(Ice::Long id, const Ice::Current&) {
  // for UserProfileClient test only
  UserProfile profile;
  MCE_INFO("get profile : " << id );
  bool b = UserProfileClient::instance().Get(id, &profile);
  if (b) {
  MCE_INFO("profile fields : " 
      << " id " << profile.id()
      << " stage " << profile.stage()
      << " gender " << profile.gender()
      << " age " << profile.age()
      << " school " << profile.school()
      << " major " << profile.major()
      << " grade " << profile.grade()
      << " home_area " << profile.home_area() << "@" << profile.home_area().size()
      << " current_area " << profile.current_area() << "@" << profile.current_area().size()
      << " ip " << profile.ip()
      << " ip_area " << profile.ip_area() << "@" << profile.ip_area().size() );
  } else {
    MCE_INFO("profile not found. id=" << id); 
  }

  return FeedMemcClient::instance().GetFeed(id);
};
Пример #3
0
bool AdNewGetRequest::response() {
  timeval start;
  gettimeofday(&start, NULL);
  if (!_fcgi_out) {
    MCE_WARN("remove notify fcgi_out null");
    return false;
  }

  _login_uid = 2;
  string uid = getProperty("uid");
  if (_cookies.find("id") != _cookies.end()) {
    uid = _cookies["id"];
  }
  if (!uid.empty()) {
    try {
      _login_uid = boost::lexical_cast<int>(uid);
    } catch (...) {
      MCE_WARN("lexical_cast cookie id error : " << uid);
    }
  }

  string serialized;
  if (_login_uid > 0) {
    bool b = false;
    try {
      StatFunc stat("memc GetSerialized");
      b = UserProfileClient::instance().GetSerialized(_login_uid, &serialized);
    } catch (std::exception& e) {
      MCE_WARN("UserProfileClient error : " << e.what() << " uid="
          << _login_uid);
    }

    if (!b) {
      MCE_INFO("profile not found in memcache. id=" << _login_uid);
      try {
        StatFunc stat("memc AdUserCacheLoader");
        serialized = AdUserCacheLoaderAdapter::instance().GetById(_login_uid);
      } catch (Ice::Exception& e) {
        MCE_WARN("AdUserCacheLoaderAdapter GetById error : " << e << " uid="
            << _login_uid);
      } catch (std::exception& e) {
        MCE_WARN("AdUserCacheLoaderAdapter GetById error : " << e.what()
            << " uid=" << _login_uid);
      }
    }
  }
  // FCGX_PutS("Content-type: application/x-javascript; charset=utf-8\r\n\r\n{}", _fcgi_out);
  // return true;

  UserProfile profile;
  if (serialized.empty()) {
    profile.set_stage(4);
    profile.set_gender(0);
    profile.set_age(25);
    profile.set_school(0);
    profile.set_major(0);
    profile.set_grade(0);
    profile.set_home_area("");
    profile.set_current_area("");
  } else {
    profile.ParseFromString(serialized);
  }

  unsigned int ip = ntohl(inet_addr(GetRemoteAddr().c_str()));

  profile.set_id(_login_uid);
  profile.set_ip(ip);
  profile.set_ip_area(IpAreaCache::instance().GetIpArea(ip));
  profile.SerializeToString(&serialized);

  int rotate_slot = GetCookieInt("an_slot", rand());
  rotate_slot %= 10000;

  AdResultMap ads;
  AdZone2Creatives final_ads;
  string referer = getProperty("ref");
  //MCE_DEBUG("[UrlMaping] ref = " << referer);
  if (referer.empty() || referer.find("http://") == string::npos) {
    referer = getProperty("r");
    if (referer.empty() || referer.find("http://") == string::npos) {
    referer = GetParamFix("HTTP_REFERER");
      //MCE_DEBUG("[UrlMaping] HTTP_REFERER = " << referer);
    }
  }

  bool err_flag = false;

  bool hide = false;
  string isvip = getProperty("isvip");
  string hideads = getProperty("hideads");
  if(isvip.compare("true")==0 && hideads.compare("true")==0) {
    hide = true;
  }

  stringstream log_url;
  try {
    char sep = '&';
    if (referer.find_first_of('?') == string::npos) {
      sep = '?';
    }
    int refresh_source = getPropertyInt("refresh_source", 0);
    int refresh_idx = getPropertyInt("refresh_idx", 0);
    log_url << referer << sep << "refresh_source=" << refresh_source
        << "&refresh_idx=" << refresh_idx;
    
    stringstream stat_desc;
    stat_desc << _login_uid << " GetAds";
    StatFunc stat(stat_desc.str());
  } catch (Ice::Exception& e) {
    MCE_WARN("AdGetRequest::response error : " << e << " uid=" << _login_uid);
    err_flag = true;
  } catch (std::exception& e) {
    MCE_WARN("AdGetRequest::response : " << e.what() << " uid=" << _login_uid);
    err_flag = true;
  }

//  string emtag = "M";

      MCE_DEBUG("debug 001");
  try {
    ads = AdEngineBAdapter::instance().GetAds(serialized, log_url.str(),
        rotate_slot, hide);
    MCE_DEBUG("EngineB size=" << ads.size());
    AdGateI::instance().translate(ads,final_ads);
    MCE_DEBUG("EngineB size=" << final_ads.size());
//    emtag = "M";
  } catch (Ice::Exception& e) {
    MCE_WARN("AdEngineBAdapter::GetAds error : " << e << " uid=" << _login_uid);
    err_flag = true;
  } catch (std::exception& e) {
    MCE_WARN("AdEngineBAdapter::GetAds error : " << e.what() << " uid="
        << _login_uid);
    err_flag = true;
  }

      MCE_DEBUG("debug 002");
  bool tw_flag = false;
  string tag, photo;
  map<long, EngineTypes> self_zones; // 需要中小自助广告广告位id
  for(AdResultMap::iterator it =  ads.begin(); it != ads.end(); it++) {
    if(!it->second.empty() && (it->second.at(0).groupid == -1)) {
      //台湾分尾号流量切分
      //MCE_INFO("Get Ads from AdEngine/AdTw");
      MCE_DEBUG("debug 003");
      if(_login_uid%10 < 2 || _login_uid == 287341024) {
        self_zones[it->first] = TW;
        tw_flag = true;
      } else {
        self_zones[it->first] = ENGINE;
      }
    } else if(!it->second.empty() && (it->second.at(0).groupid == -2)) {
      //余量,不分给台湾
      self_zones[it->first] = ENGINE;
      tag = "rr_REMAIN_1";
    } else if(!it->second.empty() && (it->second.at(0).groupid == -3)) {
      //余量,不分给台湾
      self_zones[it->first] = ENGINE;
      tag = "rr_REMAIN_2";
      photo = "true";
      MCE_DEBUG("photo = true");
    }
  }

      MCE_DEBUG("debug 004");
  if (!self_zones.empty()) {
    try {
      AdResultMap e_ads_;
      AdZone2Creatives e_ads;
      MCE_DEBUG("debug 005");
      //台湾分尾号流量切分
      if((_login_uid%10 < 2 || _login_uid == 287341024) && tw_flag) {
      MCE_DEBUG("debug 006");
        MCE_DEBUG("[TW_DEBUG] AdGetRequest::response --> enter to request Tw");
        e_ads_ = AdTwAdapter::instance().GetAds(serialized, log_url.str(), rotate_slot);
        AdGateI::instance().translate(ads,final_ads);
      } else {
      MCE_DEBUG("debug 007");
        MCE_DEBUG("AdGetRequest::response --> from AdEngine rotate_slot = "
            << rotate_slot);
        UserAndAction ua;
        ua.id = profile.id();
        ua.stage = profile.stage();
        ua.gender = profile.gender();
        ua.age = profile.age();
        ua.school = profile.school();
        ua.userMajor = profile.major();
        ua.grade = profile.grade();
        ua.homeArea = profile.home_area();
        ua.currentArea = profile.current_area();
        ua.ip = profile.ip();
        ua.ipArea = profile.ip_area();
        ua.actionType = ActionType::PAGEVIEW;
        AdRequest ad_request;
        ad_request.userAndAction = ua;
        ad_request.referer = referer;
        //url_mapping
       // set<Ice::Long> zone_ids;
        for (map<long, EngineTypes>::iterator zit = self_zones.begin(); zit != self_zones.end(); zit++) {
          long z_key = (*zit).first;
           if( photo == "true" && z_key == 100000000072 ) {
              ad_request.zoneDict[z_key] = 2;
           }else{
              ad_request.zoneDict[z_key] = 0;
            }
              ad_request.attributes[boost::lexical_cast<string>(z_key)]=tag;
        }
 //       AdUrlMaping::instance().GetAdZone(referer, ua.stage, zone_ids);
        //AdCreativeCache::instance().GetZoneDict(zone_ids, ad_request.zoneDict);
        MCE_DEBUG("AdGetRequest::response --> enter to request JavaServer");
        e_ads_=AdEngineJAdapter::instance().Request(ad_request);
        AdGateI::instance().translate(e_ads_,e_ads);
        //e_ads = AdEngineUAdapter::instance().GetAdsByZone(serialized, log_url.str(), rotate_slot, _login_uid, tag);
        //e_ads_ = AdEngineUAdapter::instance().GetAds(serialized, log_url.str(), rotate_slot, _login_uid, tag, photo);
      }
      if (e_ads.empty()) {
        MCE_DEBUG("AdGetRequest::response --> from AdEngineJ empty ");
      } else {
        for(AdZone2Creatives::iterator xxit =  e_ads.begin(); xxit != e_ads.end(); xxit++) {
          MCE_DEBUG("AdGetRequest::response --> from AdEngineJ" << xxit->second.size());
        }
      }
      for (map<long, EngineTypes>::iterator zit = self_zones.begin(); zit != self_zones.end(); zit++) {
        AdZone2Creatives::iterator eit = e_ads.find(zit->first);
        if (eit != e_ads.end()) {
          //eads[zit->first] = eit->second;
          //在相册页面,如果广告位wb1成功展示自助,则去掉wb2位置的广告
          /*if(100000000072 == zit->first) {
            ads[100000000073] = AdInfoSeq();
          }*/
        } else {
          ads[zit->first] = AdInfoSeq();
        }
      }
      for(AdZone2Creatives::const_iterator ad_x_it = e_ads.begin() ; ad_x_it != e_ads.end() ; ad_x_it ++ ){
        final_ads[ad_x_it->first] = ad_x_it->second; 
        MCE_DEBUG("AdGetRequest::response --> from AdEngineJ "  << ad_x_it->first <<"  " <<ad_x_it->second.size());
         if( ad_x_it->second.size() > 0 ) {
          for( int vi =0 ; vi < ad_x_it->second.size() ;vi ++ ) {
            MCE_DEBUG("widgetis =   " << ad_x_it->second[vi].widgetid);
          } 
         }
      }
    } catch (Ice::Exception& e) {
      MCE_WARN("AdEngineUAdapter/AdTwAdapter::GetAds error : " << e << " uid=" << _login_uid);
      err_flag = true;
    } catch (std::exception& e) {
      MCE_WARN("AdEngineUAdapter/AdTwAdapter::GetAds error : " << e.what() << " uid="
          << _login_uid);
      err_flag = true;
    }
  }
  if (err_flag) {
    stringstream stat_desc;
    stat_desc << _login_uid << " PushDefault";
    StatFunc stat(stat_desc.str());
    AdCreativeCache::instance().PushDefault(_login_uid, profile.stage(), GetRemoteAddr(),
        referer, &ads);
    AdGateI::instance().translate(ads,final_ads);
  }

  stringstream ad_header;
  string ad_body;
  if (render_ == RT_HTML) {
    ad_header
        << "Content-type: text/html; charset=utf-8\r\nSet-Cookie: an_slot="
        << ++rotate_slot << "; path=/ebpn\r\n\r\n";
    AdCreativeCache::instance().Get(final_ads, &ad_body);
    MCE_INFO("final ad size : "<< final_ads.size());
  } else if (render_ == RT_JSON) {
    ad_header
        << "Content-type: application/x-javascript; charset=utf-8\r\nSet-Cookie: an_slot="
        << ++rotate_slot << "; path=/ebpn\r\n\r\n";
    stringstream stat_desc;
    stat_desc << _login_uid << " GetJson";
    StatFunc stat(stat_desc.str());
    AdCreativeCache::instance().GetJson(referer, getPropertyInt(
        "refresh_source", 0), getPropertyInt("refresh_idx", 0), self_zones, final_ads,
        &ad_body);
    MCE_INFO("final ad size(json) : "<< final_ads.size());
  }

  FCGX_PutS(ad_header.str().c_str(), _fcgi_out);
  FCGX_PutS(ad_body.c_str(), _fcgi_out);
  timeval end;
  gettimeofday(&end, NULL);
  AdGateI::instance().ping_sender_.Send("GetAds", 1000*(end.tv_sec-start.tv_sec)+(end.tv_usec-start.tv_usec)/1000);
  return true;
}