php openai sdk
v3.0.0
이 PHP 라이브러리는 OpenAI API를 위한 간단한 래퍼를 제공하므로 OpenAI API를 PHP 프로젝트에 쉽게 통합할 수 있습니다.
Composer를 통해 라이브러리를 설치할 수 있습니다.
composer require softcreatr/php-openai-sdk
먼저 프로젝트에 라이브러리를 포함시킵니다.
<?php
require_once ' vendor/autoload.php ' ;
그런 다음 API 키, 조직(선택 사항), HTTP 클라이언트, HTTP 요청 팩토리 및 HTTP 스트림 팩토리를 사용하여 OpenAI
클래스의 인스턴스를 만듭니다.
use SoftCreatR OpenAI OpenAI ;
$ apiKey = ' your_api_key ' ;
$ organization = ' your_organization_id ' ; // optional
// Replace these lines with your chosen PSR-17 and PSR-18 compatible HTTP client and factories
$ httpClient = new YourChosenHttpClient ();
$ requestFactory = new YourChosenRequestFactory ();
$ streamFactory = new YourChosenStreamFactory ();
$ uriFactory = new YourChosenUriFactory ();
$ openAI = new OpenAI ( $ requestFactory , $ streamFactory , $ uriFactory , $ httpClient , $ apiKey , $ organization );
이제 매직 메서드 __call
사용하여 지원되는 모든 OpenAI API 엔드포인트를 호출할 수 있습니다.
$ response = $ openAI -> createChatCompletion ([
' model ' => ' gpt-4 ' ,
' messages ' => [
[ ' role ' => ' system ' , ' content ' => ' You are a helpful assistant. ' ],
[ ' role ' => ' user ' , ' content ' => ' Hello! ' ],
],
]);
// Process the API response
if ( $ response -> getStatusCode () === 200 ) {
$ responseObj = json_decode ( $ response -> getBody ()-> getContents (), true );
print_r ( $ responseObj );
} else {
echo " Error: " . $ response -> getStatusCode ();
}
채팅 완료를 위해 실시간 스트리밍을 활성화할 수 있습니다.
$ streamCallback = static function ( $ data ) {
if ( isset ( $ data [ ' choices ' ][ 0 ][ ' delta ' ][ ' content ' ])) {
echo $ data [ ' choices ' ][ 0 ][ ' delta ' ][ ' content ' ];
}
};
$ openAI -> createChatCompletion (
[
' model ' => ' gpt-4 ' ,
' messages ' => [
[
' role ' => ' user ' ,
' content ' => ' Tell me a story about a brave knight. ' ,
],
],
' stream ' => true ,
],
$ streamCallback
);
각 엔드포인트 사용 방법에 대한 자세한 내용은 OpenAI API 설명서와 리포지토리에 제공되는 예제를 참조하세요.
다음은 카테고리별로 정리된 지원 방법 목록입니다. 각 방법은 해당 OpenAI API 문서에 연결되며 이 저장소의 예제에 대한 링크를 포함합니다.
createTranscription(array $options = [])
createTranslation(array $options = [])
createSpeech(array $options = [])
createChatCompletion(array $options = [])
createEmbedding(array $options = [])
createFineTuningJob(array $options = [])
listFineTuningJobs()
retrieveFineTuningJob(array $parameters)
cancelFineTuning(array $parameters)
listFineTuningEvents(array $parameters, array $options = [])
createBatch(array $options = [])
retrieveBatch(array $parameters)
cancelBatch(array $parameters)
listBatches()
listFiles()
uploadFile(array $options = [])
deleteFile(array $parameters)
retrieveFile(array $parameters)
retrieveFileContent(array $parameters)
createUpload(array $options = [])
addUploadPart(array $parameters, array $options = [])
completeUpload(array $parameters)
cancelUpload(array $parameters)
createImage(array $options = [])
createImageEdit(array $options = [])
createImageVariation(array $options = [])
listModels()
retrieveModel(array $parameters)
deleteModel(array $parameters)
createModeration(array $options = [])
createAssistant(array $options = [])
listAssistants()
retrieveAssistant(array $parameters)
modifyAssistant(array $parameters, array $options = [])
deleteAssistant(array $parameters)
createThread(array $options = [])
retrieveThread(array $parameters)
modifyThread(array $parameters, array $options = [])
deleteThread(array $parameters)
createMessage(array $parameters, array $options = [])
listMessages(array $parameters)
retrieveMessage(array $parameters)
modifyMessage(array $parameters, array $options = [])
deleteMessage(array $parameters)
createRun(array $parameters, array $options = [])
createThreadAndRun(array $options = [])
listRuns(array $parameters)
retrieveRun(array $parameters)
modifyRun(array $parameters, array $options = [])
submitToolOutputsToRun(array $parameters, array $options = [])
cancelRun(array $parameters)
listRunSteps(array $parameters)
retrieveRunStep(array $parameters)
createVectorStore(array $options = [])
listVectorStores()
retrieveVectorStore(array $parameters)
modifyVectorStore(array $parameters, array $options = [])
deleteVectorStore(array $parameters)
createVectorStoreFile(array $parameters, array $options = [])
listVectorStoreFiles(array $parameters)
retrieveVectorStoreFile(array $parameters)
deleteVectorStoreFile(array $parameters)
createVectorStoreFileBatch(array $parameters, array $options = [])
retrieveVectorStoreFileBatch(array $parameters)
cancelVectorStoreFileBatch(array $parameters)
listVectorStoreFilesInBatch(array $parameters)
listInvites()
createInvite(array $options = [])
retrieveInvite(array $parameters)
deleteInvite(array $parameters)
listUsers()
modifyUser(array $parameters, array $options = [])
retrieveUser(array $parameters)
deleteUser(array $parameters)
listProjects()
createProject(array $options = [])
retrieveProject(array $parameters)
modifyProject(array $parameters, array $options = [])
archiveProject(array $parameters)
listProjectUsers(array $parameters)
createProjectUser(array $parameters, array $options = [])
retrieveProjectUser(array $parameters)
modifyProjectUser(array $parameters, array $options = [])
deleteProjectUser(array $parameters)
listProjectServiceAccounts(array $parameters)
createProjectServiceAccount(array $parameters, array $options = [])
retrieveProjectServiceAccount(array $parameters)
deleteProjectServiceAccount(array $parameters)
listProjectApiKeys(array $parameters)
retrieveProjectApiKey(array $parameters)
deleteProjectApiKey(array $parameters)
listAuditLogs(array $options = [])
자세한 변경 사항 및 업데이트 목록은 CHANGELOG.md 파일을 참조하세요. 우리는 의미론적 버전 관리를 준수하고 각 릴리스에 대한 주목할만한 변경 사항을 문서화합니다.
이제 채팅 완료 시 실시간 토큰 생성을 위해 스트리밍이 지원됩니다. 예제에 설명된 대로 콜백을 사용하여 스트림을 올바르게 처리하고 있는지 확인하세요.
이 라이브러리는 ISC 라이선스에 따라 라이선스가 부여됩니다. 자세한 내용은 LICENSE 파일을 참조하세요.
사샤 그루엘 |