Skip to content

Commit

Permalink
Merge pull request #2511 from TheCakeIsNaOH/gate-powershell
Browse files Browse the repository at this point in the history
(#2510) Stop Beforemodify scripts from running on non-windows
  • Loading branch information
gep13 authored Jan 10, 2022
2 parents a6a0cd9 + f2de491 commit 44d7969
Show file tree
Hide file tree
Showing 8 changed files with 32 additions and 18 deletions.
2 changes: 1 addition & 1 deletion nuget/chocolatey/tools/init.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ After you have run Initialize-Chocolatey, you can safely uninstall the chocolate
----------
Alternative NuGet -
----------
If you are not using NuGet in Visual Studio, please navigate to the directory with the chocolateysetup.psm1 and run that in Powershell, followed by Initialize-Chocolatey.
If you are not using NuGet in Visual Studio, please navigate to the directory with the chocolateysetup.psm1 and run that in PowerShell, followed by Initialize-Chocolatey.
Upgrade is the same, just run Initialize-Chocolatey again.
----------
Once you've run initialize or upgrade, you can uninstall this package from the local project without affecting your chocolatey repository.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ param(
Write-Warning "Missing package checksums are not allowed (by default for HTTP/FTP, `n HTTPS when feature 'allowEmptyChecksumsSecure' is disabled) for `n safety and security reasons. Although we strongly advise against it, `n if you need this functionality, please set the feature `n 'allowEmptyChecksums' ('choco feature enable -n `n allowEmptyChecksums') `n or pass in the option '--allow-empty-checksums'. You can also pass `n checksums at runtime (recommended). See `choco install -?` for details."
Write-Debug "If you are a maintainer attempting to determine the checksum for packaging purposes, please run `n 'choco install checksum' and run 'checksum -t sha256 -f $file' `n Ensure you do this for all remote resources."
if ($PSVersionTable.PSVersion.Major -ge 4){
Write-Debug "Because you are running Powershell with a major version of v4 or greater, you could also opt to run `n '(Get-FileHash -Path $file -Algorithm SHA256).Hash' `n rather than install a separate tool."
Write-Debug "Because you are running PowerShell with a major version of v4 or greater, you could also opt to run `n '(Get-FileHash -Path $file -Algorithm SHA256).Hash' `n rather than install a separate tool."
}

if ($env:ChocolateyPowerShellHost -eq 'true') {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -306,7 +306,7 @@ param(
$headers = Get-WebHeaders -Url $url -ErrorAction "Stop"
} catch {
if ($PSVersionTable.PSVersion -lt (New-Object 'Version' 3,0)) {
Write-Debug "Converting Security Protocol to SSL3 only for Powershell v2"
Write-Debug "Converting Security Protocol to SSL3 only for PowerShell v2"
# this should last for the entire duration
$originalProtocol = [System.Net.ServicePointManager]::SecurityProtocol
[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.SecurityProtocolType]::Ssl3
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -490,6 +490,8 @@ public void should_not_have_warning_package_result()
}

[Concern(typeof(ChocolateyUninstallCommand))]
[WindowsOnly]
[Platform(Exclude = "Mono")]
public class when_uninstalling_a_package_with_an_exclusively_locked_file : ScenariosBase
{
private PackageResult _packageResult;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ public virtual void configure_argument_parser(OptionSet optionSet, ChocolateyCon
"ForceDependencies - Force dependencies to be reinstalled when force installing package(s). Must be used in conjunction with --force. Defaults to false.",
option => configuration.ForceDependencies = option != null)
.Add("n|skippowershell|skip-powershell|skipscripts|skip-scripts|skip-automation-scripts",
"Skip Powershell - Do not run chocolateyInstall.ps1. Defaults to false.",
"Skip PowerShell - Do not run chocolateyInstall.ps1. Defaults to false.",
option => configuration.SkipPackageInstallProvider = option != null)
.Add("u=|user=",
"User - used with authenticated feeds. Defaults to empty.",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ public virtual void configure_argument_parser(OptionSet optionSet, ChocolateyCon
"RemoveDependencies - Uninstall dependencies when uninstalling package(s). Defaults to false.",
option => configuration.ForceDependencies = option != null)
.Add("n|skippowershell|skip-powershell|skipscripts|skip-scripts|skip-automation-scripts",
"Skip Powershell - Do not run chocolateyUninstall.ps1. Defaults to false.",
"Skip PowerShell - Do not run chocolateyUninstall.ps1. Defaults to false.",
option => configuration.SkipPackageInstallProvider = option != null)
.Add("ignorepackagecodes|ignorepackageexitcodes|ignore-package-codes|ignore-package-exit-codes",
"IgnorePackageExitCodes - Exit with a 0 for success and 1 for non-success, no matter what package scripts provide for exit codes. Overrides the default feature '{0}' set to '{1}'. Available in 0.9.10+.".format_with(ApplicationParameters.Features.UsePackageExitCodes, configuration.Features.UsePackageExitCodes.to_string()),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ public virtual void configure_argument_parser(OptionSet optionSet, ChocolateyCon
"IgnoreDependencies - Ignore dependencies when upgrading package(s). Defaults to false.",
option => configuration.IgnoreDependencies = option != null)
.Add("n|skippowershell|skip-powershell|skipscripts|skip-scripts|skip-automation-scripts",
"Skip Powershell - Do not run chocolateyInstall.ps1. Defaults to false.",
"Skip PowerShell - Do not run chocolateyInstall.ps1. Defaults to false.",
option => configuration.SkipPackageInstallProvider = option != null)
.Add("failonunfound|fail-on-unfound",
"Fail On Unfound Packages - If a package is not found in sources specified, fail instead of warn.",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -396,7 +396,7 @@ public virtual void handle_package_result(PackageResult packageResult, Chocolate
}
else
{
if (config.Information.PlatformType != PlatformType.Windows) this.Log().Info(ChocolateyLoggers.Important, () => " Skipping Powershell and shimgen portions of the install due to non-Windows.");
if (config.Information.PlatformType != PlatformType.Windows) this.Log().Info(ChocolateyLoggers.Important, () => " Skipping PowerShell and shimgen portions of the install due to non-Windows.");
}

if (packageResult.Success)
Expand Down Expand Up @@ -814,10 +814,14 @@ public virtual ConcurrentDictionary<string, PackageResult> upgrade_run(Chocolate

private void before_package_modify(PackageResult packageResult, ChocolateyConfiguration config)
{
if (!config.SkipPackageInstallProvider)
if (!config.SkipPackageInstallProvider && config.Information.PlatformType == PlatformType.Windows)
{
_powershellService.before_modify(config, packageResult);
}
else
{
if (config.Information.PlatformType != PlatformType.Windows) this.Log().Info(ChocolateyLoggers.Important, () => " Skipping beforemodify PowerShell script due to non-Windows.");
}
}

public void uninstall_noop(ChocolateyConfiguration config)
Expand Down Expand Up @@ -982,21 +986,29 @@ public virtual void handle_package_uninstall(PackageResult packageResult, Chocol
packageResult.InstallLocation += ".{0}".format_with(packageResult.Package.Version.to_string());
}

_shimgenService.uninstall(config, packageResult);

if (!config.SkipPackageInstallProvider)
//These items only apply to windows systems.
if (config.Information.PlatformType == PlatformType.Windows)
{
_powershellService.uninstall(config, packageResult);
}
_shimgenService.uninstall(config, packageResult);

if (packageResult.Success)
if (!config.SkipPackageInstallProvider)
{
_powershellService.uninstall(config, packageResult);
}

if (packageResult.Success)
{
_autoUninstallerService.run(packageResult, config);
}

// we don't care about the exit code
CommandExecutor.execute_static(_shutdownExe, "/a", config.CommandExecutionTimeoutSeconds, _fileSystem.get_current_directory(), (s, e) => { }, (s, e) => { }, false, false);
}
else
{
_autoUninstallerService.run(packageResult, config);
this.Log().Info(ChocolateyLoggers.Important, () => " Skipping PowerShell, shimgen, and autoUninstaller portions of the uninstall due to non-Windows.");
}

// we don't care about the exit code
if (config.Information.PlatformType == PlatformType.Windows) CommandExecutor.execute_static(_shutdownExe, "/a", config.CommandExecutionTimeoutSeconds, _fileSystem.get_current_directory(), (s, e) => { }, (s, e) => { }, false, false);

if (packageResult.Success)
{
//todo: v2 clean up package information store for things no longer installed (call it compact?)
Expand Down

0 comments on commit 44d7969

Please sign in to comment.