aboutsummaryrefslogtreecommitdiffstats
path: root/Zotlabs/Identity/OAuth2Server.php
diff options
context:
space:
mode:
Diffstat (limited to 'Zotlabs/Identity/OAuth2Server.php')
-rw-r--r--Zotlabs/Identity/OAuth2Server.php43
1 files changed, 43 insertions, 0 deletions
diff --git a/Zotlabs/Identity/OAuth2Server.php b/Zotlabs/Identity/OAuth2Server.php
new file mode 100644
index 000000000..3d7d5efb2
--- /dev/null
+++ b/Zotlabs/Identity/OAuth2Server.php
@@ -0,0 +1,43 @@
+<?php
+
+namespace Zotlabs\Identity;
+
+class OAuth2Server {
+
+ public $server;
+
+ public function __construct() {
+
+ $storage = new OAuth2Storage(\DBA::$dba->db);
+
+ $config = [
+ 'use_openid_connect' => true,
+ 'issuer' => \Zotlabs\Lib\System::get_site_name()
+ ];
+
+ // Pass a storage object or array of storage objects to the OAuth2 server class
+ $this->server = new \OAuth2\Server($storage,$config);
+
+ // Add the "Client Credentials" grant type (it is the simplest of the grant types)
+ $this->server->addGrantType(new \OAuth2\GrantType\ClientCredentials($storage));
+
+ // Add the "Authorization Code" grant type (this is where the oauth magic happens)
+ $this->server->addGrantType(new \OAuth2\GrantType\AuthorizationCode($storage));
+
+ $keyStorage = new \OAuth2\Storage\Memory( [
+ 'keys' => [
+ 'public_key' => get_config('system','pubkey'),
+ 'private_key' => get_config('system','prvkey')
+ ]
+ ]);
+
+ $this->server->addStorage($keyStorage,'public_key');
+
+ }
+
+ public function get_server() {
+ return $this->server;
+ }
+
+
+} \ No newline at end of file