From 2e3c6b4f3aa5b569b7396e36eb52360977250a4e Mon Sep 17 00:00:00 2001 From: Alex Bilbie Date: Mon, 6 Apr 2015 08:32:44 +0100 Subject: [PATCH] Refactored constructor to set defaults, added new setter methods for default token TTL and default token type --- src/Server.php | 60 +++++++++++++++++++++++++++++--------------------- 1 file changed, 35 insertions(+), 25 deletions(-) diff --git a/src/Server.php b/src/Server.php index 5a7bfaa6..1199bb27 100644 --- a/src/Server.php +++ b/src/Server.php @@ -1,4 +1,5 @@ defaultResponseType = ($defaultTokenType instanceof TokenTypeInterface) - ? $defaultTokenType - : new BearerTokenType(); - - $this->defaultAccessTokenTTL = ($defaultAccessTokenTTL instanceof DateInterval) - ? $defaultAccessTokenTTL - : new DateInterval('PT01H'); // default of 1 hour + public function __construct() { + $this->defaultTokenType = new BearerTokenType(); + $this->defaultAccessTokenTTL = new DateInterval('PT01H'); // default of 1 hour parent::__construct(); } + /** + * Set the default token type that grants will return + * + * @param TokenTypeInterface $defaultTokenType + */ + public function setDefaultTokenType(TokenTypeInterface $defaultTokenType) + { + $this->defaultTokenType = $defaultTokenType; + } + + /** + * Set the delimiter used to separate scopes in a request + * + * @param string $scopeDelimiter + */ + public function setScopeDelimiter($scopeDelimiter) + { + $this->scopeDelimiter = $scopeDelimiter; + } + + /** + * Set the default TTL of access tokens + * + * @param DateInterval $defaultAccessTokenTTL + */ + public function setDefaultAccessTokenTTL(DateInterval $defaultAccessTokenTTL) + { + $this->defaultAccessTokenTTL = $defaultAccessTokenTTL; + } + /** * @param string $grantType * @param TokenTypeInterface $tokenType @@ -83,7 +103,7 @@ class Server extends AbstractServer if ($tokenType instanceof TokenTypeInterface) { $this->grantTypeTokenTypes[$grantIdentifier] = $tokenType; } else { - $this->grantTypeTokenTypes[$grantIdentifier] = $this->defaultResponseType; + $this->grantTypeTokenTypes[$grantIdentifier] = $this->defaultTokenType; } // Set grant access token TTL @@ -124,14 +144,4 @@ class Server extends AbstractServer return $tokenType->generateHttpResponse(); } - - /** - * Set the delimiter used to separate scopes in a request - * - * @param string $scopeDelimiter - */ - public function setScopeDelimiter($scopeDelimiter) - { - $this->scopeDelimiter = $scopeDelimiter; - } }