/instagram-basic-display-php

A simple PHP class for accessing the Instagram Basic Display API

Primary LanguagePHPMIT LicenseMIT

Instagram Basic Display PHP API

A simple PHP wrapper for the Instagram Basic Display API. Based on the Instagram-PHP-API by Christian Metz

Latest Stable Version License Total Downloads

Composer package available.

Requirements

  • PHP 7 or higher
  • cURL
  • Facebook Developer Account
  • Facebook App

Get started

To use the Instagram Basic Display API, you will need to register a Facebook app and configure Instagram Basic Display. Follow the getting started guide.

Installation

I strongly advice using Composer to keep updates as smooth as possible.

$ composer require espresso-dev/instagram-basic-display-php

Initialize the class

use EspressoDev\InstagramBasicDisplay\InstagramBasicDisplay;

$instagram = new InstagramBasicDisplay([
    'appId' => 'YOUR_APP_ID',
    'appSecret' => 'YOUR_APP_SECRET',
    'redirectUri' => 'YOUR_APP_REDIRECT_URI'
]);

echo "<a href='{$instagram->getLoginUrl()}'>Login with Instagram</a>";

Authenticate user (OAuth2)

// Get the OAuth callback code
$code = $_GET['code'];

// Get the short lived access token (valid for 1 hour)
$token = $instagram->getOAuthToken($code, true);

// Exchange this token for a long lived token (valid for 60 days)
$token = $instagram->getLongLivedToken($token, true);

echo 'Your token is: ' . $token;

Get user profile

// Set user access token
$instagram->setAccessToken($token);

// Get the users profile
$profile = $instagram->getUserProfile();

echo '<pre>';
print_r($profile);
echo '<pre>';

All methods return the API data as json_decode() - so you can directly access the data.

Available methods

Setup Instagram

new Instagram(<array>/<string>);

array if you want to perform oAuth:

new InstagramBasicDisplay([
    'appId' => 'YOUR_APP_ID',
    'appSecret' => 'YOUR_APP_SECRET',
    'redirectUri' => 'YOUR_APP_REDIRECT_URI'
]);

string once you have a token and just want to return read-only data:

new InstagramBasicDisplay('ACCESS_TOKEN');

Get login URL

getLoginUrl(<array>, <string>)

getLoginUrl(
    array(
        'user_profile', 
        'user_media'
    ),
    'state'
);

Get OAuth token (Short lived valid for 1 hour)

getOAuthToken($code, <true>/<false>)

true : Returns only the OAuth token
false [default] : Returns OAuth token and profile data of the authenticated user

Exchange the OAuth token for a Long lived token (valid for 60 days)

getLongLivedToken($token, <true>/<false>)

true : Returns only the OAuth token
false [default] : Returns OAuth token and profile data of the authenticated user

Refresh access token for another 60 days before it expires

refreshToken($token, <true>/<false>)

true : Returns only the OAuth token
false [default] : Returns OAuth token and expiry data of the token

Set / Get access token

  • Set the access token, for further method calls: setAccessToken($token)
  • Get the access token, if you want to store it for later usage: getAccessToken()

User methods

Authenticated methods

  • getUserProfile()
  • getUserMedia(<$id>, <$limit>)
    • if an $id isn't defined or equals 'me', it returns the media of the logged in user

Media methods

Authenticated methods

  • getMedia($id)
  • getMediaChildren()

Pagination

The getUserMedia endpoint has a maximum range of results, so increasing the limit parameter above the limit of 99 won't help.You can use pagination to return more results for this endpoint.

Pass an object into the pagination() method and receive your next dataset:

$media = $instagram->getUserMedia();

$moreMedia = $instagram->pagination($media);