Skip to content

Commit a04c507

Browse files
authored
Terminal Chat Docs Update (#809)
1 parent 9e04e16 commit a04c507

4 files changed

+69
-38
lines changed

TerminalDocs/TOC.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -46,7 +46,7 @@
4646
href: tutorials/shell-integration.md
4747
- name: Cascadia Code
4848
href: cascadia-code.md
49-
- name: Terminal Chat
49+
- name: Terminal Chat (Experimental)
5050
href: terminal-chat.md
5151
- name: Group Policy
5252
href: group-policy.md
Loading

TerminalDocs/terminal-chat.md

+68-37
Original file line numberDiff line numberDiff line change
@@ -1,61 +1,92 @@
11
---
22
title: Terminal Chat
33
description: Learn how to setup and use Terminal Chat in Windows Terminal Canary.
4-
author: chrnguyen
5-
ms.author: chrnguyen
6-
ms.date: 11/15/2023
7-
ms.topic: how-to
4+
ms.date: 10/29/2024
5+
ms.topic: overview
86
---
97

10-
# Terminal Chat
11-
Terminal Chat is a feature in [Windows Terminal Canary](https://github.com/microsoft/terminal#installing-windows-terminal-canary) that allows the user to chat with an AI service to get intelligent suggestions (such as looking up a command or explaining an error message) while staying in the context of their terminal.
8+
# Terminal Chat (Experimental)
129

13-
This feature does not ship with its own large-language model. For now, this feature is only available in Windows Terminal Canary and only supports [Azure OpenAI Service](https://azure.microsoft.com/products/ai-services/openai-service).
10+
Terminal Chat is a new experimental feature that enables you to integrate [Windows Terminal Canary](https://github.com/microsoft/terminal#installing-windows-terminal-canary) with your preferred AI service.
1411

15-
Windows Terminal Canary only communicates with an AI service when the user sends a message in Terminal Chat. The chat history and name of the user’s active shell is also appended to the message that is sent to the AI service. The chat history is not saved by Windows Terminal Canary after their terminal session is over.
12+
Once Terminal Chat is connected to your AI service provider (GitHub Copilot, Azure OpenAI, or OpenAI), you can ask questions specific to the shell you are using (PowerShell, CMD, WSL Ubuntu, Azure Cloud Shell, etc) while staying in the context of your terminal.
1613

17-
> [!NOTE]
18-
> This feature is only available in [Windows Terminal Canary](https://github.com/microsoft/terminal#installing-windows-terminal-canary).
14+
Terminal Chat can:
15+
16+
- Provide command syntax and descriptions
17+
- Explain command line error messages
18+
- Send code suggestions to command-line text editors
19+
20+
Terminal Chat does not ship with its own large-language model. For now, this experimental feature is only available in [Windows Terminal Canary](https://github.com/microsoft/terminal#installing-windows-terminal-canary) and only supports [GitHub Copilot](https://go.microsoft.com/fwlink/?linkid=2294410), [Azure OpenAI Service](https://azure.microsoft.com/products/ai-services/openai-service), and [OpenAI](https://openai.com/).
21+
22+
Terminal Chat only communicates with your selected AI service when you enter a message in the chat. The chat history and name of the user’s active shell is also appended to the message that is sent to the AI service. The chat history is not saved by Windows Terminal after the terminal session is over.
23+
24+
![Screenshot of the Terminal Chat user interface](./images/terminal-chat.png)
25+
26+
## Prerequisites
27+
28+
- This experimental feature is only available in [Windows Terminal Canary](https://github.com/microsoft/terminal#installing-windows-terminal-canary).
29+
30+
- An AI service provider subscription is required. GitHub Copilot, Azure OpenAI, and OpenAI are currently supported.
31+
32+
## Set up a Service Provider in Terminal Chat
33+
To use Terminal Chat, you will need to connect GitHub Copilot or add an Azure OpenAI or OpenAI endpoint to your Terminal Chat settings.
34+
35+
1. Open Windows Terminal and select **Settings** from the drop-down menu on the far-right of the top menu bar.
1936

20-
![Terminal Chat UI](./images/terminal-chat.png)
37+
2. Select the **Terminal Chat (Experimental)** tab to display the service provider configuration settings.
2138

22-
## Setting up Terminal Chat
23-
To use Terminal Chat, you will need to add a service endpoint and key to the Terminal Chat settings of Windows Terminal Canary.
24-
25-
For now, Terminal Chat only supports Azure OpenAI Service. To get an Azure OpenAI Service endpoint and key, you will need to create and deploy an Azure OpenAI Service resource.
39+
3. Select a **Service Provider**. A subscription to one of the following AI service providers is required to use Terminal Chat. You will need to set up and authenticate the AI service in the service provider settings. See below for the steps to activate your preferred AI service provider.
2640

27-
![Terminal Chat Settings](./images/terminal-chat-settings.png)
41+
### AI Service Providers
2842

29-
### Creating and Deploying an Azure OpenAI Service resource
43+
**[GitHub Copilot](https://go.microsoft.com/fwlink/?linkid=2293915)**: Under Service Providers, select **GitHub Copilot** and **Authenticate via GitHub** to sign in to GitHub. Check **Set as active provider** to set GitHub Copilot as your active Service Provider.
3044

31-
To create and deploy an Azure OpenAI Service resource, please follow the official Azure OpenAI documentation on [creating and deploying an Azure OpenAI Service resource](/azure/ai-services/openai/how-to/create-resource).
45+
To connect GitHub Copilot with Terminal Chat, you must have an active subscription for GitHub Copilot in your personal account, or you need to be assigned a seat by your organization. You can sign up for a [GitHub Copilot free trial](https://go.microsoft.com/fwlink/?linkid=2293915) in your personal account to evaluate GitHub Copilot.
3246

33-
In that documentation, you will learn how to:
47+
![Animated GIF of connecting GitHub Copilot to Terminal Chat and asking a question in Terminal Chat](./images/terminal-chat-github-copilot.gif)
3448

35-
1. [Create a resource](/azure/ai-services/openai/how-to/create-resource#create-a-resource)
49+
> [!NOTE]
50+
> If you have access to GitHub Copilot via your organization, you won't be able to use GitHub Copilot if your organization owner has disabled GitHub Copilot in the CLI. See "[Managing policies for Copilot in your organization](https://docs.github.com/copilot/managing-copilot/managing-github-copilot-in-your-organization/setting-policies-for-copilot-in-your-organization/managing-policies-for-copilot-in-your-organization)."
51+
52+
For more information on how to use GitHub Copilot responsibly with Windows Terminal, see ["Responsible use of GitHub Copilot in Windows Terminal"](https://docs.github.com/en/copilot/responsible-use-of-github-copilot-features/responsible-use-of-github-copilot-in-windows-terminal).
53+
54+
**[Azure OpenAI](/azure/ai-services/openai/overview)**: Under Service Providers, select **Azure OpenAI**, enter an endpoint URL and key, select **Store** and **Save**.
55+
56+
![Screenshot of the Terminal Chat Settings for Azure OpenAI](./images/terminal-chat-settings-for-azure-openai.png)
57+
58+
To get an Azure OpenAI Service endpoint and key, you will need to create and deploy an Azure OpenAI Service resource.
3659

37-
2. [Deploy a model](/azure/ai-services/openai/how-to/create-resource#deploy-a-model)
60+
- [Create and deploy an Azure OpenAI Service resource](/azure/ai-services/openai/how-to/create-resource)
3861

39-
You will need to use a `gpt-35-turbo` model with your deployment.
62+
You will need to use a `gpt-35-turbo` model and ensure that the [jailbreak content filter](/azure/ai-services/openai/how-to/content-filters) is enabled for your deployment.
4063

41-
After creating a resource and deploying a model, you can find your Azure OpenAI Service endpoint and key by navigating to the **Chat** playground in Azure OpenAI Studio and selecting **View code** in the Chat session section.
64+
After creating a resource and deploying a model, you can find your Endpoint and API key by navigating to the **Chat** playground in Azure OpenAI Studio and selecting **View code** in the Chat session section. The pop-up dialog will provide an endpoint URL and key that you can use in the Terminal Chat Service Provider settings.
4265

43-
![Azure OpenAI Playground](./images/aoai-playground.png)
66+
**[OpenAI](https://openai.com/)**: Under Service Providers, select **OpenAI**, enter an endpoint URL and key, select **Store** and **Save**.
4467

45-
The **View code** pop-up dialog will show you a valid Azure OpenAI Service endpoint and key that you can use for Terminal Chat.
68+
To get an OpenAI endpoint and key, you will need to refer to the OpenAI documentation.
4669

47-
### Saving and Storing your Terminal Chat settings
48-
After entering your AI service endpoint and key in Terminal Chat settings, select **Store** and **Save** to store and save those values.
70+
- [Developer quickstart: Create and export an API key](https://platform.openai.com/docs/quickstart/step-2-setup-your-api-key?desktop-os=windows)
4971

50-
This will allow you to use Terminal Chat with the AI service affiliated with your service endpoint.
72+
OpenAI is provided by a third-party and not Microsoft. When you send a message in Terminal Chat, your Terminal Chat history per session and the name of your active shell profile is sent to the third-party AI service for use by OpenAI. Your use of OpenAI is governed by the relevant third-party terms, conditions, and privacy statement.
5173

52-
## Using Terminal Chat
74+
## Examples for using Terminal Chat
5375

76+
The following examples demonstrate a few ways that you might consider using Terminal Chat.
77+
78+
![Animated GIF of asking a question in Terminal Chat](./images/terminal-chat.gif)
79+
80+
- **Command suggestions**: Ask for a command that you would like to use. Terminal Chat also adds the name of the active shell to the prompt after it is sent, so if you are using PowerShell and ask "How do I make a new directory?", the response may be `md`, but if you are using an Ubuntu (Linux) command line with WSL, the response may be `mkdir`.
5481
Clicking on the suggestion will copy it to the input line of the terminal. This will not run the suggestion for the user automatically.
5582

56-
![Terminal Chat in action](./images/terminal-chat.gif)
83+
- **Translate commands**: Terminal Chat can also be used to "translate" commands. For example, you can ask "What's `touch` in PowerShell?" or "How do I `touch` in PowerShell?" to get the suggestion of `New-Item`, a PowerShell command that is equivalent to the Linux / Unix-based `touch` command for creating a new file.
84+
85+
- **Explain an error**: If you've received an unfamiliar error response in your command line, copy and paste it into the Terminal Chat and ask for an explanation of the error code and how to fix it. For example, "How do I fix `Error: getaddrinfo ENOTFOUND`?"
5786

58-
## Tips & Tricks
87+
- **Send code suggestions to command-line text editors**: If you're using a command-line text editor in WSL (like `nano` or `vi`), you can ask Terminal Chat to generate code and send the code suggestion to the editor by clicking the "Copy" button.
88+
89+
- **Find and describe PowerShell cmdlets**: A [cmdlet](/powershell/module/microsoft.powershell.management/) (pronounced command-let) is a lightweight script command used to perform a specific function in PowerShell. Terminal Chat can help you to find cmdlets that may be useful and can explain what task they accomplish. For example, "Find a cmdlet to show a list of active processes" would result in `Get-Process`. Or "Explain the `Get-ChildItem` cmdlet" would describe that the cmdlet is used to retrieve a list of items within a specified location.
5990

6091
### Terminal-specific context
6192

@@ -69,12 +100,12 @@ This means that Terminal Chat can identify whether a user's active shell is Comm
69100

70101
### Assigning a keybinding to Terminal Chat
71102

72-
Terminal Chat can be set as a keybinding Action.
73-
74-
This can be done in **Actions** in the **Settings** UI. Add a new keybinding Action by selecting **+ Add new** and then picking **Toggle Terminal Chat** from the dropdown to add a new keybinding Action for the Terminal Chat feature.
103+
Terminal Chat can be set as a keybinding in the **Actions** tab of Windows Terminal **Settings**. Add a new keybinding by selecting **+ Add new** and then selecting **Toggle Terminal Chat** from the dropdown to add a new keybinding Action for the Terminal Chat feature.
75104

76-
![Setting Terminal Chat as a keybinding Action](./images/terminal-chat-action.png)
105+
The new keybinding will also be reflected in the dropdown menu after these changes are saved.
77106

78-
The new keybinding will also be reflected in the dropdown menu after these changes are saved.
107+
### Group Policy
79108

80-
![Terminal Chat's keybinding action in the dropdown menu](./images/terminal-chat-after-action.png)
109+
Language Models and AI Services used by Terminal Chat can be disabled through the **Enabled Language Models/AI Providers** policy.
110+
The Terminal Chat feature can also be disabled with the same policy.
111+
To learn more, see the [Group Policies page](./group-policy.md).

0 commit comments

Comments
 (0)