Update: The deprecation of the Legacy Instagram API will now take place on the 29th of June 2020.
With Instagram announcing that the current Instagram API will be completely retired on the 2nd of March 2020, now is the time to switch over to the new basic display API.
Any application still using the old API will no longer be able to retrieve data from Instagram following the deprecation of the last media endpoint on the 2nd of March 2020.
Because of this, we’ve been busy switching updating SnapWidget to use the new Basic Display and Instagram Graph API’s. Below are some tips to make the process of updating your own app easier.
Note: The information below is only for app developers. If you’re a user of SnapWidget you do not need to worry about any of this
In order to switch your current application to use the new API, you will require a Facebook Developer account.
If you don’t already have a Facebook app for your application, create one now:
You will now be able to begin making changes to your existing application to access to the new Basic Display API. For this, you will need the App ID, App Secret and Redirect URL of the Instagram App you just created.
Note: This is for the Instagram app, not the Facebook application.
The API endpoints you will be using are:
The steps below briefly explain how to authenticate your user, get a token, exchange it for a long-lived one and query the media for the authenticated user. You will need to update your application accordingly.
Using PHP?
Here is a composer package we created that handles these steps for you: https://packagist.org/packages/espresso-dev/instagram-basic-display-php
Construct the following authentication URL for your users using the values from your Instagram app:
https://api.instagram.com/oauth/authorize
?client_id={app-id}
&redirect_uri={redirect-uri}
&scope=user_profile,user_media
&response_type=code
Open this URL in a new window, and allow your users to sign in with their Instagram accounts.
Keep in mind until your app is approved by Facebook / Instagram you will only be able to sign in with the test user you configured in step 3.
Once the user has accepted permissions, the page will redirect to your redirect URL where you will be able to get the authorization code that is included. For example:
https://yourapplication.com/auth/?code=AQDp3TtBQ...
You will need to perform POST request to the following endpoint to exchange the code for a token:
https://api.instagram.com/oauth/access_token
Include the following POST parameters:
client_id={app-id}
client_secret={app-secret}
grant_type=authorization_code
redirect_uri={redirect-uri}
code={code}
On success, the API will return a JSON object with the short-lived Instagram User Access Token:
{
"access_token": "IGQVJ...",
"user_id": 17841405793187218
}
Since a token that is only valid for 1 hour would not be very useful, you can now exchange it for a long-lived token that is valid for 60 days.
Your request must be made server-side and include:
To exchange the token, perform a GET request to the following endpoint and include the required query params:
https://graph.instagram.com/access_token
?grant_type=ig_exchange_token
&client_secret={instagram-app-secret}
&access_token={short-lived-access-token}
On success, the API will return a JSON object with the long-lived Instagram User Access Token:
{
"access_token":"{long-lived-user-access-token}",
"token_type": "bearer",
"expires_in": 5183944 // Number of seconds until token expires
}
You can now use this access token to query the user profile and media.
To retrieve the authenticated users profile and media, you will need to perform GET requests to the following endpoints:
https://graph.instagram.com/me?fields=id,username&access_token={access-token}
https://graph.instagram.com/me/media?fields=id,caption&access_token={access-token}
More information about the available fields here.
Once you’ve made the required changes to your application, you are ready to submit your application for approval.
If you have an application that is already live, you will need to create a test application on Facebook, and use that during the approval process. Once permission has been approved, you will be able to use the permissions on your live app.
To create a new test app, select your app from the dashboard: https://developers.facebook.com/apps and then drop down on the left, choose Create Test App
You can now use this test app as part of the submission process.
To start the submission, select Instagram > Basic Display from the products in the left sidebar. Then add the required permissions for your app.
Once added, you will need to edit the details and complete the submission for each.
You will need to do this for each of the permissions.
Here is a template for the detailed description section that you can use with your submission:
My app uses the {instagram_graph_user_profile / instagram_graph_user_media} permission to be able to {main feature permission is required for}. My app allows {benefits of your app}.
Examples of a screencast: https://developers.facebook.com/docs/apps/review/screencast/
Or reach out and we’ll share our screencast with you.
After completing the details for each permission. You will need to edit the details for App Verification.
The Testing Credentials section can be used to provide details for the Facebook team to check your application. Here is a template to use to make the process a little easier:
Site URL: {url to your stage/test environment} Testing email: {login that the Facebook team can use} Testing password: {password for the login}
To see how "instagram_graph_user_profile" and "instagram_graph_user_media" is used in my app:
- Navigate to {your site url}
- Login using the credentials provided
- ...
Try to be as detailed as possible, and make sure you have tested the process yourself using the provided login credentials.
On average it looks like approval takes about 5 business days.
Good luck!
Using PHP?
If you’re using PHP, here is a composer package we created that makes using the Instagram Basic Display API a little easier: https://packagist.org/packages/espresso-dev/instagram-basic-display-php