Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[WIP] Follow base api 1.0 #8

Open
wants to merge 23 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 10 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 5 additions & 5 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,11 @@ php:
- 5.5
- hhvm

matrix:
allow_failures:
- php: hhvm

before_script:
- composer install --dev --prefer-source

script: phpunit --coverage-text
script: vendor/bin/phpspec run

matrix:
allow_failures:
- php: hhvm
15 changes: 15 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
1.0.0 (2014-09-XX)
==================

Most changes are because of the new base api release.

New features
------------

* Compatibility with HHVM

Changes
-----------

* Configuring authentication is now possible by using the method `useAuthentication`
* Getting API classes is done via getter, before: `->api('videos')`, now: `->getVideosApi()` this method is IDE-friendly
27 changes: 19 additions & 8 deletions composer.json
Original file line number Diff line number Diff line change
@@ -1,21 +1,26 @@
{
"name": "nekland/youtube-api",
"type": "library",
"description": "Simple library you can build you're api upon.",
"keywords": ["nekland", "api", "base"],
"description": "Youtube API made easy !",
"keywords": ["nekland", "api", "youtube"],
"license": "MIT",
"authors": [
{
"name": "Maxime Veber",
"email": "nekland@gmail.com",
"email": "nek.dev@gmail.com",
"homepage": "http://nekland.fr"
},
{
"name": "Nekland Team",
"email": "[email protected]",
"homepage": "http://team.nekland.fr"
}
],
"require": {
"php": ">=5.4",
"guzzle/guzzle": ">=3.7",
"nekland/base-api": "~0.0.1",
"namshi/jose": "~1.2"
"php": ">=5.4",
"guzzlehttp/guzzle": "~4.0",
"nekland/base-api": "~1.0",
"namshi/jose": "~1.2"
},
"suggest": {
"nekland/soundcloud-api": "Soundcloud API made easy !"
Expand All @@ -24,6 +29,12 @@
"psr-0": { "Nekland\\": "lib/" }
},
"require-dev": {
"phpunit/phpunit": ">=3.7"
"phpspec/phpspec": "~2.0"
},
"minimum-stability": "dev",
"extra": {
"branch-alias": {
"dev-master": "1.x-dev"
}
}
}
4 changes: 2 additions & 2 deletions docs/Api/playlists.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ First retrieve the playlist api object (`Nekland\YoutubeApi\Api\Playlists`).
<?php

$youtube = new Youtube();
$playlistApi = $youtube->api('playlists');
$playlistApi = $youtube->getPlayslistsApi();
```

List playlists
Expand Down Expand Up @@ -72,6 +72,6 @@ The day this lines are written, it's:
* id: 0
* player: 0
* snippet: 2
*status: 2
* status: 2

> For now the playlist api only retrieve information. More coming ! PRs are accepted on the topic :) .
8 changes: 4 additions & 4 deletions lib/Nekland/YoutubeApi/Api/Behavior/ListTrait.php
Original file line number Diff line number Diff line change
Expand Up @@ -21,12 +21,12 @@ trait ListTrait
*/
public function listById($id, array $parts = ['snippet'], array $otherParameters = [])
{
$parameters = array_merge(
$body = array_merge(
['part' => implode(',', $parts), 'id' => $id],
$otherParameters
);

return $this->get(static::URL, $parameters);
return $this->get(static::URL, $body);
}

/**
Expand All @@ -50,12 +50,12 @@ public function getById($id, array $parts = ['snippet'], array $otherParameters
*/
public function listBy(array $filters, array $parts = ['snippet'], array $otherParameters = [])
{
$parameters = array_merge(
$body = array_merge(
['part' => $parts],
$filters,
$otherParameters
);

return $this->get(static::URL, $parameters);
return $this->get(static::URL, $body);
}
}
12 changes: 10 additions & 2 deletions lib/Nekland/YoutubeApi/Api/Playlists.php
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,15 @@
*/
class Playlists extends AbstractApi
{
const URL = 'youtube/v3/playlists';

use ListTrait;

public function getUrl()
{
return 'youtube/v3/playlists';
}

public function getType()
{
return 'playlist';
}
}
14 changes: 11 additions & 3 deletions lib/Nekland/YoutubeApi/Api/Videos.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,10 @@
*/

namespace Nekland\YoutubeApi\Api;

use Nekland\BaseApi\Api\AbstractApi;
use Nekland\YoutubeApi\Api\Behavior\ListTrait;


/**
* Class Videos
*
Expand All @@ -26,7 +26,15 @@
*/
class Videos extends AbstractApi
{
const URL = 'youtube/v3/videos';

use ListTrait;

public function getUrl()
{
return 'youtube/v3/videos';
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why ?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To force a user extending AbstractApi to define theses methods.
He don't have to if they are just consts.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

and with return self::URL; ?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't see the interest of having 2 way to get the information

}

public function getType()
{
return 'video';
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

best practice in constant

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -11,22 +11,17 @@

namespace Nekland\YoutubeApi\Http\Auth;


use Nekland\BaseApi\Http\Auth\AuthInterface;
use Nekland\BaseApi\Http\Auth\AuthStrategyInterface;
use Nekland\BaseApi\Http\Event\RequestEvent;
use Nekland\YoutubeApi\Exception\MissingOptionException;

class PublicApiAccessAuth implements AuthInterface
class PublicApiAccess implements AuthStrategyInterface
{
/**
* @var array
*/
private $options;

/**
* @param array $options
* @return self
* @throws \Nekland\YoutubeApi\Exception\MissingOptionException
*/
public function setOptions(array $options)
{
if (empty($options['key'])) {
Expand All @@ -38,16 +33,10 @@ public function setOptions(array $options)
$this->options = $options;
}

/**
* @param \Guzzle\Http\Message\Request $request
*/
public function auth(\Guzzle\Http\Message\Request $request)
public function auth(RequestEvent $event)
{
$url = (string) $request->getUrl();

$url .= (false === strpos($url, '?') ? '?' : '&');
$url .= 'key=' . $this->options['key'];
$request = $event->getRequest();

$request->setUrl($url);
$request->setParameter('key', $this->options['key']);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -11,45 +11,44 @@

namespace Nekland\YoutubeApi\Http\Auth;


use Guzzle\Http\Client;
use Namshi\JOSE\JWS;
use Nekland\BaseApi\Http\AbstractHttpClient;
use Nekland\BaseApi\Http\Auth\AuthInterface;
use Nekland\BaseApi\Http\Auth\AuthStrategyInterface;
use Nekland\BaseApi\Http\Event\RequestEvent;
use Nekland\BaseApi\Http\Request;
use Nekland\YoutubeApi\Exception\AuthException;
use Nekland\YoutubeApi\Exception\MissingOptionException;

class ServiceAuth implements AuthInterface
/**
* Allow Service Auth
*
* @see https://developers.google.com/accounts/docs/OAuth2#serviceaccount
*/
class Service implements AuthStrategyInterface
{
/**
* @var array
*/
private $options;

/**
* @var \Guzzle\Http\ClientInterface
* @var AbstractHttpClient
*/
private $client;

/**
* @param \Guzzle\Http\ClientInterface $client
* @param RequestEvent $requestEvent
*/
public function __construct(\Guzzle\Http\ClientInterface $client=null)
public function auth(RequestEvent $requestEvent)
{
if (null === $client) {
$this->client = new Client();
} else {
$this->client = $client;
}
}
$request = $requestEvent->getRequest();

/**
* @param \Guzzle\Http\Message\Request $request
*/
public function auth(\Guzzle\Http\Message\Request $request)
{
if (!$request->hasHeader('Authorization')) {
$this->client = $requestEvent->getClient();
$token = $this->getToken();
$request->addHeader('Authorization', 'Bearer '.$token);
$request->setHeader('Authorization', 'Bearer ' . $token);
}
}

Expand All @@ -69,17 +68,17 @@ private function getToken()

$jws->sign($this->getPrivateKey());

$response = $this->client->post(
$response = $this->client->send(new Request(
'post',
'https://accounts.google.com/o/oauth2/token',
['Content-Type' => 'application/x-www-form-urlencoded'],
[
'grant_type' => 'urn:ietf:params:oauth:grant-type:jwt-bearer',
'assertion' => $jws->getTokenString()
],
['debug' => true]
);
['Content-Type' => 'application/x-www-form-urlencoded']
), false);

$finalArray = json_decode((string) $response->send()->getBody(), true);
$finalArray = json_decode($response, true);

return $finalArray['access_token'];
}
Expand Down Expand Up @@ -124,7 +123,7 @@ private function getOption($option, $default=null)

/**
* @param array $options
* @return AuthInterface
* @return self
*/
public function setOptions(array $options)
{
Expand Down
32 changes: 0 additions & 32 deletions lib/Nekland/YoutubeApi/Http/HttpClient.php

This file was deleted.

26 changes: 26 additions & 0 deletions lib/Nekland/YoutubeApi/Transformer/Hydrator/Hydrator.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
<?php

/**
* This file is a part of nekland youtube api package
*
* (c) Nekland <[email protected]>
*
* For the full license, take a look to the LICENSE file
* on the root directory of this project
*/

namespace Nekland\YoutubeApi\Transformer\Hydrator;


class Hydrator implements HydratorInterface
{
/**
* @param string $class
* @param array $data
* @return mixed
*/
public function hydrate($class, $data)
{

}
}
Loading