Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/edbizarro/laravel-facebook-ads
Facebook & Instagram Ads API for Laravel
https://github.com/edbizarro/laravel-facebook-ads
facebook facebook-ads facebook-api instagram-ads instagram-api laravel laravel-facebook-ads
Last synced: 3 days ago
JSON representation
Facebook & Instagram Ads API for Laravel
- Host: GitHub
- URL: https://github.com/edbizarro/laravel-facebook-ads
- Owner: edbizarro
- License: mit
- Created: 2016-04-07T05:30:14.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2023-02-06T08:07:38.000Z (almost 2 years ago)
- Last Synced: 2024-12-29T17:11:50.409Z (10 days ago)
- Topics: facebook, facebook-ads, facebook-api, instagram-ads, instagram-api, laravel, laravel-facebook-ads
- Language: PHP
- Homepage:
- Size: 281 KB
- Stars: 125
- Watchers: 10
- Forks: 32
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
![logo](laravel-facebook-ads.png)
# Laravel Facebook Ads
Get ads infos (campaigns, ads, insights, etc...) from Facebook & Instagram Ads API
* Supported Facebook API version: >= v3.0
---
[![Packagist](https://img.shields.io/packagist/v/edbizarro/laravel-facebook-ads.svg)](https://packagist.org/packages/edbizarro/laravel-facebook-ads) [![Code Climate](https://codeclimate.com/github/edbizarro/laravel-facebook-ads/badges/gpa.svg)](https://codeclimate.com/github/edbizarro/laravel-facebook-ads) [![Codacy Badge](https://api.codacy.com/project/badge/Grade/1417f30a21a549be812b54d59fdfdf0e)](https://www.codacy.com/app/edbizarro/laravel-facebook-ads?utm_source=github.com&utm_medium=referral&utm_content=edbizarro/laravel-facebook-ads&utm_campaign=Badge_Grade) [![StyleCI](https://styleci.io/repos/55666212/shield)](https://styleci.io/repos/55666212) ![Packagist](https://img.shields.io/packagist/dm/edbizarro/laravel-facebook-ads.svg)
---
## Installation
Follow this steps to use this package on your Laravel installation
### Installing with composer
```bash
composer require edbizarro/laravel-facebook-ads
```The package will automatically register it's service provider.
For Laravel <= 5.4 add the provider manually
### Load service provider (optional Laravel <= 5.4 only)
You need to update your `config/app.php` configuration file to register our service provider, adding this line on `providers` array:
```php
Edbizarro\LaravelFacebookAds\Providers\LaravelFacebookServiceProvider::class
```### Enable the facade (optional)
This package comes with an facade to make the usage easier. To enable it, add this line at `config/app.php` on `alias` array:
```php
'FacebookAds' => Edbizarro\LaravelFacebookAds\Facades\FacebookAds::class
```## Configuration
If you want to change any configurations, you need to publish the package configuration file. To do this, run ` artisan vendor:publish --provider="Edbizarro\LaravelFacebookAds\Providers\LaravelFacebookServiceProvider"` on terminal.
This will publish a `facebook-ads.php` file on your configuration folder like this:```php
env('FB_ADS_APP_ID'),
'app_secret' => env('FB_ADS_APP_SECRET'),
];
```> Note that this file uses environment variables, it's a good practice put your secret keys on your `.env` file adding this lines on it:
```
FB_ADS_APP_ID="YOUR_APP_ID"
FB_ADS_APP_SECRET="YOUR_APP_SECRET_KEY"
```## First steps
Before using it, it's necessary to initialize the library with an valid [access token](https://developers.facebook.com/docs/facebook-login/access-tokens#usertokens), [php example](https://github.com/facebook/php-graph-sdk/blob/master/docs/examples/facebook_login.md) with:
```php
FacebookAds::init($accessToken);
```Now that everything is set up, it's easy to start using!
#### Example getting all ads
```php
$ads = FacebookAds::adAccounts()->all()->map(function ($adAccount) {
return $adAccount->ads(
[
'name',
'account_id',
'account_status',
'balance',
'campaign',
'campaign_id',
'status'
]
);
});
```## Usage
To obtain a list of all `AdAccount` available fields, look at [this](https://github.com/facebook/facebook-php-ads-sdk/blob/master/src/FacebookAds/Object/Fields/AdAccountFields.php).
### adAccounts
To obtain an adAccounts instance:
```php
$adAccounts = $adsApi->adAccounts();
```#### all
Use this method to retrieve your owned Ad Accounts. This method accepts an array as argument containing a list of fields.
To obtain a list of all available fields, look at [this](https://github.com/facebook/facebook-php-ads-sdk/blob/master/src/FacebookAds/Object/Fields/AdAccountFields.php).
```php
$adAccounts->all(['account_id', 'balance', 'name']);
```#### get
Use this method to get details of an AdAccount. This method accepts an array as argument containing a list of fields and an account_id `act_`
To obtain a list of all available fields, look at [this](https://github.com/facebook/facebook-php-ads-sdk/blob/master/src/FacebookAds/Object/Fields/AdAccountFields.php).
```php
$adAccounts->get(['account_id', 'balance', 'name'], 'act_');
```### Campaigns
To obtain an Campaigns instance:
```php
$campaigns = $adsApi->campaigns();
```#### all
Use this method to retrieve your adAccount campaigns. This method accepts an array as argument containing a list of fields and an account_id `act_`
To obtain a list of all available fields, look at [this](https://github.com/facebook/facebook-php-business-sdk/blob/master/src/FacebookAds/Object/Fields/CampaignFields.php).
```php
$campaigns->all(['name'], 'act_');
```## License
[![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2Fedbizarro%2Flaravel-facebook-ads.svg?type=large)](https://app.fossa.io/projects/git%2Bgithub.com%2Fedbizarro%2Flaravel-facebook-ads?ref=badge_large)