Spotify #2
This commit is contained in:
parent
a70caca58d
commit
51f7ce9dbd
@ -52,4 +52,7 @@ $router->any('/api/example', 'ExampleApi@example');
|
||||
$router->any('/example', 'ExampleController@index');
|
||||
$router->any('/example/subpage', 'ExampleController@subpage');
|
||||
|
||||
//module routes
|
||||
//$router->any('/plugins/spotify/callback', 'Spotify@callback');
|
||||
|
||||
$router->run($_SERVER['REQUEST_METHOD'], '/'.(isset($_GET['url']) ? $_GET['url'] : ''));
|
||||
|
33
app/models/managers/SettingsManager.php
Normal file
33
app/models/managers/SettingsManager.php
Normal file
@ -0,0 +1,33 @@
|
||||
<?php
|
||||
class SettingsManager{
|
||||
static function getAllValues () {
|
||||
return Db::loadAll ("SELECT * FROM settings");
|
||||
}
|
||||
|
||||
static function getByName($settingName) {
|
||||
return Db::loadOne("SELECT * FROM settings WHERE name = ?", array($settingName));
|
||||
}
|
||||
|
||||
public static function create ($name, $value) {
|
||||
$setting = array (
|
||||
'name' => $name,
|
||||
'value' => $value,
|
||||
);
|
||||
try {
|
||||
Db::add ('settings', $setting);
|
||||
} catch(PDOException $error) {
|
||||
echo $error->getMessage();
|
||||
die();
|
||||
}
|
||||
}
|
||||
|
||||
public static function update ($name, $value) {
|
||||
try {
|
||||
Db::edit ('settings', ['value' => $value], 'WHERE name = ?', array($name));
|
||||
} catch(PDOException $error) {
|
||||
echo $error->getMessage();
|
||||
die();
|
||||
}
|
||||
}
|
||||
}
|
||||
?>
|
@ -1,13 +1,29 @@
|
||||
<?php
|
||||
class Spotify extends VirtualDeviceManager {
|
||||
private $token = "";
|
||||
private $client_id = '76840e2199e34dcd903d19877bd726dd'; // Your client id
|
||||
private $redirect_uri = 'https://dev.steelants.cz/vasek/home-update/plugins/spotify/callback'; // Your redirect uri
|
||||
|
||||
public function oAuth(){
|
||||
$client_secret = 'CLIENT_SECRET'; // Your secret
|
||||
$scopes = 'user-read-private user-read-email';
|
||||
|
||||
header('Location: https://accounts.spotify.com/authorize?client_id='. $this->client_id . '&response_type=token&redirect_uri='.urlencode($this->redirect_uri).'&scope=user-read-playback-state');
|
||||
}
|
||||
|
||||
private function setToken($token){
|
||||
$this->token = $token;
|
||||
}
|
||||
|
||||
private function autorize(){
|
||||
$client_id = '76840e2199e34dcd903d19877bd726dd';
|
||||
public function callback(){
|
||||
$token = $_GET;
|
||||
$actual_link = "http://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
|
||||
var_dump($actual_link);
|
||||
(new SettingsManager)->create('spotify_token', $token);
|
||||
}
|
||||
|
||||
public function autorize(){
|
||||
|
||||
$client_secret = '0f94ed2c0bd64bf791ea13b7e6310ba3';
|
||||
|
||||
$ch = curl_init();
|
||||
@ -15,7 +31,7 @@ class Spotify extends VirtualDeviceManager {
|
||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1 );
|
||||
curl_setopt($ch, CURLOPT_POST, 1 );
|
||||
curl_setopt($ch, CURLOPT_POSTFIELDS, 'grant_type=client_credentials&scope=user-read-playback-state' );
|
||||
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Authorization: Basic '.base64_encode($client_id.':'.$client_secret)));
|
||||
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Authorization: Basic '.base64_encode($this->client_id.':'.$client_secret)));
|
||||
|
||||
$result=curl_exec($ch);
|
||||
|
||||
@ -25,9 +41,9 @@ class Spotify extends VirtualDeviceManager {
|
||||
|
||||
private function getPlayerData(){
|
||||
$ch = curl_init();
|
||||
curl_setopt($ch, CURLOPT_URL, 'https://api.spotify.com/v1/users/byzolscj4vc1p0xcjqykbesn8' );
|
||||
curl_setopt($ch, CURLOPT_URL, 'https://api.spotify.com/v1/me/player' );
|
||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1 );
|
||||
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Authorization: Bearer ' . $this->token));
|
||||
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Authorization: Bearer ' . (new SettingsManager)->getByName('spotify_token')['value']));
|
||||
|
||||
$result=curl_exec($ch);
|
||||
echo $result;
|
||||
|
Loading…
Reference in New Issue
Block a user