summaryrefslogtreecommitdiff
path: root/server/core/LibOverride
diff options
context:
space:
mode:
authorEole <EoleDev@outlook.fr>2016-01-31 11:54:53 +0100
committerEole <EoleDev@outlook.fr>2016-01-31 11:54:53 +0100
commitf6c4c90567161fdb73e0fcec5f3d330c3a118a60 (patch)
tree985018e2dc5aa89f7d398a6254d27ca8161778e4 /server/core/LibOverride
parentc796facb137a908b36e5477abfc3ff7828b45c6e (diff)
Fin test Token Management
Diffstat (limited to 'server/core/LibOverride')
-rwxr-xr-xserver/core/LibOverride/Test.php172
1 files changed, 123 insertions, 49 deletions
diff --git a/server/core/LibOverride/Test.php b/server/core/LibOverride/Test.php
index beb4e70..91ea84d 100755
--- a/server/core/LibOverride/Test.php
+++ b/server/core/LibOverride/Test.php
@@ -4,8 +4,10 @@ use GuzzleHttp\Client;
use OpenStack\Common\Transport\HandlerStack;
use OpenStack\Common\Transport\Middleware;
use OpenStack\Identity\v3\Service;
+use OpenStack\Identity\v3\Api;
use OpenStack\Common\Auth\Token;
use OpenStack\Common\Transport\Utils;
+use OpenStack\Identity\v3\Models;
class genTokenOptions
{
@@ -13,9 +15,9 @@ class genTokenOptions
private $stack;
private $backup = [];
+ private $httpClient;
public function __construct($options){
- echo "test";
$this->stack = HandlerStack::create();
@@ -24,6 +26,8 @@ class genTokenOptions
'handler' => $this->stack,
]);
+ $this->httpClient = $httpClient;
+
$options['identityService'] = Service::factory($httpClient);
$options['authHandler'] = function () use ($options) {
@@ -63,49 +67,8 @@ class genTokenOptions
'base_uri' => Utils::normalizeUrl($baseUrl),
'handler' => $this->stack,
]);
- $this->backup['Compute'] = array('token' => json_encode($token), 'baseUrl' => $baseUrl );
- serialize($token->methods);
- foreach($token->roles as $role){
- serialize($role->name);
- serialize($role->links);
- serialize($role->id);
- }
- serialize($token->expires);
- serialize($token->project->domainId);
- serialize($token->project->parentId);
- serialize($token->project->enabled);
- serialize($token->project->description);
- serialize($token->project->id);
- serialize($token->project->links);
- serialize($token->project->name);
- foreach($token->catalog->services as $service){
- serialize($service->id);
- serialize($service->name);
- serialize($service->description);
- serialize($service->type);
- foreach($service->endpoints as $end){
- serialize($end->id);
- serialize($end->interface);
- serialize($end->name);
- serialize($end->serviceId);
- serialize($end->region);
- serialize($end->links);
- serialize($end->url);
- }
- serialize($service->links);
- }
- serialize($token->extras);
- serialize($token->user->domainId);
- serialize($token->user->defaultProjectId);
- serialize($token->user->id);
- serialize($token->user->email);
- serialize($token->user->enabled);
- serialize($token->user->description);
- serialize($token->user->links);
- serialize($token->user->name);
- serialize($token->issued);
- serialize($token->id);
- var_dump($token->id);
+ $this->backup['Compute'] = array('token' => $this->serializeToken($token), 'baseUrl' => $baseUrl );
+
$this->optionsGlobal['Compute'] = $options;
}
@@ -117,9 +80,9 @@ class genTokenOptions
$options['region'] = 'RegionOne';
//list($token, $baseUrl) = $options['identityService']->authenticate($options);
- $this->backup['Compute'] = json_decode($opt, true);
- var_dump($this->backup['Compute']);
- $token = json_decode($this->backup['Compute']['token'], true);
+ $this->backup['Compute'] = unserialize($opt);
+ //var_dump($this->backup['Compute']);
+ $token = $this->unserializeToken($this->backup['Compute']['token']);
$baseUrl = $this->backup['Compute']['baseUrl'];
//$stack = HandlerStack::create();
@@ -132,15 +95,126 @@ class genTokenOptions
'base_uri' => Utils::normalizeUrl($baseUrl),
'handler' => $this->stack,
]);
- $this->backup['Compute'] = array('token' => json_encode($token), 'baseUrl' => $baseUrl );
+ $this->backup['Compute'] = array('token' => $this->serializeToken($token), 'baseUrl' => $baseUrl );
$this->optionsGlobal['Compute'] = $options;
}
public function getBackup($service){
- return json_encode($this->backup[$service]);
+ return serialize($this->backup[$service]);
}
public function getOptionsCompute(){
return $this->optionsGlobal['Compute'];
}
+
+ private function serializeToken($token){
+ $tokenSerialized = [];
+ $tokenSerialized["methods"] = serialize($token->methods);
+ $tokenSerialized["roles"] = [];
+ //var_dump($token->roles);
+ foreach($token->roles as $role){
+ $tokenSerialized["roles"][serialize($role->name)]["links"] = serialize($role->links);
+ $tokenSerialized["roles"][serialize($role->name)]["id"] = serialize($role->id);
+ }
+ $tokenSerialized["expires"] = serialize($token->expires);
+ $tokenSerialized["project"]["domainId"] = serialize($token->project->domainId);
+ $tokenSerialized["project"]["parentId"] = serialize($token->project->parentId);
+ $tokenSerialized["project"]["enabled"] = serialize($token->project->enabled);
+ $tokenSerialized["project"]["description"] = serialize($token->project->description);
+ $tokenSerialized["project"]["id"] = serialize($token->project->id);
+ $tokenSerialized["project"]["links"] = serialize($token->project->links);
+ $tokenSerialized["project"]["name"] = serialize($token->project->name);
+ foreach($token->catalog->services as $service){
+ $tokenSerialized["catalog"][serialize($service->id)]["name"] = serialize($service->name);
+ $tokenSerialized["catalog"][serialize($service->id)]["description"] = serialize($service->description);
+ $tokenSerialized["catalog"][serialize($service->id)]["type"] = serialize($service->type);
+ foreach($service->endpoints as $end){
+ $tokenSerialized["catalog"][serialize($service->id)]["endpoints"][serialize($end->id)]["interface"] = serialize($end->interface);
+ $tokenSerialized["catalog"][serialize($service->id)]["endpoints"][serialize($end->id)]["name"] = serialize($end->name);
+ $tokenSerialized["catalog"][serialize($service->id)]["endpoints"][serialize($end->id)]["serviceId"] = serialize($end->serviceId);
+ $tokenSerialized["catalog"][serialize($service->id)]["endpoints"][serialize($end->id)]["region"] = serialize($end->region);
+ $tokenSerialized["catalog"][serialize($service->id)]["endpoints"][serialize($end->id)]["links"] = serialize($end->links);
+ $tokenSerialized["catalog"][serialize($service->id)]["endpoints"][serialize($end->id)]["url"] = serialize($end->url);
+ }
+ $tokenSerialized["roles"][serialize($service->id)]["links"] = serialize($service->links);
+ }
+ $tokenSerialized["extras"] = serialize($token->extras);
+ $tokenSerialized["user"]["domainId"] = serialize($token->user->domainId);
+ $tokenSerialized["user"]["defaultProjectId"] = serialize($token->user->defaultProjectId);
+ $tokenSerialized["user"]["id"] = serialize($token->user->id);
+ $tokenSerialized["user"]["email"] = serialize($token->user->email);
+ $tokenSerialized["user"]["enabled"] = serialize($token->user->enabled);
+ $tokenSerialized["user"]["description"] = serialize($token->user->description);
+ $tokenSerialized["user"]["links"] = serialize($token->user->links);
+ $tokenSerialized["user"]["name"] = serialize($token->user->name);
+ $tokenSerialized["issued"] = serialize($token->issued);
+ $tokenSerialized["id"] = serialize($token->id);
+
+ return $tokenSerialized;
+ }
+
+ private function unserializeToken($tokenSerialized){
+ $api = new Api();
+ $token = new Models\Token($this->httpClient, $api);
+ $token->methods = unserialize($tokenSerialized["methods"]);
+ $token->roles = [];
+ foreach($tokenSerialized["roles"] as $key => $role){
+ $tmp = new Models\Role($this->httpClient, $api);
+
+ $tmp->name = unserialize($key);
+ $tmp->links = unserialize($role["links"]);
+ $tmp->id = unserialize($role["id"]);
+
+ $token->roles[] = $tmp;
+ }
+
+ $token->expires = unserialize($tokenSerialized["expires"]);
+ $token->project = new Models\Project($this->httpClient, $api);
+ $token->project->domainId = unserialize($tokenSerialized["project"]["domainId"]);
+ $token->project->parentId = unserialize($tokenSerialized["project"]["parentId"]);
+ $token->project->enabled = unserialize($tokenSerialized["project"]["enabled"]);
+ $token->project->description = unserialize($tokenSerialized["project"]["description"]);
+ $token->project->id = unserialize($tokenSerialized["project"]["id"]);
+ $token->project->links = unserialize($tokenSerialized["project"]["links"]);
+ $token->project->name = unserialize($tokenSerialized["project"]["name"]);
+
+ $token->catalog = [];
+ foreach($tokenSerialized["catalog"] as $key => $service){
+ $tmp = new Models\Service($this->httpClient, $api);
+
+ $tmp->id = unserialize($key);
+ $tmp->name = unserialize($service["name"]);
+ $tmp->description = unserialize($service["description"]);
+ $tmp->type = unserialize($service["type"]);
+ $tmp->endpoints = [];
+ foreach($service["endpoints"] as $key => $end){
+ $tmpEnd = new Models\Endpoint($this->httpClient, $api);
+ $tmpEnd->id = unserialize($key);
+ $tmpEnd->interface = unserialize($end["interface"]);
+ $tmpEnd->name = unserialize($end["name"]);
+ $tmpEnd->serviceId = unserialize($end["serviceId"]);
+ $tmpEnd->region = unserialize($end["region"]);
+ $tmpEnd->links = unserialize($end["links"]);
+ $tmpEnd->url = unserialize($end["url"]);
+ $tmp->endpoints[] = $tmpEnd;
+ }
+ $tmp->links = unserialize($service["links"]);
+ $token->catalog[] = $tmp;
+ }
+
+ $token->extras = unserialize($tokenSerialized["extras"]);
+ $token->user = new Models\User($this->httpClient, $api);
+ $token->user->domainId = unserialize($tokenSerialized["user"]["domainId"]);
+ $token->user->defaultProjectId = unserialize($tokenSerialized["user"]["defaultProjectId"]);
+ $token->user->id = unserialize($tokenSerialized["user"]["id"]);
+ $token->user->email = unserialize($tokenSerialized["user"]["email"]);
+ $token->user->enabled = unserialize($tokenSerialized["user"]["enabled"]);
+ $token->user->links = unserialize($tokenSerialized["user"]["links"]);
+ $token->user->name = unserialize($tokenSerialized["user"]["name"]);
+ $token->user->description = unserialize($tokenSerialized["user"]["description"]);
+ $token->issued = unserialize($tokenSerialized["issued"]);
+ $token->id = unserialize($tokenSerialized["id"]);
+
+ return $token;
+ }
}