Installation
Use NPM or your package manager of choice to install thelangtail
package:
Usage
Here are the different ways you can use the SDK.1. Invoke a prompt that’s deployed on Langtail (recommended)
To invoke a deployed prompt, you can uselt.prompts.invoke
like this:
Invoke a prompt
2. Invoke a prompt that’s stored in code
If you’re storing your prompt in your codebase and want to give Langtail a try, use this method. You can uselt.chat.completions.create
as a light wrapper over the OpenAI API that still sends logs and metrics to Langtail.
For more, see the example in this doc.
3. Fetch prompt from Langtail and invoke directly (proxyless)
If you’re storing your prompt in Langtail but want to invoke it directly from your code without using Langtail as a proxy, use this method. You can callLangtailPrompts.get
to retrieve the contents of the prompt:
Fetch prompt from Langtail
Prompt response
Build the final output
OpenAI body
Call OpenAI SDK
API reference
LangtailNode
Constructor
The constructor accepts an options object with the following properties:The API key for Langtail.
The base URL for the Langtail API.
A boolean indicating whether to record the API calls.
The organization ID.
The project ID.
The fetch function to use for making HTTP requests. It is passed to openAI
client under the
hood.
Properties
An object containing a
completions
object with a create
method.An instance of the
LangtailPrompts
class.Methods
chat.completions.create
This method accepts two parameters:An object that can be of type
ChatCompletionCreateParamsNonStreaming & ILangtailExtraProps
, ChatCompletionCreateParamsStreaming & ILangtailExtraProps
, ChatCompletionCreateParamsBase & ILangtailExtraProps
,
or ChatCompletionCreateParams & ILangtailExtraProps
.OpenAI
Core.RequestOptions
object (optional).ChatCompletion
or a Stream<ChatCompletionChunk>
depending whether you are using streaming or not.
Create a chat completion
Exceptions
- Throws an error if the
apiKey
is not provided in the options object or as an environment variable.
LangtailPrompts
Constructor
The constructor accepts an options object with the following properties:The API key for Langtail.
The base URL for the Langtail API.
The organization ID.
The project ID.
The fetch function to use for making HTTP requests. It is passed to openAI
client under the
hood.
Properties
The API key for Langtail.
The base URL for the Langtail API.
An object containing the options for the Langtail API.
Methods
invoke
This method accepts:An
IRequestParams
or IRequestParamsStream
object.OpenAIResponseWithHttp
or a StreamResponseType
depending on whether you use streaming or not.
Invoke a prompt
get
This method accepts one parameter with these fields:A string representing the prompt.
An
Environment
string identifier. Accepts values: "preview" | "staging" | "production"
. Defaults to production
String for version. Necessary for preview environment.
Fetch prompt from Langtail
build
This method accepts two parameters:The state object returned from the
get
method.An object containing the options for the Langtail API.
Build the final output
Exceptions
- Throws an error if the fetch operation fails.
- Throws an error if there is no body in the response when streaming is enabled.