-
Notifications
You must be signed in to change notification settings - Fork 1.5k
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
First drafted client cmdlets from Hackathon 221 #1760
Conversation
@@ -0,0 +1,41 @@ | |||
Function Enable-WinGetLocalManifest |
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.
From @JohnMcPMS on earlier PR:
These should probably be something like
Set-WinGetAdminSetting -Setting LocalManifest -Value true
rather than creating a new cmdlet for every setting.
From @denelon
The PowerShell cmdlet structure tends to use Enable and Disable. It makes them more discoverable. Maybe someone from the community can weigh in on this one. @doctordns what do you think?
From @JohnMcPMS
I just expect the possibility of non-boolean values in the future, but it could also be
Enable
/Disable
for booleans andSet
in the future for non-booleans. But the larger takeaway is to make the actual setting that is being modified be a parameter rather than making new cmdlets per setting.
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.
I like Enable and Disable, but I agree that it could probably be simplified to Enable-AdminSetting -Setting LocalManifest
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.
As noted somewhere else - the enable verb is used to move a resource to be available or active. Disable does the opposite. I would prefer Set, especially since the target could possibly take non boolean values.
IMHO Enable-Adminsetting -Setting
is not great PowerShell. The noun should be the specific thing we are enableling (eg Enable-LocalUser, Enable-PSRemoting). Enabler-LocalManifest would be better than this.
What other commands are there that have the noun "LocalManifest" ?
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.
I guess I would agree about the noun being specific; However, I still believe that enable and disable are appropriate based on the Microsoft Documentation. From https://docs.microsoft.com/en-us/powershell/scripting/developer/cmdlet/approved-verbs-for-windows-powershell-commands?view=powershell-7.1 -
Disable (d) | Configures a resource to an unavailable or inactive state. For example, the Disable-PSBreakpoint cmdlet makes a breakpoint inactive. This verb is paired with Enable.
Enable (e) | Configures a resource to an available or active state. For example, the Enable-PSBreakpoint cmdlet makes a breakpoint active. This verb is paired with Disable.
In this case, it is making the setting active or inactive. A setting can be considered a resource just as much as a breakpoint can be considered a resource
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.
Didn't get through all the files, but here's what I noticed so far
tools/PowerShell/Microsoft.WinGet.Client/src/Library/Add-WinGetSource.ps1
Show resolved
Hide resolved
} | ||
} | ||
|
||
Export-ModuleMember -Function Add-WinGetSource |
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.
Is there a reason these are being exported from here rather than being included in the FunctionsToExport
section of the module manifest? It may be better to have one or the other, rather than both
@@ -0,0 +1,41 @@ | |||
Function Enable-WinGetLocalManifest |
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.
I like Enable and Disable, but I agree that it could probably be simplified to Enable-AdminSetting -Setting LocalManifest
This example searches for a package containing "Package" as a valid name on all configured sources. | ||
#> | ||
PARAM( | ||
[Parameter(Position=0)] $Filter, |
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.
Do these need to be explicitly stated as strings? What happens if I try to pipe an object or an array to the function?
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 is very early. Pipelining won't work well with anything depending on list or a display where we truncate strings in the Terminal until we get JSON output via the COM API.
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.
Fair point; I guess I’m thinking like a tester in that someone could do something that would end up being like -
Install-WingetPackage -Id @{“Id”=“Google.Chrome”}
I know its not something that would be common, but if people try writing custom scripts, what happens if an error like that occurrs? I’m assuming it will be fine as is, but just want to be sure that we are aware of any potential adverse effects
$Result = [version](& "winget" $WinGetArgs).trimstart("v") | ||
} | ||
catch { | ||
} |
This comment was marked as resolved.
This comment was marked as resolved.
Sorry, something went wrong.
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.
Good catch, so to speak.
Shoudl the catch throw an exception or just issue a warning?
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.
I don't think it needs to throw since it is set to "0.0.0.0" beforehand and shouldn't cause any issues. Maybe it doesn't need a warning either, perhaps a Write-Verbose is fine. Just as long as it is being considered and if the block is empty that it's intentional
tools/PowerShell/Microsoft.WinGet.Client/src/Library/Install-WinGetPackage.ps1
Outdated
Show resolved
Hide resolved
tools/PowerShell/Microsoft.WinGet.Client/src/Library/Install-WinGetPackage.ps1
Outdated
Show resolved
Hide resolved
…inGetPackage.ps1 Co-authored-by: Kaleb Luedtke <[email protected]>
…inGetPackage.ps1 Co-authored-by: Kaleb Luedtke <[email protected]>
PARAM { | ||
[Parameter()] [switch] $VerboseLog | ||
} |
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.
PARAM { | |
[Parameter()] [switch] $VerboseLog | |
} | |
PARAM ( ) |
Braces mistakenly used instead of Parens; Verbose doesn't appear to be valid for settings?
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.
Should this be just -Verbose
?
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.
I think that -Verbose
is an inherent property if it has a cmdlet binding, and since the settings command for winget doesn't support a verbose option, I don't think it needs to be included here at all
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.
-Verbose
is a standard parameter, so if the intent of this is just to create verbose user output, then it need not be a separate parameter here.
At least with normal functions, you enable this by making the function an advanced function. Just add [CMDLETBINDING]
just above the parm block.
I initially thought this switch might be a special diag log for winget? Useful to clarify that.
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.
I think it is intended to be a diagnostic log for winget, but I don't think the setting command supports the diagnostic logging in winget. It's also probably not important to have a cmdlet binding here, since there is nothing using Write-verbose
. Since these functions are just a wrapper for winget commands anyways, I would argue that keeping it simple at the start is better. If the verbose functionality is wanted or needed, then it can be added later
BEGIN | ||
{ | ||
[string[]] $WinGetArgs = "Settings" | ||
$WinGetArgs += "--Verbose-Logs", $VerboseLog |
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.
$WinGetArgs += "--Verbose-Logs", $VerboseLog |
I get an error if verbose logs is specified here; Verbose isn't listed in the help for the winget settings command
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.
It is a valid parameter for the client. It's just not listed in help yet.
tools/PowerShell/Microsoft.WinGet.Client/src/Library/Enable-WinGetLocalManifest.ps1
Show resolved
Hide resolved
tools/PowerShell/Microsoft.WinGet.Client/src/Library/Enable-WinGetLocalManifest.ps1
Outdated
Show resolved
Hide resolved
tools/PowerShell/Microsoft.WinGet.Client/src/Library/Disable-WinGetLocalManifest.ps1
Show resolved
Hide resolved
|
||
foreach($item in $Index) { | ||
if($Item.Ends) { | ||
#try { |
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.
#try { |
tools/PowerShell/Microsoft.WinGet.Client/src/Library/Uninstall-WinGetPackage.ps1
Outdated
Show resolved
Hide resolved
tools/PowerShell/Microsoft.WinGet.Client/src/Library/Uninstall-WinGetPackage.ps1
Show resolved
Hide resolved
|
||
We started this project as an exploration to design the right set of cmdlets with PowerShell approved nouns and verbs. As we began to explore wrapping the Windows Package Manager we identified several areas of complexity. Rather than slow down progress on building PowerShell cmdlets, we decided to forge ahead and call out the areas where the experience with pipelines is sub-optimal. | ||
|
||
For example, the Windows Package Manager (later referenced as just CLI) CLI was designed for displaying output in the standard width Windows Terminal. As such, long package names and "Id"s are truncated with a single width ellipsis character. Users wanting to use the PowerShell pipeline to pass values to another cmdlet will likely encounter undesired behavior due to this truncation. We have decided to declare the "Microsoft.WinGet" module as an alpha release until these problems have been resolved. We are planning to change the status of "PreRelease" to beta once we believe we have addressed the issues related to piping the output to other cmdlets. |
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.
For example, the Windows Package Manager (later referenced as just CLI) CLI was designed for displaying output in the standard width Windows Terminal. As such, long package names and "Id"s are truncated with a single width ellipsis character. Users wanting to use the PowerShell pipeline to pass values to another cmdlet will likely encounter undesired behavior due to this truncation. We have decided to declare the "Microsoft.WinGet" module as an alpha release until these problems have been resolved. We are planning to change the status of "PreRelease" to beta once we believe we have addressed the issues related to piping the output to other cmdlets. | |
For example, the Windows Package Manager (later referenced as winget or CLI) CLI was designed for displaying output in the standard width Windows Terminal. As such, long package names and "Id"s are truncated with a single width ellipsis character. Users wanting to use the PowerShell pipeline to pass values to another cmdlet will likely encounter undesired behavior due to this truncation. We have decided to declare the "Microsoft.WinGet" module as an alpha release until these problems have been resolved. We are planning to change the status of "PreRelease" to beta once we believe we have addressed the issues related to piping the output to other cmdlets. |
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 is, at one level, very poor. You have a property with a value that you then truncate. I really hate any application that can not round-trip data - I set a string but you return it to me different to what was set.
One solution might be to have an -JSON switch that just emits the information in JSON. Or have a -RAW switch that does no formatting?
And if it were me, I;'d fix this before calling it alpha.
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.
I completely agree with the feedback here.
We're going to add the capability to output data as JSON in the COM API. Then we will switch these cmdlets to use that mechanism. These cmdlets are very "Hackathon". My thought is that a (mostly) "working" sample at least gets the nouns and verbs out in a manner that we can share to get feedback.
I don't know what to call something that's earlier than "alpha". There seemed to be some limitations on what we could use for pre-release values.
Is there an easy way to download these cmdlets to test them?? |
Clone the repository, checkout the branch associated with this PR, copy the path to the ,psm1 file, then |
Not yet. We need to get some tests in place and look at a build to generate them for release. This was very much a Hackathon project. I consider myself a noob at PowerShell. I just knew that we had to get this going sooner rather than later. As soon as we meet the requirements for signing, we will get them signed and then publish to the PowerShell gallery. It involves other teams performing reviews and checks, so that's not likely before next year. My apologies for this taking so long. |
Co-authored-by: Kaleb Luedtke <[email protected]>
At least, can you zip up the module and leave it here on GitHub? Let's get the basics right before pushing to the PS Gallery. These cmdlets are an excellent start, but need a lot of basic work before, IMHO, they are ready to push to a wider audience. And it may just be me, but I am having a huge problem trying to work out what is where! :-) I almost need a Readme(FIRST).MD to tell me where to look for what. |
Treat empty strings in constructors as null
Closes #674
This is the first set of PowerShell cmdlets drafted during the 2021 Hackathon at Microsoft to explore PowerShell syntax for the Windows Package Manager. This is a very early draft and is subject to substantial change. Notes and historical context are in the README.md.
Microsoft Reviewers: Open in CodeFlow