-
Notifications
You must be signed in to change notification settings - Fork 89
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add disable access token saving feature #32
add disable access token saving feature #32
Conversation
src/LeagueOAuth2ServerBundle.php
Outdated
@@ -44,17 +44,36 @@ private function configureSecurityExtension(ContainerBuilder $container): void | |||
private function configureDoctrineExtension(ContainerBuilder $container): void | |||
{ | |||
/** @var string $modelDirectory */ | |||
$modelDirectory = realpath(__DIR__ . '/Resources/config/doctrine/model'); | |||
$modelCommonDirectory = realpath(__DIR__ . '/Resources/config/doctrine/common'); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not really comfortable with creating several XML mapping config files.
That's why in another PR I used the "php" approach. Have a look at https://github.com/thephpleague/oauth2-server-bundle/pull/25/files#diff-bbea8ca4dd205bd3df8e9ce6f139afa2852196075bea90a24f320ea3e449ba88R70.
Therefore it could be great if #25 could be merged before that PR (so you can base your mapping configuration on it)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah yes good point, I will check to do the same
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For this point I will do it when #25 will be merged to avoid multiple conflicts
@@ -256,6 +271,7 @@ private function configureDoctrinePersistence(ContainerBuilder $container, array | |||
$container | |||
->findDefinition(AccessTokenManager::class) | |||
->replaceArgument(0, $entityManager) | |||
->replaceArgument('$disableAccessTokenSaving', $disableAccessTokenSaving) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We try to use the argument index instead. In that way, renaming the argument won't require any changes elsewhere.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok, I will change
if ($disableAccessTokenSaving) { | ||
$container->setParameter('league.oauth2_server.persistence.doctrine.access_token.disabled', true); | ||
} else { | ||
$container->setParameter('league.oauth2_server.persistence.doctrine.access_token.enabled', true); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is that parameter needed?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
And if you think it's needed, I'd rather did like that:
$container->setParameter('league.oauth2_server.persistence.doctrine.persist_access_token', !$disableAccessTokenSaving);
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yes it's mandatory for configureDoctrineExtension. I need both because I didn't find how to invert boolean value from string parameter. But maybe with php approach I could remove it
{ | ||
$container | ||
->findDefinition(InMemoryAccessTokenManager::class) | ||
->replaceArgument('$disableAccessTokenSaving', $disableAccessTokenSaving) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same here
We try to use the argument index instead. In that way, renaming the argument won't require any changes elsewhere.
$loader->load('access_token/default.php'); | ||
} | ||
|
||
$container->setParameter('league.oauth2_server.authorization_server.disable_access_token_saving', $config['disable_access_token_saving']); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is that parameter needed? Moreover it's kind of redundant with league.oauth2_server.persistence.doctrine.access_token.disabled
parameter
/** | ||
* {@inheritdoc} | ||
*/ | ||
public function getNewToken(ClientEntityInterface $clientEntity, array $scopes, $userIdentifier = null) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you add typehints?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes I can it was not on the AccessTokenRepository so I did the same 😉
/** @var bool */ | ||
private $disableAccessTokenSaving; | ||
|
||
public function __construct(EntityManagerInterface $entityManager, bool $disableAccessTokenSaving) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
WDYT about a NullAccessTokenManager
instead?
@Orkin are you still interested in finishing this PR? If you want someone to take over, just tell us. |
Hi, I would like to finish but currently don't have time so if someone want to continue I'll appreciate. Sorry for that. |
No worry, thanks for the quick reply. Please keep this open. |
172f5f9
to
0a9bded
Compare
/** @var bool */ | ||
private $persistAccessToken; | ||
|
||
public function __construct(bool $persistAccessToken) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we add a NullAccessTokenManager
instead?
e998f57
to
156d13d
Compare
156d13d
to
03e815d
Compare
Thank you @Orkin. |
@mtarld @chalasr this is the port of disabled access token saving feature 😉