aboutsummaryrefslogblamecommitdiffstats
path: root/Zotlabs/Identity/OAuth2Server.php
blob: b747b95dbb24302816a62474f93235e1cf6172de (plain) (tree)
1
2
3
4
5
6
7
8


                           
                                           
 
                                                                             
 




                                                                                
 
                                                       
                                                                                                  
                                                                                       
                                                                                                  
                                                                                                                                 
 


                                                                                

                         
                                                             
         
 
<?php

namespace Zotlabs\Identity;

class OAuth2Server extends \OAuth2\Server {

	public function __construct(OAuth2Storage $storage, $config = null) {

		if(! is_array($config)) {
			$config = [
				'use_openid_connect' => true,
				'issuer' => \Zotlabs\Lib\System::get_site_name()
			];
		}

		parent::__construct($storage, $config);

		// Add the "Client Credentials" grant type (it is the simplest of the grant types)
		$this->addGrantType(new \OAuth2\GrantType\ClientCredentials($storage));

		// Add the "Authorization Code" grant type (this is where the oauth magic happens)
                // Need to use OpenID\GrantType to return id_token (see:https://github.com/bshaffer/oauth2-server-php/issues/443)
		$this->addGrantType(new \OAuth2\OpenID\GrantType\AuthorizationCode($storage));

		$keyStorage = new \OAuth2\Storage\Memory( [
			'keys' => [
				'public_key'  => get_config('system', 'pubkey'),
				'private_key' => get_config('system', 'prvkey')
			]
		]);

		$this->addStorage($keyStorage, 'public_key');
	}

}