about_PSReadLine
Short Description
PSReadLine fornece uma experiência de edição de linha de comando aprimorada no console do PowerShell.
Houve muitas atualizações para PSReadLine desde a versão que acompanha o Windows PowerShell 5.1.
- v2.3.5 enviado pela primeira vez no PowerShell 7.4.2 e 7.5.0-preview.3
- v2.3.4 enviado pela primeira vez no PowerShell 7.4.0-rc.1
- v2.2.6 enviado pela primeira vez no PowerShell 7.3.0
- v2.1.0 enviado pela primeira vez no PowerShell 7.2.5
- v2.0.4 enviado pela primeira vez no PowerShell 7.0.11
- v2.0.0 é fornecido no Windows PowerShell 5.1
Para obter mais informações sobre diferenças de versão, consulte about_PSReadLine_Release_Notes.
Descrição longa
A versão atual do PSReadLine pode ser instalada e usada no Windows PowerShell 5.1 e mais recente. Para alguns recursos, você precisa estar executando o PowerShell 7.2 ou superior.
PSReadLine fornece uma poderosa experiência de edição de linha de comando para o console do PowerShell. Fornece:
- Coloração da sintaxe da linha de comando
- Uma indicação visual de erros de sintaxe
- Uma melhor experiência multi-linha (edição e histórico)
- Ligações de teclas personalizáveis
- Modos Cmd e Emacs
- Muitas opções de configuração
- Conclusão do estilo Bash (opcional no modo Cmd, padrão no modo Emacs)
- Emacs yank/kill-ring
- Movimento e exclusão de "palavra" baseados em token do PowerShell
PSReadLine requer PowerShell 5.1 ou mais recente. PSReadLine funciona com o host de console padrão do Windows, Terminal do Windows e Visual Studio Code. Ele não funciona no ISE do Windows PowerShell.
PSReadLine pode ser instalado a partir da Galeria do PowerShell. Para instalar o PSReadLine em uma versão suportada do PowerShell, execute o seguinte comando.
Install-Module -Name PSReadLine -AllowClobber -Force
Ligações de chave personalizadas
PSReadLine oferece suporte a associações de chave personalizadas usando o Set-PSReadLineKeyHandler
cmdlet. A maioria das ligações de teclas personalizadas chama uma das funções vinculáveis, por exemplo
Set-PSReadLineKeyHandler -Key UpArrow -Function HistorySearchBackward
Você pode vincular um ScriptBlock a uma chave. O ScriptBlock pode fazer praticamente tudo o que você quiser. Alguns exemplos úteis incluem:
- Editar a linha de comando
- Abrir uma nova janela (por exemplo, Ajuda)
- alterar diretórios sem alterar a linha de comando
O ScriptBlock recebe dois argumentos:
$key
- Um objeto [ConsoleKeyInfo] que é a chave que disparou a ligação personalizada. Se você vincular o mesmo ScriptBlock a várias chaves e precisar executar ações diferentes dependendo da chave, poderá verificar$key
. Muitas ligações personalizadas ignoram esse argumento.$arg
- Um argumento arbitrário. Na maioria das vezes, esse seria um argumento inteiro que o usuário passa das ligações de chave DigitArgument. Se a sua vinculação não aceitar argumentos, é razoável ignorá-los.
Vamos dar uma olhada em um exemplo que adiciona uma linha de comando ao histórico sem executá-lo. Isso é útil quando você percebe que esqueceu de fazer algo, mas não quer entrar novamente na linha de comando que já entrou.
$parameters = @{
Key = 'Alt+w'
BriefDescription = 'SaveInHistory'
LongDescription = 'Save current line in history but do not execute'
ScriptBlock = {
param($key, $arg) # The arguments are ignored in this example
# GetBufferState gives us the command line (with the cursor position)
$line = $null
$cursor = $null
[Microsoft.PowerShell.PSConsoleReadLine]::GetBufferState([ref]$line,
[ref]$cursor)
# AddToHistory saves the line in history, but does not execute it.
[Microsoft.PowerShell.PSConsoleReadLine]::AddToHistory($line)
# RevertLine is like pressing Escape.
[Microsoft.PowerShell.PSConsoleReadLine]::RevertLine()
}
}
Set-PSReadLineKeyHandler @parameters
Você pode ver muitos outros exemplos no arquivo SamplePSReadLineProfile.ps1
, que está instalado na pasta do módulo PSReadLine .
A maioria das ligações de teclas usa algumas funções auxiliares para editar a linha de comando. Essas APIs estão documentadas em about_PSReadLine_Functions.
Notas
Histórico de comandos
PSReadLine mantém um arquivo de histórico contendo todos os comandos e dados que você inseriu a partir da linha de comando. Os arquivos de histórico são um arquivo chamado $($host.Name)_history.txt
. Em sistemas Windows, o arquivo de histórico é armazenado em $env:APPDATA\Microsoft\Windows\PowerShell\PSReadLine
.
O histórico pode conter dados confidenciais, incluindo senhas. PSReadLine tenta filtrar informações confidenciais. As linhas de comando que contêm as seguintes cadeias de caracteres não são gravadas no arquivo de histórico.
password
asplaintext
token
apikey
secret
PSReadLine 2.2.0 melhora a filtragem de dados confidenciais
- Usa a Árvore de Sintaxe Abstrata (AST) do PowerShell da linha de comando analisada para procurar dados confidenciais.
- Usa uma lista de permissões de cmdlets seguros do módulo SecretManagement para permitir que esses comandos sejam adicionados ao histórico. A lista de permissões contém:
Get-Secret
Get-SecretInfo
Get-SecretVault
Register-SecretVault
Remove-Secret
Set-SecretInfo
Set-SecretVaultDefault
Test-SecretVault
Unlock-SecretVault
Unregister-SecretVault
Por exemplo, os seguintes comandos podem ser gravados no arquivo de histórico:
Get-Secret PSGalleryApiKey -AsPlainText # Get-Secret is in the allowlist
$token = Get-Secret -Name github-token -Vault MySecret
[MyType]::CallRestAPI($token, $url, $args)
$template -f $token
Os seguintes comandos não estão sendo gravados no arquivo de histórico:
$token = 'abcd' # Assign expr-value to sensitive variable name.
Set-Secret abc $mySecret # Set-Secret is not in the allowlist.
ConvertTo-SecureString stringValue -AsPlainText # '-AsPlainText' is an alert.
Invoke-WebRequest -Token xxx # Expr-value as argument to '-Token'.
Get-ResultFromTwo -Secret1 (Get-Secret -Name blah -AsPlainText) -Secret2 sdv87ysdfayf798hfasd8f7ha # '-Secret2' has expr-value argument.
Se houver outros comandos que você não deseja gravar nos arquivos de histórico, você pode usar o parâmetro AddToHistoryHandler do Set-PSReadLineOption
cmdlet. Para obter um exemplo de como usar AddToHistoryHandler, consulte Exemplo 7 de Set-PSReadLineOption.
PSReadLine 2.3.4 melhora a filtragem de dados confidenciais
Aperfeiçoada a depuração de histórico confidencial padrão para permitir que o histórico contenha acesso seguro à propriedade.
Quando a cadeia de caracteres sensível faz parte de um acesso à propriedade:
- Se esta operação de acesso de membro não fizer parte de uma atribuição, consideramo-la segura
- Caso contrário, se o lado direito for um gasoduto ou uma variável, também o consideramos seguro
Por exemplo, os seguintes casos de uso são considerados seguros e podem ser salvos no histórico.
$a.Secret = Get-Secret -Name github-token -Vault MySecret
$a.Secret = $secret
$a.Password.Secret | Set-Value
$token = (Get-AzAccessToken -ResourceUrl 'https://app.contoso.com').Token
A versão também melhorou a depuração de histórico sensível para permitir a recuperação de token usando as az
ferramentas , gcloud
e linha kubectl
de comando.
Por exemplo, os seguintes casos de uso são considerados seguros e podem ser salvos no histórico.
kubectl get secrets
kubectl get secret db-user-pass -o jsonpath='{.data.password}' | base64 --decode
kubectl describe secret db-user-pass
az account get-access-token --resource=https://app.contoso.com --query accessToken --output tsv
$env:PGPASS = gcloud auth print-access-token
Feedback & contribuindo para PSReadLine
Sinta-se à vontade para enviar uma solicitação pull ou enviar feedback na página do GitHub.
Consulte Também
- PSReadLine é fortemente influenciado pela biblioteca de linha de leitura GNU.