Skip to content

Commit

Permalink
Initial commit
Browse files Browse the repository at this point in the history
  • Loading branch information
Maxim Kerstens committed Jul 28, 2016
1 parent 5f675c6 commit e4e0554
Show file tree
Hide file tree
Showing 8 changed files with 1,206 additions and 0 deletions.
36 changes: 36 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
# UitDatabank API wrapper

Met deze wrapper kan je makkelijk verbinding maken met UITdatabank's API.

De UiTdatabank is de rijkste bron van evenementen en activiteiten in Vlaanderen en Brussel vb. films, concerten, theater, ... zie [www.uitinvlaanderen.be](http://www.uitinvlaanderen.be).
UiTID is een user platform met cultuurprofielen van meer dan 70.000 cultuur- en vrijetijdszoekers.

Er word gebruikt gemaakt van [cultuurnet/cdb](https://github.com/cultuurnet/Cdb) om de binnenkomende data te converteren.

[UITdatabank](http://tools.uitdatabank.be/)

### Voorbeeld

```
use HappyDemon\UitDatabank\UitDatabank;
$uitDatabank = new UitDatabank(
env('UIT_KEY'),// Jouw UIT API key
env('UIT_SECRET'), // Jouw UIT API secret
env('UIT_SERVER') // UIT server (basis foor endpoints)
);
try {
$filter = new Filter();
$filter->setQ('*:*');
$filter->setGroup('event');
$filter->setRows(300);
$response = $uitDatabank->search($filter);
} catch (\Exception $e) {
die(var_dump($e));
}
// output
var_dump($response->getEvents());
```
25 changes: 25 additions & 0 deletions composer.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
{
"name": "happydemon/uitdatabank",
"type": "library",
"description": "Een handige package om verbinding te maken met Cultuurnet's API in PHP.",
"homepage": "https://github.com/happyDemon/UiTdatabank",
"license": "BSD",
"authors": [
{
"name": "Maxim Kerstens",
"email": "[email protected]",
"role": "Developer"
}
],
"require": {
"php": ">=5.3.0",
"ext-curl": "*",
"cultuurnet/cdb": "^2.1"
},
"autoload": {
"psr-4": {
"HappyDemon\\UitDatabank\\": "src"
}
}
}

7 changes: 7 additions & 0 deletions src/Exception.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
<?php

namespace HappyDemon\UitDatabank;

class Exception extends \Exception {

}
138 changes: 138 additions & 0 deletions src/OAuth/OAuth.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,138 @@
<?php

namespace HappyDemon\UitDatabank\OAuth;

class OAuth
{
/**
* All OAuth 1.0 requests use the same basic algorithm for creating a
* signature base string and a signature. The signature base string is
* composed of the HTTP method being used, followed by an ampersand ("&")
* and then the URL-encoded base URL being accessed, complete with path
* (but not query parameters), followed by an ampersand ("&"). Then, you
* take all query parameters and POST body parameters (when the POST body is
* of the URL-encoded type, otherwise the POST body is ignored), including
* the OAuth parameters necessary for negotiation with the request at hand,
* and sort them in lexicographical order by first parameter name and then
* parameter value (for duplicate parameters), all the while ensuring that
* both the key and the value for each parameter are URL encoded in
* isolation. Instead of using the equals ("=") sign to mark the key/value
* relationship, you use the URL-encoded form of "%3D". Each parameter is
* then joined by the URL-escaped ampersand sign, "%26".
*
* @param string $url The URL.
* @param string $method The method to use.
* @param array $parameters The parameters.
* @return string
*/
public static function calculateBaseString($url, $method, array $parameters = null)
{
// redefine
$url = (string) $url;
$parameters = (array) $parameters;

// init var
$chunks = array();

// sort parameters by key
uksort($parameters, 'strcmp');

// loop parameters
foreach ($parameters as $key => $value) {
// sort by value
if (is_array($value)) {
$parameters[$key] = natsort($value);
}
}

// process queries
foreach ($parameters as $key => $value) {
// only add if not already in the url
if (substr_count($url, $key . '=' . $value) == 0) {
$chunks[] = self::urlencode_rfc3986($key) . '%3D' .
self::urlencode_rfc3986($value);
}
}

// buils base
$base = $method . '&';
$base .= urlencode($url);
$base .= (substr_count($url, '?')) ? '%26' : '&';
$base .= implode('%26', $chunks);
$base = str_replace('%3F', '&', $base);

// return
return $base;
}

/**
* URL-encode method for internal use
*
* @param mixed $value The value to encode.
* @return string
*/
private static function urlencode_rfc3986($value)
{
if (is_array($value)) {
return array_map(array(__CLASS__, 'urlencode_rfc3986'), $value);
} else {
$search = array('+', ' ', '%7E', '%');
$replace = array('%20', '%20', '~', '%25');

return str_replace($search, $replace, urlencode($value));
}
}

/**
* Build the Authorization header
* @later: fix me
*
* @param array $parameters The parameters.
* @param string $url The URL.
* @return string
*/
public static function calculateHeader(array $parameters, $url)
{
// redefine
$url = (string) $url;

// divide into parts
$parts = parse_url($url);

// init var
$chunks = array();

// process queries
foreach ($parameters as $key => $value) {
$chunks[] = str_replace(
'%25',
'%',
self::urlencode_rfc3986($key) . '="' . self::urlencode_rfc3986($value) . '"'
);
}

// build return
$return = 'Authorization: OAuth realm="' . $parts['scheme'] . '://' .
$parts['host'];
if (isset($parts['path'])) {
$return .= $parts['path'];
}
$return .= '", ';
$return .= implode(',', $chunks);

// prepend name and OAuth part
return $return;
}

/**
* Build the signature for the data
*
* @param string $key The key to use for signing.
* @param string $data The data that has to be signed.
* @return string
*/
public static function hmacsha1($key, $data)
{
return base64_encode(hash_hmac('SHA1', $data, $key, true));
}
}
Loading

0 comments on commit e4e0554

Please sign in to comment.