Download the PHP package ianrothmann/langserve-php-client without Composer
On this page you can find all versions of the php package ianrothmann/langserve-php-client. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download ianrothmann/langserve-php-client
More information about ianrothmann/langserve-php-client
Files in ianrothmann/langserve-php-client
Package langserve-php-client
Short Description A PHP Client for your LangServe project that is able to call API endpoints such as invoke, batch and stream.
License MIT
Informations about the package langserve-php-client
LangServe PHP Client
Purpose
This package provides a PHP client for the LangServe API, allowing you to easily call API endpoints such as invoke
, batch
, and stream
. It simplifies the process of sending requests and handling responses from your LangServe project.
It was designed to work with vanilla PHP so it can be included with any framework (such as Laravel).
https://www.langchain.com/langserve
Installation
To install the package, use Composer:
Dependencies
This package requires:
- PHP 8.0 or higher
- Symfony HttpClient component, to support communication and streaming capabilities.
Ensure these are included in your project by adding them to your composer.json if not already present:
Usage
First, instantiate the RemoteRunnable
with the base URL of your LangServe API:
You can optionally add a Bearer token as the second parameter (remember to implement it in LangServe):
You have some different options for adding headers and authentication:
Invoke
Invoke a single API call:
Batch
Invoke multiple API calls in a batch:
Stream
Handle streaming responses:
Response Classes
Responses from invoke
and batch
are handled through RemoteRunnableResponse
and RemoteRunnableBatchResponse
, respectively. stream
initially provides RemoteRunnableStreamEvent
for each received event, and finally, a RemoteRunnableStreamResponse
aggregates all events to compile the total content.
Exceptions
This client can throw several exceptions based on API response:
InternalServerErrorException
for server errors.MalformedInputException
for input schema mismatches.NotFoundException
when the requested resource is not found.RemoteInvocationException
for errors during the remote invocation.
These exceptions help in accurately diagnosing issues with API interactions.
Contributions
Any contributions to this package is welcome. I'm looking to add more functionality to it and will work on it as required.