softcreatr/php-openai-sdk

A powerful and easy-to-use PHP SDK for the OpenAI API, allowing seamless integration of advanced AI-powered features into your PHP projects.

2.2.0 2024-02-04 06:27 UTC

This package is auto-updated.

Last update: 2024-05-04 06:59:57 UTC


README

Build Latest Release ISC licensed Plant Tree Codecov branch Code Climate maintainability

This PHP library provides a simple wrapper for the OpenAI API, allowing you to easily integrate the OpenAI API into your PHP projects.

Features

  • Easy integration with OpenAI API
  • Supports all OpenAI API endpoints
  • Utilizes PSR-17 and PSR-18 compliant HTTP clients, and factories for making API requests

Requirements

Installation

You can install the library via Composer:

composer require softcreatr/php-openai-sdk

Usage

First, include the library in your project:

<?php

require_once 'vendor/autoload.php';

Then, create an instance of the OpenAI class with your API key, organization (optional), an HTTP client, an HTTP request factory, and an HTTP stream factory:

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);

Now you can call any supported OpenAI API endpoint using the magic method __call:

$response = $openAI->listModels();

// Process the API response
if ($response->getStatusCode() === 200) {
    $models = json_decode($response->getBody()->getContents(), true);
    
    print_r($models);
} else {
    echo "Error: " . $response->getStatusCode();
}

For more details on how to use each endpoint, refer to the OpenAI API documentation, and the examples provided in the repository.

Supported Methods

Models

Chat Completions

Images

Embeddings

Audio

Files

Fine-tuning

Moderations

Changelog

For a detailed list of changes and updates, please refer to the CHANGELOG.md file. We adhere to Semantic Versioning and document notable changes for each release.

Known Problems and limitations

Streaming Support

Currently, streaming is not supported in the createCompletion and createChatCompletion methods. It's planned to address this limitation asap. For now, please be aware that these methods cannot be used for streaming purposes.

If you require streaming functionality, consider using an alternative implementation or keep an eye out for future updates to this library.

License

This library is licensed under the ISC License. See the LICENSE file for more information.

Maintainers 🛠️

Sascha Greuel
Sascha Greuel

Contributors ✨