Fix UID handling with cask installer script:
#17782
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Broadly speaking, Homebrew respects EUID and writes all files using that EUID.
When using
installer script:
this contract may not necessarily be true for third-party scripts, leading to permission issues under setups where EUID != UID. For example, bash scripts by default will respect UID instead unless you use Bash protected mode (bash -p
).In formulae, we already handle this here:
brew/Library/Homebrew/utils/fork.rb
Line 48 in 2cdc092
This PR adds the same to casks via a
reset_uid
system_command
option. Unfortunately Open3 isn't flexible enough to handle this so we need to replace it with our own implementation.