6.3 KiB
chatgpt / Exports / ChatGPTAPI
Class: ChatGPTAPI
Table of contents
Constructors
Accessors
Methods
Constructors
constructor
• new ChatGPTAPI(opts
)
Creates a new client wrapper around the unofficial ChatGPT REST API.
Note that your IP address and userAgent
must match the same values that you used
to obtain your clearanceToken
.
Parameters
Name | Type | Description |
---|---|---|
opts |
Object |
- |
opts.accessToken? |
string |
Default Value undefined * |
opts.accessTokenTTL? |
number |
Default Value 1 hour * |
opts.apiBaseUrl? |
string |
Default Value 'https://chat.openai.com/api' * |
opts.backendApiBaseUrl? |
string |
Default Value 'https://chat.openai.com/backend-api' * |
opts.clearanceToken |
string |
= Required Cloudflare cf_clearance cookie value (see readme for instructions) |
opts.debug? |
boolean |
Default Value false * |
opts.headers? |
Record <string , string > |
Default Value undefined * |
opts.markdown? |
boolean |
Default Value true * |
opts.sessionToken |
string |
= Required OpenAI session token which can be found in a valid session's cookies (see readme for instructions) |
opts.userAgent? |
string |
Default Value Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36' * |
Defined in
Accessors
clearanceToken
• get
clearanceToken(): string
Gets the current Cloudflare clearance token (cf_clearance
cookie value).
Returns
string
Defined in
sessionToken
• get
sessionToken(): string
Gets the current session token.
Returns
string
Defined in
user
• get
user(): User
Gets the currently signed-in user, if authenticated, null
otherwise.
Returns
Defined in
userAgent
• get
userAgent(): string
Gets the current user agent.
Returns
string
Defined in
Methods
ensureAuth
▸ ensureAuth(): Promise
<string
>
Refreshes the client's access token which will succeed only if the session is still valid.
Returns
Promise
<string
>
Defined in
getConversation
▸ getConversation(opts?
): ChatGPTConversation
Gets a new ChatGPTConversation instance, which can be used to send multiple messages as part of a single conversation.
Parameters
Name | Type | Description |
---|---|---|
opts |
Object |
- |
opts.conversationId? |
string |
Optional ID of the previous message in a conversation |
opts.parentMessageId? |
string |
Optional ID of the previous message in a conversation |
Returns
The new conversation instance
Defined in
getIsAuthenticated
▸ getIsAuthenticated(): Promise
<boolean
>
Returns
Promise
<boolean
>
true
if the client has a valid acces token or false
if refreshing
the token fails.
Defined in
refreshAccessToken
▸ refreshAccessToken(): Promise
<string
>
Attempts to refresh the current access token using the ChatGPT
sessionToken
cookie.
Access tokens will be cached for up to accessTokenTTL
milliseconds to
prevent refreshing access tokens too frequently.
Throws
An error if refreshing the access token fails.
Returns
Promise
<string
>
A valid access token
Defined in
sendMessage
▸ sendMessage(message
, opts?
): Promise
<string
>
Sends a message to ChatGPT, waits for the response to resolve, and returns the response.
If you want to receive a stream of partial responses, use opts.onProgress
.
If you want to receive the full response, including message and conversation IDs,
you can use opts.onConversationResponse
or use the ChatGPTAPI.getConversation
helper.
Parameters
Name | Type | Description |
---|---|---|
message |
string |
The prompt message to send |
opts |
SendMessageOptions |
- |
Returns
Promise
<string
>
The response from ChatGPT
Defined in
sendModeration
▸ sendModeration(input
): Promise
<ModerationsJSONResult
>
Parameters
Name | Type |
---|---|
input |
string |
Returns
Promise
<ModerationsJSONResult
>