in anthropic-java-core/src/main/kotlin/com/anthropic/services/blocking/MessageServiceImpl.kt [47:171]
override fun createStreaming(
params: MessageCreateParams,
requestOptions: RequestOptions,
): StreamResponse<RawMessageStreamEvent> =
// post /v1/messages
withRawResponse().createStreaming(params, requestOptions).parse()
override fun countTokens(
params: MessageCountTokensParams,
requestOptions: RequestOptions,
): MessageTokensCount =
// post /v1/messages/count_tokens
withRawResponse().countTokens(params, requestOptions).parse()
class WithRawResponseImpl internal constructor(private val clientOptions: ClientOptions) :
MessageService.WithRawResponse {
private val errorHandler: Handler<JsonValue> = errorHandler(clientOptions.jsonMapper)
private val batches: BatchService.WithRawResponse by lazy {
BatchServiceImpl.WithRawResponseImpl(clientOptions)
}
override fun batches(): BatchService.WithRawResponse = batches
private val createHandler: Handler<Message> =
jsonHandler<Message>(clientOptions.jsonMapper).withErrorHandler(errorHandler)
override fun create(
params: MessageCreateParams,
requestOptions: RequestOptions,
): HttpResponseFor<Message> {
val request =
HttpRequest.builder()
.method(HttpMethod.POST)
.addPathSegments("v1", "messages")
.body(json(clientOptions.jsonMapper, params._body()))
.build()
.prepare(clientOptions, params)
val requestOptions =
requestOptions
.applyDefaults(RequestOptions.from(clientOptions))
.applyDefaultTimeoutFromMaxTokens(params.maxTokens(), isStreaming = false)
val response = clientOptions.httpClient.execute(request, requestOptions)
return response.parseable {
response
.use { createHandler.handle(it) }
.also {
if (requestOptions.responseValidation!!) {
it.validate()
}
}
}
}
private val createStreamingHandler: Handler<StreamResponse<RawMessageStreamEvent>> =
sseHandler(clientOptions.jsonMapper)
.mapJson<RawMessageStreamEvent>()
.withErrorHandler(errorHandler)
override fun createStreaming(
params: MessageCreateParams,
requestOptions: RequestOptions,
): HttpResponseFor<StreamResponse<RawMessageStreamEvent>> {
val request =
HttpRequest.builder()
.method(HttpMethod.POST)
.addPathSegments("v1", "messages")
.body(
json(
clientOptions.jsonMapper,
params
._body()
.toBuilder()
.putAdditionalProperty("stream", JsonValue.from(true))
.build(),
)
)
.build()
.prepare(clientOptions, params)
val requestOptions =
requestOptions
.applyDefaults(RequestOptions.from(clientOptions))
.applyDefaultTimeoutFromMaxTokens(params.maxTokens(), isStreaming = true)
val response = clientOptions.httpClient.execute(request, requestOptions)
return response.parseable {
response
.let { createStreamingHandler.handle(it) }
.let { streamResponse ->
if (requestOptions.responseValidation!!) {
streamResponse.map { it.validate() }
} else {
streamResponse
}
}
}
}
private val countTokensHandler: Handler<MessageTokensCount> =
jsonHandler<MessageTokensCount>(clientOptions.jsonMapper).withErrorHandler(errorHandler)
override fun countTokens(
params: MessageCountTokensParams,
requestOptions: RequestOptions,
): HttpResponseFor<MessageTokensCount> {
val request =
HttpRequest.builder()
.method(HttpMethod.POST)
.addPathSegments("v1", "messages", "count_tokens")
.body(json(clientOptions.jsonMapper, params._body()))
.build()
.prepare(clientOptions, params)
val requestOptions = requestOptions.applyDefaults(RequestOptions.from(clientOptions))
val response = clientOptions.httpClient.execute(request, requestOptions)
return response.parseable {
response
.use { countTokensHandler.handle(it) }
.also {
if (requestOptions.responseValidation!!) {
it.validate()
}
}
}
}
}