Skip to main content

facebook-business | Update from 10->12

Does anyone know what could be causing this depreciation issue (act_******** technically is an actual number, but hiding it from the question)?

 Message: Call was not successful
  Method:  POST
  Path:    https://graph.facebook.com/v10.0/act_*********/insights
  Params:  {'date_preset': 'today', 'action_attribution_windows': '["1d_click"]', 'level': 'ad', 'limit': '1000', 'status': '["ACTIVE"]', 'fields': '["account_id","account_name","action_values","actions","ad_id","ad_name","adset_id","adset_name","campaign_id","campaign_name","clicks","cpc","cpm","ctr","date_start","date_stop","impressions","inline_link_clicks","reach","spend","website_purchase_roas"]'}

I'm running a script that makes requests every hour to FB Marketing API from an EC2 instance. I use the following packages:

from facebook_business.api import FacebookAdsApi

from facebook_business.adobjects.ad import Ad
from facebook_business.adobjects.adset import AdSet
from facebook_business.adobjects.user import User
from facebook_business.adobjects.campaign import Campaign
from facebook_business.adobjects.adaccount import AdAccount
from facebook_business.adobjects.adsinsights import AdsInsights
from facebook_business.adobjects.adreportrun import AdReportRun

And they have been updated to version 12.0:

facebook-business 12.0.0

This is the script that runs every hour:

    if str(kwargs['timeframe']) == 'hourly':
        # Looping through AdAccount ids:
        for account in KEYS['ACCOUNT_IDs']:
            print(f'Hourly calls - Loading account: {account}')

            # Fetching ad insights without async on:
            ads = AdAccount(account).get_insights(
                params=kwargs['params'],
                fields=kwargs['fields'],
                is_async=True)
            ads.api_get()

            # While loop to verify that async is done:
            while ads[AdReportRun.Field.async_status] != 'Job Completed':
                time.sleep(1)
                print(ads.api_get())
                if ads[AdReportRun.Field.async_status] == 'Job Failed':
                    break
                else:
                    continue

            counter += 1
            print(f'Daily active calls, counter: {counter}')

            insights = str(ads.get_result(
                params={"limit": 1000},
                fields=ad_fields))

            # Replacing extra string and converting into JSON:
            df_normalized = json.loads(insights.replace('<AdsInsights>', ''))
            print(f'Ad Insights: {df_normalized}')

            # Appending response to main df:
            df = df.append(df_normalized, ignore_index=True)

            time.sleep(.75)

Weirdly enough, if I run this locally in my laptop it runs normally after upgrading the package. I did update in my app under "Settings"->"Advanced" to use version 12.0 on both Upgrade All Calls and Upgrade Calls for App Roles.

I noticed that my Path is still calling an older version (10.0) maybe updating that will do the trick? If yes, how can I update that? However, why wouldn't this call it when running locally in my laptop?

Thanks in advance!!



source https://stackoverflow.com/questions/69352900/facebook-business-update-from-10-12

Comments

Popular posts from this blog

Prop `className` did not match in next js app

I have written a sample code ( Github Link here ). this is a simple next js app, but giving me error when I refresh the page. This seems to be the common problem and I tried the fix provided in the internet but does not seem to fix my issue. The error is Warning: Prop className did not match. Server: "MuiBox-root MuiBox-root-1" Client: "MuiBox-root MuiBox-root-2". Did changes for _document.js, modified _app.js as mentioned in official website and solutions in stackoverflow. but nothing seems to work. Could someone take a look and help me whats wrong with the code? Via Active questions tagged javascript - Stack Overflow https://ift.tt/2FdjaAW

How to show number of registered users in Laravel based on usertype?

i'm trying to display data from the database in the admin dashboard i used this: <?php use Illuminate\Support\Facades\DB; $users = DB::table('users')->count(); echo $users; ?> and i have successfully get the correct data from the database but what if i want to display a specific data for example in this user table there is "usertype" that specify if the user is normal user or admin i want to user the same code above but to display a specific usertype i tried this: <?php use Illuminate\Support\Facades\DB; $users = DB::table('users')->count()->WHERE usertype =admin; echo $users; ?> but it didn't work, what am i doing wrong? source https://stackoverflow.com/questions/68199726/how-to-show-number-of-registered-users-in-laravel-based-on-usertype

Why is my reports service not connecting?

I am trying to pull some data from a Postgres database using Node.js and node-postures but I can't figure out why my service isn't connecting. my routes/index.js file: const express = require('express'); const router = express.Router(); const ordersCountController = require('../controllers/ordersCountController'); const ordersController = require('../controllers/ordersController'); const weeklyReportsController = require('../controllers/weeklyReportsController'); router.get('/orders_count', ordersCountController); router.get('/orders', ordersController); router.get('/weekly_reports', weeklyReportsController); module.exports = router; My controllers/weeklyReportsController.js file: const weeklyReportsService = require('../services/weeklyReportsService'); const weeklyReportsController = async (req, res) => { try { const data = await weeklyReportsService; res.json({data}) console