Skip to content

Commit

Permalink
Allow preResponseCallback and preResponseChunkCallback to return void
Browse files Browse the repository at this point in the history
  • Loading branch information
flakey5 committed Apr 18, 2024
1 parent f065ebf commit 8ee2106
Show file tree
Hide file tree
Showing 7 changed files with 15 additions and 9 deletions.
2 changes: 1 addition & 1 deletion ai-providers/azure.ts
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ class AzureByteSource implements UnderlyingByteSource {

let response = delta.content
if (this.chunkCallback !== undefined) {
response = await this.chunkCallback(response)
response = await this.chunkCallback(response) ?? response
}

const eventData: AiStreamEvent = {
Expand Down
2 changes: 1 addition & 1 deletion ai-providers/mistral.ts
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ class MistralByteSource implements UnderlyingByteSource {

let response = content ?? ''
if (this.chunkCallback !== undefined) {
response = await this.chunkCallback(response)
response = await this.chunkCallback(response) ?? response
}

const eventData: AiStreamEvent = {
Expand Down
2 changes: 1 addition & 1 deletion ai-providers/ollama.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ class OllamaByteSource implements UnderlyingByteSource {

let response = value.message.content
if (this.chunkCallback !== undefined) {
response = await this.chunkCallback(response)
response = await this.chunkCallback(response) ?? response
}

const eventData: AiStreamEvent = {
Expand Down
2 changes: 1 addition & 1 deletion ai-providers/open-ai.ts
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ class OpenAiByteSource implements UnderlyingByteSource {

let response = content ?? ''
if (this.chunkCallback !== undefined) {
response = await this.chunkCallback(response)
response = await this.chunkCallback(response) ?? response
}

const eventData: AiStreamEvent = {
Expand Down
2 changes: 1 addition & 1 deletion ai-providers/provider.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { ReadableStream } from 'node:stream/web'
import createError from '@fastify/error'

export type StreamChunkCallback = (response: string) => Promise<string>
export type StreamChunkCallback = (response: string) => Promise<string | undefined>

export interface AiProvider {
ask: (prompt: string) => Promise<string>
Expand Down
10 changes: 8 additions & 2 deletions index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,14 @@ declare module 'fastify' {
ai: {
warp: (request: FastifyRequest, prompt: string) => Promise<string>
warpStream: (request: FastifyRequest, prompt: string) => Promise<ReadableStream>
preResponseCallback?: ((request: FastifyRequest, response: string) => string) | ((request: FastifyRequest, response: string) => Promise<string>)
preResponseChunkCallback?: ((request: FastifyRequest, response: string) => string) | ((request: FastifyRequest, response: string) => Promise<string>)
preResponseCallback?: ((request: FastifyRequest, response: string) => void) |
((request: FastifyRequest, response: string) => string) |
((request: FastifyRequest, response: string) => Promise<void>) |
((request: FastifyRequest, response: string) => Promise<string>)
preResponseChunkCallback?: ((request: FastifyRequest, response: string) => void) |
((request: FastifyRequest, response: string) => string) |
((request: FastifyRequest, response: string) => Promise<void>) |
((request: FastifyRequest, response: string) => Promise<string>)
rateLimiting: {
max?: ((req: FastifyRequest, key: string) => number) | ((req: FastifyRequest, key: string) => Promise<number>)
allowList?: (req: FastifyRequest, key: string) => boolean | Promise<boolean>
Expand Down
4 changes: 2 additions & 2 deletions plugins/warp.ts
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ export default fastifyPlugin(async (fastify) => {

let response = await provider.ask(decoratedPrompt)
if (fastify.ai.preResponseCallback !== undefined) {
response = await fastify.ai.preResponseCallback(request, response)
response = await fastify.ai.preResponseCallback(request, response) ?? response
}

return response
Expand All @@ -57,7 +57,7 @@ export default fastifyPlugin(async (fastify) => {
if (fastify.ai.preResponseChunkCallback === undefined) {
return response
}
return await fastify.ai.preResponseChunkCallback(request, response)
return await fastify.ai.preResponseChunkCallback(request, response) ?? undefined
}
}

Expand Down

0 comments on commit 8ee2106

Please sign in to comment.