Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Jandev/sk-plugin-sample
Sample project to show how plugins can be used with Semantic Kernel
https://github.com/Jandev/sk-plugin-sample
Last synced: 2 months ago
JSON representation
Sample project to show how plugins can be used with Semantic Kernel
- Host: GitHub
- URL: https://github.com/Jandev/sk-plugin-sample
- Owner: Jandev
- License: mit
- Created: 2023-10-03T08:08:51.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-11-28T20:25:01.000Z (about 1 year ago)
- Last Synced: 2024-08-01T13:18:26.984Z (5 months ago)
- Language: C#
- Size: 25.4 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: contributing.md
- License: LICENSE
Awesome Lists containing this project
- awesome-semantickernel - sk-plugin-sample
README
# Semantic Kernel Open AI Plugin example
This repository contains two sample projects.
One project, `Domain.Platform.Service`, is the service exposing an Open AI plugin. This service is using Semantic Kernel to create a summary for websites.
The other project, `Partner.Copilot.Service`, is the service exposing a rich Copilot experience. Users can ask questions to the REST API endpoint. For summarization of a website, the Open AI plugin of the former project is used.## Set up
Configure the Azure Open AI settings in the `appsettings.json` file. Both projects can be configured to use the same service.
```jsonc
{
// ...
"OpenAI": {
"ServiceCompletionEndpoint": "https://{yourInstance}.openai.azure.com/",
"ServiceKey": "{yourKey}",
"ServiceDeploymentId": "{yourDeployment}",
"ServiceModelName": "{yourDeployment}",
"EmbeddingsDeploymentId": "{yourEmbeddingDeployment}"
}
}
```When the settings are configured correctly, you can run both projects and try it out yourself.
## Sample usage
### Domain service
To get a summary for a website, you can make a GET request, using the `websiteUrl` in the querystring.
```bash
curl "{{pluginDomainHost}}api/Summarize?websiteUrl=https://jan-v.nl"
```### Partner service
The partner service also exposes an endpoint to which questions can be asked to.
```bash
curl -X POST -H "Content-Type: application/json" -d '{ "Ask" : "Please create me a summary for the website https://jan-v.nl/" }' "{{pluginPartnerHost}}api/Copilot"
```