Good morning,
I am trying to create an Assistant that interacts in Google Sheet. The assistant has its own knowledge thanks to File Search.
In the playground everything is fine but in Google Sheet it seems to no longer have the knowledge. How can I bring the knowledge into Google Sheets via Api?
Here is my code:
`function commercialassistant(userInput) {
var OPENAI_API_KEY = ‘my api key’; // OpenAI API key here
var ASSISTANT_ID = ‘my assistand id’; // Assistant ID here
var headers = {
‘Authorization’: 'Bearer ’ + OPENAI_API_KEY,
‘Content-Type’: ‘application/json’,
‘OpenAI-Beta’: ‘assistants=v1’
};
// Create a thread
var threadResponse = UrlFetchApp.fetch(‘https://api.openai.com/v1/threads’, {
‘method’: ‘post’,
‘headers’: headers,
‘muteHttpExceptions’: true
});
if (threadResponse.getResponseCode() !== 200) {
return "Failed to create thread. Response: " + threadResponse.getContentText();
}
var threadData = JSON.parse(threadResponse.getContentText());
var threadId = threadData.id; // Adjust based on actual response format
// Send a message to the thread
var messageResponse = UrlFetchApp.fetch(https://api.openai.com/v1/threads/${threadId}/messages
, {
‘method’: ‘post’,
‘headers’: headers,
‘payload’: JSON.stringify({
‘role’: ‘user’,
‘content’: userInput
}),
‘muteHttpExceptions’: true
});
if (messageResponse.getResponseCode() !== 200) {
return "Failed to send message. Response: " + messageResponse.getContentText();
}
// Run the thread using the assistant
var runResponse = UrlFetchApp.fetch(https://api.openai.com/v1/threads/${threadId}/runs
, {
‘method’: ‘post’,
‘headers’: headers,
‘payload’: JSON.stringify({
‘assistant_id’: ASSISTANT_ID
}),
‘muteHttpExceptions’: true
});
if (runResponse.getResponseCode() !== 200) {
return "Failed to run thread. Response: " + runResponse.getContentText();
}
var runData = JSON.parse(runResponse.getContentText());
var runId = runData.id;
var status = runData.status;
var startTime = new Date().getTime();
// Poll the run status until it is ‘completed’
while (status === ‘queued’ || status === ‘in_progress’) {
Utilities.sleep(500); // Wait for half a second before checking again
var checkResponse = UrlFetchApp.fetch(https://api.openai.com/v1/threads/${threadId}/runs/${runId}
, {
‘method’: ‘get’,
‘headers’: headers,
‘muteHttpExceptions’: true
});
var checkData = JSON.parse(checkResponse.getContentText());
status = checkData.status;
// Check for timeout to avoid exceeding the execution limit
var currentTime = new Date().getTime();
if (currentTime - startTime > 29000) { // 29 seconds limit to be safe
return "Timeout waiting for the run to complete.";
}
}
// Once the run is completed, fetch the final result
if (status === ‘completed’) {
var messagesResponse = UrlFetchApp.fetch(https://api.openai.com/v1/threads/${threadId}/messages
, {
‘method’: ‘get’,
‘headers’: headers,
‘muteHttpExceptions’: true
});
if (messagesResponse.getResponseCode() === 200) {
var messagesData = JSON.parse(messagesResponse.getContentText());
// Iterate over messages to find the assistant's response
for (var i = messagesData.data.length - 1; i >= 0; i--) {
var message = messagesData.data[i];
if (message.role === 'assistant' && message.content && message.content.length > 0) {
// Assuming the first content item contains the text response
var contentItem = message.content.find(c => c.type === 'text');
if (contentItem && contentItem.text && contentItem.text.value) {
return contentItem.text.value; // Return the text value of the assistant's message
}
}
}
return "Assistant's final response not found.";
} else {
return "Failed to fetch messages. Response: " + messagesResponse.getContentText();
}
} else {
return "Run did not complete successfully. Status: " + status;
}
}
`