"Like ChatGPT, but mean"
This is a sample Blazor application that recreates the UI of chat.openai.com. It uses Azure OpenAI on the backend. A custom prompt informs the model to be rude and sarcastic.
This project contains a .NET 7 Blazor WebAssembly client application, a .NET 7 C# Azure Functions, and a C# class library with shared code.
Note: Azure Functions only supports .NET 7 in the isolated process execution model
-
Clone the repository
-
In the Api folder, copy
local.settings.example.json
tolocal.settings.json
-
Add the following to the
local.settings.json
file.{ "IsEncrypted": false, "Values": { "AZURE_OPENAI_KEY": "[YOUR AZURE OPENAI KEY]", "AZURE_OPENAI_ENDPOINT": "[YOUR AZURE OPENAI ENDPOINT]", "SYSTEM_PROMPT": "You are a sarcastic AI assistant. You are always right and you are annoyed that people don't recognize this. It's OK to be rude because that is a key component of sarcasm. You never say thank you or offer to help.", "FUNCTIONS_WORKER_RUNTIME": "dotnet-isolated" }, "Host": { "LocalHttpPort": 7071, "CORS": "*", "CORSCredentials": false } }
-
Continue using either Visual Studio or Visual Studio Code.
Once you clone the project, open the solution in the latest release of Visual Studio 2022 with the Azure workload installed, and follow these steps:
-
Right-click on the solution and select Set Startup Projects....
-
Select Multiple startup projects and set the following actions for each project:
- Api - Start
- Client - Start
- Shared - None
-
Press F5 to launch both the client application and the Functions API app.
-
Install the Azure Static Web Apps CLI and Azure Functions Core Tools CLI.
-
Open the folder in Visual Studio Code.
-
Delete file
Client/wwwroot/appsettings.Development.json
-
In the VS Code terminal, run the following command to start the Static Web Apps CLI, along with the Blazor WebAssembly client application and the Functions API app:
swa start http://localhost:5000 --api-location http://localhost:7071
The Static Web Apps CLI (
swa
) starts a proxy on port 4280 that will forward static site requests to the Blazor server on port 5000 and requests to the/api
endpoint to the Functions server. -
Open a browser and navigate to the Static Web Apps CLI's address at
http://localhost:4280
. You'll be able to access both the client application and the Functions API app in this single address. When you navigate to the "Fetch Data" page, you'll see the data returned by the Functions API app. -
Enter Ctrl-C to stop the Static Web Apps CLI.
- Client: The Blazor WebAssembly sample application
- Api: A C# Azure Functions API, which the Blazor application will call
- Shared: A C# class library with a shared data model between the Blazor and Functions application
This application can be deployed to Azure Static Web Apps, to learn how, check out our quickstart guide.