Node.js client for the unofficial ChatGPT API.
Go to file
Travis Fischer cdd71d7ab4 feat: garbage collection chromium browser on close() 2022-12-04 04:33:17 -06:00
.github feat: init 2022-12-02 17:43:59 -06:00
.husky feat: init 2022-12-02 17:43:59 -06:00
docs fix: initial login flow bugs 2022-12-03 02:46:57 -06:00
src feat: garbage collection chromium browser on close() 2022-12-04 04:33:17 -06:00
.gitignore feat: init 2022-12-02 17:43:59 -06:00
.npmrc feat: init 2022-12-02 17:43:59 -06:00
.prettierignore feat: init 2022-12-02 17:43:59 -06:00
.prettierrc.cjs feat: init 2022-12-02 17:43:59 -06:00
license feat: init 2022-12-02 17:43:59 -06:00
package.json 0.4.1 2022-12-03 03:01:10 -06:00
pnpm-lock.yaml feat: remove extra deps 2022-12-02 18:36:07 -06:00
readme.md docs: add vscode extension to examples 2022-12-04 04:10:22 -06:00
tsconfig.json feat: init 2022-12-02 17:43:59 -06:00
tsup.config.ts feat: init 2022-12-02 17:43:59 -06:00
typedoc.json feat: init 2022-12-02 17:43:59 -06:00

readme.md

ChatGPT API

Node.js wrapper around ChatGPT. Uses headless Chrome until the official API is released.

NPM Build Status MIT License Prettier Code Formatting

Intro

This package is a Node.js wrapper around ChatGPT by OpenAI. TS batteries included.

You can use it to start building projects powered by ChatGPT like chatbots, websites, etc...

How it works

It uses headless Chromium via Playwright to automate the webapp, so you still need to have access to ChatGPT. It just makes building API-like integrations much easier.

Chromium will be opened in non-headless mode by default, which is important because the first time you run ChatGPTAPI.init(), you'll need to log in manually. We launch Chromium with a persistent session, however, so you shouldn't need to keep re-logging in after the first time.

When you log in the first time, we recommend dismissing the welcome modal so you can watch the progress. This isn't strictly necessary, but it helps to understand what's going on.

  • Demo video showing how the initial auth flow works (29 seconds)
  • Demo video showing how it works if you're already authed (13 seconds)

Note We'll replace headless chrome with the official API once it's released.

Install

npm install --save chatgpt
# or
yarn add chatgpt
# or
pnpm add chatgpt

Usage

import { ChatGPTAPI } from 'chatgpt'

async function example() {
  const api = new ChatGPTAPI()

  // open chromium and wait until you've logged in
  await api.init({ auth: 'blocking' })

  // send a message and wait for the response
  const response = await api.sendMessage(
    'Write a python version of bubble sort. Do not include example usage.'
  )

  // response is a markdown-formatted string
  console.log(response)
}

By default, ChatGPT responses are parsed as markdown using html-to-md. I've found that this works really well during my testing, but if you'd rather output plaintext, you can use:

const api = new ChatGPTAPI({ markdown: false })

A full example is included for testing purposes:

# clone repo
# install node deps
# then run
npx tsx src/example.ts

Docs

See the auto-generated docs for more info on methods and parameters.

Examples

License

MIT © Travis Fischer

Support my open source work by following me on twitter twitter