ramsey / laravel-oauth2-instagram
A Laravel 5 service provider for league/oauth2-instagram.
Requires
- php: ^7.1.3
- illuminate/support: ^5.6
- league/oauth2-instagram: ^2.0
Requires (Dev)
- jakub-onderka/php-parallel-lint: ^1
- mockery/mockery: ^1
- orchestra/testbench: ^3.6
- phpstan/phpstan: ^0.10
- phpstan/phpstan-mockery: ^0.10
- phpunit/phpunit: ^7
- squizlabs/php_codesniffer: ^3
This package is auto-updated.
Last update: 2024-12-08 14:59:36 UTC
README
ramsey/laravel-oauth2-instagram is a Laravel 5 service provider for league/oauth2-instagram.
This project adheres to a Contributor Code of Conduct. By participating in this project and its community, you are expected to uphold this code.
Installation
The preferred method of installation is via Composer. Run the following
command to install the package and add it as a requirement to your project's
composer.json
:
composer require ramsey/laravel-oauth2-instagram
After requiring the package with Composer, you'll need to add the following to
the providers
array in config/app.php
:
Ramsey\Laravel\OAuth2\Instagram\InstagramServiceProvider::class
Then, add the following to the aliases
array in the same file:
'Instagram' => Ramsey\Laravel\OAuth2\Instagram\Facades\Instagram::class
Now, run the following to properly set up the package with your Laravel application:
php artisan vendor:publish
Finally, register your application with Instagram
and add your client ID, client secret, and redirect URI to config/instagram.php
.
Examples
Create an authorization URL and redirect users to it in order to request access to their Instagram account:
$authUrl = Instagram::authorize([], function ($url, $provider) use ($request) { $request->session()->put('instagramState', $provider->getState()); return $url; }); return redirect()->away($authUrl);
In the route for the redirect URI, check the state and authorization code, and use the code to get an access token. Store the token to the session or to the user's profile in your data store.
if (!$request->has('state') || $request->state !== $request->session()->get('instagramState')) { abort(400, 'Invalid state'); } if (!$request->has('code')) { abort(400, 'Authorization code not available'); } $token = Instagram::getAccessToken('authorization_code', [ 'code' => $request->code, ]); $request->session()->put('instagramToken', $token);
Use the access token to make authenticated requests to Instagram.
$instagramToken = $request->session()->get('instagramToken'); $instagramUser = Instagram::getResourceOwner($instagramToken); $name = $instagramUser->getName(); $bio = $instagramUser->getDescription(); $feedRequest = Instagram::getAuthenticatedRequest( 'GET', 'https://api.instagram.com/v1/users/self/feed', $instagramToken ); $client = new \GuzzleHttp\Client(); $feedResponse = $client->send($feedRequest); $instagramFeed = json_decode($feedResponse->getBody()->getContents());
Contributing
Contributions are welcome! Please read CONTRIBUTING for details.
Copyright and License
The ramsey/laravel-oauth2-instagram library is copyright © Ben Ramsey and licensed for use under the MIT License (MIT). Please see LICENSE for more information.