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

ValueError: X has 10 features, but LinearRegression is expecting 1 features as input

So, I am trying to predict the model but its throwing error like it has 10 features but it expacts only 1. So I am confused can anyone help me with it? more importantly its not working for me when my friend runs it. It works perfectly fine dose anyone know the reason about it? cv = KFold(n_splits = 10) all_loss = [] for i in range(9): # 1st for loop over polynomial orders poly_order = i X_train = make_polynomial(x, poly_order) loss_at_order = [] # initiate a set to collect loss for CV for train_index, test_index in cv.split(X_train): print('TRAIN:', train_index, 'TEST:', test_index) X_train_cv, X_test_cv = X_train[train_index], X_test[test_index] t_train_cv, t_test_cv = t[train_index], t[test_index] reg.fit(X_train_cv, t_train_cv) loss_at_order.append(np.mean((t_test_cv - reg.predict(X_test_cv))**2)) # collect loss at fold all_loss.append(np.mean(loss_at_order)) # collect loss at order plt.plot(np.log(al...

Sorting large arrays of big numeric stings

I was solving bigSorting() problem from hackerrank: Consider an array of numeric strings where each string is a positive number with anywhere from to digits. Sort the array's elements in non-decreasing, or ascending order of their integer values and return the sorted array. I know it works as follows: def bigSorting(unsorted): return sorted(unsorted, key=int) But I didnt guess this approach earlier. Initially I tried below: def bigSorting(unsorted): int_unsorted = [int(i) for i in unsorted] int_sorted = sorted(int_unsorted) return [str(i) for i in int_sorted] However, for some of the test cases, it was showing time limit exceeded. Why is it so? PS: I dont know exactly what those test cases were as hacker rank does not reveal all test cases. source https://stackoverflow.com/questions/73007397/sorting-large-arrays-of-big-numeric-stings

How to load Javascript with imported modules?

I am trying to import modules from tensorflowjs, and below is my code. test.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title </head> <body> <script src="https://cdn.jsdelivr.net/npm/@tensorflow/tfjs@2.0.0/dist/tf.min.js"></script> <script type="module" src="./test.js"></script> </body> </html> test.js import * as tf from "./node_modules/@tensorflow/tfjs"; import {loadGraphModel} from "./node_modules/@tensorflow/tfjs-converter"; const MODEL_URL = './model.json'; const model = await loadGraphModel(MODEL_URL); const cat = document.getElementById('cat'); model.execute(tf.browser.fromPixels(cat)); Besides, I run the server using python -m http.server in my command prompt(Windows 10), and this is the error prompt in the console log of my browser: Failed to loa...