hansott / pinterest-php
PHP client for the official Pinterest API
Installs: 134 807
Dependents: 0
Suggesters: 0
Security: 0
Stars: 45
Watchers: 10
Forks: 22
Open Issues: 1
Requires
- kriswallsmith/buzz: v0.15
- netresearch/jsonmapper: ^1.0
Requires (Dev)
- phpunit/phpunit: 4.8.12
- symfony/yaml: 2.7.5
- vlucas/phpdotenv: dev-master
README
Install
Via Composer
$ composer require hansott/pinterest-php
Donate
If you like this package, please consider buying me a coffee. Thank you for your support! 🙇♂️
Usage
Authentication
To use the API, you need an access token from Pinterest. Create a new Pinterest application if you haven't already. You then get a client ID and a client secret, specific for that application.
Back in your PHP application, create a Pinterest\Http\ClientInterface
instance (the default is Pinterest\Http\BuzzClient
) and use it to create an Pinterest\Authentication
instance:
$client = new Pinterest\Http\BuzzClient(); $auth = new Pinterest\Authentication($client, $clientId, $clientSecret);
Replace the $clientId
and $clientSecret
variables with the data of your Pinterest application.
You can now let your user authenticate with your application be redirecting them to the URL obtained by a call to $auth->getAuthenticationUrl()
, like this:
use Pinterest\App\Scope; $url = $auth->getAuthenticationUrl( 'https://your/redirect/url/here', array( Scope::READ_PUBLIC, Scope::WRITE_PUBLIC, Scope::READ_RELATIONSHIPS, Scope::WRITE_RELATIONSHIPS, ), 'random-string' ); header('Location: ' . $url); exit;
- The redirect URL is the URL to the page where pinterest will send us the authentication code for the user registering with your application. This URL needs to be accessible over https, and it has to be filled into to form of your Pinterst application (in the Pinterest backend).
- The second parameter is an array of permissions your app needs on the user's account. There needs to be at least one here.
- The validation state is a random code that you generate for the user registering, and persist (in SESSION for instance). Pinterest will send it back to us for further reference.
When your application user agrees to let your app take control of their Pinterest account via the API, Pinterest will redirect them to the URL you provided as redirect URL, with some added GET parameters. The most important being "code", which we'll trade for an OAuth access token in the next step. They'll also send the validation state back to us as a GET parameter so we can check if we expected this call.
The last step in the process is trading that code for an access token:
$code = $_GET['code']; $token = $auth->requestAccessToken($code);
You should persist that token safely at this point. You can use it from now on to connect to the Pinterest API from your application, on behalf of the user.
Initialize the Pinterest\Api
class:
$auth = Pinterest\Authentication::onlyAccessToken($client, $token); $api = new Pinterest\Api($auth);
Using the Pinterest\Api
instance in $api
, you can now make authenticated API requests to Pinterest's API on behalf of the user.
Get the authenticated user
$response = $api->getCurrentUser(); if (!$response->ok()) { die($response->getError()); } $user = $response->result(); // $user instanceof Objects\User
Get a user
// Get user by username $response = $api->getUser('otthans'); // Get user by user id $response = $api->getUser('314196648911734959'); if (!$response->ok()) { die($response->getError()); } $user = $response->result(); // $user instanceof Objects\User
Get a board
$response = $api->getBoard('314196580192594085'); if (!$response->ok()) { die($response->getError()); } $board = $response->result(); // $board instanceof Objects\Board
Update a board
// First, get the board using getBoard() $response = $api->getBoard('314196580192594085'); if (!$response->ok()) { die($response->getError()); } $board = $response->result(); // $board instanceof Objects\Board // Or create a new board without getBoard() $board = new Board; $board->id = 'the-board-id'; // Then, update the fields you want to change $board->name = 'New board name'; $board->description = 'New board description'; $response = $api->updateBoard($board); if (!$response->ok()) { die($response->getError()); } $updatedBoard = $response->result(); // $updatedBoard instanceof Objects\Board
Get the boards of the authenticated user
$response = $api->getUserBoards(); if (!$response->ok()) { die($response->getError()); } $pagedList = $response->result(); // $pagedList instanceof Objects\PagedList $boards = $pagedList->items(); // array of Objects\Board objects
Get the pins of the authenticated user
$response = $api->getUserPins(); if (!$response->ok()) { die($response->getError()); } $pagedList = $response->result(); // $pagedList instanceof Objects\PagedList $pins = $pagedList->items(); // array of Objects\Pin objects
Get the pins of a board
$response = $api->getBoardPins($boardId); if (!$response->ok()) { die($response->getError()); } $pagedList = $response->result(); // $pagedList instanceof Objects\PagedList $pins = $pagedList->items(); // array of Objects\Pin objects
See Get the next items of a paged list
Get the followers of the authenticated user
$response = $api->getUserFollowers(); if (!$response->ok()) { die($response->getError()); } $pagedList = $response->result(); // $boards instanceof Objects\PagedList $users = $pagedList->items(); // array of Objects\User objects
See Get the next items of a paged list
Get the boards that the authenticated user follows
$response = $api->getUserFollowingBoards(); if (!$response->ok()) { die($response->getError()); } $pagedList = $response->result(); // $boards instanceof Objects\PagedList $boards = $pagedList->items(); // array of Objects\Board objects
See Get the next items of a paged list
Get the users that the authenticated user follows
$response = $api->getUserFollowing(); if (!$response->ok()) { die($response->getError()); } $pagedList = $response->result(); // $boards instanceof Objects\PagedList $users = $pagedList->items(); // array of Objects\User objects
See Get the next items of a paged list
Get the interests that the authenticated user follows
Example: Modern architecture
$response = $api->getUserInterests(); if (!$response->ok()) { die($response->getError()); } $pagedList = $response->result(); // $boards instanceof Objects\PagedList $boards = $pagedList->items(); // array of Objects\Board objects
See Get the next items of a paged list
Follow a user
$response = $api->followUser('otthans'); if (!$response->ok()) { die($response->getError()); }
Unfollow a user
$response = $api->unfollowUser('otthans'); // username or user ID if (!$response->ok()) { die($response->getError()); }
Follow a board
$response = $api->followBoard('teslamotors', 'model-x'); if (!$response->ok()) { die($response->getError()); }
Unfollow a board
$response = $api->unfollowBoard('teslamotors', 'model-x'); if (!$response->ok()) { die($response->getError()); }
Create a board
$name = 'My new board'; $optionalDescription = 'The description of the board'; $response = $api->createBoard($name, $optionalDescription); if (!$response->ok()) { die($response->getError()); } $board = $response->result(); // $board instanceof Objects\Board
Delete a board
$boardId = '314196580192594085'; $response = $api->createBoard($boardId); if (!$response->ok()) { die($response->getError()); }
Create a pin
$board = '<username>/<board_name>'; $note = 'This is an amazing pin!'; $optionalLink = 'http://hansott.github.io/'; // Load an image from a url. $image = Pinterest\Image::url('http://lorempixel.com/g/400/200/cats/'); // Load an image from a file. $pathToFile = 'myfolder/myimage.png'; $image = Pinterest\Image::file($pathToFile); // Load a base64 encoded image. $pathToFile = 'myfolder/myimage.png'; $data = file_get_contents($pathToFile); $base64 = base64_encode($data); $image = Pinterest\Image::base64($base64); $response = $api->createPin($board, $note, $image, $optionalLink); if (!$response->ok()) { die($response->getError()); } $pin = $response->result(); // $pin instanceof Objects\Pin
Get a pin
$pinId = 'the-pin-id'; $response = $api->getPin($pinId); if (!$response->ok()) { die($response->getError()); } $pin = $response->result(); // $pin instanceof Objects\Pin
Update a pin
// First, get the pin using getPin() $pinId = 'the-pin-id'; $response = $api->getPin($pinId); if (!$response->ok()) { die($response->getError()); } $pin = $response->result(); // Or create a new Pin without getPin() $pin = new Pin; $pin->id = 'the-pin-id'; // Then, update the fields you want to change // Update note $pin->note = 'a new note'; // Update link $pin->link = 'https://google.com'; $response = $api->updatePin($pin); if (!$response->ok()) { die($response->getError()); } $updatedPin = $response->result();
Delete a pin
$pinId = 'the-pin-id'; $response = $api->deletePin($pinId); if (!$response->ok()) { die($response->getError()); }
Get the next items of a paged list
$hasMoreItems = $pagedList->hasNext(); if (!$hasMoreItems) { return; } $response = $api->getNextItems($pagedList); if (!$response->ok()) { die($response->getError()); } $nextPagedList = $response->result();
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email hansott at hotmail be instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.