mirror of
https://github.com/elyby/oauth2-server.git
synced 2025-01-11 22:32:07 +05:30
Merge pull request #457 from juliangut/renderer
V5 - Allow different template engines
This commit is contained in:
commit
4c55b6879d
@ -64,6 +64,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"suggest": {
|
"suggest": {
|
||||||
"league/plates": "Required for parsing authorization code templates"
|
"league/plates": "Used for parsing authorization code templates",
|
||||||
|
"twig/twig": "Used for parsing authorization code templates",
|
||||||
|
"smarty/smarty": "Used for parsing authorization code templates",
|
||||||
|
"mustache/mustache": "Used for parsing authorization code templates"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
90
src/Grant/AbstractAuthorizeGrant.php
Normal file
90
src/Grant/AbstractAuthorizeGrant.php
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Abstract authorization grant.
|
||||||
|
*
|
||||||
|
* @author Julián Gutiérrez <juliangut@gmail.com>
|
||||||
|
* @copyright Copyright (c) Alex Bilbie
|
||||||
|
* @license http://mit-license.org/
|
||||||
|
*
|
||||||
|
* @link https://github.com/thephpleague/oauth2-server
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace League\OAuth2\Server\Grant;
|
||||||
|
|
||||||
|
use League\OAuth2\Server\TemplateRenderer\PlatesRenderer;
|
||||||
|
use League\OAuth2\Server\TemplateRenderer\RendererInterface;
|
||||||
|
use League\Plates\Engine;
|
||||||
|
|
||||||
|
abstract class AbstractAuthorizeGrant extends AbstractGrant
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @var null|\League\OAuth2\Server\TemplateRenderer\RendererInterface
|
||||||
|
*/
|
||||||
|
protected $templateRenderer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var null|string
|
||||||
|
*/
|
||||||
|
protected $loginTemplate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var null|string
|
||||||
|
*/
|
||||||
|
protected $authorizeTemplate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array $data
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
protected function renderLoginTemplate(array $data = [])
|
||||||
|
{
|
||||||
|
return $this->getTemplateRenderer()->render($this->getLoginTemplate(), $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array $data
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
protected function renderAuthorizeTemplate(array $data = [])
|
||||||
|
{
|
||||||
|
return $this->getTemplateRenderer()->render($this->getAuthorizeTemplate(), $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return \League\OAuth2\Server\TemplateRenderer\RendererInterface
|
||||||
|
*/
|
||||||
|
protected function getTemplateRenderer()
|
||||||
|
{
|
||||||
|
if (!$this->templateRenderer instanceof RendererInterface) {
|
||||||
|
$this->templateRenderer = new PlatesRenderer(new Engine(__DIR__ . '/../ResponseTypes/DefaultTemplates'));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->templateRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
protected function getLoginTemplate()
|
||||||
|
{
|
||||||
|
if (empty($this->loginTemplate)) {
|
||||||
|
$this->loginTemplate = 'login_user';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->loginTemplate;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
protected function getAuthorizeTemplate()
|
||||||
|
{
|
||||||
|
if (empty($this->authorizeTemplate)) {
|
||||||
|
$this->authorizeTemplate = 'authorize_client';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->authorizeTemplate;
|
||||||
|
}
|
||||||
|
}
|
@ -11,13 +11,13 @@ use League\OAuth2\Server\Repositories\AuthCodeRepositoryInterface;
|
|||||||
use League\OAuth2\Server\Repositories\RefreshTokenRepositoryInterface;
|
use League\OAuth2\Server\Repositories\RefreshTokenRepositoryInterface;
|
||||||
use League\OAuth2\Server\Repositories\UserRepositoryInterface;
|
use League\OAuth2\Server\Repositories\UserRepositoryInterface;
|
||||||
use League\OAuth2\Server\ResponseTypes\ResponseTypeInterface;
|
use League\OAuth2\Server\ResponseTypes\ResponseTypeInterface;
|
||||||
|
use League\OAuth2\Server\TemplateRenderer\RendererInterface;
|
||||||
use League\OAuth2\Server\Utils\KeyCrypt;
|
use League\OAuth2\Server\Utils\KeyCrypt;
|
||||||
use League\Plates\Engine;
|
|
||||||
use Psr\Http\Message\ServerRequestInterface;
|
use Psr\Http\Message\ServerRequestInterface;
|
||||||
use Zend\Diactoros\Response;
|
use Zend\Diactoros\Response;
|
||||||
use Zend\Diactoros\Uri;
|
use Zend\Diactoros\Uri;
|
||||||
|
|
||||||
class AuthCodeGrant extends AbstractGrant
|
class AuthCodeGrant extends AbstractAuthorizeGrant
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @var \DateInterval
|
* @var \DateInterval
|
||||||
@ -29,51 +29,32 @@ class AuthCodeGrant extends AbstractGrant
|
|||||||
*/
|
*/
|
||||||
private $userRepository;
|
private $userRepository;
|
||||||
|
|
||||||
/**
|
|
||||||
* @var null|string
|
|
||||||
*/
|
|
||||||
private $pathToLoginTemplate;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var null|string
|
|
||||||
*/
|
|
||||||
private $pathToAuthorizeTemplate;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param \League\OAuth2\Server\Repositories\AuthCodeRepositoryInterface $authCodeRepository
|
* @param \League\OAuth2\Server\Repositories\AuthCodeRepositoryInterface $authCodeRepository
|
||||||
* @param \League\OAuth2\Server\Repositories\RefreshTokenRepositoryInterface $refreshTokenRepository
|
* @param \League\OAuth2\Server\Repositories\RefreshTokenRepositoryInterface $refreshTokenRepository
|
||||||
* @param \League\OAuth2\Server\Repositories\UserRepositoryInterface $userRepository
|
* @param \League\OAuth2\Server\Repositories\UserRepositoryInterface $userRepository
|
||||||
* @param \DateInterval $authCodeTTL
|
* @param \DateInterval $authCodeTTL
|
||||||
* @param string|null $pathToLoginTemplate
|
* @param string|null $loginTemplate
|
||||||
* @param string|null $pathToAuthorizeTemplate
|
* @param string|null $authorizeTemplate
|
||||||
|
* @param \League\OAuth2\Server\TemplateRenderer\RendererInterface|null $templateRenderer
|
||||||
*/
|
*/
|
||||||
public function __construct(
|
public function __construct(
|
||||||
AuthCodeRepositoryInterface $authCodeRepository,
|
AuthCodeRepositoryInterface $authCodeRepository,
|
||||||
RefreshTokenRepositoryInterface $refreshTokenRepository,
|
RefreshTokenRepositoryInterface $refreshTokenRepository,
|
||||||
UserRepositoryInterface $userRepository,
|
UserRepositoryInterface $userRepository,
|
||||||
\DateInterval $authCodeTTL,
|
\DateInterval $authCodeTTL,
|
||||||
$pathToLoginTemplate = null,
|
$loginTemplate = null,
|
||||||
$pathToAuthorizeTemplate = null
|
$authorizeTemplate = null,
|
||||||
|
RendererInterface $templateRenderer = null
|
||||||
) {
|
) {
|
||||||
$this->setAuthCodeRepository($authCodeRepository);
|
$this->setAuthCodeRepository($authCodeRepository);
|
||||||
$this->setRefreshTokenRepository($refreshTokenRepository);
|
$this->setRefreshTokenRepository($refreshTokenRepository);
|
||||||
$this->userRepository = $userRepository;
|
$this->userRepository = $userRepository;
|
||||||
$this->authCodeTTL = $authCodeTTL;
|
$this->authCodeTTL = $authCodeTTL;
|
||||||
$this->refreshTokenTTL = new \DateInterval('P1M');
|
$this->refreshTokenTTL = new \DateInterval('P1M');
|
||||||
|
$this->loginTemplate = $loginTemplate;
|
||||||
$this->pathToLoginTemplate = __DIR__ . '/../ResponseTypes/DefaultTemplates/login_user';
|
$this->authorizeTemplate = $authorizeTemplate;
|
||||||
if ($pathToLoginTemplate !== null) {
|
$this->templateRenderer = $templateRenderer;
|
||||||
$this->pathToLoginTemplate = (substr($pathToLoginTemplate, -4) === '.php')
|
|
||||||
? substr($pathToLoginTemplate, 0, -4)
|
|
||||||
: $pathToLoginTemplate;
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->pathToAuthorizeTemplate = __DIR__ . '/../ResponseTypes/DefaultTemplates/authorize_client';
|
|
||||||
if ($pathToAuthorizeTemplate !== null) {
|
|
||||||
$this->pathToAuthorizeTemplate = (substr($pathToAuthorizeTemplate, -4) === '.php')
|
|
||||||
? substr($pathToAuthorizeTemplate, 0, -4)
|
|
||||||
: $pathToAuthorizeTemplate;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -164,31 +145,21 @@ class AuthCodeGrant extends AbstractGrant
|
|||||||
|
|
||||||
// The user hasn't logged in yet so show a login form
|
// The user hasn't logged in yet so show a login form
|
||||||
if ($userId === null) {
|
if ($userId === null) {
|
||||||
$engine = new Engine(dirname($this->pathToLoginTemplate));
|
$html = $this->renderLoginTemplate([
|
||||||
$pathParts = explode(DIRECTORY_SEPARATOR, $this->pathToLoginTemplate);
|
|
||||||
$html = $engine->render(
|
|
||||||
end($pathParts),
|
|
||||||
[
|
|
||||||
'error' => $loginError,
|
'error' => $loginError,
|
||||||
'postback_uri' => (string) $postbackUri->withQuery($queryString),
|
'postback_uri' => (string) $postbackUri->withQuery($queryString),
|
||||||
]
|
]);
|
||||||
);
|
|
||||||
|
|
||||||
return new Response\HtmlResponse($html);
|
return new Response\HtmlResponse($html);
|
||||||
}
|
}
|
||||||
|
|
||||||
// The user hasn't approved the client yet so show an authorize form
|
// The user hasn't approved the client yet so show an authorize form
|
||||||
if ($userId !== null && $userHasApprovedClient === null) {
|
if ($userId !== null && $userHasApprovedClient === null) {
|
||||||
$engine = new Engine(dirname($this->pathToAuthorizeTemplate));
|
$html = $this->renderAuthorizeTemplate([
|
||||||
$pathParts = explode(DIRECTORY_SEPARATOR, $this->pathToAuthorizeTemplate);
|
|
||||||
$html = $engine->render(
|
|
||||||
end($pathParts),
|
|
||||||
[
|
|
||||||
'client' => $client,
|
'client' => $client,
|
||||||
'scopes' => $scopes,
|
'scopes' => $scopes,
|
||||||
'postback_uri' => (string) $postbackUri->withQuery($queryString),
|
'postback_uri' => (string) $postbackUri->withQuery($queryString),
|
||||||
]
|
]);
|
||||||
);
|
|
||||||
|
|
||||||
return new Response\HtmlResponse(
|
return new Response\HtmlResponse(
|
||||||
$html,
|
$html,
|
||||||
|
@ -8,55 +8,36 @@ use League\OAuth2\Server\Entities\Interfaces\UserEntityInterface;
|
|||||||
use League\OAuth2\Server\Exception\OAuthServerException;
|
use League\OAuth2\Server\Exception\OAuthServerException;
|
||||||
use League\OAuth2\Server\Repositories\UserRepositoryInterface;
|
use League\OAuth2\Server\Repositories\UserRepositoryInterface;
|
||||||
use League\OAuth2\Server\ResponseTypes\ResponseTypeInterface;
|
use League\OAuth2\Server\ResponseTypes\ResponseTypeInterface;
|
||||||
|
use League\OAuth2\Server\TemplateRenderer\RendererInterface;
|
||||||
use League\OAuth2\Server\Utils\KeyCrypt;
|
use League\OAuth2\Server\Utils\KeyCrypt;
|
||||||
use League\Plates\Engine;
|
|
||||||
use Psr\Http\Message\ServerRequestInterface;
|
use Psr\Http\Message\ServerRequestInterface;
|
||||||
use Zend\Diactoros\Response;
|
use Zend\Diactoros\Response;
|
||||||
use Zend\Diactoros\Uri;
|
use Zend\Diactoros\Uri;
|
||||||
|
|
||||||
class ImplicitGrant extends AbstractGrant
|
class ImplicitGrant extends AbstractAuthorizeGrant
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @var \League\OAuth2\Server\Repositories\UserRepositoryInterface
|
* @var \League\OAuth2\Server\Repositories\UserRepositoryInterface
|
||||||
*/
|
*/
|
||||||
private $userRepository;
|
private $userRepository;
|
||||||
|
|
||||||
/**
|
|
||||||
* @var null|string
|
|
||||||
*/
|
|
||||||
private $pathToLoginTemplate;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var null|string
|
|
||||||
*/
|
|
||||||
private $pathToAuthorizeTemplate;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param \League\OAuth2\Server\Repositories\UserRepositoryInterface $userRepository
|
* @param \League\OAuth2\Server\Repositories\UserRepositoryInterface $userRepository
|
||||||
* @param string|null $pathToLoginTemplate
|
* @param string|null $loginTemplate
|
||||||
* @param string|null $pathToAuthorizeTemplate
|
* @param string|null $authorizeTemplate
|
||||||
|
* @param \League\OAuth2\Server\TemplateRenderer\RendererInterface|null $templateRenderer
|
||||||
*/
|
*/
|
||||||
public function __construct(
|
public function __construct(
|
||||||
UserRepositoryInterface $userRepository,
|
UserRepositoryInterface $userRepository,
|
||||||
$pathToLoginTemplate = null,
|
$loginTemplate = null,
|
||||||
$pathToAuthorizeTemplate = null
|
$authorizeTemplate = null,
|
||||||
|
RendererInterface $templateRenderer = null
|
||||||
) {
|
) {
|
||||||
$this->userRepository = $userRepository;
|
$this->userRepository = $userRepository;
|
||||||
$this->refreshTokenTTL = new \DateInterval('P1M');
|
$this->refreshTokenTTL = new \DateInterval('P1M');
|
||||||
|
$this->loginTemplate = $loginTemplate;
|
||||||
$this->pathToLoginTemplate = __DIR__ . '/../ResponseTypes/DefaultTemplates/login_user';
|
$this->authorizeTemplate = $authorizeTemplate;
|
||||||
if ($pathToLoginTemplate !== null) {
|
$this->templateRenderer = $templateRenderer;
|
||||||
$this->pathToLoginTemplate = (substr($pathToLoginTemplate, -4) === '.php')
|
|
||||||
? substr($pathToLoginTemplate, 0, -4)
|
|
||||||
: $pathToLoginTemplate;
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->pathToAuthorizeTemplate = __DIR__ . '/../ResponseTypes/DefaultTemplates/authorize_client';
|
|
||||||
if ($pathToAuthorizeTemplate !== null) {
|
|
||||||
$this->pathToAuthorizeTemplate = (substr($pathToAuthorizeTemplate, -4) === '.php')
|
|
||||||
? substr($pathToAuthorizeTemplate, 0, -4)
|
|
||||||
: $pathToAuthorizeTemplate;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -164,31 +145,21 @@ class ImplicitGrant extends AbstractGrant
|
|||||||
|
|
||||||
// The user hasn't logged in yet so show a login form
|
// The user hasn't logged in yet so show a login form
|
||||||
if ($userId === null) {
|
if ($userId === null) {
|
||||||
$engine = new Engine(dirname($this->pathToLoginTemplate));
|
$html = $this->renderLoginTemplate([
|
||||||
$pathParts = explode(DIRECTORY_SEPARATOR, $this->pathToLoginTemplate);
|
|
||||||
$html = $engine->render(
|
|
||||||
end($pathParts),
|
|
||||||
[
|
|
||||||
'error' => $loginError,
|
'error' => $loginError,
|
||||||
'postback_uri' => (string) $postbackUri->withQuery($queryString),
|
'postback_uri' => (string) $postbackUri->withQuery($queryString),
|
||||||
]
|
]);
|
||||||
);
|
|
||||||
|
|
||||||
return new Response\HtmlResponse($html);
|
return new Response\HtmlResponse($html);
|
||||||
}
|
}
|
||||||
|
|
||||||
// The user hasn't approved the client yet so show an authorize form
|
// The user hasn't approved the client yet so show an authorize form
|
||||||
if ($userId !== null && $userHasApprovedClient === null) {
|
if ($userId !== null && $userHasApprovedClient === null) {
|
||||||
$engine = new Engine(dirname($this->pathToAuthorizeTemplate));
|
$html = $this->renderAuthorizeTemplate([
|
||||||
$pathParts = explode(DIRECTORY_SEPARATOR, $this->pathToAuthorizeTemplate);
|
|
||||||
$html = $engine->render(
|
|
||||||
end($pathParts),
|
|
||||||
[
|
|
||||||
'client' => $client,
|
'client' => $client,
|
||||||
'scopes' => $scopes,
|
'scopes' => $scopes,
|
||||||
'postback_uri' => (string) $postbackUri->withQuery($queryString),
|
'postback_uri' => (string) $postbackUri->withQuery($queryString),
|
||||||
]
|
]);
|
||||||
);
|
|
||||||
|
|
||||||
return new Response\HtmlResponse(
|
return new Response\HtmlResponse(
|
||||||
$html,
|
$html,
|
||||||
|
39
src/TemplateRenderer/MustacheRenderer.php
Normal file
39
src/TemplateRenderer/MustacheRenderer.php
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Mustache template renderer bridge.
|
||||||
|
*
|
||||||
|
* @author Julián Gutiérrez <juliangut@gmail.com>
|
||||||
|
* @copyright Copyright (c) Alex Bilbie
|
||||||
|
* @license http://mit-license.org/
|
||||||
|
*
|
||||||
|
* @link https://github.com/thephpleague/oauth2-server
|
||||||
|
*/
|
||||||
|
namespace League\OAuth2\Server\TemplateRenderer;
|
||||||
|
|
||||||
|
use Mustache_Engine;
|
||||||
|
|
||||||
|
class MustacheRenderer implements RendererInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @var \Mustache_Engine
|
||||||
|
*/
|
||||||
|
private $engine;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TwigRenderer constructor.
|
||||||
|
*
|
||||||
|
* @param \Mustache_Engine $engine
|
||||||
|
*/
|
||||||
|
public function __construct(Mustache_Engine $engine)
|
||||||
|
{
|
||||||
|
$this->engine = $engine;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function render($template, array $data = [])
|
||||||
|
{
|
||||||
|
return $this->engine->render($template, $data);
|
||||||
|
}
|
||||||
|
}
|
43
src/TemplateRenderer/PlatesRenderer.php
Normal file
43
src/TemplateRenderer/PlatesRenderer.php
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Plates template renderer bridge.
|
||||||
|
*
|
||||||
|
* @author Julián Gutiérrez <juliangut@gmail.com>
|
||||||
|
* @copyright Copyright (c) Alex Bilbie
|
||||||
|
* @license http://mit-license.org/
|
||||||
|
*
|
||||||
|
* @link https://github.com/thephpleague/oauth2-server
|
||||||
|
*/
|
||||||
|
namespace League\OAuth2\Server\TemplateRenderer;
|
||||||
|
|
||||||
|
use League\Plates\Engine;
|
||||||
|
|
||||||
|
class PlatesRenderer implements RendererInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @var \League\Plates\Engine
|
||||||
|
*/
|
||||||
|
private $engine;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* PlatesRenderer constructor.
|
||||||
|
*
|
||||||
|
* @param \League\Plates\Engine $engine
|
||||||
|
*/
|
||||||
|
public function __construct(Engine $engine)
|
||||||
|
{
|
||||||
|
$this->engine = $engine;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function render($template, array $data = [])
|
||||||
|
{
|
||||||
|
if ($this->engine->getFileExtension()) {
|
||||||
|
$template = preg_replace(sprintf('/\.%s$/', $this->engine->getFileExtension()), '', $template);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->engine->render($template, $data);
|
||||||
|
}
|
||||||
|
}
|
22
src/TemplateRenderer/RendererInterface.php
Normal file
22
src/TemplateRenderer/RendererInterface.php
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Template renderer Interface.
|
||||||
|
*
|
||||||
|
* @author Julián Gutiérrez <juliangut@gmail.com>
|
||||||
|
* @copyright Copyright (c) Alex Bilbie
|
||||||
|
* @license http://mit-license.org/
|
||||||
|
*
|
||||||
|
* @link https://github.com/thephpleague/oauth2-server
|
||||||
|
*/
|
||||||
|
namespace League\OAuth2\Server\TemplateRenderer;
|
||||||
|
|
||||||
|
interface RendererInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param string $template
|
||||||
|
* @param array $data
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function render($template, array $data = []);
|
||||||
|
}
|
45
src/TemplateRenderer/SmartyRenderer.php
Normal file
45
src/TemplateRenderer/SmartyRenderer.php
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty template renderer bridge.
|
||||||
|
*
|
||||||
|
* @author Julián Gutiérrez <juliangut@gmail.com>
|
||||||
|
* @copyright Copyright (c) Alex Bilbie
|
||||||
|
* @license http://mit-license.org/
|
||||||
|
*
|
||||||
|
* @link https://github.com/thephpleague/oauth2-server
|
||||||
|
*/
|
||||||
|
namespace League\OAuth2\Server\TemplateRenderer;
|
||||||
|
|
||||||
|
use Smarty;
|
||||||
|
|
||||||
|
class SmartyRenderer implements RendererInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Smarty class.
|
||||||
|
*
|
||||||
|
* @var \Smarty
|
||||||
|
*/
|
||||||
|
private $smarty;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param \Smarty $smarty
|
||||||
|
*/
|
||||||
|
public function __construct(Smarty $smarty)
|
||||||
|
{
|
||||||
|
$this->smarty = $smarty;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function render($template, array $data = [])
|
||||||
|
{
|
||||||
|
$this->smarty->assign($data);
|
||||||
|
|
||||||
|
$output = $this->smarty->fetch($template);
|
||||||
|
|
||||||
|
$this->smarty->clear_assign(array_keys($data));
|
||||||
|
|
||||||
|
return $output;
|
||||||
|
}
|
||||||
|
}
|
39
src/TemplateRenderer/TwigRenderer.php
Normal file
39
src/TemplateRenderer/TwigRenderer.php
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Twig template renderer bridge.
|
||||||
|
*
|
||||||
|
* @author Julián Gutiérrez <juliangut@gmail.com>
|
||||||
|
* @copyright Copyright (c) Alex Bilbie
|
||||||
|
* @license http://mit-license.org/
|
||||||
|
*
|
||||||
|
* @link https://github.com/thephpleague/oauth2-server
|
||||||
|
*/
|
||||||
|
namespace League\OAuth2\Server\TemplateRenderer;
|
||||||
|
|
||||||
|
use Twig_Environment;
|
||||||
|
|
||||||
|
class TwigRenderer implements RendererInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @var \Twig_Environment
|
||||||
|
*/
|
||||||
|
private $environment;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TwigRenderer constructor.
|
||||||
|
*
|
||||||
|
* @param \Twig_Environment $environment
|
||||||
|
*/
|
||||||
|
public function __construct(Twig_Environment $environment)
|
||||||
|
{
|
||||||
|
$this->environment = $environment;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function render($template, array $data = [])
|
||||||
|
{
|
||||||
|
return $this->environment->loadTemplate($template)->render($data);
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user