Skip to content
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

make superglobals more specific #8473

Merged
merged 5 commits into from
Sep 19, 2022
Merged

Conversation

kkmuffme
Copy link
Contributor

@kkmuffme kkmuffme commented Sep 9, 2022

Make the types of superglobals like $_GET, $_POST,... more specific than "Mixed" to allow for simpler and stricter conditions and more effective psalm checks in many cases.

@kkmuffme kkmuffme force-pushed the detailed-superglobal-types branch from e8e8f1f to db51fe8 Compare September 9, 2022 03:26
@kkmuffme kkmuffme force-pushed the detailed-superglobal-types branch 6 times, most recently from 297de41 to c2b2144 Compare September 11, 2022 05:56
@kkmuffme kkmuffme marked this pull request as ready for review September 11, 2022 05:57
@kkmuffme
Copy link
Contributor Author

Ready to be merged.

There are tons of reworks, as there is a bug in taint (#8477) that confused me, as I haven't used/worked with taint before and thought there's an issue in my code, while it was a bug in taint all along.

@AndrolGenhald
Copy link
Collaborator

We might have to think about this for the same reasons given in #1087. Mutating $_GET and other superglobals is a bad idea, but it's a bad idea that's still somewhat common unfortunately.

@kkmuffme kkmuffme force-pushed the detailed-superglobal-types branch 3 times, most recently from d81033b to 9a7d85f Compare September 11, 2022 16:29
@kkmuffme
Copy link
Contributor Author

You can still mutate $_GET just like before. The behavior for this isn't changed, is it?

Nevertheless, I think psalm should not account for niche, bad coding practices (since there's psalm-suppress and @var anyway) - there are very limited maintainer resources it being open source, so we shouldn't put too much thought into what is a 0.01% niche issue and a (very) bad coding practice in the first place to be honest. (but if anybody wants to fix it, we can still be open for it, I just don't think we should waste time with those things)

@staabm
Copy link
Contributor

staabm commented Sep 12, 2022

One way could be to make the more precise type inference a opt-in feature and also add a rule which reports errors when code modifies superglobals

@kkmuffme
Copy link
Contributor Author

add a rule which reports errors when code modifies superglobals

Definitely, but not within this PR. Please feel free to create a separate PR for that.

One way could be to make the more precise type inference a opt-in feature

It already is. Psalm already supports declaring any globals in your config. However this PR is not about that - it's about declaring what those ~6 generally available superglobals can contain in every environment (if you didn't specify that yourself in your config already).

@AndrolGenhald
Copy link
Collaborator

This might be something we'd want to consider.

@kkmuffme
Copy link
Contributor Author

This might be something we'd want to consider.

Actually, that's not the only issue. You can also have an auto_prepend_file in php.ini which changes ALL of them (including these), therefore nothing is safe here. Adding any conditions/checks for these few, would create a false sense of "security", as all of them can be changed in an auto_prepend_file or any file that runs before the current one in fact - which is an issue with all globals anyway.
Alas, don't need to consider this for this PR.

@AndrolGenhald
Copy link
Collaborator

which is an issue with all globals anyway

If we don't have one already, we should open an issue to make superglobals immutable.

@kkmuffme kkmuffme force-pushed the detailed-superglobal-types branch 3 times, most recently from c46fa9a to 87d6d47 Compare September 15, 2022 17:29
@kkmuffme kkmuffme force-pushed the detailed-superglobal-types branch 3 times, most recently from 661c7b3 to 26faa4b Compare September 15, 2022 18:03
@kkmuffme
Copy link
Contributor Author

@orklah all changes done, branch rebased.

Shepherd has a bug it seems, bc I don't get an error when I do this here: https://psalm.dev/r/66e2a12517 (also this error makes no sense)

$this->argv with declared type 'list' cannot be assigned type 'non-empty-list'

I think this is caused by having "possibly_undefined" and "ignore_nullable_issues" added as you suggested.
I mean I can just fix this in the test by changing it to non-empty-list, but it will be a pain for everybody else.
What do you suggest?

@psalm-github-bot
Copy link

I found these snippets:

https://psalm.dev/r/66e2a12517
<?php

class Foo {
    /**
     * @var array<int, string>
     */
    private $argv = [];
    
    /**
     * @param non-empty-list<string> $arg
     */
    public function __construct($arg) {
    	$this->argv = $arg;
    }
}
Psalm output (using commit d957ff2):

No issues!

@orklah
Copy link
Collaborator

orklah commented Sep 18, 2022

I think this is caused by having "possibly_undefined" and "ignore_nullable_issues" added as you suggested.

Yeah, it's probably due to the check for InvalidPropertyAssignmentValue considering that possibly_undefined could lead to null and not checking ignore_nullable. Can you coalesce with empty array here? It should solve the issue

@kkmuffme
Copy link
Contributor Author

Yes, but that's what I had before with TNull already, however the error made much more sense then.

Because the error now doesn't make any sense:

$this->argv with declared type 'list' cannot be assigned type 'non-empty-list'

The reason why it reports this is because it's nullable, but psalm hides the fact that it could be "null".

Maybe putting back TNull and removing possibly_undefined make it better? let me try that. If not, I think I'll revert it as it was, bc at least the error made sense then.

@kkmuffme kkmuffme force-pushed the detailed-superglobal-types branch from 3ec15f6 to e2e6265 Compare September 19, 2022 07:46
@kkmuffme
Copy link
Contributor Author

kkmuffme commented Sep 19, 2022

@orklah yeah it works how you want it when I do it with TNull and $argv_nullable->ignore_nullable_issues = true;

When using without TNull but doing:

$argv_nullable->possibly_undefined = true;
$argv_nullable->ignore_nullable_issues = true;

It reports those wrong errors.

Changed now.

Ready to be merged now.

@orklah orklah added the release:feature The PR will be included in 'Features' section of the release notes label Sep 19, 2022
@orklah orklah merged commit 3b7e508 into vimeo:4.x Sep 19, 2022
@orklah
Copy link
Collaborator

orklah commented Sep 19, 2022

Thanks!

@olleharstedt
Copy link
Contributor

I think this PR broke our CI. See my latest bug here: #8559

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
release:feature The PR will be included in 'Features' section of the release notes
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants