Skip to content

Commit

Permalink
Check for case insensitive License.txt when RequireLicense is specifi…
Browse files Browse the repository at this point in the history
…ed (#1757)
  • Loading branch information
alerickson authored Dec 3, 2024
1 parent d3090c2 commit 5adcf9b
Showing 1 changed file with 31 additions and 9 deletions.
40 changes: 31 additions & 9 deletions src/code/InstallHelper.cs
Original file line number Diff line number Diff line change
Expand Up @@ -1338,7 +1338,6 @@ private bool CallAcceptLicense(PSResourceInfo p, string moduleManifest, string t
_cmdletPassedIn.WriteDebug("In InstallHelper::CallAcceptLicense()");
error = null;
var requireLicenseAcceptance = false;
var success = true;

if (File.Exists(moduleManifest))
{
Expand Down Expand Up @@ -1366,22 +1365,44 @@ private bool CallAcceptLicense(PSResourceInfo p, string moduleManifest, string t
if (!_acceptLicense)
{
var PkgTempInstallPath = Path.Combine(tempInstallPath, p.Name, newVersion);
var LicenseFilePath = Path.Combine(PkgTempInstallPath, "License.txt");
if (!Directory.Exists(PkgTempInstallPath))
{
error = new ErrorRecord(
new ArgumentException($"Package '{p.Name}' could not be installed: Temporary installation path does not exist."),
"TempPathNotFound",
ErrorCategory.ObjectNotFound,
_cmdletPassedIn);

return false;
}

string[] files = Directory.GetFiles(PkgTempInstallPath);

bool foundLicense = false;
string LicenseFilePath = string.Empty;
foreach (string file in files)
{
if (string.Equals(Path.GetFileName(file), "License.txt", StringComparison.OrdinalIgnoreCase))
{
foundLicense = true;
LicenseFilePath = Path.GetFullPath(file);
break;
}
}

if (!File.Exists(LicenseFilePath))
if (!foundLicense)
{
error = new ErrorRecord(
new ArgumentException($"Package '{p.Name}' could not be installed: License.txt not found. License.txt must be provided when user license acceptance is required."),
"LicenseTxtNotFound",
ErrorCategory.ObjectNotFound,
_cmdletPassedIn);;
success = false;
_cmdletPassedIn);

return success;
return false;
}

// Otherwise read LicenseFile
string licenseText = System.IO.File.ReadAllText(LicenseFilePath);
string licenseText = File.ReadAllText(LicenseFilePath);
var acceptanceLicenseQuery = $"Do you accept the license terms for module '{p.Name}'?";
var message = licenseText + "\r\n" + acceptanceLicenseQuery;

Expand All @@ -1404,12 +1425,13 @@ private bool CallAcceptLicense(PSResourceInfo p, string moduleManifest, string t
"ForceAcceptLicense",
ErrorCategory.InvalidArgument,
_cmdletPassedIn);
success = false;

return false;
}
}
}

return success;
return true;
}

/// <summary>
Expand Down

0 comments on commit 5adcf9b

Please sign in to comment.