-
-
Notifications
You must be signed in to change notification settings - Fork 31
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
Upgrade Service Manager to v4 in require
, Cache to v4 and Validator to v3 in require-dev
#103
base: 3.0.x
Are you sure you want to change the base?
Conversation
@Jurj-Bogdan See #102 |
@laminas/technical-steering-committee So, should I create the branch 3.0.x and merge this one there ? |
Yes, create 3.0.x from the tip of the next minor release - You should probably get 2.24.x patches resolved first such as #106 so that merge-ups from 2.x have fewer conflicts |
@Jurj-Bogdan Please fix the conflicts |
@@ -41,28 +40,20 @@ class ContainerAbstractServiceFactory implements AbstractFactoryInterface | |||
{ |
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.
This class should be made final and all properties private. You should also mark this class soft final with @final
in a 2.x release
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.
Done - also a related question here. I just noticed there are already some classes marked as deprecated, maybe this should be a good time to remove them as well?
Talking about AbstractValidatorChain
and AbstractValidatorChainEM3
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 - anything that's deprecated should be dealt with in the next major. I don't know this lib well enough to know what the implications or plans might have been though.
Don't forget to document any BC breaks here with companion patches against 2.x including deprecations, and, make a start on a migration guide that lists all the BC breaking changes
* session?: Container, | ||
* timeout?: ?int, | ||
* } | ||
*/ | ||
final class Csrf extends AbstractValidator |
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.
This whole class will probably need further refactoring such as deprecating and dropping all the public setters and getters
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.
Not suggesting that work should happen in this patch tho!
@@ -114,7 +114,8 @@ public function testFactoryWillAddValidatorViaConfiguration(): void | |||
|
|||
$manager->start(); | |||
|
|||
$chain = $manager->getValidatorChain(); | |||
$chain = $manager->getValidatorChain(); | |||
/** @psalm-suppress ArgumentTypeCoercion **/ |
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.
Please remove this suppression and replace it with assertions.
Assert the manager is ManagerInterface
Assert the chain is a EventManagerInterface
or whatever it's supposed to be
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.
Added some phpunit assertions as they're useful, but Psalm is still adamant in throwing "ArgumentTypeCoercion" errors which is why the suppressions are still there.
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.
You need to assert $chain
is an instance of EventManager
(The concrete class) because that's what getListenersForEvent
expects.
Please also add findUnusedPsalmSuppress="true"
to psalm.xml
so that unused inline suppressions are flagged.
@@ -198,7 +199,8 @@ public function testFactoryDoesNotAttachValidatorTwoTimes(): void | |||
// Ignore exception, because we are not interested whether session validation passes in this test | |||
} | |||
|
|||
$chain = $manager->getValidatorChain(); | |||
$chain = $manager->getValidatorChain(); | |||
/** @psalm-suppress ArgumentTypeCoercion **/ |
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… More assertions!
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.
This suppression still needs fixing too!
Signed-off-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Signed-off-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
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.
Thanks @Jurj-Bogdan - A few more tweaks please :)
Apart from inline comments, all of the changed factories need to be made final
and they should all have a good cleanup - i.e protected
props to private
, drop any methods that are pointless etc. Happy to wait for another patch for those things, but we really don't want users extending factories and need to prevent that in the next major
*/ | ||
protected function getConfig(ContainerInterface $container) | ||
protected function getConfig(ContainerInterface $container): array |
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.
This should be private
*/ | ||
protected function getSessionManager(ContainerInterface $container) | ||
protected function getSessionManager(ContainerInterface $container): ?ManagerInterface |
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.
This should be private
*/ | ||
protected function normalizeContainerName($name) | ||
protected function normalizeContainerName(string $name): string |
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.
This should be private
or maybe inlined if it's only used once
@@ -114,7 +114,8 @@ public function testFactoryWillAddValidatorViaConfiguration(): void | |||
|
|||
$manager->start(); | |||
|
|||
$chain = $manager->getValidatorChain(); | |||
$chain = $manager->getValidatorChain(); | |||
/** @psalm-suppress ArgumentTypeCoercion **/ |
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.
You need to assert $chain
is an instance of EventManager
(The concrete class) because that's what getListenersForEvent
expects.
Please also add findUnusedPsalmSuppress="true"
to psalm.xml
so that unused inline suppressions are flagged.
@@ -198,7 +199,8 @@ public function testFactoryDoesNotAttachValidatorTwoTimes(): void | |||
// Ignore exception, because we are not interested whether session validation passes in this test | |||
} | |||
|
|||
$chain = $manager->getValidatorChain(); | |||
$chain = $manager->getValidatorChain(); | |||
/** @psalm-suppress ArgumentTypeCoercion **/ |
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.
This suppression still needs fixing too!
require
, Cache to v4 and Validator to v3 in require-dev
Signed-off-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
…ed deprecated usage functions Signed-off-by: Jurj-Bogdan <[email protected]>
Signed-off-by: Jurj-Bogdan <[email protected]>
Signed-off-by: Jurj-Bogdan <[email protected]>
…ed deprecated usage functions Signed-off-by: Jurj-Bogdan <[email protected]>
Signed-off-by: Jurj-Bogdan <[email protected]>
Signed-off-by: Jurj-Bogdan <[email protected]>
…hanges Signed-off-by: Jurj-Bogdan <[email protected]>
3411dbd
to
61f4a8c
Compare
@gsteel Just added the latest requested changes, i hope i didn't miss anything. A note related to the My understanding of the comment is that Since the old getters for both Also removed the sequences marked as "@todo remove", including the adding of the hash to the session container directly instead of as an entry in the "tokenList" only - i take it this feature is no longer wanted, right? As for the failing test, since issue #115 mentions removing mongoDb altogether, I'll go ahead and create a different PR with that change (and for the other sub issues as well) so this PR doesn't get too cluttered. |
If all the red CI here is MongoDB's fault, why not work on a patch to fix #115 first and then rebase here when its done. |
Mind you, looking at the CI logs, the problem is a simple deprecation in the mongo lib. Has anyone looked at just fixing that deprecation? |
That would be the fix in another PR for the 2.x version, but from what i understand mongoDb is to be removed in version 3, no? |
There's currently no rationale for its removal as far as I know - just an issue to remove it. Perhaps @arhimede has more information on why it should be removed |
First of all, MongoDB is an external dependency of this package , I see no point to be included in this package . Last but not least, see this old discussion on this matter: #23 |
And not to mention the licensing of MongoDB which is quite complex. |
I have no problem with it being removed as long as the decision making and docs are sound 👍 My point here is: Why not send in a patches now to…
That way devlopment can move forward on other things more easily because there will be fewer red builds |
Upgraded
laminas/laminas-servicemanager
to version 4, as well as the other dependencies required for it, and added various Psalm tweaks.I seems I was working on this PR alongside #102 , with the main difference seemingly being the removal of
v2
functions from the codebase in preparation for a new major release.I was about to make a different PR to the current branch marking the functions removed here as
deprecated
, but I'll wait for feedback regarding the desired way forward.