Openaikit est un package rapide utilisé pour communiquer avec l'API OpenAI.
Ajoutez la dépendance à package.swift:
dependencies: [
...
. package ( url : " https://github.com/dylanshine/openai-kit.git " , from : " 1.0.0 " )
] ,
targets: [
. target ( name : " App " , dependencies : [
. product ( name : " OpenAIKit " , package : " openai-kit " ) ,
] ) ,Il est encouragé à utiliser des variables d'environnement pour injecter la clé API OpenAI, au lieu de le coder en dur dans le code source.
# .env
OPENAI_API_KEY= " YOUR-API-KEY "
OPENAI_ORGANIZATION= " YOUR-ORGANIZATION " Créez un OpenAIKit.Client en passant une configuration.
var apiKey : String {
ProcessInfo . processInfo . environment [ " OPENAI_API_KEY " ] !
}
var organization : String {
ProcessInfo . processInfo . environment [ " OPENAI_ORGANIZATION " ] !
}
...
// Generally we would advise on creating a single HTTPClient for the lifecycle of your application and recommend shutting it down on application close.
let eventLoopGroup = MultiThreadedEventLoopGroup ( numberOfThreads : 1 )
let httpClient = HTTPClient ( eventLoopGroupProvider : . shared ( eventLoopGroup ) )
defer {
// it's important to shutdown the httpClient after all requests are done, even if one failed. See: https://github.com/swift-server/async-http-client
try ? httpClient . syncShutdown ( )
}
let configuration = Configuration ( apiKey : apiKey , organization : organization )
let openAIClient = OpenAIKit . Client ( httpClient : httpClient , configuration : configuration )Si vous ne souhaitez pas utiliser Swiftnio, vous pouvez utiliser URLSession.
let urlSession = URLSession ( configuration : . default )
let configuration = Configuration ( apiKey : apiKey , organization : organization )
let openAIClient = OpenAIKit . Client ( session : urlSession , configuration : configuration ) The Openaikit.Client implémente une poignée de méthodes pour interagir avec l'API OpenAI:
import OpenAIKit
let completion = try await openAIClient . completions . create (
model : Model . GPT3 . davinci ,
prompts : [ " Write a haiku " ]
) Si la demande à l'API a échoué pour une raison quelconque, un OpenAIKit.APIErrorResponse est thrown . Assurez-vous simplement d'attraper les erreurs lancées comme toute autre fonction de lancer
do {
...
} catch let error as APIErrorResponse {
print ( error )
}