Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/PawanOsman/chatgpt-io

ChatGPT Client API, Blazing Fast, without using browser
https://github.com/PawanOsman/chatgpt-io

Last synced: about 1 month ago
JSON representation

ChatGPT Client API, Blazing Fast, without using browser

Awesome Lists containing this project

README

        

## For support join [[Discord](https://discord.pawan.krd)]

# chatgpt-io - Unofficial API client for ChatGPT [[Discord](https://discord.pawan.krd)]

[![NPM](https://img.shields.io/npm/v/chatgpt-io.svg?label=NPM&logo=npm&color=CB3837)](https://www.npmjs.com/package/chatgpt-io)
[![NPM](https://img.shields.io/npm/dm/chatgpt-io?label=Downloads&color=CB3837&logo=data%3Aimage%2Fpng%3Bbase64%2CiVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAAsQAAALEBxi1JjQAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAAKoSURBVEiJ7ZZLTBNRFIb%2FedDS6UNKVQgZAkJTlJdACoZgGhKj0QSNwUVxIbrRhSaasCJh58atcaExkYXogoRISF2UxJVReYkWK6gTB9KK1bZjBQlMNcz0ujAlJe3QamSl%2F%2B7m3PP995w592aAbRaVy6bqanujycZeSa4TKlGXo2qvKIpStlw2FwOdjnG5zvFnS%2BuMAIDJoci3icHoLQB%2FxwAATDYWBSX5AADOwiZyzaNz3fin%2Bm%2FwDxhojSlTW19xgaXz9ACgqIpr05WkQOWb6dMNDVUHAUBJrP%2BY9S%2FcBpA2vpo3udHpeNx0sqiNrzExFEVQWm8Gq%2FtVsLysIPxeBgB8nFtVfZ7o2MspwZWJo9kiKSwf9Xujs9YSHfY4d2zAAYArYFHRbEEhr4ffK71VgsvHtDiMVmBlZUXRMeaRRd9qZ%2B0RmzXVAAASCsHA5XcLkWC8XQiFlrQ4W37kQCAQlhbXOwd7hVBCIZvg%2FlFpms6nnYFAILwVQ7OCpGKxWMRssIhRUT60r73QCACeawuSbyTWN%2FXkzYts%2BRtTVNfc9ojhOCtREsxaJHhRFMXxZMzvEz163V7H0%2Fuf%2BmhC6KBv7cbMjDCUCrLb7a3GorKbFEurqiwvvX7%2B7PAmp5YO93yPQEhXv5c4yivdmU7jbK0acLY57maKOcor3V39XtIjENLS4Z5PqyApmmHA6jkuE2R6XOjW6ARYPcfRTHrH0wxsNU5wFfarDcXFl7RgmZRnMO0urG3ewiChqgCQZ7HCdX2YB8D%2FjkGqiKqoaQbxr1%2BmPowO8Tv3HzCAYcDtKoEcDQGEgCviEZc%2Bg6hKVrj0aiL%2BfSk2mVynPhV0dVPLeZ3B2ApCkcoTZ4bnHw6cAoCy490Pgp57naBI1p%2BE9TV5bG5m8g4yvEvbop%2BZL%2FJtWVlNhAAAAABJRU5ErkJggg%3D%3D)](https://www.npmjs.com/package/chatgpt-io)
[![GitHub issues](https://img.shields.io/github/issues/PawanOsman/chatgpt-io?label=Issues&logo=)](https://github.com/PawanOsman/ChatGPT.Net/issues)
[![GitHub forks](https://img.shields.io/github/forks/PawanOsman/chatgpt-io?label=Forks&logo=)](https://github.com/PawanOsman/ChatGPT.Net/network)
[![GitHub stars](https://img.shields.io/github/stars/PawanOsman/chatgpt-io?label=Starts&logo=)](https://github.com/PawanOsman/ChatGPT.Net/stargazers)
[![GitHub license](https://img.shields.io/github/license/PawanOsman/chatgpt-io?label=License&logo=)](https://github.com/PawanOsman/ChatGPT.Net)
[![Discord server](https://img.shields.io/discord/1055397662976905229?color=5865F2&label=Discord&logo=discord&logoColor=white)](https://discord.pawan.krd)

## [Check the new Google Bard Chatbot!](https://github.com/PawanOsman/GoogleBard)

A simple NPM package for interacting with the ChatGPT without a browser.

```javascript
import chatGPT from "chatgpt-io";

let bot = new chatGPT("");
let response = await bot.ask("Hello?");
console.log(response);
```

## Table of Contents

- [How the new method working without a browser?](#how-the-new-method-working-without-a-browser)
- [Installation](#installation)
- [Usage](#usage)
- [API Reference](#api-reference)
- [Example](#example)
- [License](#license)

## How the new method working without a browser?

The new method operates without a browser by utilizing a server that has implemented bypass methods to function as a proxy. The library sends requests to the server, which then redirects the request to ChatGPT while bypassing Cloudflare and other bot detection measures. The server then returns the ChatGPT response, ensuring that the method remains effective even if ChatGPT implements changes to prevent bot usage. Our servers are continuously updated to maintain their bypass capabilities.

## Installation

To install the package, run the following command:

```bash
npm install chatgpt-io
```

## Usage

To use the package, require it in your code and create a new instance of the `ChatGPT` class, passing in your ChatGPT API session token as an argument.

```javascript
import ChatGPT from "chatgpt-io";

let bot = new ChatGPT("");

// set the model manually, for plus accounts
let bot = new ChatGPT("", {
model: "text-davinci-002-render-sha",
});
```

Then you can send a message to the API using the `ask` method. This method takes a message string as its first argument and an optional conversation ID as its second argument. If a conversation ID is not provided, the default conversation will be used.

```javascript
let response = await bot.ask("Hello?");
console.log(response);

let response2 = await bot.ask("Hello?", "any-unique-string");
console.log(response2);
```

The `ask` method returns a promise that resolves with the API's response to the message.

## API Reference

### `ChatGPT` class

#### `constructor(sessionToken: string, options: object)`

Creates a new instance of the `ChatGPT` class.

##### Parameters

- `sessionToken` (string): Your ChatGPT API session token.
- `options` (object):

```javascript
options = {
name?: string; // name of the instance (default: "chatgpt-io")
logLevel?: LogLevel; // log level (default: LogLevel.Info)
bypassNode?: string; // bypass node url (default: https://api.pawan.krd)
model?: string; // model to use (default: text-davinci-002-render-sha)
configsDir?: string; // directory to save configs (default: ./configs)
saveInterval?: number; // interval to save configs (default: 1000 * 60 * 5)
}
```

```javascript
LogLevel = { // log levels
Trace = 0,
Debug = 1,
Info = 2, // default
Warning = 3,
Error = 4
}
```

### `ask(prompt: string, id: string = "default", parentId?: string): Promise`

Sends a message to the API and returns a promise that resolves with the API's response.

#### Parameters

- `message` (string): The message to send to the API.
- `conversationId` (string, optional): The ID of the conversation to send the message to. If not provided, the default conversation will be used.
- `parentId` (string, optional): The ID of the parent message. If not provided, the message will not have a parent.

### `askStream(callback: (arg0: string) => void, prompt: string, id: string = "default", parentId?: string): Promise`

Sends a message to the API and returns a promise that resolves with the API's response. This method is similar to `ask`, but it will call the callback function with the API's response as it is received instead of waiting for the entire response to be received.

#### Parameters

- `callback` (function): The callback function to call with the API's response as it is received.
- `message` (string): The message to send to the API.
- `conversationId` (string, optional): The ID of the conversation to send the message to. If not provided, the default conversation will be used.
- `parentId` (string, optional): The ID of the parent message. If not provided, the message will not have a parent.

## Example

Here is an example of how to use the `chatgpt-io` module to send a message to the API and log the response:

```javascript
import ChatGPT from "chatgpt-io";

let bot = new ChatGPT("");

// default conversation
let response = await bot.ask("Hello?");
console.log(response);

// specific conversation
let response2 = await bot.ask("Hello?", "any-unique-string");
console.log(response2);

// stream response
await bot.askStream((response) => {
console.log(response);
}, "Hello?");

// stream response with conversation
await bot.askStream(
(response) => {
console.log(response);
},
"Hello?",
"any-unique-string",
);
```

## License

This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.