An OpenAI GPT-3 API client enabling Go/Golang programs to interact with the gpt3 APIs.
Supports using the completion APIs with or without streaming.
Simple usage to call the main gpt-3 API, completion:
client := gpt3.NewClient(apiKey)
resp, err := client.Completion(ctx, gpt3.CompletionRequest{
Prompt: []string{"2, 3, 5, 7, 11,"},
})
fmt.Print(resp.Choices[0].Text)
// prints " 13, 17, 19, 23, 29, 31", etcCheck out the go docs for more detailed documentation on the types and methods provided: https://pkg.go.dev/github.com/PullRequestInc/go-gpt3
Try out any of these examples with putting the contents in a main.go and running go run main.go.
I would recommend using go modules in which case you will also need to run go mod init within your
test repo. Alternatively you can clone this repo and run the test script with go run cmd/test/main.go.
You will also need to have a .env file that looks like this to use these examples:
API_KEY=<openAI API Key>
package main
import (
"context"
"fmt"
"log"
"os"
"github.com/PullRequestInc/go-gpt3"
"github.com/joho/godotenv"
)
func main() {
godotenv.Load()
apiKey := os.Getenv("API_KEY")
if apiKey == "" {
log.Fatalln("Missing API KEY")
}
ctx := context.Background()
client := gpt3.NewClient(apiKey)
resp, err := client.Completion(ctx, gpt3.CompletionRequest{
Prompt: []string{"The first thing you should know about javascript is"},
MaxTokens: gpt3.IntPtr(30),
Stop: []string{"."},
Echo: true,
})
if err != nil {
log.Fatalln(err)
}
fmt.Println(resp.Choices[0].Text)
}- List Engines API
- Get Engine API
- Completion API (this is the main gpt-3 API)
- Streaming support for the Completion API
- Document Search API
- Overriding default url, user-agent, timeout, and other options