我创建我自己的仪表板,可以帮助我保持我运行的Facebook广告的轨道。
我已经无法搞清楚的是:
我怎样才能检索到的广告ID的有活动或之后对我而言没有进一步的动作可能很快就会被激活的所有广告的阵列?
换句话说,我想我已经设置为有效,内Adsets并且是有效的广告活动中存在的所有广告(因此这些广告是活现在)...加上所有的广告,从我的角度来看是积极但Facebook已经设置到另一个状态,如待审核(并将于近期重新设置为活动)。
下面我有一些代码,但问题是,它也意外地包括挂起广告 - 一次审查和批准的Facebook - 将不活动而不是主动的(因为我已经设置他们的方式)。我不希望被包含在我的报告这类广告。
我的报告应只显示我的人在那里我主动花钱或有尽快批准FB他们花钱的潜力。
我想我明白在configured_status
effective_status
和AbstractArchivableCrudObjectFields
之间的差别,但我不知道这是足以帮助我,因为我有很多设置为活动是内Adsets是无效的广告的,我不希望看到我在报告中列出的那些。
任何建议?
public function getActiveAdIds() {
$key = 'activeAdIds';
$adIdsJson = Cache::get($key);
if ($adIdsJson) {
$adIds = json_decode($adIdsJson);
} else {
$adsResponse = $this->getAdsByStatus([ArchivableCrudObjectEffectiveStatuses::ACTIVE, ArchivableCrudObjectEffectiveStatuses::PENDING_REVIEW]);
$ads = $adsResponse->data;
$adIds = [];
foreach ($ads as $ad) {
$adIds[] = $ad->id;
}
$adIdsJson = json_encode($adIds);
Cache::put($key, $adIdsJson, 1);
}
return $adIds;
}
public function getAdsByStatus($statuses) {
$params = [\FacebookAds\Object\Fields\AbstractArchivableCrudObjectFields::EFFECTIVE_STATUS => $statuses];
$adAccount = new AdAccount(self::ACT_PREPEND . $this->fbConfig['account_id']);
$cursor = $adAccount->getAds([], $params);
$response = $cursor->getResponse();
$jsonString = $response->getBody();
return json_decode($jsonString);
}
我得到基于对我的积极活动的资产统计。我有119个广告帐户。这是PHP代码我将它用于这个目的(改善将理解任何建议):
$fields = array(AdsInsightsFields::ACCOUNT_NAME,AdsInsightsFields::CAMPAIGN_ID,
AdsInsightsFields::CAMPAIGN_NAME, AdsInsightsFields::ADSET_ID,
AdsInsightsFields::ADSET_NAME,AdsInsightsFields::DATE_START,
AdsInsightsFields::DATE_STOP,AdsInsightsFields::REACH,
AdsInsightsFields::SPEND, AdsInsightsFields::IMPRESSIONS,
AdsInsightsFields::CLICKS, AdsInsightsFields::WEBSITE_CLICKS,
AdsInsightsFields::CALL_TO_ACTION_CLICKS,AdsInsightsFields::ACTIONS,
AdsInsightsFields::TOTAL_ACTIONS,AdsInsightsFields::CPC,
AdsInsightsFields::CPM,AdsInsightsFields::CPP,
AdsInsightsFields::CTR,AdsInsightsFields::OBJECTIVE,);
$params_c['date_preset'] = AdDatePresetValues::YESTERDAY;
$params_c['time_increment'] = 1;
$params_c['action_attribution_windows'] = array('1d_view', '28d_click');
$params_c['effective_status'] = AdStatusValues::ACTIVE;
$params_c['level'] = AdsInsightsLevelValues::ADSET;
$params_c['filtering'] = [array("field"=>"campaign.delivery_info",
"operator"=>"IN",
"value"=>array("active"))];
$params_c['fields']= $fields;
try{
// Initialize a new Session and instanciate an Api object
Api::init(self::api_key, self::secret_token, self::extended_token)->getHttpClient()->setCaBundlePath( $this->path_cert);
// The Api object is now available trough singleton
$api = Api::instance();
$user = new \FacebookAds\Object\Business($business_id);
$user->read(array(BusinessFields::ID));
//get all ad_account from Business
$accounts = $user->getAssignedAdAccounts(
array(
AdAccountFields::ID,
),
array('limit'=>1000,)
);
} catch (FacebookAds\Exception\Exception $ex) {
return $ex->getMessage();
}
if(isset($accounts) && ($accounts->count() > 0)):
do{
$ad_account = $accounts->current();
$adset_insights = $ad_account->getInsights($fields,$params_c);
do {
$adset_insights->fetchAfter();
} while ($adset_insights->getNext());
$adsets = $adset_insights->getArrayCopy(true);
}
while ($accounts->current());
endif;
如果您在查询中包含该广告的adset{end_time}
场,你可以假设广告没有实际运行,如果END_TIME在过去。这是我们如何让广告的基地名单来查询。
我们把(这可能不会帮助你,很遗憾,但可以帮助他人)的下一步是建立一个批处理简单的要求(每一个AD),看看是否有这一天任何见解数据。如果响应是一个空的“数据”阵列,我们可以从广告列表中删除该ID。
之后,我们已经降低了广告列表的大小与这两个步骤中,我们可以然后进行运行我们所有的细目报告的要求。这种方法几乎减少了一半我们的API请求。
我还没有找到一种方法,做到了“给我是肯定的运行这一天的所有广告”一步到位查询。
编辑:我只是找到了一个更好的办法来做到这一点....:
curl -G \
-d 'access_token=<ACCESS_TOKEN>' \
-d 'level=campaign' \
-d 'filtering=[{field:"ad.impressions",operator:"GREATER_THAN",value:0}]' \
'https://graph.facebook.com/v2.7/act_<ACCOUNT_ID>/insights'