diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 5813609..b5c77a3 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -6,6 +6,7 @@ on: pull_request: branches: - main + - next jobs: lint: @@ -34,3 +35,4 @@ jobs: - name: Run lints run: ./scripts/lint + diff --git a/.github/workflows/create-releases.yml b/.github/workflows/create-releases.yml new file mode 100644 index 0000000..58107af --- /dev/null +++ b/.github/workflows/create-releases.yml @@ -0,0 +1,47 @@ +name: Create releases +on: + schedule: + - cron: '0 5 * * *' # every day at 5am UTC + push: + branches: + - main + +jobs: + release: + name: release + if: github.ref == 'refs/heads/main' && github.repository == 'openlayer-ai/openlayer-java' + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v4 + + - uses: stainless-api/trigger-release-please@v1 + id: release + with: + repo: ${{ github.event.repository.full_name }} + stainless-api-key: ${{ secrets.STAINLESS_API_KEY }} + + - name: Set up Java + if: ${{ steps.release.outputs.releases_created }} + uses: actions/setup-java@v3 + with: + distribution: temurin + java-version: | + 8 + 17 + cache: gradle + + - name: Set up Gradle + if: ${{ steps.release.outputs.releases_created }} + uses: gradle/gradle-build-action@v2 + + - name: Publish to Sonatype + if: ${{ steps.release.outputs.releases_created }} + run: | + ./gradlew --parallel --no-daemon publish + env: + SONATYPE_USERNAME: ${{ secrets.OPENLAYER_SONATYPE_USERNAME || secrets.SONATYPE_USERNAME }} + SONATYPE_PASSWORD: ${{ secrets.OPENLAYER_SONATYPE_PASSWORD || secrets.SONATYPE_PASSWORD }} + GPG_SIGNING_KEY_ID: ${{ secrets.OPENLAYER_SONATYPE_GPG_SIGNING_KEY_ID || secrets.GPG_SIGNING_KEY_ID }} + GPG_SIGNING_KEY: ${{ secrets.OPENLAYER_SONATYPE_GPG_SIGNING_KEY || secrets.GPG_SIGNING_KEY }} + GPG_SIGNING_PASSWORD: ${{ secrets.OPENLAYER_SONATYPE_GPG_SIGNING_PASSWORD || secrets.GPG_SIGNING_PASSWORD }} diff --git a/.github/workflows/handle-release-pr-title-edit.yml b/.github/workflows/handle-release-pr-title-edit.yml new file mode 100644 index 0000000..ac2a680 --- /dev/null +++ b/.github/workflows/handle-release-pr-title-edit.yml @@ -0,0 +1,25 @@ +name: Handle release PR title edits +on: + pull_request: + types: + - edited + - unlabeled + +jobs: + update_pr_content: + name: Update pull request content + if: | + ((github.event.action == 'edited' && github.event.changes.title.from != github.event.pull_request.title) || + (github.event.action == 'unlabeled' && github.event.label.name == 'autorelease: custom version')) && + startsWith(github.event.pull_request.head.ref, 'release-please--') && + github.event.pull_request.state == 'open' && + github.event.sender.login != 'stainless-bot' && + github.event.sender.login != 'stainless-app' && + github.repository == 'openlayer-ai/openlayer-java' + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: stainless-api/trigger-release-please@v1 + with: + repo: ${{ github.event.repository.full_name }} + stainless-api-key: ${{ secrets.STAINLESS_API_KEY }} diff --git a/.github/workflows/release-doctor.yml b/.github/workflows/release-doctor.yml index c09f373..7a3754c 100644 --- a/.github/workflows/release-doctor.yml +++ b/.github/workflows/release-doctor.yml @@ -1,6 +1,8 @@ name: Release Doctor on: pull_request: + branches: + - main workflow_dispatch: jobs: diff --git a/.gitignore b/.gitignore index 1c94d9f..39c31e3 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ +.prism.log .gradle .idea build diff --git a/.release-please-manifest.json b/.release-please-manifest.json index ba6c348..f14b480 100644 --- a/.release-please-manifest.json +++ b/.release-please-manifest.json @@ -1,3 +1,3 @@ { - ".": "0.1.0-alpha.1" + ".": "0.1.0-alpha.2" } \ No newline at end of file diff --git a/.stats.yml b/.stats.yml index 2b7dbf3..6a8c142 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1 +1 @@ -configured_endpoints: 6 +configured_endpoints: 13 diff --git a/CHANGELOG.md b/CHANGELOG.md index 9398600..beede32 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,38 @@ # Changelog +## 0.1.0-alpha.2 (2024-08-15) + +Full Changelog: [v0.1.0-alpha.1...v0.1.0-alpha.2](https://github.com/openlayer-ai/openlayer-java/compare/v0.1.0-alpha.1...v0.1.0-alpha.2) + +### Features + +* **api:** OpenAPI spec update via Stainless API ([f3a2e94](https://github.com/openlayer-ai/openlayer-java/commit/f3a2e94096f7065baaf412330b4d82098144a7c6)) +* **api:** OpenAPI spec update via Stainless API ([#13](https://github.com/openlayer-ai/openlayer-java/issues/13)) ([3d51770](https://github.com/openlayer-ai/openlayer-java/commit/3d51770cd80a882159c7bd267ebb4b1f82e1bbf2)) +* **api:** OpenAPI spec update via Stainless API ([#16](https://github.com/openlayer-ai/openlayer-java/issues/16)) ([700e5dd](https://github.com/openlayer-ai/openlayer-java/commit/700e5dd17a46e547f1a2433993bbb4b586ae2159)) +* **api:** OpenAPI spec update via Stainless API ([#22](https://github.com/openlayer-ai/openlayer-java/issues/22)) ([57cd9b9](https://github.com/openlayer-ai/openlayer-java/commit/57cd9b93d5cc5a955a2ca30136e53fcbc0db3fe1)) +* **api:** OpenAPI spec update via Stainless API ([#8](https://github.com/openlayer-ai/openlayer-java/issues/8)) ([8edaa4b](https://github.com/openlayer-ai/openlayer-java/commit/8edaa4b24bf2b90d987ed7f64d2f789016f0f2ef)) +* **api:** OpenAPI spec update via Stainless API ([#9](https://github.com/openlayer-ai/openlayer-java/issues/9)) ([69c5aba](https://github.com/openlayer-ai/openlayer-java/commit/69c5aba6d450e4a924a1ec1bf8f427cd66ba29a0)) +* **api:** update via SDK Studio ([#10](https://github.com/openlayer-ai/openlayer-java/issues/10)) ([75a4d98](https://github.com/openlayer-ai/openlayer-java/commit/75a4d984832a11a4561b7b45ef1667dad6e8bd0a)) +* **api:** update via SDK Studio ([#14](https://github.com/openlayer-ai/openlayer-java/issues/14)) ([b5ecd1c](https://github.com/openlayer-ai/openlayer-java/commit/b5ecd1cffeec8cc90c8fc37eb86d270671adcc73)) +* **api:** update via SDK Studio ([#15](https://github.com/openlayer-ai/openlayer-java/issues/15)) ([ca3563b](https://github.com/openlayer-ai/openlayer-java/commit/ca3563b438c684f30bdc57fe95bd0bee33a0b201)) +* **api:** update via SDK Studio ([#21](https://github.com/openlayer-ai/openlayer-java/issues/21)) ([b3df178](https://github.com/openlayer-ai/openlayer-java/commit/b3df178a8dba68759f3e9146c32ab2b52afa07a4)) +* **api:** update via SDK Studio ([#23](https://github.com/openlayer-ai/openlayer-java/issues/23)) ([656bca9](https://github.com/openlayer-ai/openlayer-java/commit/656bca961e35da983260b1f6e5b3117d97bfebcf)) +* **api:** update via SDK Studio ([#24](https://github.com/openlayer-ai/openlayer-java/issues/24)) ([1166c1b](https://github.com/openlayer-ai/openlayer-java/commit/1166c1beeda0ba4d25c01820cd3646c14555491c)) +* **api:** update via SDK Studio ([#27](https://github.com/openlayer-ai/openlayer-java/issues/27)) ([9ed736f](https://github.com/openlayer-ai/openlayer-java/commit/9ed736f97e978d70402de098e6ba131057e0d080)) +* **api:** update via SDK Studio ([#5](https://github.com/openlayer-ai/openlayer-java/issues/5)) ([f01f468](https://github.com/openlayer-ai/openlayer-java/commit/f01f468c2b6a0521a5f67bf7715d9d1e68eab49c)) +* **api:** update via SDK Studio ([#7](https://github.com/openlayer-ai/openlayer-java/issues/7)) ([8c4398e](https://github.com/openlayer-ai/openlayer-java/commit/8c4398ed39212e1e018729727d7dfbe70a8db27d)) + + +### Chores + +* **ci:** limit release doctor target branches ([#17](https://github.com/openlayer-ai/openlayer-java/issues/17)) ([ef0d7e9](https://github.com/openlayer-ai/openlayer-java/commit/ef0d7e9c91d7798039e01600b762b13f1f5ada23)) +* go live ([#6](https://github.com/openlayer-ai/openlayer-java/issues/6)) ([30ba342](https://github.com/openlayer-ai/openlayer-java/commit/30ba3429a02384007ec45e95db462a07d6a8e892)) +* **internal:** codegen related update ([#18](https://github.com/openlayer-ai/openlayer-java/issues/18)) ([ff15d61](https://github.com/openlayer-ai/openlayer-java/commit/ff15d6179d277e41ab1910b69e90e49323530e3b)) +* **internal:** refactor release doctor script ([#19](https://github.com/openlayer-ai/openlayer-java/issues/19)) ([6ce88ff](https://github.com/openlayer-ai/openlayer-java/commit/6ce88ff0c6f47bc4ae9d64e97dfedccc98edc5f7)) +* **internal:** restore release-please configuration files ([#26](https://github.com/openlayer-ai/openlayer-java/issues/26)) ([a309673](https://github.com/openlayer-ai/openlayer-java/commit/a309673d5c7e72df8b006156d5458570d251995e)) +* **internal:** version bump ([#3](https://github.com/openlayer-ai/openlayer-java/issues/3)) ([2e46974](https://github.com/openlayer-ai/openlayer-java/commit/2e46974aefcd77a33417b3d675bea14ccb95befd)) +* **tests:** update prism version ([#25](https://github.com/openlayer-ai/openlayer-java/issues/25)) ([67bc5ea](https://github.com/openlayer-ai/openlayer-java/commit/67bc5ea91b7b482e09c8e4ccbbd544185e221a10)) + ## 0.1.0-alpha.1 (2024-06-24) Full Changelog: [v0.0.1-alpha.0...v0.1.0-alpha.1](https://github.com/openlayer-ai/openlayer-java/compare/v0.0.1-alpha.0...v0.1.0-alpha.1) diff --git a/README.md b/README.md index c027e07..da1c440 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ -[![Maven Central](https://img.shields.io/maven-central/v/org.openlayer/openlayer-java)](https://central.sonatype.com/artifact/org.openlayer/openlayer-java/0.1.0-alpha.1) +[![Maven Central](https://img.shields.io/maven-central/v/com.openlayer.api/openlayer-java)](https://central.sonatype.com/artifact/com.openlayer.api/openlayer-java/0.1.0-alpha.2) @@ -14,7 +14,7 @@ It is generated with [Stainless](https://www.stainlessapi.com/). ## Documentation -The REST API documentation can be found [on openlayer.com](https://openlayer.com/docs/api-reference/rest/overview). +The REST API documentation can be found on [openlayer.com](https://openlayer.com/docs/api-reference/rest/overview). --- @@ -27,16 +27,16 @@ The REST API documentation can be found [on openlayer.com](https://openlayer.co ```kotlin -implementation("org.openlayer:openlayer-java:0.1.0-alpha.1") +implementation("com.openlayer.api:openlayer-java:0.1.0-alpha.2") ``` #### Maven ```xml - org.openlayer + com.openlayer.api openlayer-java - 0.1.0-alpha.1 + 0.1.0-alpha.2 ``` @@ -72,9 +72,9 @@ To create a new inference pipeline data, first use the `InferencePipelineDataStr then pass that to the `stream` method of the `data` service. ```java +import com.openlayer.api.models.InferencePipelineDataStreamParams; +import com.openlayer.api.models.InferencePipelineDataStreamResponse; import java.util.List; -import org.openlayer.models.InferencePipelineDataStreamParams; -import org.openlayer.models.InferencePipelineDataStreamResponse; InferencePipelineDataStreamParams params = InferencePipelineDataStreamParams.builder() .rows(List.of(InferencePipelineDataStreamParams.Row.builder().build())) @@ -250,3 +250,7 @@ This package generally follows [SemVer](https://semver.org/spec/v2.0.0.html) con We take backwards-compatibility seriously and work hard to ensure you can rely on a smooth upgrade experience. We are keen for your feedback; please open an [issue](https://www.github.com/openlayer-ai/openlayer-java/issues) with questions, bugs, or suggestions. + +## Requirements + +This library requires Java 8 or later. diff --git a/bin/check-release-environment b/bin/check-release-environment index 6fcdea6..14a9e4d 100644 --- a/bin/check-release-environment +++ b/bin/check-release-environment @@ -1,32 +1,21 @@ #!/usr/bin/env bash -warnings=() errors=() if [ -z "${SONATYPE_USERNAME}" ]; then - warnings+=("The OPENLAYER_SONATYPE_USERNAME secret has not been set. Please set it in either this repository's secrets or your organization secrets") + errors+=("The OPENLAYER_SONATYPE_USERNAME secret has not been set. Please set it in either this repository's secrets or your organization secrets") fi if [ -z "${SONATYPE_PASSWORD}" ]; then - warnings+=("The OPENLAYER_SONATYPE_PASSWORD secret has not been set. Please set it in either this repository's secrets or your organization secrets") + errors+=("The OPENLAYER_SONATYPE_PASSWORD secret has not been set. Please set it in either this repository's secrets or your organization secrets") fi if [ -z "${GPG_SIGNING_KEY}" ]; then - warnings+=("The OPENLAYER_SONATYPE_GPG_SIGNING_KEY secret has not been set. Please set it in either this repository's secrets or your organization secrets") + errors+=("The OPENLAYER_SONATYPE_GPG_SIGNING_KEY secret has not been set. Please set it in either this repository's secrets or your organization secrets") fi if [ -z "${GPG_SIGNING_PASSWORD}" ]; then - warnings+=("The OPENLAYER_SONATYPE_GPG_SIGNING_PASSWORD secret has not been set. Please set it in either this repository's secrets or your organization secrets") -fi - -lenWarnings=${#warnings[@]} - -if [[ lenWarnings -gt 0 ]]; then - echo -e "Found the following warnings in the release environment:\n" - - for warning in "${warnings[@]}"; do - echo -e "- $warning\n" - done + errors+=("The OPENLAYER_SONATYPE_GPG_SIGNING_PASSWORD secret has not been set. Please set it in either this repository's secrets or your organization secrets") fi lenErrors=${#errors[@]} diff --git a/build.gradle.kts b/build.gradle.kts index 4cac40f..0e8d4a4 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -3,8 +3,8 @@ plugins { } allprojects { - group = "org.openlayer" - version = "0.1.0-alpha.1" // x-release-please-version + group = "com.openlayer.api" + version = "0.1.0-alpha.2" // x-release-please-version } diff --git a/openlayer-java-client-okhttp/src/main/kotlin/org/openlayer/client/okhttp/OkHttpClient.kt b/openlayer-java-client-okhttp/src/main/kotlin/com/openlayer/api/client/okhttp/OkHttpClient.kt similarity index 93% rename from openlayer-java-client-okhttp/src/main/kotlin/org/openlayer/client/okhttp/OkHttpClient.kt rename to openlayer-java-client-okhttp/src/main/kotlin/com/openlayer/api/client/okhttp/OkHttpClient.kt index bfa04c9..13779b0 100644 --- a/openlayer-java-client-okhttp/src/main/kotlin/org/openlayer/client/okhttp/OkHttpClient.kt +++ b/openlayer-java-client-okhttp/src/main/kotlin/com/openlayer/api/client/okhttp/OkHttpClient.kt @@ -1,7 +1,14 @@ -package org.openlayer.client.okhttp +package com.openlayer.api.client.okhttp import com.google.common.collect.ListMultimap import com.google.common.collect.MultimapBuilder +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpClient +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpRequestBody +import com.openlayer.api.core.http.HttpResponse +import com.openlayer.api.errors.OpenlayerIoException import java.io.IOException import java.io.InputStream import java.net.Proxy @@ -19,13 +26,6 @@ import okhttp3.RequestBody import okhttp3.RequestBody.Companion.toRequestBody import okhttp3.Response import okio.BufferedSink -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpClient -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpRequestBody -import org.openlayer.core.http.HttpResponse -import org.openlayer.errors.OpenlayerIoException class OkHttpClient private constructor(private val okHttpClient: okhttp3.OkHttpClient, private val baseUrl: HttpUrl) : diff --git a/openlayer-java-client-okhttp/src/main/kotlin/org/openlayer/client/okhttp/OpenlayerOkHttpClient.kt b/openlayer-java-client-okhttp/src/main/kotlin/com/openlayer/api/client/okhttp/OpenlayerOkHttpClient.kt similarity index 93% rename from openlayer-java-client-okhttp/src/main/kotlin/org/openlayer/client/okhttp/OpenlayerOkHttpClient.kt rename to openlayer-java-client-okhttp/src/main/kotlin/com/openlayer/api/client/okhttp/OpenlayerOkHttpClient.kt index ad640c1..1dff803 100644 --- a/openlayer-java-client-okhttp/src/main/kotlin/org/openlayer/client/okhttp/OpenlayerOkHttpClient.kt +++ b/openlayer-java-client-okhttp/src/main/kotlin/com/openlayer/api/client/okhttp/OpenlayerOkHttpClient.kt @@ -1,14 +1,14 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.client.okhttp +package com.openlayer.api.client.okhttp import com.fasterxml.jackson.databind.json.JsonMapper +import com.openlayer.api.client.OpenlayerClient +import com.openlayer.api.client.OpenlayerClientImpl +import com.openlayer.api.core.ClientOptions import java.net.Proxy import java.time.Clock import java.time.Duration -import org.openlayer.client.OpenlayerClient -import org.openlayer.client.OpenlayerClientImpl -import org.openlayer.core.ClientOptions class OpenlayerOkHttpClient private constructor() { diff --git a/openlayer-java-client-okhttp/src/main/kotlin/org/openlayer/client/okhttp/OpenlayerOkHttpClientAsync.kt b/openlayer-java-client-okhttp/src/main/kotlin/com/openlayer/api/client/okhttp/OpenlayerOkHttpClientAsync.kt similarity index 93% rename from openlayer-java-client-okhttp/src/main/kotlin/org/openlayer/client/okhttp/OpenlayerOkHttpClientAsync.kt rename to openlayer-java-client-okhttp/src/main/kotlin/com/openlayer/api/client/okhttp/OpenlayerOkHttpClientAsync.kt index 1a33a1c..0866f95 100644 --- a/openlayer-java-client-okhttp/src/main/kotlin/org/openlayer/client/okhttp/OpenlayerOkHttpClientAsync.kt +++ b/openlayer-java-client-okhttp/src/main/kotlin/com/openlayer/api/client/okhttp/OpenlayerOkHttpClientAsync.kt @@ -1,14 +1,14 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.client.okhttp +package com.openlayer.api.client.okhttp import com.fasterxml.jackson.databind.json.JsonMapper +import com.openlayer.api.client.OpenlayerClientAsync +import com.openlayer.api.client.OpenlayerClientAsyncImpl +import com.openlayer.api.core.ClientOptions import java.net.Proxy import java.time.Clock import java.time.Duration -import org.openlayer.client.OpenlayerClientAsync -import org.openlayer.client.OpenlayerClientAsyncImpl -import org.openlayer.core.ClientOptions class OpenlayerOkHttpClientAsync private constructor() { diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClient.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClient.kt similarity index 70% rename from openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClient.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClient.kt index 916c328..3a24286 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClient.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClient.kt @@ -2,10 +2,10 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.client +package com.openlayer.api.client -import org.openlayer.models.* -import org.openlayer.services.blocking.* +import com.openlayer.api.models.* +import com.openlayer.api.services.blocking.* interface OpenlayerClient { @@ -16,4 +16,6 @@ interface OpenlayerClient { fun commits(): CommitService fun inferencePipelines(): InferencePipelineService + + fun storage(): StorageService } diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClientAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClientAsync.kt similarity index 70% rename from openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClientAsync.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClientAsync.kt index 38f2d7e..7d8847c 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClientAsync.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClientAsync.kt @@ -2,10 +2,10 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.client +package com.openlayer.api.client -import org.openlayer.models.* -import org.openlayer.services.async.* +import com.openlayer.api.models.* +import com.openlayer.api.services.async.* interface OpenlayerClientAsync { @@ -16,4 +16,6 @@ interface OpenlayerClientAsync { fun commits(): CommitServiceAsync fun inferencePipelines(): InferencePipelineServiceAsync + + fun storage(): StorageServiceAsync } diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClientAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClientAsyncImpl.kt similarity index 67% rename from openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClientAsyncImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClientAsyncImpl.kt index 2b4bbce..d3c13ec 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClientAsyncImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClientAsyncImpl.kt @@ -1,13 +1,13 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.client +package com.openlayer.api.client -import org.openlayer.core.ClientOptions -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.* -import org.openlayer.services.async.* -import org.openlayer.services.errorHandler +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.* +import com.openlayer.api.services.async.* +import com.openlayer.api.services.errorHandler class OpenlayerClientAsyncImpl constructor( @@ -26,6 +26,8 @@ constructor( InferencePipelineServiceAsyncImpl(clientOptions) } + private val storage: StorageServiceAsync by lazy { StorageServiceAsyncImpl(clientOptions) } + override fun sync(): OpenlayerClient = sync override fun projects(): ProjectServiceAsync = projects @@ -33,4 +35,6 @@ constructor( override fun commits(): CommitServiceAsync = commits override fun inferencePipelines(): InferencePipelineServiceAsync = inferencePipelines + + override fun storage(): StorageServiceAsync = storage } diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClientImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClientImpl.kt similarity index 67% rename from openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClientImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClientImpl.kt index 7f1a32e..29a6187 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/client/OpenlayerClientImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/client/OpenlayerClientImpl.kt @@ -1,13 +1,13 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.client +package com.openlayer.api.client -import org.openlayer.core.ClientOptions -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.* -import org.openlayer.services.blocking.* -import org.openlayer.services.errorHandler +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.* +import com.openlayer.api.services.blocking.* +import com.openlayer.api.services.errorHandler class OpenlayerClientImpl constructor( @@ -26,6 +26,8 @@ constructor( InferencePipelineServiceImpl(clientOptions) } + private val storage: StorageService by lazy { StorageServiceImpl(clientOptions) } + override fun async(): OpenlayerClientAsync = async override fun projects(): ProjectService = projects @@ -33,4 +35,6 @@ constructor( override fun commits(): CommitService = commits override fun inferencePipelines(): InferencePipelineService = inferencePipelines + + override fun storage(): StorageService = storage } diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/BaseDeserializer.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/BaseDeserializer.kt similarity index 98% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/BaseDeserializer.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/BaseDeserializer.kt index e2344e5..0573e16 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/BaseDeserializer.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/BaseDeserializer.kt @@ -1,4 +1,4 @@ -package org.openlayer.core +package com.openlayer.api.core import com.fasterxml.jackson.core.JsonParser import com.fasterxml.jackson.core.ObjectCodec diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/BaseSerializer.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/BaseSerializer.kt similarity index 85% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/BaseSerializer.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/BaseSerializer.kt index d3031ef..eb87e2c 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/BaseSerializer.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/BaseSerializer.kt @@ -1,4 +1,4 @@ -package org.openlayer.core +package com.openlayer.api.core import com.fasterxml.jackson.databind.ser.std.StdSerializer import kotlin.reflect.KClass diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/ClientOptions.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/ClientOptions.kt similarity index 97% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/ClientOptions.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/ClientOptions.kt index d3434c8..ed353b4 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/ClientOptions.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/ClientOptions.kt @@ -1,13 +1,13 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.core +package com.openlayer.api.core import com.fasterxml.jackson.databind.json.JsonMapper import com.google.common.collect.ArrayListMultimap import com.google.common.collect.ListMultimap +import com.openlayer.api.core.http.HttpClient +import com.openlayer.api.core.http.RetryingHttpClient import java.time.Clock -import org.openlayer.core.http.HttpClient -import org.openlayer.core.http.RetryingHttpClient class ClientOptions private constructor( diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/ObjectMappers.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/ObjectMappers.kt similarity index 97% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/ObjectMappers.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/ObjectMappers.kt index 5c86b9e..2a22f38 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/ObjectMappers.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/ObjectMappers.kt @@ -1,6 +1,6 @@ @file:JvmName("ObjectMappers") -package org.openlayer.core +package com.openlayer.api.core import com.fasterxml.jackson.annotation.JsonInclude import com.fasterxml.jackson.databind.DeserializationFeature diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/Properties.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/Properties.kt similarity index 97% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/Properties.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/Properties.kt index d057b2f..bc0d02a 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/Properties.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/Properties.kt @@ -1,6 +1,6 @@ @file:JvmName("Properties") -package org.openlayer.core +package com.openlayer.api.core import java.util.Properties diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/RequestOptions.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/RequestOptions.kt similarity index 97% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/RequestOptions.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/RequestOptions.kt index 2afeccc..2b862a3 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/RequestOptions.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/RequestOptions.kt @@ -1,4 +1,4 @@ -package org.openlayer.core +package com.openlayer.api.core import java.time.Duration diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/Utils.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/Utils.kt similarity index 93% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/Utils.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/Utils.kt index a7ca7ec..8f46e25 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/Utils.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/Utils.kt @@ -1,12 +1,12 @@ @file:JvmName("Utils") -package org.openlayer.core +package com.openlayer.api.core import com.google.common.collect.ImmutableListMultimap import com.google.common.collect.ListMultimap import com.google.common.collect.Multimaps +import com.openlayer.api.errors.OpenlayerInvalidDataException import java.util.Collections -import org.openlayer.errors.OpenlayerInvalidDataException @JvmSynthetic internal fun T?.getOrThrow(name: String): T { diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/Values.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/Values.kt similarity index 99% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/Values.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/Values.kt index b89c39b..12b454f 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/Values.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/Values.kt @@ -1,4 +1,4 @@ -package org.openlayer.core +package com.openlayer.api.core import com.fasterxml.jackson.annotation.JacksonAnnotationsInside import com.fasterxml.jackson.annotation.JsonAutoDetect @@ -26,11 +26,11 @@ import com.fasterxml.jackson.databind.node.JsonNodeType.OBJECT import com.fasterxml.jackson.databind.node.JsonNodeType.POJO import com.fasterxml.jackson.databind.node.JsonNodeType.STRING import com.fasterxml.jackson.databind.ser.std.NullSerializer +import com.openlayer.api.errors.OpenlayerInvalidDataException import java.nio.charset.Charset import java.util.Objects import java.util.Optional import org.apache.hc.core5.http.ContentType -import org.openlayer.errors.OpenlayerInvalidDataException @JsonDeserialize(using = JsonField.Deserializer::class) sealed class JsonField { diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/BinaryResponseContent.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/BinaryResponseContent.kt similarity index 50% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/http/BinaryResponseContent.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/BinaryResponseContent.kt index 852939a..79dd3d8 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/BinaryResponseContent.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/BinaryResponseContent.kt @@ -1,13 +1,14 @@ -package org.openlayer.core.http +package com.openlayer.api.core.http -import java.io.Closeable import java.io.IOException import java.io.InputStream import java.io.OutputStream +import java.lang.AutoCloseable +import java.util.Optional -interface BinaryResponseContent : Closeable { +interface BinaryResponseContent : AutoCloseable { - fun contentType(): String? + fun contentType(): Optional fun body(): InputStream diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpClient.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpClient.kt similarity index 69% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpClient.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpClient.kt index 354581b..e6fb4bc 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpClient.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpClient.kt @@ -1,10 +1,10 @@ -package org.openlayer.core.http +package com.openlayer.api.core.http -import java.io.Closeable +import com.openlayer.api.core.RequestOptions +import java.lang.AutoCloseable import java.util.concurrent.CompletableFuture -import org.openlayer.core.RequestOptions -interface HttpClient : Closeable { +interface HttpClient : AutoCloseable { fun execute( request: HttpRequest, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpMethod.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpMethod.kt similarity index 77% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpMethod.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpMethod.kt index 53afed9..f029948 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpMethod.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpMethod.kt @@ -1,4 +1,4 @@ -package org.openlayer.core.http +package com.openlayer.api.core.http enum class HttpMethod { GET, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpRequest.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpRequest.kt similarity index 97% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpRequest.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpRequest.kt index 3f30a60..243c19a 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpRequest.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpRequest.kt @@ -1,10 +1,10 @@ -package org.openlayer.core.http +package com.openlayer.api.core.http import com.google.common.collect.ArrayListMultimap import com.google.common.collect.ListMultimap import com.google.common.collect.Multimap import com.google.common.collect.MultimapBuilder -import org.openlayer.core.toUnmodifiable +import com.openlayer.api.core.toUnmodifiable class HttpRequest private constructor( diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpRequestBody.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpRequestBody.kt similarity index 83% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpRequestBody.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpRequestBody.kt index e85338d..32b5f81 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpRequestBody.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpRequestBody.kt @@ -1,10 +1,10 @@ -package org.openlayer.core.http +package com.openlayer.api.core.http -import java.io.Closeable import java.io.IOException import java.io.OutputStream +import java.lang.AutoCloseable -interface HttpRequestBody : Closeable { +interface HttpRequestBody : AutoCloseable { @Throws(IOException::class) fun writeTo(outputStream: OutputStream) diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpResponse.kt similarity index 70% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpResponse.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpResponse.kt index 8f50461..5c5f3ce 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/HttpResponse.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/HttpResponse.kt @@ -1,10 +1,10 @@ -package org.openlayer.core.http +package com.openlayer.api.core.http import com.google.common.collect.ListMultimap -import java.io.Closeable import java.io.InputStream +import java.lang.AutoCloseable -interface HttpResponse : Closeable { +interface HttpResponse : AutoCloseable { fun statusCode(): Int diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/RetryingHttpClient.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/RetryingHttpClient.kt similarity index 98% rename from openlayer-java-core/src/main/kotlin/org/openlayer/core/http/RetryingHttpClient.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/RetryingHttpClient.kt index 4f33c10..a90d6f4 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/core/http/RetryingHttpClient.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/core/http/RetryingHttpClient.kt @@ -1,8 +1,10 @@ @file:JvmSynthetic -package org.openlayer.core.http +package com.openlayer.api.core.http import com.google.common.util.concurrent.MoreExecutors +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.errors.OpenlayerIoException import java.io.IOException import java.time.Clock import java.time.Duration @@ -19,8 +21,6 @@ import java.util.concurrent.TimeUnit import java.util.function.Function import kotlin.math.min import kotlin.math.pow -import org.openlayer.core.RequestOptions -import org.openlayer.errors.OpenlayerIoException class RetryingHttpClient private constructor( diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/BadRequestException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/BadRequestException.kt similarity index 90% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/BadRequestException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/BadRequestException.kt index 0e7c4a5..f51b5d2 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/BadRequestException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/BadRequestException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors import com.google.common.collect.ListMultimap diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/InternalServerException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/InternalServerException.kt similarity index 91% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/InternalServerException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/InternalServerException.kt index fab7f30..b0c6a67 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/InternalServerException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/InternalServerException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors import com.google.common.collect.ListMultimap diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/NotFoundException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/NotFoundException.kt similarity index 90% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/NotFoundException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/NotFoundException.kt index eaf39a8..9efe856 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/NotFoundException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/NotFoundException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors import com.google.common.collect.ListMultimap diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerError.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerError.kt similarity index 92% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerError.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerError.kt index 0edb21a..59250fe 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerError.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerError.kt @@ -1,14 +1,14 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.errors +package com.openlayer.api.errors import com.fasterxml.jackson.annotation.JsonAnyGetter import com.fasterxml.jackson.annotation.JsonAnySetter import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable import java.util.Objects -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.toUnmodifiable @JsonDeserialize(builder = OpenlayerError.Builder::class) @NoAutoDetect diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerException.kt similarity index 81% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerException.kt index 29dd500..741adba 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors open class OpenlayerException @JvmOverloads diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerInvalidDataException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerInvalidDataException.kt similarity index 82% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerInvalidDataException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerInvalidDataException.kt index aaaaa7f..e576549 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerInvalidDataException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerInvalidDataException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors class OpenlayerInvalidDataException @JvmOverloads diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerIoException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerIoException.kt similarity index 81% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerIoException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerIoException.kt index 4cefedf..23217df 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerIoException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerIoException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors class OpenlayerIoException @JvmOverloads diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerServiceException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerServiceException.kt similarity index 91% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerServiceException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerServiceException.kt index 39024b5..916e4ed 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/OpenlayerServiceException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/OpenlayerServiceException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors import com.google.common.collect.ListMultimap diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/PermissionDeniedException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/PermissionDeniedException.kt similarity index 90% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/PermissionDeniedException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/PermissionDeniedException.kt index 88acfb1..cc7f0d6 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/PermissionDeniedException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/PermissionDeniedException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors import com.google.common.collect.ListMultimap diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/RateLimitException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/RateLimitException.kt similarity index 90% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/RateLimitException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/RateLimitException.kt index 3abc49b..5b83fd0 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/RateLimitException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/RateLimitException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors import com.google.common.collect.ListMultimap diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/UnauthorizedException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/UnauthorizedException.kt similarity index 90% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/UnauthorizedException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/UnauthorizedException.kt index 8e5ea1d..f0e8f0f 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/UnauthorizedException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/UnauthorizedException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors import com.google.common.collect.ListMultimap diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/UnexpectedStatusCodeException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/UnexpectedStatusCodeException.kt similarity index 91% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/UnexpectedStatusCodeException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/UnexpectedStatusCodeException.kt index 083edeb..30e8d3a 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/UnexpectedStatusCodeException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/UnexpectedStatusCodeException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors import com.google.common.collect.ListMultimap diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/UnprocessableEntityException.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/UnprocessableEntityException.kt similarity index 90% rename from openlayer-java-core/src/main/kotlin/org/openlayer/errors/UnprocessableEntityException.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/UnprocessableEntityException.kt index 32c5117..87dba98 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/errors/UnprocessableEntityException.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/errors/UnprocessableEntityException.kt @@ -1,4 +1,4 @@ -package org.openlayer.errors +package com.openlayer.api.errors import com.google.common.collect.ListMultimap diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/CommitTestResultListParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/CommitTestResultListParams.kt similarity index 90% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/CommitTestResultListParams.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/CommitTestResultListParams.kt index 8f36b3d..6b1c3e4 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/CommitTestResultListParams.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/CommitTestResultListParams.kt @@ -1,21 +1,21 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import com.fasterxml.jackson.annotation.JsonCreator +import com.openlayer.api.core.Enum +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import com.openlayer.api.models.* import java.util.Objects import java.util.Optional -import org.openlayer.core.Enum -import org.openlayer.core.JsonField -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.toUnmodifiable -import org.openlayer.errors.OpenlayerInvalidDataException -import org.openlayer.models.* class CommitTestResultListParams constructor( - private val id: String, + private val projectVersionId: String, private val includeArchived: Boolean?, private val page: Long?, private val perPage: Long?, @@ -26,7 +26,7 @@ constructor( private val additionalBodyProperties: Map, ) { - fun id(): String = id + fun projectVersionId(): String = projectVersionId fun includeArchived(): Optional = Optional.ofNullable(includeArchived) @@ -54,7 +54,7 @@ constructor( fun getPathParam(index: Int): String { return when (index) { - 0 -> id + 0 -> projectVersionId else -> "" } } @@ -71,7 +71,7 @@ constructor( } return other is CommitTestResultListParams && - this.id == other.id && + this.projectVersionId == other.projectVersionId && this.includeArchived == other.includeArchived && this.page == other.page && this.perPage == other.perPage && @@ -84,7 +84,7 @@ constructor( override fun hashCode(): Int { return Objects.hash( - id, + projectVersionId, includeArchived, page, perPage, @@ -97,7 +97,7 @@ constructor( } override fun toString() = - "CommitTestResultListParams{id=$id, includeArchived=$includeArchived, page=$page, perPage=$perPage, status=$status, type=$type, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + "CommitTestResultListParams{projectVersionId=$projectVersionId, includeArchived=$includeArchived, page=$page, perPage=$perPage, status=$status, type=$type, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" fun toBuilder() = Builder().from(this) @@ -109,7 +109,7 @@ constructor( @NoAutoDetect class Builder { - private var id: String? = null + private var projectVersionId: String? = null private var includeArchived: Boolean? = null private var page: Long? = null private var perPage: Long? = null @@ -121,7 +121,7 @@ constructor( @JvmSynthetic internal fun from(commitTestResultListParams: CommitTestResultListParams) = apply { - this.id = commitTestResultListParams.id + this.projectVersionId = commitTestResultListParams.projectVersionId this.includeArchived = commitTestResultListParams.includeArchived this.page = commitTestResultListParams.page this.perPage = commitTestResultListParams.perPage @@ -132,7 +132,9 @@ constructor( additionalBodyProperties(commitTestResultListParams.additionalBodyProperties) } - fun id(id: String) = apply { this.id = id } + fun projectVersionId(projectVersionId: String) = apply { + this.projectVersionId = projectVersionId + } /** Include archived goals. */ fun includeArchived(includeArchived: Boolean) = apply { @@ -213,7 +215,7 @@ constructor( fun build(): CommitTestResultListParams = CommitTestResultListParams( - checkNotNull(id) { "`id` is required but was not set" }, + checkNotNull(projectVersionId) { "`projectVersionId` is required but was not set" }, includeArchived, page, perPage, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/CommitTestResultListResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/CommitTestResultListResponse.kt similarity index 99% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/CommitTestResultListResponse.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/CommitTestResultListResponse.kt index 04127f0..731f3b5 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/CommitTestResultListResponse.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/CommitTestResultListResponse.kt @@ -1,6 +1,6 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import com.fasterxml.jackson.annotation.JsonAnyGetter import com.fasterxml.jackson.annotation.JsonAnySetter @@ -13,20 +13,20 @@ import com.fasterxml.jackson.databind.SerializerProvider import com.fasterxml.jackson.databind.annotation.JsonDeserialize import com.fasterxml.jackson.databind.annotation.JsonSerialize import com.fasterxml.jackson.module.kotlin.jacksonTypeRef +import com.openlayer.api.core.BaseDeserializer +import com.openlayer.api.core.BaseSerializer +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.getOrThrow +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException import java.time.OffsetDateTime import java.util.Objects import java.util.Optional -import org.openlayer.core.BaseDeserializer -import org.openlayer.core.BaseSerializer -import org.openlayer.core.Enum -import org.openlayer.core.ExcludeMissing -import org.openlayer.core.JsonField -import org.openlayer.core.JsonMissing -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.getOrThrow -import org.openlayer.core.toUnmodifiable -import org.openlayer.errors.OpenlayerInvalidDataException @JsonDeserialize(builder = CommitTestResultListResponse.Builder::class) @NoAutoDetect diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineDataStreamParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineDataStreamParams.kt similarity index 98% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineDataStreamParams.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineDataStreamParams.kt index 759d243..62d6be9 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineDataStreamParams.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineDataStreamParams.kt @@ -1,6 +1,6 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import com.fasterxml.jackson.annotation.JsonAnyGetter import com.fasterxml.jackson.annotation.JsonAnySetter @@ -12,23 +12,23 @@ import com.fasterxml.jackson.databind.SerializerProvider import com.fasterxml.jackson.databind.annotation.JsonDeserialize import com.fasterxml.jackson.databind.annotation.JsonSerialize import com.fasterxml.jackson.module.kotlin.jacksonTypeRef +import com.openlayer.api.core.BaseDeserializer +import com.openlayer.api.core.BaseSerializer +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.getOrThrow +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import com.openlayer.api.models.* import java.util.Objects import java.util.Optional -import org.openlayer.core.BaseDeserializer -import org.openlayer.core.BaseSerializer -import org.openlayer.core.ExcludeMissing -import org.openlayer.core.JsonField -import org.openlayer.core.JsonMissing -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.getOrThrow -import org.openlayer.core.toUnmodifiable -import org.openlayer.errors.OpenlayerInvalidDataException -import org.openlayer.models.* class InferencePipelineDataStreamParams constructor( - private val id: String, + private val inferencePipelineId: String, private val config: Config, private val rows: List, private val additionalQueryParams: Map>, @@ -36,7 +36,7 @@ constructor( private val additionalBodyProperties: Map, ) { - fun id(): String = id + fun inferencePipelineId(): String = inferencePipelineId fun config(): Config = config @@ -57,7 +57,7 @@ constructor( fun getPathParam(index: Int): String { return when (index) { - 0 -> id + 0 -> inferencePipelineId else -> "" } } @@ -76,7 +76,7 @@ constructor( /** Configuration for the data stream. Depends on your **Openlayer project task type**. */ @JsonProperty("config") fun config(): Config? = config - /** A list of entries that represent rows of a csv file */ + /** A list of inference data points with inputs and outputs */ @JsonProperty("rows") fun rows(): List? = rows @JsonAnyGetter @@ -135,7 +135,7 @@ constructor( */ @JsonProperty("config") fun config(config: Config) = apply { this.config = config } - /** A list of entries that represent rows of a csv file */ + /** A list of inference data points with inputs and outputs */ @JsonProperty("rows") fun rows(rows: List) = apply { this.rows = rows } fun additionalProperties(additionalProperties: Map) = apply { @@ -173,7 +173,7 @@ constructor( } return other is InferencePipelineDataStreamParams && - this.id == other.id && + this.inferencePipelineId == other.inferencePipelineId && this.config == other.config && this.rows == other.rows && this.additionalQueryParams == other.additionalQueryParams && @@ -183,7 +183,7 @@ constructor( override fun hashCode(): Int { return Objects.hash( - id, + inferencePipelineId, config, rows, additionalQueryParams, @@ -193,7 +193,7 @@ constructor( } override fun toString() = - "InferencePipelineDataStreamParams{id=$id, config=$config, rows=$rows, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + "InferencePipelineDataStreamParams{inferencePipelineId=$inferencePipelineId, config=$config, rows=$rows, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" fun toBuilder() = Builder().from(this) @@ -205,7 +205,7 @@ constructor( @NoAutoDetect class Builder { - private var id: String? = null + private var inferencePipelineId: String? = null private var config: Config? = null private var rows: MutableList = mutableListOf() private var additionalQueryParams: MutableMap> = mutableMapOf() @@ -215,7 +215,7 @@ constructor( @JvmSynthetic internal fun from(inferencePipelineDataStreamParams: InferencePipelineDataStreamParams) = apply { - this.id = inferencePipelineDataStreamParams.id + this.inferencePipelineId = inferencePipelineDataStreamParams.inferencePipelineId this.config = inferencePipelineDataStreamParams.config this.rows(inferencePipelineDataStreamParams.rows) additionalQueryParams(inferencePipelineDataStreamParams.additionalQueryParams) @@ -223,7 +223,9 @@ constructor( additionalBodyProperties(inferencePipelineDataStreamParams.additionalBodyProperties) } - fun id(id: String) = apply { this.id = id } + fun inferencePipelineId(inferencePipelineId: String) = apply { + this.inferencePipelineId = inferencePipelineId + } /** Configuration for the data stream. Depends on your **Openlayer project task type**. */ fun config(config: Config) = apply { this.config = config } @@ -246,13 +248,13 @@ constructor( this.config = Config.ofTextClassificationData(textClassificationData) } - /** A list of entries that represent rows of a csv file */ + /** A list of inference data points with inputs and outputs */ fun rows(rows: List) = apply { this.rows.clear() this.rows.addAll(rows) } - /** A list of entries that represent rows of a csv file */ + /** A list of inference data points with inputs and outputs */ fun addRow(row: Row) = apply { this.rows.add(row) } fun additionalQueryParams(additionalQueryParams: Map>) = apply { @@ -311,7 +313,9 @@ constructor( fun build(): InferencePipelineDataStreamParams = InferencePipelineDataStreamParams( - checkNotNull(id) { "`id` is required but was not set" }, + checkNotNull(inferencePipelineId) { + "`inferencePipelineId` is required but was not set" + }, checkNotNull(config) { "`config` is required but was not set" }, checkNotNull(rows) { "`rows` is required but was not set" }.toUnmodifiable(), additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), @@ -1095,7 +1099,7 @@ constructor( /** * Array with the names of all categorical features in the dataset. E.g. - * ["Gender", "Geography"]. + * ["Age", "Geography"]. */ fun categoricalFeatureNames(): Optional> = Optional.ofNullable(categoricalFeatureNames.getNullable("categoricalFeatureNames")) @@ -1149,7 +1153,7 @@ constructor( /** * Array with the names of all categorical features in the dataset. E.g. - * ["Gender", "Geography"]. + * ["Age", "Geography"]. */ @JsonProperty("categoricalFeatureNames") @ExcludeMissing @@ -1308,14 +1312,14 @@ constructor( /** * Array with the names of all categorical features in the dataset. E.g. - * ["Gender", "Geography"]. + * ["Age", "Geography"]. */ fun categoricalFeatureNames(categoricalFeatureNames: List) = categoricalFeatureNames(JsonField.of(categoricalFeatureNames)) /** * Array with the names of all categorical features in the dataset. E.g. - * ["Gender", "Geography"]. + * ["Age", "Geography"]. */ @JsonProperty("categoricalFeatureNames") @ExcludeMissing diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineDataStreamResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineDataStreamResponse.kt similarity index 92% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineDataStreamResponse.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineDataStreamResponse.kt index 3ecfc52..087ceda 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineDataStreamResponse.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineDataStreamResponse.kt @@ -1,21 +1,21 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import com.fasterxml.jackson.annotation.JsonAnyGetter import com.fasterxml.jackson.annotation.JsonAnySetter import com.fasterxml.jackson.annotation.JsonCreator import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException import java.util.Objects -import org.openlayer.core.Enum -import org.openlayer.core.ExcludeMissing -import org.openlayer.core.JsonField -import org.openlayer.core.JsonMissing -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.toUnmodifiable -import org.openlayer.errors.OpenlayerInvalidDataException @JsonDeserialize(builder = InferencePipelineDataStreamResponse.Builder::class) @NoAutoDetect diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineDeleteParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineDeleteParams.kt new file mode 100644 index 0000000..623bef1 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineDeleteParams.kt @@ -0,0 +1,159 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.models.* +import java.util.Objects +import java.util.Optional + +class InferencePipelineDeleteParams +constructor( + private val inferencePipelineId: String, + private val additionalQueryParams: Map>, + private val additionalHeaders: Map>, + private val additionalBodyProperties: Map, +) { + + fun inferencePipelineId(): String = inferencePipelineId + + @JvmSynthetic + internal fun getBody(): Optional> { + return Optional.ofNullable(additionalBodyProperties.ifEmpty { null }) + } + + @JvmSynthetic internal fun getQueryParams(): Map> = additionalQueryParams + + @JvmSynthetic internal fun getHeaders(): Map> = additionalHeaders + + fun getPathParam(index: Int): String { + return when (index) { + 0 -> inferencePipelineId + else -> "" + } + } + + fun _additionalQueryParams(): Map> = additionalQueryParams + + fun _additionalHeaders(): Map> = additionalHeaders + + fun _additionalBodyProperties(): Map = additionalBodyProperties + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is InferencePipelineDeleteParams && + this.inferencePipelineId == other.inferencePipelineId && + this.additionalQueryParams == other.additionalQueryParams && + this.additionalHeaders == other.additionalHeaders && + this.additionalBodyProperties == other.additionalBodyProperties + } + + override fun hashCode(): Int { + return Objects.hash( + inferencePipelineId, + additionalQueryParams, + additionalHeaders, + additionalBodyProperties, + ) + } + + override fun toString() = + "InferencePipelineDeleteParams{inferencePipelineId=$inferencePipelineId, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + + fun toBuilder() = Builder().from(this) + + companion object { + + @JvmStatic fun builder() = Builder() + } + + @NoAutoDetect + class Builder { + + private var inferencePipelineId: String? = null + private var additionalQueryParams: MutableMap> = mutableMapOf() + private var additionalHeaders: MutableMap> = mutableMapOf() + private var additionalBodyProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(inferencePipelineDeleteParams: InferencePipelineDeleteParams) = apply { + this.inferencePipelineId = inferencePipelineDeleteParams.inferencePipelineId + additionalQueryParams(inferencePipelineDeleteParams.additionalQueryParams) + additionalHeaders(inferencePipelineDeleteParams.additionalHeaders) + additionalBodyProperties(inferencePipelineDeleteParams.additionalBodyProperties) + } + + fun inferencePipelineId(inferencePipelineId: String) = apply { + this.inferencePipelineId = inferencePipelineId + } + + fun additionalQueryParams(additionalQueryParams: Map>) = apply { + this.additionalQueryParams.clear() + putAllQueryParams(additionalQueryParams) + } + + fun putQueryParam(name: String, value: String) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putQueryParams(name: String, values: Iterable) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllQueryParams(additionalQueryParams: Map>) = apply { + additionalQueryParams.forEach(this::putQueryParams) + } + + fun removeQueryParam(name: String) = apply { + this.additionalQueryParams.put(name, mutableListOf()) + } + + fun additionalHeaders(additionalHeaders: Map>) = apply { + this.additionalHeaders.clear() + putAllHeaders(additionalHeaders) + } + + fun putHeader(name: String, value: String) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putHeaders(name: String, values: Iterable) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllHeaders(additionalHeaders: Map>) = apply { + additionalHeaders.forEach(this::putHeaders) + } + + fun removeHeader(name: String) = apply { this.additionalHeaders.put(name, mutableListOf()) } + + fun additionalBodyProperties(additionalBodyProperties: Map) = apply { + this.additionalBodyProperties.clear() + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun putAdditionalBodyProperty(key: String, value: JsonValue) = apply { + this.additionalBodyProperties.put(key, value) + } + + fun putAllAdditionalBodyProperties(additionalBodyProperties: Map) = + apply { + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun build(): InferencePipelineDeleteParams = + InferencePipelineDeleteParams( + checkNotNull(inferencePipelineId) { + "`inferencePipelineId` is required but was not set" + }, + additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalHeaders.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalBodyProperties.toUnmodifiable(), + ) + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRetrieveParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRetrieveParams.kt new file mode 100644 index 0000000..1b2409f --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRetrieveParams.kt @@ -0,0 +1,154 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.models.* +import java.util.Objects + +class InferencePipelineRetrieveParams +constructor( + private val inferencePipelineId: String, + private val additionalQueryParams: Map>, + private val additionalHeaders: Map>, + private val additionalBodyProperties: Map, +) { + + fun inferencePipelineId(): String = inferencePipelineId + + @JvmSynthetic internal fun getQueryParams(): Map> = additionalQueryParams + + @JvmSynthetic internal fun getHeaders(): Map> = additionalHeaders + + fun getPathParam(index: Int): String { + return when (index) { + 0 -> inferencePipelineId + else -> "" + } + } + + fun _additionalQueryParams(): Map> = additionalQueryParams + + fun _additionalHeaders(): Map> = additionalHeaders + + fun _additionalBodyProperties(): Map = additionalBodyProperties + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is InferencePipelineRetrieveParams && + this.inferencePipelineId == other.inferencePipelineId && + this.additionalQueryParams == other.additionalQueryParams && + this.additionalHeaders == other.additionalHeaders && + this.additionalBodyProperties == other.additionalBodyProperties + } + + override fun hashCode(): Int { + return Objects.hash( + inferencePipelineId, + additionalQueryParams, + additionalHeaders, + additionalBodyProperties, + ) + } + + override fun toString() = + "InferencePipelineRetrieveParams{inferencePipelineId=$inferencePipelineId, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + + fun toBuilder() = Builder().from(this) + + companion object { + + @JvmStatic fun builder() = Builder() + } + + @NoAutoDetect + class Builder { + + private var inferencePipelineId: String? = null + private var additionalQueryParams: MutableMap> = mutableMapOf() + private var additionalHeaders: MutableMap> = mutableMapOf() + private var additionalBodyProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(inferencePipelineRetrieveParams: InferencePipelineRetrieveParams) = + apply { + this.inferencePipelineId = inferencePipelineRetrieveParams.inferencePipelineId + additionalQueryParams(inferencePipelineRetrieveParams.additionalQueryParams) + additionalHeaders(inferencePipelineRetrieveParams.additionalHeaders) + additionalBodyProperties(inferencePipelineRetrieveParams.additionalBodyProperties) + } + + fun inferencePipelineId(inferencePipelineId: String) = apply { + this.inferencePipelineId = inferencePipelineId + } + + fun additionalQueryParams(additionalQueryParams: Map>) = apply { + this.additionalQueryParams.clear() + putAllQueryParams(additionalQueryParams) + } + + fun putQueryParam(name: String, value: String) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putQueryParams(name: String, values: Iterable) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllQueryParams(additionalQueryParams: Map>) = apply { + additionalQueryParams.forEach(this::putQueryParams) + } + + fun removeQueryParam(name: String) = apply { + this.additionalQueryParams.put(name, mutableListOf()) + } + + fun additionalHeaders(additionalHeaders: Map>) = apply { + this.additionalHeaders.clear() + putAllHeaders(additionalHeaders) + } + + fun putHeader(name: String, value: String) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putHeaders(name: String, values: Iterable) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllHeaders(additionalHeaders: Map>) = apply { + additionalHeaders.forEach(this::putHeaders) + } + + fun removeHeader(name: String) = apply { this.additionalHeaders.put(name, mutableListOf()) } + + fun additionalBodyProperties(additionalBodyProperties: Map) = apply { + this.additionalBodyProperties.clear() + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun putAdditionalBodyProperty(key: String, value: JsonValue) = apply { + this.additionalBodyProperties.put(key, value) + } + + fun putAllAdditionalBodyProperties(additionalBodyProperties: Map) = + apply { + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun build(): InferencePipelineRetrieveParams = + InferencePipelineRetrieveParams( + checkNotNull(inferencePipelineId) { + "`inferencePipelineId` is required but was not set" + }, + additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalHeaders.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalBodyProperties.toUnmodifiable(), + ) + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRetrieveResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRetrieveResponse.kt new file mode 100644 index 0000000..95ec229 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRetrieveResponse.kt @@ -0,0 +1,612 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.fasterxml.jackson.annotation.JsonAnyGetter +import com.fasterxml.jackson.annotation.JsonAnySetter +import com.fasterxml.jackson.annotation.JsonCreator +import com.fasterxml.jackson.annotation.JsonProperty +import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import java.time.OffsetDateTime +import java.util.Objects +import java.util.Optional + +@JsonDeserialize(builder = InferencePipelineRetrieveResponse.Builder::class) +@NoAutoDetect +class InferencePipelineRetrieveResponse +private constructor( + private val id: JsonField, + private val projectId: JsonField, + private val name: JsonField, + private val dateCreated: JsonField, + private val dateUpdated: JsonField, + private val dateLastSampleReceived: JsonField, + private val description: JsonField, + private val dateLastEvaluated: JsonField, + private val dateOfNextEvaluation: JsonField, + private val passingGoalCount: JsonField, + private val failingGoalCount: JsonField, + private val totalGoalCount: JsonField, + private val status: JsonField, + private val statusMessage: JsonField, + private val links: JsonField, + private val additionalProperties: Map, +) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + /** The inference pipeline id. */ + fun id(): String = id.getRequired("id") + + /** The project id. */ + fun projectId(): String = projectId.getRequired("projectId") + + /** The inference pipeline name. */ + fun name(): String = name.getRequired("name") + + /** The creation date. */ + fun dateCreated(): OffsetDateTime = dateCreated.getRequired("dateCreated") + + /** The last updated date. */ + fun dateUpdated(): OffsetDateTime = dateUpdated.getRequired("dateUpdated") + + /** The last data sample received date. */ + fun dateLastSampleReceived(): Optional = + Optional.ofNullable(dateLastSampleReceived.getNullable("dateLastSampleReceived")) + + /** The inference pipeline description. */ + fun description(): Optional = + Optional.ofNullable(description.getNullable("description")) + + /** The last test evaluation date. */ + fun dateLastEvaluated(): Optional = + Optional.ofNullable(dateLastEvaluated.getNullable("dateLastEvaluated")) + + /** The next test evaluation date. */ + fun dateOfNextEvaluation(): Optional = + Optional.ofNullable(dateOfNextEvaluation.getNullable("dateOfNextEvaluation")) + + /** The number of tests passing. */ + fun passingGoalCount(): Long = passingGoalCount.getRequired("passingGoalCount") + + /** The number of tests failing. */ + fun failingGoalCount(): Long = failingGoalCount.getRequired("failingGoalCount") + + /** The total number of tests. */ + fun totalGoalCount(): Long = totalGoalCount.getRequired("totalGoalCount") + + /** The status of test evaluation for the inference pipeline. */ + fun status(): Status = status.getRequired("status") + + /** The status message of test evaluation for the inference pipeline. */ + fun statusMessage(): Optional = + Optional.ofNullable(statusMessage.getNullable("statusMessage")) + + fun links(): Links = links.getRequired("links") + + /** The inference pipeline id. */ + @JsonProperty("id") @ExcludeMissing fun _id() = id + + /** The project id. */ + @JsonProperty("projectId") @ExcludeMissing fun _projectId() = projectId + + /** The inference pipeline name. */ + @JsonProperty("name") @ExcludeMissing fun _name() = name + + /** The creation date. */ + @JsonProperty("dateCreated") @ExcludeMissing fun _dateCreated() = dateCreated + + /** The last updated date. */ + @JsonProperty("dateUpdated") @ExcludeMissing fun _dateUpdated() = dateUpdated + + /** The last data sample received date. */ + @JsonProperty("dateLastSampleReceived") + @ExcludeMissing + fun _dateLastSampleReceived() = dateLastSampleReceived + + /** The inference pipeline description. */ + @JsonProperty("description") @ExcludeMissing fun _description() = description + + /** The last test evaluation date. */ + @JsonProperty("dateLastEvaluated") @ExcludeMissing fun _dateLastEvaluated() = dateLastEvaluated + + /** The next test evaluation date. */ + @JsonProperty("dateOfNextEvaluation") + @ExcludeMissing + fun _dateOfNextEvaluation() = dateOfNextEvaluation + + /** The number of tests passing. */ + @JsonProperty("passingGoalCount") @ExcludeMissing fun _passingGoalCount() = passingGoalCount + + /** The number of tests failing. */ + @JsonProperty("failingGoalCount") @ExcludeMissing fun _failingGoalCount() = failingGoalCount + + /** The total number of tests. */ + @JsonProperty("totalGoalCount") @ExcludeMissing fun _totalGoalCount() = totalGoalCount + + /** The status of test evaluation for the inference pipeline. */ + @JsonProperty("status") @ExcludeMissing fun _status() = status + + /** The status message of test evaluation for the inference pipeline. */ + @JsonProperty("statusMessage") @ExcludeMissing fun _statusMessage() = statusMessage + + @JsonProperty("links") @ExcludeMissing fun _links() = links + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): InferencePipelineRetrieveResponse = apply { + if (!validated) { + id() + projectId() + name() + dateCreated() + dateUpdated() + dateLastSampleReceived() + description() + dateLastEvaluated() + dateOfNextEvaluation() + passingGoalCount() + failingGoalCount() + totalGoalCount() + status() + statusMessage() + links().validate() + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is InferencePipelineRetrieveResponse && + this.id == other.id && + this.projectId == other.projectId && + this.name == other.name && + this.dateCreated == other.dateCreated && + this.dateUpdated == other.dateUpdated && + this.dateLastSampleReceived == other.dateLastSampleReceived && + this.description == other.description && + this.dateLastEvaluated == other.dateLastEvaluated && + this.dateOfNextEvaluation == other.dateOfNextEvaluation && + this.passingGoalCount == other.passingGoalCount && + this.failingGoalCount == other.failingGoalCount && + this.totalGoalCount == other.totalGoalCount && + this.status == other.status && + this.statusMessage == other.statusMessage && + this.links == other.links && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + id, + projectId, + name, + dateCreated, + dateUpdated, + dateLastSampleReceived, + description, + dateLastEvaluated, + dateOfNextEvaluation, + passingGoalCount, + failingGoalCount, + totalGoalCount, + status, + statusMessage, + links, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "InferencePipelineRetrieveResponse{id=$id, projectId=$projectId, name=$name, dateCreated=$dateCreated, dateUpdated=$dateUpdated, dateLastSampleReceived=$dateLastSampleReceived, description=$description, dateLastEvaluated=$dateLastEvaluated, dateOfNextEvaluation=$dateOfNextEvaluation, passingGoalCount=$passingGoalCount, failingGoalCount=$failingGoalCount, totalGoalCount=$totalGoalCount, status=$status, statusMessage=$statusMessage, links=$links, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var id: JsonField = JsonMissing.of() + private var projectId: JsonField = JsonMissing.of() + private var name: JsonField = JsonMissing.of() + private var dateCreated: JsonField = JsonMissing.of() + private var dateUpdated: JsonField = JsonMissing.of() + private var dateLastSampleReceived: JsonField = JsonMissing.of() + private var description: JsonField = JsonMissing.of() + private var dateLastEvaluated: JsonField = JsonMissing.of() + private var dateOfNextEvaluation: JsonField = JsonMissing.of() + private var passingGoalCount: JsonField = JsonMissing.of() + private var failingGoalCount: JsonField = JsonMissing.of() + private var totalGoalCount: JsonField = JsonMissing.of() + private var status: JsonField = JsonMissing.of() + private var statusMessage: JsonField = JsonMissing.of() + private var links: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(inferencePipelineRetrieveResponse: InferencePipelineRetrieveResponse) = + apply { + this.id = inferencePipelineRetrieveResponse.id + this.projectId = inferencePipelineRetrieveResponse.projectId + this.name = inferencePipelineRetrieveResponse.name + this.dateCreated = inferencePipelineRetrieveResponse.dateCreated + this.dateUpdated = inferencePipelineRetrieveResponse.dateUpdated + this.dateLastSampleReceived = + inferencePipelineRetrieveResponse.dateLastSampleReceived + this.description = inferencePipelineRetrieveResponse.description + this.dateLastEvaluated = inferencePipelineRetrieveResponse.dateLastEvaluated + this.dateOfNextEvaluation = inferencePipelineRetrieveResponse.dateOfNextEvaluation + this.passingGoalCount = inferencePipelineRetrieveResponse.passingGoalCount + this.failingGoalCount = inferencePipelineRetrieveResponse.failingGoalCount + this.totalGoalCount = inferencePipelineRetrieveResponse.totalGoalCount + this.status = inferencePipelineRetrieveResponse.status + this.statusMessage = inferencePipelineRetrieveResponse.statusMessage + this.links = inferencePipelineRetrieveResponse.links + additionalProperties(inferencePipelineRetrieveResponse.additionalProperties) + } + + /** The inference pipeline id. */ + fun id(id: String) = id(JsonField.of(id)) + + /** The inference pipeline id. */ + @JsonProperty("id") @ExcludeMissing fun id(id: JsonField) = apply { this.id = id } + + /** The project id. */ + fun projectId(projectId: String) = projectId(JsonField.of(projectId)) + + /** The project id. */ + @JsonProperty("projectId") + @ExcludeMissing + fun projectId(projectId: JsonField) = apply { this.projectId = projectId } + + /** The inference pipeline name. */ + fun name(name: String) = name(JsonField.of(name)) + + /** The inference pipeline name. */ + @JsonProperty("name") + @ExcludeMissing + fun name(name: JsonField) = apply { this.name = name } + + /** The creation date. */ + fun dateCreated(dateCreated: OffsetDateTime) = dateCreated(JsonField.of(dateCreated)) + + /** The creation date. */ + @JsonProperty("dateCreated") + @ExcludeMissing + fun dateCreated(dateCreated: JsonField) = apply { + this.dateCreated = dateCreated + } + + /** The last updated date. */ + fun dateUpdated(dateUpdated: OffsetDateTime) = dateUpdated(JsonField.of(dateUpdated)) + + /** The last updated date. */ + @JsonProperty("dateUpdated") + @ExcludeMissing + fun dateUpdated(dateUpdated: JsonField) = apply { + this.dateUpdated = dateUpdated + } + + /** The last data sample received date. */ + fun dateLastSampleReceived(dateLastSampleReceived: OffsetDateTime) = + dateLastSampleReceived(JsonField.of(dateLastSampleReceived)) + + /** The last data sample received date. */ + @JsonProperty("dateLastSampleReceived") + @ExcludeMissing + fun dateLastSampleReceived(dateLastSampleReceived: JsonField) = apply { + this.dateLastSampleReceived = dateLastSampleReceived + } + + /** The inference pipeline description. */ + fun description(description: String) = description(JsonField.of(description)) + + /** The inference pipeline description. */ + @JsonProperty("description") + @ExcludeMissing + fun description(description: JsonField) = apply { this.description = description } + + /** The last test evaluation date. */ + fun dateLastEvaluated(dateLastEvaluated: OffsetDateTime) = + dateLastEvaluated(JsonField.of(dateLastEvaluated)) + + /** The last test evaluation date. */ + @JsonProperty("dateLastEvaluated") + @ExcludeMissing + fun dateLastEvaluated(dateLastEvaluated: JsonField) = apply { + this.dateLastEvaluated = dateLastEvaluated + } + + /** The next test evaluation date. */ + fun dateOfNextEvaluation(dateOfNextEvaluation: OffsetDateTime) = + dateOfNextEvaluation(JsonField.of(dateOfNextEvaluation)) + + /** The next test evaluation date. */ + @JsonProperty("dateOfNextEvaluation") + @ExcludeMissing + fun dateOfNextEvaluation(dateOfNextEvaluation: JsonField) = apply { + this.dateOfNextEvaluation = dateOfNextEvaluation + } + + /** The number of tests passing. */ + fun passingGoalCount(passingGoalCount: Long) = + passingGoalCount(JsonField.of(passingGoalCount)) + + /** The number of tests passing. */ + @JsonProperty("passingGoalCount") + @ExcludeMissing + fun passingGoalCount(passingGoalCount: JsonField) = apply { + this.passingGoalCount = passingGoalCount + } + + /** The number of tests failing. */ + fun failingGoalCount(failingGoalCount: Long) = + failingGoalCount(JsonField.of(failingGoalCount)) + + /** The number of tests failing. */ + @JsonProperty("failingGoalCount") + @ExcludeMissing + fun failingGoalCount(failingGoalCount: JsonField) = apply { + this.failingGoalCount = failingGoalCount + } + + /** The total number of tests. */ + fun totalGoalCount(totalGoalCount: Long) = totalGoalCount(JsonField.of(totalGoalCount)) + + /** The total number of tests. */ + @JsonProperty("totalGoalCount") + @ExcludeMissing + fun totalGoalCount(totalGoalCount: JsonField) = apply { + this.totalGoalCount = totalGoalCount + } + + /** The status of test evaluation for the inference pipeline. */ + fun status(status: Status) = status(JsonField.of(status)) + + /** The status of test evaluation for the inference pipeline. */ + @JsonProperty("status") + @ExcludeMissing + fun status(status: JsonField) = apply { this.status = status } + + /** The status message of test evaluation for the inference pipeline. */ + fun statusMessage(statusMessage: String) = statusMessage(JsonField.of(statusMessage)) + + /** The status message of test evaluation for the inference pipeline. */ + @JsonProperty("statusMessage") + @ExcludeMissing + fun statusMessage(statusMessage: JsonField) = apply { + this.statusMessage = statusMessage + } + + fun links(links: Links) = links(JsonField.of(links)) + + @JsonProperty("links") + @ExcludeMissing + fun links(links: JsonField) = apply { this.links = links } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): InferencePipelineRetrieveResponse = + InferencePipelineRetrieveResponse( + id, + projectId, + name, + dateCreated, + dateUpdated, + dateLastSampleReceived, + description, + dateLastEvaluated, + dateOfNextEvaluation, + passingGoalCount, + failingGoalCount, + totalGoalCount, + status, + statusMessage, + links, + additionalProperties.toUnmodifiable(), + ) + } + + @JsonDeserialize(builder = Links.Builder::class) + @NoAutoDetect + class Links + private constructor( + private val app: JsonField, + private val additionalProperties: Map, + ) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + fun app(): String = app.getRequired("app") + + @JsonProperty("app") @ExcludeMissing fun _app() = app + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): Links = apply { + if (!validated) { + app() + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Links && + this.app == other.app && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = Objects.hash(app, additionalProperties) + } + return hashCode + } + + override fun toString() = "Links{app=$app, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var app: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(links: Links) = apply { + this.app = links.app + additionalProperties(links.additionalProperties) + } + + fun app(app: String) = app(JsonField.of(app)) + + @JsonProperty("app") + @ExcludeMissing + fun app(app: JsonField) = apply { this.app = app } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): Links = Links(app, additionalProperties.toUnmodifiable()) + } + } + + class Status + @JsonCreator + private constructor( + private val value: JsonField, + ) : Enum { + + @com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Status && this.value == other.value + } + + override fun hashCode() = value.hashCode() + + override fun toString() = value.toString() + + companion object { + + @JvmField val QUEUED = Status(JsonField.of("queued")) + + @JvmField val RUNNING = Status(JsonField.of("running")) + + @JvmField val PAUSED = Status(JsonField.of("paused")) + + @JvmField val FAILED = Status(JsonField.of("failed")) + + @JvmField val COMPLETED = Status(JsonField.of("completed")) + + @JvmField val UNKNOWN = Status(JsonField.of("unknown")) + + @JvmStatic fun of(value: String) = Status(JsonField.of(value)) + } + + enum class Known { + QUEUED, + RUNNING, + PAUSED, + FAILED, + COMPLETED, + UNKNOWN, + } + + enum class Value { + QUEUED, + RUNNING, + PAUSED, + FAILED, + COMPLETED, + UNKNOWN, + _UNKNOWN, + } + + fun value(): Value = + when (this) { + QUEUED -> Value.QUEUED + RUNNING -> Value.RUNNING + PAUSED -> Value.PAUSED + FAILED -> Value.FAILED + COMPLETED -> Value.COMPLETED + UNKNOWN -> Value.UNKNOWN + else -> Value._UNKNOWN + } + + fun known(): Known = + when (this) { + QUEUED -> Known.QUEUED + RUNNING -> Known.RUNNING + PAUSED -> Known.PAUSED + FAILED -> Known.FAILED + COMPLETED -> Known.COMPLETED + UNKNOWN -> Known.UNKNOWN + else -> throw OpenlayerInvalidDataException("Unknown Status: $value") + } + + fun asString(): String = _value().asStringOrThrow() + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateParams.kt new file mode 100644 index 0000000..a8072f9 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateParams.kt @@ -0,0 +1,462 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.fasterxml.jackson.annotation.JsonAnyGetter +import com.fasterxml.jackson.annotation.JsonAnySetter +import com.fasterxml.jackson.annotation.JsonProperty +import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.models.* +import java.util.Objects +import java.util.Optional + +class InferencePipelineRowUpdateParams +constructor( + private val inferencePipelineId: String, + private val inferenceId: String, + private val row: JsonValue, + private val config: Config?, + private val additionalQueryParams: Map>, + private val additionalHeaders: Map>, + private val additionalBodyProperties: Map, +) { + + fun inferencePipelineId(): String = inferencePipelineId + + fun inferenceId(): String = inferenceId + + fun row(): JsonValue = row + + fun config(): Optional = Optional.ofNullable(config) + + @JvmSynthetic + internal fun getBody(): InferencePipelineRowUpdateBody { + return InferencePipelineRowUpdateBody( + row, + config, + additionalBodyProperties, + ) + } + + @JvmSynthetic + internal fun getQueryParams(): Map> { + val params = mutableMapOf>() + this.inferenceId.let { params.put("inferenceId", listOf(it.toString())) } + params.putAll(additionalQueryParams) + return params.toUnmodifiable() + } + + @JvmSynthetic internal fun getHeaders(): Map> = additionalHeaders + + fun getPathParam(index: Int): String { + return when (index) { + 0 -> inferencePipelineId + else -> "" + } + } + + @JsonDeserialize(builder = InferencePipelineRowUpdateBody.Builder::class) + @NoAutoDetect + class InferencePipelineRowUpdateBody + internal constructor( + private val row: JsonValue?, + private val config: Config?, + private val additionalProperties: Map, + ) { + + private var hashCode: Int = 0 + + @JsonProperty("row") fun row(): JsonValue? = row + + @JsonProperty("config") fun config(): Config? = config + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is InferencePipelineRowUpdateBody && + this.row == other.row && + this.config == other.config && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + row, + config, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "InferencePipelineRowUpdateBody{row=$row, config=$config, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var row: JsonValue? = null + private var config: Config? = null + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(inferencePipelineRowUpdateBody: InferencePipelineRowUpdateBody) = + apply { + this.row = inferencePipelineRowUpdateBody.row + this.config = inferencePipelineRowUpdateBody.config + additionalProperties(inferencePipelineRowUpdateBody.additionalProperties) + } + + @JsonProperty("row") fun row(row: JsonValue) = apply { this.row = row } + + @JsonProperty("config") fun config(config: Config) = apply { this.config = config } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): InferencePipelineRowUpdateBody = + InferencePipelineRowUpdateBody( + checkNotNull(row) { "`row` is required but was not set" }, + config, + additionalProperties.toUnmodifiable(), + ) + } + } + + fun _additionalQueryParams(): Map> = additionalQueryParams + + fun _additionalHeaders(): Map> = additionalHeaders + + fun _additionalBodyProperties(): Map = additionalBodyProperties + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is InferencePipelineRowUpdateParams && + this.inferencePipelineId == other.inferencePipelineId && + this.row == other.row && + this.config == other.config && + this.inferenceId == other.inferenceId && + this.additionalQueryParams == other.additionalQueryParams && + this.additionalHeaders == other.additionalHeaders && + this.additionalBodyProperties == other.additionalBodyProperties + } + + override fun hashCode(): Int { + return Objects.hash( + inferencePipelineId, + row, + config, + inferenceId, + additionalQueryParams, + additionalHeaders, + additionalBodyProperties, + ) + } + + override fun toString() = + "InferencePipelineRowUpdateParams{inferencePipelineId=$inferencePipelineId, row=$row, config=$config, inferenceId=$inferenceId, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + + fun toBuilder() = Builder().from(this) + + companion object { + + @JvmStatic fun builder() = Builder() + } + + @NoAutoDetect + class Builder { + + private var inferencePipelineId: String? = null + private var inferenceId: String? = null + private var row: JsonValue? = null + private var config: Config? = null + private var additionalQueryParams: MutableMap> = mutableMapOf() + private var additionalHeaders: MutableMap> = mutableMapOf() + private var additionalBodyProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(inferencePipelineRowUpdateParams: InferencePipelineRowUpdateParams) = + apply { + this.inferencePipelineId = inferencePipelineRowUpdateParams.inferencePipelineId + this.inferenceId = inferencePipelineRowUpdateParams.inferenceId + this.row = inferencePipelineRowUpdateParams.row + this.config = inferencePipelineRowUpdateParams.config + additionalQueryParams(inferencePipelineRowUpdateParams.additionalQueryParams) + additionalHeaders(inferencePipelineRowUpdateParams.additionalHeaders) + additionalBodyProperties(inferencePipelineRowUpdateParams.additionalBodyProperties) + } + + fun inferencePipelineId(inferencePipelineId: String) = apply { + this.inferencePipelineId = inferencePipelineId + } + + /** Specify the inference id as a query param. */ + fun inferenceId(inferenceId: String) = apply { this.inferenceId = inferenceId } + + fun row(row: JsonValue) = apply { this.row = row } + + fun config(config: Config) = apply { this.config = config } + + fun additionalQueryParams(additionalQueryParams: Map>) = apply { + this.additionalQueryParams.clear() + putAllQueryParams(additionalQueryParams) + } + + fun putQueryParam(name: String, value: String) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putQueryParams(name: String, values: Iterable) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllQueryParams(additionalQueryParams: Map>) = apply { + additionalQueryParams.forEach(this::putQueryParams) + } + + fun removeQueryParam(name: String) = apply { + this.additionalQueryParams.put(name, mutableListOf()) + } + + fun additionalHeaders(additionalHeaders: Map>) = apply { + this.additionalHeaders.clear() + putAllHeaders(additionalHeaders) + } + + fun putHeader(name: String, value: String) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putHeaders(name: String, values: Iterable) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllHeaders(additionalHeaders: Map>) = apply { + additionalHeaders.forEach(this::putHeaders) + } + + fun removeHeader(name: String) = apply { this.additionalHeaders.put(name, mutableListOf()) } + + fun additionalBodyProperties(additionalBodyProperties: Map) = apply { + this.additionalBodyProperties.clear() + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun putAdditionalBodyProperty(key: String, value: JsonValue) = apply { + this.additionalBodyProperties.put(key, value) + } + + fun putAllAdditionalBodyProperties(additionalBodyProperties: Map) = + apply { + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun build(): InferencePipelineRowUpdateParams = + InferencePipelineRowUpdateParams( + checkNotNull(inferencePipelineId) { + "`inferencePipelineId` is required but was not set" + }, + checkNotNull(inferenceId) { "`inferenceId` is required but was not set" }, + checkNotNull(row) { "`row` is required but was not set" }, + config, + additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalHeaders.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalBodyProperties.toUnmodifiable(), + ) + } + + @JsonDeserialize(builder = Config.Builder::class) + @NoAutoDetect + class Config + private constructor( + private val inferenceIdColumnName: String?, + private val latencyColumnName: String?, + private val timestampColumnName: String?, + private val groundTruthColumnName: String?, + private val humanFeedbackColumnName: String?, + private val additionalProperties: Map, + ) { + + private var hashCode: Int = 0 + + /** + * Name of the column with the inference ids. This is useful if you want to update rows at a + * later point in time. If not provided, a unique id is generated by Openlayer. + */ + @JsonProperty("inferenceIdColumnName") + fun inferenceIdColumnName(): String? = inferenceIdColumnName + + /** Name of the column with the latencies. */ + @JsonProperty("latencyColumnName") fun latencyColumnName(): String? = latencyColumnName + + /** + * Name of the column with the timestamps. Timestamps must be in UNIX sec format. If not + * provided, the upload timestamp is used. + */ + @JsonProperty("timestampColumnName") + fun timestampColumnName(): String? = timestampColumnName + + /** Name of the column with the ground truths. */ + @JsonProperty("groundTruthColumnName") + fun groundTruthColumnName(): String? = groundTruthColumnName + + /** Name of the column with human feedback. */ + @JsonProperty("humanFeedbackColumnName") + fun humanFeedbackColumnName(): String? = humanFeedbackColumnName + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Config && + this.inferenceIdColumnName == other.inferenceIdColumnName && + this.latencyColumnName == other.latencyColumnName && + this.timestampColumnName == other.timestampColumnName && + this.groundTruthColumnName == other.groundTruthColumnName && + this.humanFeedbackColumnName == other.humanFeedbackColumnName && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + inferenceIdColumnName, + latencyColumnName, + timestampColumnName, + groundTruthColumnName, + humanFeedbackColumnName, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "Config{inferenceIdColumnName=$inferenceIdColumnName, latencyColumnName=$latencyColumnName, timestampColumnName=$timestampColumnName, groundTruthColumnName=$groundTruthColumnName, humanFeedbackColumnName=$humanFeedbackColumnName, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var inferenceIdColumnName: String? = null + private var latencyColumnName: String? = null + private var timestampColumnName: String? = null + private var groundTruthColumnName: String? = null + private var humanFeedbackColumnName: String? = null + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(config: Config) = apply { + this.inferenceIdColumnName = config.inferenceIdColumnName + this.latencyColumnName = config.latencyColumnName + this.timestampColumnName = config.timestampColumnName + this.groundTruthColumnName = config.groundTruthColumnName + this.humanFeedbackColumnName = config.humanFeedbackColumnName + additionalProperties(config.additionalProperties) + } + + /** + * Name of the column with the inference ids. This is useful if you want to update rows + * at a later point in time. If not provided, a unique id is generated by Openlayer. + */ + @JsonProperty("inferenceIdColumnName") + fun inferenceIdColumnName(inferenceIdColumnName: String) = apply { + this.inferenceIdColumnName = inferenceIdColumnName + } + + /** Name of the column with the latencies. */ + @JsonProperty("latencyColumnName") + fun latencyColumnName(latencyColumnName: String) = apply { + this.latencyColumnName = latencyColumnName + } + + /** + * Name of the column with the timestamps. Timestamps must be in UNIX sec format. If not + * provided, the upload timestamp is used. + */ + @JsonProperty("timestampColumnName") + fun timestampColumnName(timestampColumnName: String) = apply { + this.timestampColumnName = timestampColumnName + } + + /** Name of the column with the ground truths. */ + @JsonProperty("groundTruthColumnName") + fun groundTruthColumnName(groundTruthColumnName: String) = apply { + this.groundTruthColumnName = groundTruthColumnName + } + + /** Name of the column with human feedback. */ + @JsonProperty("humanFeedbackColumnName") + fun humanFeedbackColumnName(humanFeedbackColumnName: String) = apply { + this.humanFeedbackColumnName = humanFeedbackColumnName + } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): Config = + Config( + inferenceIdColumnName, + latencyColumnName, + timestampColumnName, + groundTruthColumnName, + humanFeedbackColumnName, + additionalProperties.toUnmodifiable(), + ) + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateResponse.kt new file mode 100644 index 0000000..35e877e --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateResponse.kt @@ -0,0 +1,160 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.fasterxml.jackson.annotation.JsonAnyGetter +import com.fasterxml.jackson.annotation.JsonAnySetter +import com.fasterxml.jackson.annotation.JsonCreator +import com.fasterxml.jackson.annotation.JsonProperty +import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import java.util.Objects + +@JsonDeserialize(builder = InferencePipelineRowUpdateResponse.Builder::class) +@NoAutoDetect +class InferencePipelineRowUpdateResponse +private constructor( + private val success: JsonField, + private val additionalProperties: Map, +) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + fun success(): Success = success.getRequired("success") + + @JsonProperty("success") @ExcludeMissing fun _success() = success + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): InferencePipelineRowUpdateResponse = apply { + if (!validated) { + success() + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is InferencePipelineRowUpdateResponse && + this.success == other.success && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = Objects.hash(success, additionalProperties) + } + return hashCode + } + + override fun toString() = + "InferencePipelineRowUpdateResponse{success=$success, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var success: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(inferencePipelineRowUpdateResponse: InferencePipelineRowUpdateResponse) = + apply { + this.success = inferencePipelineRowUpdateResponse.success + additionalProperties(inferencePipelineRowUpdateResponse.additionalProperties) + } + + fun success(success: Success) = success(JsonField.of(success)) + + @JsonProperty("success") + @ExcludeMissing + fun success(success: JsonField) = apply { this.success = success } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): InferencePipelineRowUpdateResponse = + InferencePipelineRowUpdateResponse(success, additionalProperties.toUnmodifiable()) + } + + class Success + @JsonCreator + private constructor( + private val value: JsonField, + ) : Enum { + + @com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Success && this.value == other.value + } + + override fun hashCode() = value.hashCode() + + override fun toString() = value.toString() + + companion object { + + @JvmField val TRUE = Success(JsonField.of(true)) + + @JvmStatic fun of(value: Boolean) = Success(JsonField.of(value)) + } + + enum class Known { + TRUE, + } + + enum class Value { + TRUE, + _UNKNOWN, + } + + fun value(): Value = + when (this) { + TRUE -> Value.TRUE + else -> Value._UNKNOWN + } + + fun known(): Known = + when (this) { + TRUE -> Known.TRUE + else -> throw OpenlayerInvalidDataException("Unknown Success: $value") + } + + fun asString(): String = _value().asStringOrThrow() + } +} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineTestResultListParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineTestResultListParams.kt similarity index 89% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineTestResultListParams.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineTestResultListParams.kt index 36afe62..e82d5a1 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineTestResultListParams.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineTestResultListParams.kt @@ -1,22 +1,21 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import com.fasterxml.jackson.annotation.JsonCreator +import com.openlayer.api.core.Enum +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import com.openlayer.api.models.* import java.util.Objects import java.util.Optional -import org.openlayer.core.Enum -import org.openlayer.core.JsonField -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.toUnmodifiable -import org.openlayer.errors.OpenlayerInvalidDataException -import org.openlayer.models.* class InferencePipelineTestResultListParams constructor( - private val id: String, - private val includeArchived: Boolean?, + private val inferencePipelineId: String, private val page: Long?, private val perPage: Long?, private val status: Status?, @@ -26,9 +25,7 @@ constructor( private val additionalBodyProperties: Map, ) { - fun id(): String = id - - fun includeArchived(): Optional = Optional.ofNullable(includeArchived) + fun inferencePipelineId(): String = inferencePipelineId fun page(): Optional = Optional.ofNullable(page) @@ -41,7 +38,6 @@ constructor( @JvmSynthetic internal fun getQueryParams(): Map> { val params = mutableMapOf>() - this.includeArchived?.let { params.put("includeArchived", listOf(it.toString())) } this.page?.let { params.put("page", listOf(it.toString())) } this.perPage?.let { params.put("perPage", listOf(it.toString())) } this.status?.let { params.put("status", listOf(it.toString())) } @@ -54,7 +50,7 @@ constructor( fun getPathParam(index: Int): String { return when (index) { - 0 -> id + 0 -> inferencePipelineId else -> "" } } @@ -71,8 +67,7 @@ constructor( } return other is InferencePipelineTestResultListParams && - this.id == other.id && - this.includeArchived == other.includeArchived && + this.inferencePipelineId == other.inferencePipelineId && this.page == other.page && this.perPage == other.perPage && this.status == other.status && @@ -84,8 +79,7 @@ constructor( override fun hashCode(): Int { return Objects.hash( - id, - includeArchived, + inferencePipelineId, page, perPage, status, @@ -97,7 +91,7 @@ constructor( } override fun toString() = - "InferencePipelineTestResultListParams{id=$id, includeArchived=$includeArchived, page=$page, perPage=$perPage, status=$status, type=$type, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + "InferencePipelineTestResultListParams{inferencePipelineId=$inferencePipelineId, page=$page, perPage=$perPage, status=$status, type=$type, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" fun toBuilder() = Builder().from(this) @@ -109,8 +103,7 @@ constructor( @NoAutoDetect class Builder { - private var id: String? = null - private var includeArchived: Boolean? = null + private var inferencePipelineId: String? = null private var page: Long? = null private var perPage: Long? = null private var status: Status? = null @@ -123,8 +116,7 @@ constructor( internal fun from( inferencePipelineTestResultListParams: InferencePipelineTestResultListParams ) = apply { - this.id = inferencePipelineTestResultListParams.id - this.includeArchived = inferencePipelineTestResultListParams.includeArchived + this.inferencePipelineId = inferencePipelineTestResultListParams.inferencePipelineId this.page = inferencePipelineTestResultListParams.page this.perPage = inferencePipelineTestResultListParams.perPage this.status = inferencePipelineTestResultListParams.status @@ -134,11 +126,8 @@ constructor( additionalBodyProperties(inferencePipelineTestResultListParams.additionalBodyProperties) } - fun id(id: String) = apply { this.id = id } - - /** Include archived goals. */ - fun includeArchived(includeArchived: Boolean) = apply { - this.includeArchived = includeArchived + fun inferencePipelineId(inferencePipelineId: String) = apply { + this.inferencePipelineId = inferencePipelineId } /** The page to return in a paginated query. */ @@ -215,8 +204,9 @@ constructor( fun build(): InferencePipelineTestResultListParams = InferencePipelineTestResultListParams( - checkNotNull(id) { "`id` is required but was not set" }, - includeArchived, + checkNotNull(inferencePipelineId) { + "`inferencePipelineId` is required but was not set" + }, page, perPage, status, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineTestResultListResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineTestResultListResponse.kt similarity index 99% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineTestResultListResponse.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineTestResultListResponse.kt index a11dfed..045ce71 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/InferencePipelineTestResultListResponse.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineTestResultListResponse.kt @@ -1,6 +1,6 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import com.fasterxml.jackson.annotation.JsonAnyGetter import com.fasterxml.jackson.annotation.JsonAnySetter @@ -13,20 +13,20 @@ import com.fasterxml.jackson.databind.SerializerProvider import com.fasterxml.jackson.databind.annotation.JsonDeserialize import com.fasterxml.jackson.databind.annotation.JsonSerialize import com.fasterxml.jackson.module.kotlin.jacksonTypeRef +import com.openlayer.api.core.BaseDeserializer +import com.openlayer.api.core.BaseSerializer +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.getOrThrow +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException import java.time.OffsetDateTime import java.util.Objects import java.util.Optional -import org.openlayer.core.BaseDeserializer -import org.openlayer.core.BaseSerializer -import org.openlayer.core.Enum -import org.openlayer.core.ExcludeMissing -import org.openlayer.core.JsonField -import org.openlayer.core.JsonMissing -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.getOrThrow -import org.openlayer.core.toUnmodifiable -import org.openlayer.errors.OpenlayerInvalidDataException @JsonDeserialize(builder = InferencePipelineTestResultListResponse.Builder::class) @NoAutoDetect diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineUpdateParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineUpdateParams.kt new file mode 100644 index 0000000..66bece6 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineUpdateParams.kt @@ -0,0 +1,326 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.fasterxml.jackson.annotation.JsonAnyGetter +import com.fasterxml.jackson.annotation.JsonAnySetter +import com.fasterxml.jackson.annotation.JsonProperty +import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.models.* +import java.util.Objects +import java.util.Optional + +class InferencePipelineUpdateParams +constructor( + private val inferencePipelineId: String, + private val description: String?, + private val name: String?, + private val referenceDatasetUri: String?, + private val additionalQueryParams: Map>, + private val additionalHeaders: Map>, + private val additionalBodyProperties: Map, +) { + + fun inferencePipelineId(): String = inferencePipelineId + + fun description(): Optional = Optional.ofNullable(description) + + fun name(): Optional = Optional.ofNullable(name) + + fun referenceDatasetUri(): Optional = Optional.ofNullable(referenceDatasetUri) + + @JvmSynthetic + internal fun getBody(): InferencePipelineUpdateBody { + return InferencePipelineUpdateBody( + description, + name, + referenceDatasetUri, + additionalBodyProperties, + ) + } + + @JvmSynthetic internal fun getQueryParams(): Map> = additionalQueryParams + + @JvmSynthetic internal fun getHeaders(): Map> = additionalHeaders + + fun getPathParam(index: Int): String { + return when (index) { + 0 -> inferencePipelineId + else -> "" + } + } + + @JsonDeserialize(builder = InferencePipelineUpdateBody.Builder::class) + @NoAutoDetect + class InferencePipelineUpdateBody + internal constructor( + private val description: String?, + private val name: String?, + private val referenceDatasetUri: String?, + private val additionalProperties: Map, + ) { + + private var hashCode: Int = 0 + + /** The inference pipeline description. */ + @JsonProperty("description") fun description(): String? = description + + /** The inference pipeline name. */ + @JsonProperty("name") fun name(): String? = name + + /** + * The storage uri of your reference dataset. We recommend using the Python SDK or the UI to + * handle your reference dataset updates. + */ + @JsonProperty("referenceDatasetUri") + fun referenceDatasetUri(): String? = referenceDatasetUri + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is InferencePipelineUpdateBody && + this.description == other.description && + this.name == other.name && + this.referenceDatasetUri == other.referenceDatasetUri && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + description, + name, + referenceDatasetUri, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "InferencePipelineUpdateBody{description=$description, name=$name, referenceDatasetUri=$referenceDatasetUri, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var description: String? = null + private var name: String? = null + private var referenceDatasetUri: String? = null + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(inferencePipelineUpdateBody: InferencePipelineUpdateBody) = apply { + this.description = inferencePipelineUpdateBody.description + this.name = inferencePipelineUpdateBody.name + this.referenceDatasetUri = inferencePipelineUpdateBody.referenceDatasetUri + additionalProperties(inferencePipelineUpdateBody.additionalProperties) + } + + /** The inference pipeline description. */ + @JsonProperty("description") + fun description(description: String) = apply { this.description = description } + + /** The inference pipeline name. */ + @JsonProperty("name") fun name(name: String) = apply { this.name = name } + + /** + * The storage uri of your reference dataset. We recommend using the Python SDK or the + * UI to handle your reference dataset updates. + */ + @JsonProperty("referenceDatasetUri") + fun referenceDatasetUri(referenceDatasetUri: String) = apply { + this.referenceDatasetUri = referenceDatasetUri + } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): InferencePipelineUpdateBody = + InferencePipelineUpdateBody( + description, + name, + referenceDatasetUri, + additionalProperties.toUnmodifiable(), + ) + } + } + + fun _additionalQueryParams(): Map> = additionalQueryParams + + fun _additionalHeaders(): Map> = additionalHeaders + + fun _additionalBodyProperties(): Map = additionalBodyProperties + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is InferencePipelineUpdateParams && + this.inferencePipelineId == other.inferencePipelineId && + this.description == other.description && + this.name == other.name && + this.referenceDatasetUri == other.referenceDatasetUri && + this.additionalQueryParams == other.additionalQueryParams && + this.additionalHeaders == other.additionalHeaders && + this.additionalBodyProperties == other.additionalBodyProperties + } + + override fun hashCode(): Int { + return Objects.hash( + inferencePipelineId, + description, + name, + referenceDatasetUri, + additionalQueryParams, + additionalHeaders, + additionalBodyProperties, + ) + } + + override fun toString() = + "InferencePipelineUpdateParams{inferencePipelineId=$inferencePipelineId, description=$description, name=$name, referenceDatasetUri=$referenceDatasetUri, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + + fun toBuilder() = Builder().from(this) + + companion object { + + @JvmStatic fun builder() = Builder() + } + + @NoAutoDetect + class Builder { + + private var inferencePipelineId: String? = null + private var description: String? = null + private var name: String? = null + private var referenceDatasetUri: String? = null + private var additionalQueryParams: MutableMap> = mutableMapOf() + private var additionalHeaders: MutableMap> = mutableMapOf() + private var additionalBodyProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(inferencePipelineUpdateParams: InferencePipelineUpdateParams) = apply { + this.inferencePipelineId = inferencePipelineUpdateParams.inferencePipelineId + this.description = inferencePipelineUpdateParams.description + this.name = inferencePipelineUpdateParams.name + this.referenceDatasetUri = inferencePipelineUpdateParams.referenceDatasetUri + additionalQueryParams(inferencePipelineUpdateParams.additionalQueryParams) + additionalHeaders(inferencePipelineUpdateParams.additionalHeaders) + additionalBodyProperties(inferencePipelineUpdateParams.additionalBodyProperties) + } + + fun inferencePipelineId(inferencePipelineId: String) = apply { + this.inferencePipelineId = inferencePipelineId + } + + /** The inference pipeline description. */ + fun description(description: String) = apply { this.description = description } + + /** The inference pipeline name. */ + fun name(name: String) = apply { this.name = name } + + /** + * The storage uri of your reference dataset. We recommend using the Python SDK or the UI to + * handle your reference dataset updates. + */ + fun referenceDatasetUri(referenceDatasetUri: String) = apply { + this.referenceDatasetUri = referenceDatasetUri + } + + fun additionalQueryParams(additionalQueryParams: Map>) = apply { + this.additionalQueryParams.clear() + putAllQueryParams(additionalQueryParams) + } + + fun putQueryParam(name: String, value: String) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putQueryParams(name: String, values: Iterable) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllQueryParams(additionalQueryParams: Map>) = apply { + additionalQueryParams.forEach(this::putQueryParams) + } + + fun removeQueryParam(name: String) = apply { + this.additionalQueryParams.put(name, mutableListOf()) + } + + fun additionalHeaders(additionalHeaders: Map>) = apply { + this.additionalHeaders.clear() + putAllHeaders(additionalHeaders) + } + + fun putHeader(name: String, value: String) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putHeaders(name: String, values: Iterable) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllHeaders(additionalHeaders: Map>) = apply { + additionalHeaders.forEach(this::putHeaders) + } + + fun removeHeader(name: String) = apply { this.additionalHeaders.put(name, mutableListOf()) } + + fun additionalBodyProperties(additionalBodyProperties: Map) = apply { + this.additionalBodyProperties.clear() + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun putAdditionalBodyProperty(key: String, value: JsonValue) = apply { + this.additionalBodyProperties.put(key, value) + } + + fun putAllAdditionalBodyProperties(additionalBodyProperties: Map) = + apply { + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun build(): InferencePipelineUpdateParams = + InferencePipelineUpdateParams( + checkNotNull(inferencePipelineId) { + "`inferencePipelineId` is required but was not set" + }, + description, + name, + referenceDatasetUri, + additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalHeaders.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalBodyProperties.toUnmodifiable(), + ) + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineUpdateResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineUpdateResponse.kt new file mode 100644 index 0000000..3e7d741 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/InferencePipelineUpdateResponse.kt @@ -0,0 +1,611 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.fasterxml.jackson.annotation.JsonAnyGetter +import com.fasterxml.jackson.annotation.JsonAnySetter +import com.fasterxml.jackson.annotation.JsonCreator +import com.fasterxml.jackson.annotation.JsonProperty +import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import java.time.OffsetDateTime +import java.util.Objects +import java.util.Optional + +@JsonDeserialize(builder = InferencePipelineUpdateResponse.Builder::class) +@NoAutoDetect +class InferencePipelineUpdateResponse +private constructor( + private val id: JsonField, + private val projectId: JsonField, + private val name: JsonField, + private val dateCreated: JsonField, + private val dateUpdated: JsonField, + private val dateLastSampleReceived: JsonField, + private val description: JsonField, + private val dateLastEvaluated: JsonField, + private val dateOfNextEvaluation: JsonField, + private val passingGoalCount: JsonField, + private val failingGoalCount: JsonField, + private val totalGoalCount: JsonField, + private val status: JsonField, + private val statusMessage: JsonField, + private val links: JsonField, + private val additionalProperties: Map, +) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + /** The inference pipeline id. */ + fun id(): String = id.getRequired("id") + + /** The project id. */ + fun projectId(): String = projectId.getRequired("projectId") + + /** The inference pipeline name. */ + fun name(): String = name.getRequired("name") + + /** The creation date. */ + fun dateCreated(): OffsetDateTime = dateCreated.getRequired("dateCreated") + + /** The last updated date. */ + fun dateUpdated(): OffsetDateTime = dateUpdated.getRequired("dateUpdated") + + /** The last data sample received date. */ + fun dateLastSampleReceived(): Optional = + Optional.ofNullable(dateLastSampleReceived.getNullable("dateLastSampleReceived")) + + /** The inference pipeline description. */ + fun description(): Optional = + Optional.ofNullable(description.getNullable("description")) + + /** The last test evaluation date. */ + fun dateLastEvaluated(): Optional = + Optional.ofNullable(dateLastEvaluated.getNullable("dateLastEvaluated")) + + /** The next test evaluation date. */ + fun dateOfNextEvaluation(): Optional = + Optional.ofNullable(dateOfNextEvaluation.getNullable("dateOfNextEvaluation")) + + /** The number of tests passing. */ + fun passingGoalCount(): Long = passingGoalCount.getRequired("passingGoalCount") + + /** The number of tests failing. */ + fun failingGoalCount(): Long = failingGoalCount.getRequired("failingGoalCount") + + /** The total number of tests. */ + fun totalGoalCount(): Long = totalGoalCount.getRequired("totalGoalCount") + + /** The status of test evaluation for the inference pipeline. */ + fun status(): Status = status.getRequired("status") + + /** The status message of test evaluation for the inference pipeline. */ + fun statusMessage(): Optional = + Optional.ofNullable(statusMessage.getNullable("statusMessage")) + + fun links(): Links = links.getRequired("links") + + /** The inference pipeline id. */ + @JsonProperty("id") @ExcludeMissing fun _id() = id + + /** The project id. */ + @JsonProperty("projectId") @ExcludeMissing fun _projectId() = projectId + + /** The inference pipeline name. */ + @JsonProperty("name") @ExcludeMissing fun _name() = name + + /** The creation date. */ + @JsonProperty("dateCreated") @ExcludeMissing fun _dateCreated() = dateCreated + + /** The last updated date. */ + @JsonProperty("dateUpdated") @ExcludeMissing fun _dateUpdated() = dateUpdated + + /** The last data sample received date. */ + @JsonProperty("dateLastSampleReceived") + @ExcludeMissing + fun _dateLastSampleReceived() = dateLastSampleReceived + + /** The inference pipeline description. */ + @JsonProperty("description") @ExcludeMissing fun _description() = description + + /** The last test evaluation date. */ + @JsonProperty("dateLastEvaluated") @ExcludeMissing fun _dateLastEvaluated() = dateLastEvaluated + + /** The next test evaluation date. */ + @JsonProperty("dateOfNextEvaluation") + @ExcludeMissing + fun _dateOfNextEvaluation() = dateOfNextEvaluation + + /** The number of tests passing. */ + @JsonProperty("passingGoalCount") @ExcludeMissing fun _passingGoalCount() = passingGoalCount + + /** The number of tests failing. */ + @JsonProperty("failingGoalCount") @ExcludeMissing fun _failingGoalCount() = failingGoalCount + + /** The total number of tests. */ + @JsonProperty("totalGoalCount") @ExcludeMissing fun _totalGoalCount() = totalGoalCount + + /** The status of test evaluation for the inference pipeline. */ + @JsonProperty("status") @ExcludeMissing fun _status() = status + + /** The status message of test evaluation for the inference pipeline. */ + @JsonProperty("statusMessage") @ExcludeMissing fun _statusMessage() = statusMessage + + @JsonProperty("links") @ExcludeMissing fun _links() = links + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): InferencePipelineUpdateResponse = apply { + if (!validated) { + id() + projectId() + name() + dateCreated() + dateUpdated() + dateLastSampleReceived() + description() + dateLastEvaluated() + dateOfNextEvaluation() + passingGoalCount() + failingGoalCount() + totalGoalCount() + status() + statusMessage() + links().validate() + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is InferencePipelineUpdateResponse && + this.id == other.id && + this.projectId == other.projectId && + this.name == other.name && + this.dateCreated == other.dateCreated && + this.dateUpdated == other.dateUpdated && + this.dateLastSampleReceived == other.dateLastSampleReceived && + this.description == other.description && + this.dateLastEvaluated == other.dateLastEvaluated && + this.dateOfNextEvaluation == other.dateOfNextEvaluation && + this.passingGoalCount == other.passingGoalCount && + this.failingGoalCount == other.failingGoalCount && + this.totalGoalCount == other.totalGoalCount && + this.status == other.status && + this.statusMessage == other.statusMessage && + this.links == other.links && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + id, + projectId, + name, + dateCreated, + dateUpdated, + dateLastSampleReceived, + description, + dateLastEvaluated, + dateOfNextEvaluation, + passingGoalCount, + failingGoalCount, + totalGoalCount, + status, + statusMessage, + links, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "InferencePipelineUpdateResponse{id=$id, projectId=$projectId, name=$name, dateCreated=$dateCreated, dateUpdated=$dateUpdated, dateLastSampleReceived=$dateLastSampleReceived, description=$description, dateLastEvaluated=$dateLastEvaluated, dateOfNextEvaluation=$dateOfNextEvaluation, passingGoalCount=$passingGoalCount, failingGoalCount=$failingGoalCount, totalGoalCount=$totalGoalCount, status=$status, statusMessage=$statusMessage, links=$links, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var id: JsonField = JsonMissing.of() + private var projectId: JsonField = JsonMissing.of() + private var name: JsonField = JsonMissing.of() + private var dateCreated: JsonField = JsonMissing.of() + private var dateUpdated: JsonField = JsonMissing.of() + private var dateLastSampleReceived: JsonField = JsonMissing.of() + private var description: JsonField = JsonMissing.of() + private var dateLastEvaluated: JsonField = JsonMissing.of() + private var dateOfNextEvaluation: JsonField = JsonMissing.of() + private var passingGoalCount: JsonField = JsonMissing.of() + private var failingGoalCount: JsonField = JsonMissing.of() + private var totalGoalCount: JsonField = JsonMissing.of() + private var status: JsonField = JsonMissing.of() + private var statusMessage: JsonField = JsonMissing.of() + private var links: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(inferencePipelineUpdateResponse: InferencePipelineUpdateResponse) = + apply { + this.id = inferencePipelineUpdateResponse.id + this.projectId = inferencePipelineUpdateResponse.projectId + this.name = inferencePipelineUpdateResponse.name + this.dateCreated = inferencePipelineUpdateResponse.dateCreated + this.dateUpdated = inferencePipelineUpdateResponse.dateUpdated + this.dateLastSampleReceived = inferencePipelineUpdateResponse.dateLastSampleReceived + this.description = inferencePipelineUpdateResponse.description + this.dateLastEvaluated = inferencePipelineUpdateResponse.dateLastEvaluated + this.dateOfNextEvaluation = inferencePipelineUpdateResponse.dateOfNextEvaluation + this.passingGoalCount = inferencePipelineUpdateResponse.passingGoalCount + this.failingGoalCount = inferencePipelineUpdateResponse.failingGoalCount + this.totalGoalCount = inferencePipelineUpdateResponse.totalGoalCount + this.status = inferencePipelineUpdateResponse.status + this.statusMessage = inferencePipelineUpdateResponse.statusMessage + this.links = inferencePipelineUpdateResponse.links + additionalProperties(inferencePipelineUpdateResponse.additionalProperties) + } + + /** The inference pipeline id. */ + fun id(id: String) = id(JsonField.of(id)) + + /** The inference pipeline id. */ + @JsonProperty("id") @ExcludeMissing fun id(id: JsonField) = apply { this.id = id } + + /** The project id. */ + fun projectId(projectId: String) = projectId(JsonField.of(projectId)) + + /** The project id. */ + @JsonProperty("projectId") + @ExcludeMissing + fun projectId(projectId: JsonField) = apply { this.projectId = projectId } + + /** The inference pipeline name. */ + fun name(name: String) = name(JsonField.of(name)) + + /** The inference pipeline name. */ + @JsonProperty("name") + @ExcludeMissing + fun name(name: JsonField) = apply { this.name = name } + + /** The creation date. */ + fun dateCreated(dateCreated: OffsetDateTime) = dateCreated(JsonField.of(dateCreated)) + + /** The creation date. */ + @JsonProperty("dateCreated") + @ExcludeMissing + fun dateCreated(dateCreated: JsonField) = apply { + this.dateCreated = dateCreated + } + + /** The last updated date. */ + fun dateUpdated(dateUpdated: OffsetDateTime) = dateUpdated(JsonField.of(dateUpdated)) + + /** The last updated date. */ + @JsonProperty("dateUpdated") + @ExcludeMissing + fun dateUpdated(dateUpdated: JsonField) = apply { + this.dateUpdated = dateUpdated + } + + /** The last data sample received date. */ + fun dateLastSampleReceived(dateLastSampleReceived: OffsetDateTime) = + dateLastSampleReceived(JsonField.of(dateLastSampleReceived)) + + /** The last data sample received date. */ + @JsonProperty("dateLastSampleReceived") + @ExcludeMissing + fun dateLastSampleReceived(dateLastSampleReceived: JsonField) = apply { + this.dateLastSampleReceived = dateLastSampleReceived + } + + /** The inference pipeline description. */ + fun description(description: String) = description(JsonField.of(description)) + + /** The inference pipeline description. */ + @JsonProperty("description") + @ExcludeMissing + fun description(description: JsonField) = apply { this.description = description } + + /** The last test evaluation date. */ + fun dateLastEvaluated(dateLastEvaluated: OffsetDateTime) = + dateLastEvaluated(JsonField.of(dateLastEvaluated)) + + /** The last test evaluation date. */ + @JsonProperty("dateLastEvaluated") + @ExcludeMissing + fun dateLastEvaluated(dateLastEvaluated: JsonField) = apply { + this.dateLastEvaluated = dateLastEvaluated + } + + /** The next test evaluation date. */ + fun dateOfNextEvaluation(dateOfNextEvaluation: OffsetDateTime) = + dateOfNextEvaluation(JsonField.of(dateOfNextEvaluation)) + + /** The next test evaluation date. */ + @JsonProperty("dateOfNextEvaluation") + @ExcludeMissing + fun dateOfNextEvaluation(dateOfNextEvaluation: JsonField) = apply { + this.dateOfNextEvaluation = dateOfNextEvaluation + } + + /** The number of tests passing. */ + fun passingGoalCount(passingGoalCount: Long) = + passingGoalCount(JsonField.of(passingGoalCount)) + + /** The number of tests passing. */ + @JsonProperty("passingGoalCount") + @ExcludeMissing + fun passingGoalCount(passingGoalCount: JsonField) = apply { + this.passingGoalCount = passingGoalCount + } + + /** The number of tests failing. */ + fun failingGoalCount(failingGoalCount: Long) = + failingGoalCount(JsonField.of(failingGoalCount)) + + /** The number of tests failing. */ + @JsonProperty("failingGoalCount") + @ExcludeMissing + fun failingGoalCount(failingGoalCount: JsonField) = apply { + this.failingGoalCount = failingGoalCount + } + + /** The total number of tests. */ + fun totalGoalCount(totalGoalCount: Long) = totalGoalCount(JsonField.of(totalGoalCount)) + + /** The total number of tests. */ + @JsonProperty("totalGoalCount") + @ExcludeMissing + fun totalGoalCount(totalGoalCount: JsonField) = apply { + this.totalGoalCount = totalGoalCount + } + + /** The status of test evaluation for the inference pipeline. */ + fun status(status: Status) = status(JsonField.of(status)) + + /** The status of test evaluation for the inference pipeline. */ + @JsonProperty("status") + @ExcludeMissing + fun status(status: JsonField) = apply { this.status = status } + + /** The status message of test evaluation for the inference pipeline. */ + fun statusMessage(statusMessage: String) = statusMessage(JsonField.of(statusMessage)) + + /** The status message of test evaluation for the inference pipeline. */ + @JsonProperty("statusMessage") + @ExcludeMissing + fun statusMessage(statusMessage: JsonField) = apply { + this.statusMessage = statusMessage + } + + fun links(links: Links) = links(JsonField.of(links)) + + @JsonProperty("links") + @ExcludeMissing + fun links(links: JsonField) = apply { this.links = links } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): InferencePipelineUpdateResponse = + InferencePipelineUpdateResponse( + id, + projectId, + name, + dateCreated, + dateUpdated, + dateLastSampleReceived, + description, + dateLastEvaluated, + dateOfNextEvaluation, + passingGoalCount, + failingGoalCount, + totalGoalCount, + status, + statusMessage, + links, + additionalProperties.toUnmodifiable(), + ) + } + + @JsonDeserialize(builder = Links.Builder::class) + @NoAutoDetect + class Links + private constructor( + private val app: JsonField, + private val additionalProperties: Map, + ) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + fun app(): String = app.getRequired("app") + + @JsonProperty("app") @ExcludeMissing fun _app() = app + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): Links = apply { + if (!validated) { + app() + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Links && + this.app == other.app && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = Objects.hash(app, additionalProperties) + } + return hashCode + } + + override fun toString() = "Links{app=$app, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var app: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(links: Links) = apply { + this.app = links.app + additionalProperties(links.additionalProperties) + } + + fun app(app: String) = app(JsonField.of(app)) + + @JsonProperty("app") + @ExcludeMissing + fun app(app: JsonField) = apply { this.app = app } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): Links = Links(app, additionalProperties.toUnmodifiable()) + } + } + + class Status + @JsonCreator + private constructor( + private val value: JsonField, + ) : Enum { + + @com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Status && this.value == other.value + } + + override fun hashCode() = value.hashCode() + + override fun toString() = value.toString() + + companion object { + + @JvmField val QUEUED = Status(JsonField.of("queued")) + + @JvmField val RUNNING = Status(JsonField.of("running")) + + @JvmField val PAUSED = Status(JsonField.of("paused")) + + @JvmField val FAILED = Status(JsonField.of("failed")) + + @JvmField val COMPLETED = Status(JsonField.of("completed")) + + @JvmField val UNKNOWN = Status(JsonField.of("unknown")) + + @JvmStatic fun of(value: String) = Status(JsonField.of(value)) + } + + enum class Known { + QUEUED, + RUNNING, + PAUSED, + FAILED, + COMPLETED, + UNKNOWN, + } + + enum class Value { + QUEUED, + RUNNING, + PAUSED, + FAILED, + COMPLETED, + UNKNOWN, + _UNKNOWN, + } + + fun value(): Value = + when (this) { + QUEUED -> Value.QUEUED + RUNNING -> Value.RUNNING + PAUSED -> Value.PAUSED + FAILED -> Value.FAILED + COMPLETED -> Value.COMPLETED + UNKNOWN -> Value.UNKNOWN + else -> Value._UNKNOWN + } + + fun known(): Known = + when (this) { + QUEUED -> Known.QUEUED + RUNNING -> Known.RUNNING + PAUSED -> Known.PAUSED + FAILED -> Known.FAILED + COMPLETED -> Known.COMPLETED + UNKNOWN -> Known.UNKNOWN + else -> throw OpenlayerInvalidDataException("Unknown Status: $value") + } + + fun asString(): String = _value().asStringOrThrow() + } +} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectCommitListParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCommitListParams.kt similarity index 87% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectCommitListParams.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCommitListParams.kt index 5b862ce..9266137 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectCommitListParams.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCommitListParams.kt @@ -1,17 +1,17 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.models.* import java.util.Objects import java.util.Optional -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.toUnmodifiable -import org.openlayer.models.* class ProjectCommitListParams constructor( - private val id: String, + private val projectId: String, private val page: Long?, private val perPage: Long?, private val additionalQueryParams: Map>, @@ -19,7 +19,7 @@ constructor( private val additionalBodyProperties: Map, ) { - fun id(): String = id + fun projectId(): String = projectId fun page(): Optional = Optional.ofNullable(page) @@ -38,7 +38,7 @@ constructor( fun getPathParam(index: Int): String { return when (index) { - 0 -> id + 0 -> projectId else -> "" } } @@ -55,7 +55,7 @@ constructor( } return other is ProjectCommitListParams && - this.id == other.id && + this.projectId == other.projectId && this.page == other.page && this.perPage == other.perPage && this.additionalQueryParams == other.additionalQueryParams && @@ -65,7 +65,7 @@ constructor( override fun hashCode(): Int { return Objects.hash( - id, + projectId, page, perPage, additionalQueryParams, @@ -75,7 +75,7 @@ constructor( } override fun toString() = - "ProjectCommitListParams{id=$id, page=$page, perPage=$perPage, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + "ProjectCommitListParams{projectId=$projectId, page=$page, perPage=$perPage, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" fun toBuilder() = Builder().from(this) @@ -87,7 +87,7 @@ constructor( @NoAutoDetect class Builder { - private var id: String? = null + private var projectId: String? = null private var page: Long? = null private var perPage: Long? = null private var additionalQueryParams: MutableMap> = mutableMapOf() @@ -96,7 +96,7 @@ constructor( @JvmSynthetic internal fun from(projectCommitListParams: ProjectCommitListParams) = apply { - this.id = projectCommitListParams.id + this.projectId = projectCommitListParams.projectId this.page = projectCommitListParams.page this.perPage = projectCommitListParams.perPage additionalQueryParams(projectCommitListParams.additionalQueryParams) @@ -104,7 +104,7 @@ constructor( additionalBodyProperties(projectCommitListParams.additionalBodyProperties) } - fun id(id: String) = apply { this.id = id } + fun projectId(projectId: String) = apply { this.projectId = projectId } /** The page to return in a paginated query. */ fun page(page: Long) = apply { this.page = page } @@ -168,7 +168,7 @@ constructor( fun build(): ProjectCommitListParams = ProjectCommitListParams( - checkNotNull(id) { "`id` is required but was not set" }, + checkNotNull(projectId) { "`projectId` is required but was not set" }, page, perPage, additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectCommitListResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCommitListResponse.kt similarity index 99% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectCommitListResponse.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCommitListResponse.kt index e75be66..da9d1fd 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectCommitListResponse.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCommitListResponse.kt @@ -1,23 +1,23 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import com.fasterxml.jackson.annotation.JsonAnyGetter import com.fasterxml.jackson.annotation.JsonAnySetter import com.fasterxml.jackson.annotation.JsonCreator import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException import java.time.OffsetDateTime import java.util.Objects import java.util.Optional -import org.openlayer.core.Enum -import org.openlayer.core.ExcludeMissing -import org.openlayer.core.JsonField -import org.openlayer.core.JsonMissing -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.toUnmodifiable -import org.openlayer.errors.OpenlayerInvalidDataException @JsonDeserialize(builder = ProjectCommitListResponse.Builder::class) @NoAutoDetect diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCreateParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCreateParams.kt new file mode 100644 index 0000000..559574f --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCreateParams.kt @@ -0,0 +1,705 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.fasterxml.jackson.annotation.JsonAnyGetter +import com.fasterxml.jackson.annotation.JsonAnySetter +import com.fasterxml.jackson.annotation.JsonCreator +import com.fasterxml.jackson.annotation.JsonProperty +import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import com.openlayer.api.models.* +import java.time.OffsetDateTime +import java.util.Objects +import java.util.Optional + +class ProjectCreateParams +constructor( + private val name: String, + private val taskType: TaskType, + private val description: String?, + private val additionalQueryParams: Map>, + private val additionalHeaders: Map>, + private val additionalBodyProperties: Map, +) { + + fun name(): String = name + + fun taskType(): TaskType = taskType + + fun description(): Optional = Optional.ofNullable(description) + + @JvmSynthetic + internal fun getBody(): ProjectCreateBody { + return ProjectCreateBody( + name, + taskType, + description, + additionalBodyProperties, + ) + } + + @JvmSynthetic internal fun getQueryParams(): Map> = additionalQueryParams + + @JvmSynthetic internal fun getHeaders(): Map> = additionalHeaders + + @JsonDeserialize(builder = ProjectCreateBody.Builder::class) + @NoAutoDetect + class ProjectCreateBody + internal constructor( + private val name: String?, + private val taskType: TaskType?, + private val description: String?, + private val additionalProperties: Map, + ) { + + private var hashCode: Int = 0 + + /** The project name. */ + @JsonProperty("name") fun name(): String? = name + + /** The task type of the project. */ + @JsonProperty("taskType") fun taskType(): TaskType? = taskType + + /** The project description. */ + @JsonProperty("description") fun description(): String? = description + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is ProjectCreateBody && + this.name == other.name && + this.taskType == other.taskType && + this.description == other.description && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + name, + taskType, + description, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "ProjectCreateBody{name=$name, taskType=$taskType, description=$description, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var name: String? = null + private var taskType: TaskType? = null + private var description: String? = null + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(projectCreateBody: ProjectCreateBody) = apply { + this.name = projectCreateBody.name + this.taskType = projectCreateBody.taskType + this.description = projectCreateBody.description + additionalProperties(projectCreateBody.additionalProperties) + } + + /** The project name. */ + @JsonProperty("name") fun name(name: String) = apply { this.name = name } + + /** The task type of the project. */ + @JsonProperty("taskType") + fun taskType(taskType: TaskType) = apply { this.taskType = taskType } + + /** The project description. */ + @JsonProperty("description") + fun description(description: String) = apply { this.description = description } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): ProjectCreateBody = + ProjectCreateBody( + checkNotNull(name) { "`name` is required but was not set" }, + checkNotNull(taskType) { "`taskType` is required but was not set" }, + description, + additionalProperties.toUnmodifiable(), + ) + } + } + + fun _additionalQueryParams(): Map> = additionalQueryParams + + fun _additionalHeaders(): Map> = additionalHeaders + + fun _additionalBodyProperties(): Map = additionalBodyProperties + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is ProjectCreateParams && + this.name == other.name && + this.taskType == other.taskType && + this.description == other.description && + this.additionalQueryParams == other.additionalQueryParams && + this.additionalHeaders == other.additionalHeaders && + this.additionalBodyProperties == other.additionalBodyProperties + } + + override fun hashCode(): Int { + return Objects.hash( + name, + taskType, + description, + additionalQueryParams, + additionalHeaders, + additionalBodyProperties, + ) + } + + override fun toString() = + "ProjectCreateParams{name=$name, taskType=$taskType, description=$description, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + + fun toBuilder() = Builder().from(this) + + companion object { + + @JvmStatic fun builder() = Builder() + } + + @NoAutoDetect + class Builder { + + private var name: String? = null + private var taskType: TaskType? = null + private var description: String? = null + private var additionalQueryParams: MutableMap> = mutableMapOf() + private var additionalHeaders: MutableMap> = mutableMapOf() + private var additionalBodyProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(projectCreateParams: ProjectCreateParams) = apply { + this.name = projectCreateParams.name + this.taskType = projectCreateParams.taskType + this.description = projectCreateParams.description + additionalQueryParams(projectCreateParams.additionalQueryParams) + additionalHeaders(projectCreateParams.additionalHeaders) + additionalBodyProperties(projectCreateParams.additionalBodyProperties) + } + + /** The project name. */ + fun name(name: String) = apply { this.name = name } + + /** The task type of the project. */ + fun taskType(taskType: TaskType) = apply { this.taskType = taskType } + + /** The project description. */ + fun description(description: String) = apply { this.description = description } + + fun additionalQueryParams(additionalQueryParams: Map>) = apply { + this.additionalQueryParams.clear() + putAllQueryParams(additionalQueryParams) + } + + fun putQueryParam(name: String, value: String) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putQueryParams(name: String, values: Iterable) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllQueryParams(additionalQueryParams: Map>) = apply { + additionalQueryParams.forEach(this::putQueryParams) + } + + fun removeQueryParam(name: String) = apply { + this.additionalQueryParams.put(name, mutableListOf()) + } + + fun additionalHeaders(additionalHeaders: Map>) = apply { + this.additionalHeaders.clear() + putAllHeaders(additionalHeaders) + } + + fun putHeader(name: String, value: String) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putHeaders(name: String, values: Iterable) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllHeaders(additionalHeaders: Map>) = apply { + additionalHeaders.forEach(this::putHeaders) + } + + fun removeHeader(name: String) = apply { this.additionalHeaders.put(name, mutableListOf()) } + + fun additionalBodyProperties(additionalBodyProperties: Map) = apply { + this.additionalBodyProperties.clear() + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun putAdditionalBodyProperty(key: String, value: JsonValue) = apply { + this.additionalBodyProperties.put(key, value) + } + + fun putAllAdditionalBodyProperties(additionalBodyProperties: Map) = + apply { + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun build(): ProjectCreateParams = + ProjectCreateParams( + checkNotNull(name) { "`name` is required but was not set" }, + checkNotNull(taskType) { "`taskType` is required but was not set" }, + description, + additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalHeaders.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalBodyProperties.toUnmodifiable(), + ) + } + + /** Links to the project. */ + @JsonDeserialize(builder = Links.Builder::class) + @NoAutoDetect + class Links + private constructor( + private val app: String?, + private val additionalProperties: Map, + ) { + + private var hashCode: Int = 0 + + @JsonProperty("app") fun app(): String? = app + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Links && + this.app == other.app && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = Objects.hash(app, additionalProperties) + } + return hashCode + } + + override fun toString() = "Links{app=$app, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var app: String? = null + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(links: Links) = apply { + this.app = links.app + additionalProperties(links.additionalProperties) + } + + @JsonProperty("app") fun app(app: String) = apply { this.app = app } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): Links = + Links( + checkNotNull(app) { "`app` is required but was not set" }, + additionalProperties.toUnmodifiable() + ) + } + } + + class Source + @JsonCreator + private constructor( + private val value: JsonField, + ) : Enum { + + @com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Source && this.value == other.value + } + + override fun hashCode() = value.hashCode() + + override fun toString() = value.toString() + + companion object { + + @JvmField val WEB = Source(JsonField.of("web")) + + @JvmField val API = Source(JsonField.of("api")) + + @JvmField val NULL = Source(JsonField.of("null")) + + @JvmStatic fun of(value: String) = Source(JsonField.of(value)) + } + + enum class Known { + WEB, + API, + NULL, + } + + enum class Value { + WEB, + API, + NULL, + _UNKNOWN, + } + + fun value(): Value = + when (this) { + WEB -> Value.WEB + API -> Value.API + NULL -> Value.NULL + else -> Value._UNKNOWN + } + + fun known(): Known = + when (this) { + WEB -> Known.WEB + API -> Known.API + NULL -> Known.NULL + else -> throw OpenlayerInvalidDataException("Unknown Source: $value") + } + + fun asString(): String = _value().asStringOrThrow() + } + + class TaskType + @JsonCreator + private constructor( + private val value: JsonField, + ) : Enum { + + @com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is TaskType && this.value == other.value + } + + override fun hashCode() = value.hashCode() + + override fun toString() = value.toString() + + companion object { + + @JvmField val LLM_BASE = TaskType(JsonField.of("llm-base")) + + @JvmField val TABULAR_CLASSIFICATION = TaskType(JsonField.of("tabular-classification")) + + @JvmField val TABULAR_REGRESSION = TaskType(JsonField.of("tabular-regression")) + + @JvmField val TEXT_CLASSIFICATION = TaskType(JsonField.of("text-classification")) + + @JvmStatic fun of(value: String) = TaskType(JsonField.of(value)) + } + + enum class Known { + LLM_BASE, + TABULAR_CLASSIFICATION, + TABULAR_REGRESSION, + TEXT_CLASSIFICATION, + } + + enum class Value { + LLM_BASE, + TABULAR_CLASSIFICATION, + TABULAR_REGRESSION, + TEXT_CLASSIFICATION, + _UNKNOWN, + } + + fun value(): Value = + when (this) { + LLM_BASE -> Value.LLM_BASE + TABULAR_CLASSIFICATION -> Value.TABULAR_CLASSIFICATION + TABULAR_REGRESSION -> Value.TABULAR_REGRESSION + TEXT_CLASSIFICATION -> Value.TEXT_CLASSIFICATION + else -> Value._UNKNOWN + } + + fun known(): Known = + when (this) { + LLM_BASE -> Known.LLM_BASE + TABULAR_CLASSIFICATION -> Known.TABULAR_CLASSIFICATION + TABULAR_REGRESSION -> Known.TABULAR_REGRESSION + TEXT_CLASSIFICATION -> Known.TEXT_CLASSIFICATION + else -> throw OpenlayerInvalidDataException("Unknown TaskType: $value") + } + + fun asString(): String = _value().asStringOrThrow() + } + + @JsonDeserialize(builder = GitRepo.Builder::class) + @NoAutoDetect + class GitRepo + private constructor( + private val id: String?, + private val gitId: Long?, + private val dateConnected: OffsetDateTime?, + private val dateUpdated: OffsetDateTime?, + private val branch: String?, + private val name: String?, + private val private_: Boolean?, + private val slug: String?, + private val url: String?, + private val rootDir: String?, + private val projectId: String?, + private val gitAccountId: String?, + private val additionalProperties: Map, + ) { + + private var hashCode: Int = 0 + + @JsonProperty("id") fun id(): String? = id + + @JsonProperty("gitId") fun gitId(): Long? = gitId + + @JsonProperty("dateConnected") fun dateConnected(): OffsetDateTime? = dateConnected + + @JsonProperty("dateUpdated") fun dateUpdated(): OffsetDateTime? = dateUpdated + + @JsonProperty("branch") fun branch(): String? = branch + + @JsonProperty("name") fun name(): String? = name + + @JsonProperty("private") fun private_(): Boolean? = private_ + + @JsonProperty("slug") fun slug(): String? = slug + + @JsonProperty("url") fun url(): String? = url + + @JsonProperty("rootDir") fun rootDir(): String? = rootDir + + @JsonProperty("projectId") fun projectId(): String? = projectId + + @JsonProperty("gitAccountId") fun gitAccountId(): String? = gitAccountId + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is GitRepo && + this.id == other.id && + this.gitId == other.gitId && + this.dateConnected == other.dateConnected && + this.dateUpdated == other.dateUpdated && + this.branch == other.branch && + this.name == other.name && + this.private_ == other.private_ && + this.slug == other.slug && + this.url == other.url && + this.rootDir == other.rootDir && + this.projectId == other.projectId && + this.gitAccountId == other.gitAccountId && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + id, + gitId, + dateConnected, + dateUpdated, + branch, + name, + private_, + slug, + url, + rootDir, + projectId, + gitAccountId, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "GitRepo{id=$id, gitId=$gitId, dateConnected=$dateConnected, dateUpdated=$dateUpdated, branch=$branch, name=$name, private_=$private_, slug=$slug, url=$url, rootDir=$rootDir, projectId=$projectId, gitAccountId=$gitAccountId, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var id: String? = null + private var gitId: Long? = null + private var dateConnected: OffsetDateTime? = null + private var dateUpdated: OffsetDateTime? = null + private var branch: String? = null + private var name: String? = null + private var private_: Boolean? = null + private var slug: String? = null + private var url: String? = null + private var rootDir: String? = null + private var projectId: String? = null + private var gitAccountId: String? = null + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(gitRepo: GitRepo) = apply { + this.id = gitRepo.id + this.gitId = gitRepo.gitId + this.dateConnected = gitRepo.dateConnected + this.dateUpdated = gitRepo.dateUpdated + this.branch = gitRepo.branch + this.name = gitRepo.name + this.private_ = gitRepo.private_ + this.slug = gitRepo.slug + this.url = gitRepo.url + this.rootDir = gitRepo.rootDir + this.projectId = gitRepo.projectId + this.gitAccountId = gitRepo.gitAccountId + additionalProperties(gitRepo.additionalProperties) + } + + @JsonProperty("id") fun id(id: String) = apply { this.id = id } + + @JsonProperty("gitId") fun gitId(gitId: Long) = apply { this.gitId = gitId } + + @JsonProperty("dateConnected") + fun dateConnected(dateConnected: OffsetDateTime) = apply { + this.dateConnected = dateConnected + } + + @JsonProperty("dateUpdated") + fun dateUpdated(dateUpdated: OffsetDateTime) = apply { this.dateUpdated = dateUpdated } + + @JsonProperty("branch") fun branch(branch: String) = apply { this.branch = branch } + + @JsonProperty("name") fun name(name: String) = apply { this.name = name } + + @JsonProperty("private") + fun private_(private_: Boolean) = apply { this.private_ = private_ } + + @JsonProperty("slug") fun slug(slug: String) = apply { this.slug = slug } + + @JsonProperty("url") fun url(url: String) = apply { this.url = url } + + @JsonProperty("rootDir") fun rootDir(rootDir: String) = apply { this.rootDir = rootDir } + + @JsonProperty("projectId") + fun projectId(projectId: String) = apply { this.projectId = projectId } + + @JsonProperty("gitAccountId") + fun gitAccountId(gitAccountId: String) = apply { this.gitAccountId = gitAccountId } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): GitRepo = + GitRepo( + checkNotNull(id) { "`id` is required but was not set" }, + checkNotNull(gitId) { "`gitId` is required but was not set" }, + checkNotNull(dateConnected) { "`dateConnected` is required but was not set" }, + checkNotNull(dateUpdated) { "`dateUpdated` is required but was not set" }, + branch, + checkNotNull(name) { "`name` is required but was not set" }, + checkNotNull(private_) { "`private_` is required but was not set" }, + checkNotNull(slug) { "`slug` is required but was not set" }, + checkNotNull(url) { "`url` is required but was not set" }, + rootDir, + checkNotNull(projectId) { "`projectId` is required but was not set" }, + checkNotNull(gitAccountId) { "`gitAccountId` is required but was not set" }, + additionalProperties.toUnmodifiable(), + ) + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCreateResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCreateResponse.kt new file mode 100644 index 0000000..eb6afee --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectCreateResponse.kt @@ -0,0 +1,964 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.fasterxml.jackson.annotation.JsonAnyGetter +import com.fasterxml.jackson.annotation.JsonAnySetter +import com.fasterxml.jackson.annotation.JsonCreator +import com.fasterxml.jackson.annotation.JsonProperty +import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import java.time.OffsetDateTime +import java.util.Objects +import java.util.Optional + +@JsonDeserialize(builder = ProjectCreateResponse.Builder::class) +@NoAutoDetect +class ProjectCreateResponse +private constructor( + private val id: JsonField, + private val workspaceId: JsonField, + private val creatorId: JsonField, + private val name: JsonField, + private val dateCreated: JsonField, + private val dateUpdated: JsonField, + private val description: JsonField, + private val source: JsonField, + private val taskType: JsonField, + private val versionCount: JsonField, + private val inferencePipelineCount: JsonField, + private val goalCount: JsonField, + private val developmentGoalCount: JsonField, + private val monitoringGoalCount: JsonField, + private val links: JsonField, + private val gitRepo: JsonField, + private val additionalProperties: Map, +) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + /** The project id. */ + fun id(): String = id.getRequired("id") + + /** The workspace id. */ + fun workspaceId(): Optional = + Optional.ofNullable(workspaceId.getNullable("workspaceId")) + + /** The project creator id. */ + fun creatorId(): Optional = Optional.ofNullable(creatorId.getNullable("creatorId")) + + /** The project name. */ + fun name(): String = name.getRequired("name") + + /** The project creation date. */ + fun dateCreated(): OffsetDateTime = dateCreated.getRequired("dateCreated") + + /** The project last updated date. */ + fun dateUpdated(): OffsetDateTime = dateUpdated.getRequired("dateUpdated") + + /** The project description. */ + fun description(): Optional = + Optional.ofNullable(description.getNullable("description")) + + /** The source of the project. */ + fun source(): Optional = Optional.ofNullable(source.getNullable("source")) + + /** The task type of the project. */ + fun taskType(): TaskType = taskType.getRequired("taskType") + + /** The number of versions (commits) in the project. */ + fun versionCount(): Long = versionCount.getRequired("versionCount") + + /** The number of inference pipelines in the project. */ + fun inferencePipelineCount(): Long = + inferencePipelineCount.getRequired("inferencePipelineCount") + + /** The total number of tests in the project. */ + fun goalCount(): Long = goalCount.getRequired("goalCount") + + /** The number of tests in the development mode of the project. */ + fun developmentGoalCount(): Long = developmentGoalCount.getRequired("developmentGoalCount") + + /** The number of tests in the monitoring mode of the project. */ + fun monitoringGoalCount(): Long = monitoringGoalCount.getRequired("monitoringGoalCount") + + /** Links to the project. */ + fun links(): Links = links.getRequired("links") + + fun gitRepo(): Optional = Optional.ofNullable(gitRepo.getNullable("gitRepo")) + + /** The project id. */ + @JsonProperty("id") @ExcludeMissing fun _id() = id + + /** The workspace id. */ + @JsonProperty("workspaceId") @ExcludeMissing fun _workspaceId() = workspaceId + + /** The project creator id. */ + @JsonProperty("creatorId") @ExcludeMissing fun _creatorId() = creatorId + + /** The project name. */ + @JsonProperty("name") @ExcludeMissing fun _name() = name + + /** The project creation date. */ + @JsonProperty("dateCreated") @ExcludeMissing fun _dateCreated() = dateCreated + + /** The project last updated date. */ + @JsonProperty("dateUpdated") @ExcludeMissing fun _dateUpdated() = dateUpdated + + /** The project description. */ + @JsonProperty("description") @ExcludeMissing fun _description() = description + + /** The source of the project. */ + @JsonProperty("source") @ExcludeMissing fun _source() = source + + /** The task type of the project. */ + @JsonProperty("taskType") @ExcludeMissing fun _taskType() = taskType + + /** The number of versions (commits) in the project. */ + @JsonProperty("versionCount") @ExcludeMissing fun _versionCount() = versionCount + + /** The number of inference pipelines in the project. */ + @JsonProperty("inferencePipelineCount") + @ExcludeMissing + fun _inferencePipelineCount() = inferencePipelineCount + + /** The total number of tests in the project. */ + @JsonProperty("goalCount") @ExcludeMissing fun _goalCount() = goalCount + + /** The number of tests in the development mode of the project. */ + @JsonProperty("developmentGoalCount") + @ExcludeMissing + fun _developmentGoalCount() = developmentGoalCount + + /** The number of tests in the monitoring mode of the project. */ + @JsonProperty("monitoringGoalCount") + @ExcludeMissing + fun _monitoringGoalCount() = monitoringGoalCount + + /** Links to the project. */ + @JsonProperty("links") @ExcludeMissing fun _links() = links + + @JsonProperty("gitRepo") @ExcludeMissing fun _gitRepo() = gitRepo + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): ProjectCreateResponse = apply { + if (!validated) { + id() + workspaceId() + creatorId() + name() + dateCreated() + dateUpdated() + description() + source() + taskType() + versionCount() + inferencePipelineCount() + goalCount() + developmentGoalCount() + monitoringGoalCount() + links().validate() + gitRepo().map { it.validate() } + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is ProjectCreateResponse && + this.id == other.id && + this.workspaceId == other.workspaceId && + this.creatorId == other.creatorId && + this.name == other.name && + this.dateCreated == other.dateCreated && + this.dateUpdated == other.dateUpdated && + this.description == other.description && + this.source == other.source && + this.taskType == other.taskType && + this.versionCount == other.versionCount && + this.inferencePipelineCount == other.inferencePipelineCount && + this.goalCount == other.goalCount && + this.developmentGoalCount == other.developmentGoalCount && + this.monitoringGoalCount == other.monitoringGoalCount && + this.links == other.links && + this.gitRepo == other.gitRepo && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + id, + workspaceId, + creatorId, + name, + dateCreated, + dateUpdated, + description, + source, + taskType, + versionCount, + inferencePipelineCount, + goalCount, + developmentGoalCount, + monitoringGoalCount, + links, + gitRepo, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "ProjectCreateResponse{id=$id, workspaceId=$workspaceId, creatorId=$creatorId, name=$name, dateCreated=$dateCreated, dateUpdated=$dateUpdated, description=$description, source=$source, taskType=$taskType, versionCount=$versionCount, inferencePipelineCount=$inferencePipelineCount, goalCount=$goalCount, developmentGoalCount=$developmentGoalCount, monitoringGoalCount=$monitoringGoalCount, links=$links, gitRepo=$gitRepo, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var id: JsonField = JsonMissing.of() + private var workspaceId: JsonField = JsonMissing.of() + private var creatorId: JsonField = JsonMissing.of() + private var name: JsonField = JsonMissing.of() + private var dateCreated: JsonField = JsonMissing.of() + private var dateUpdated: JsonField = JsonMissing.of() + private var description: JsonField = JsonMissing.of() + private var source: JsonField = JsonMissing.of() + private var taskType: JsonField = JsonMissing.of() + private var versionCount: JsonField = JsonMissing.of() + private var inferencePipelineCount: JsonField = JsonMissing.of() + private var goalCount: JsonField = JsonMissing.of() + private var developmentGoalCount: JsonField = JsonMissing.of() + private var monitoringGoalCount: JsonField = JsonMissing.of() + private var links: JsonField = JsonMissing.of() + private var gitRepo: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(projectCreateResponse: ProjectCreateResponse) = apply { + this.id = projectCreateResponse.id + this.workspaceId = projectCreateResponse.workspaceId + this.creatorId = projectCreateResponse.creatorId + this.name = projectCreateResponse.name + this.dateCreated = projectCreateResponse.dateCreated + this.dateUpdated = projectCreateResponse.dateUpdated + this.description = projectCreateResponse.description + this.source = projectCreateResponse.source + this.taskType = projectCreateResponse.taskType + this.versionCount = projectCreateResponse.versionCount + this.inferencePipelineCount = projectCreateResponse.inferencePipelineCount + this.goalCount = projectCreateResponse.goalCount + this.developmentGoalCount = projectCreateResponse.developmentGoalCount + this.monitoringGoalCount = projectCreateResponse.monitoringGoalCount + this.links = projectCreateResponse.links + this.gitRepo = projectCreateResponse.gitRepo + additionalProperties(projectCreateResponse.additionalProperties) + } + + /** The project id. */ + fun id(id: String) = id(JsonField.of(id)) + + /** The project id. */ + @JsonProperty("id") @ExcludeMissing fun id(id: JsonField) = apply { this.id = id } + + /** The workspace id. */ + fun workspaceId(workspaceId: String) = workspaceId(JsonField.of(workspaceId)) + + /** The workspace id. */ + @JsonProperty("workspaceId") + @ExcludeMissing + fun workspaceId(workspaceId: JsonField) = apply { this.workspaceId = workspaceId } + + /** The project creator id. */ + fun creatorId(creatorId: String) = creatorId(JsonField.of(creatorId)) + + /** The project creator id. */ + @JsonProperty("creatorId") + @ExcludeMissing + fun creatorId(creatorId: JsonField) = apply { this.creatorId = creatorId } + + /** The project name. */ + fun name(name: String) = name(JsonField.of(name)) + + /** The project name. */ + @JsonProperty("name") + @ExcludeMissing + fun name(name: JsonField) = apply { this.name = name } + + /** The project creation date. */ + fun dateCreated(dateCreated: OffsetDateTime) = dateCreated(JsonField.of(dateCreated)) + + /** The project creation date. */ + @JsonProperty("dateCreated") + @ExcludeMissing + fun dateCreated(dateCreated: JsonField) = apply { + this.dateCreated = dateCreated + } + + /** The project last updated date. */ + fun dateUpdated(dateUpdated: OffsetDateTime) = dateUpdated(JsonField.of(dateUpdated)) + + /** The project last updated date. */ + @JsonProperty("dateUpdated") + @ExcludeMissing + fun dateUpdated(dateUpdated: JsonField) = apply { + this.dateUpdated = dateUpdated + } + + /** The project description. */ + fun description(description: String) = description(JsonField.of(description)) + + /** The project description. */ + @JsonProperty("description") + @ExcludeMissing + fun description(description: JsonField) = apply { this.description = description } + + /** The source of the project. */ + fun source(source: Source) = source(JsonField.of(source)) + + /** The source of the project. */ + @JsonProperty("source") + @ExcludeMissing + fun source(source: JsonField) = apply { this.source = source } + + /** The task type of the project. */ + fun taskType(taskType: TaskType) = taskType(JsonField.of(taskType)) + + /** The task type of the project. */ + @JsonProperty("taskType") + @ExcludeMissing + fun taskType(taskType: JsonField) = apply { this.taskType = taskType } + + /** The number of versions (commits) in the project. */ + fun versionCount(versionCount: Long) = versionCount(JsonField.of(versionCount)) + + /** The number of versions (commits) in the project. */ + @JsonProperty("versionCount") + @ExcludeMissing + fun versionCount(versionCount: JsonField) = apply { this.versionCount = versionCount } + + /** The number of inference pipelines in the project. */ + fun inferencePipelineCount(inferencePipelineCount: Long) = + inferencePipelineCount(JsonField.of(inferencePipelineCount)) + + /** The number of inference pipelines in the project. */ + @JsonProperty("inferencePipelineCount") + @ExcludeMissing + fun inferencePipelineCount(inferencePipelineCount: JsonField) = apply { + this.inferencePipelineCount = inferencePipelineCount + } + + /** The total number of tests in the project. */ + fun goalCount(goalCount: Long) = goalCount(JsonField.of(goalCount)) + + /** The total number of tests in the project. */ + @JsonProperty("goalCount") + @ExcludeMissing + fun goalCount(goalCount: JsonField) = apply { this.goalCount = goalCount } + + /** The number of tests in the development mode of the project. */ + fun developmentGoalCount(developmentGoalCount: Long) = + developmentGoalCount(JsonField.of(developmentGoalCount)) + + /** The number of tests in the development mode of the project. */ + @JsonProperty("developmentGoalCount") + @ExcludeMissing + fun developmentGoalCount(developmentGoalCount: JsonField) = apply { + this.developmentGoalCount = developmentGoalCount + } + + /** The number of tests in the monitoring mode of the project. */ + fun monitoringGoalCount(monitoringGoalCount: Long) = + monitoringGoalCount(JsonField.of(monitoringGoalCount)) + + /** The number of tests in the monitoring mode of the project. */ + @JsonProperty("monitoringGoalCount") + @ExcludeMissing + fun monitoringGoalCount(monitoringGoalCount: JsonField) = apply { + this.monitoringGoalCount = monitoringGoalCount + } + + /** Links to the project. */ + fun links(links: Links) = links(JsonField.of(links)) + + /** Links to the project. */ + @JsonProperty("links") + @ExcludeMissing + fun links(links: JsonField) = apply { this.links = links } + + fun gitRepo(gitRepo: GitRepo) = gitRepo(JsonField.of(gitRepo)) + + @JsonProperty("gitRepo") + @ExcludeMissing + fun gitRepo(gitRepo: JsonField) = apply { this.gitRepo = gitRepo } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): ProjectCreateResponse = + ProjectCreateResponse( + id, + workspaceId, + creatorId, + name, + dateCreated, + dateUpdated, + description, + source, + taskType, + versionCount, + inferencePipelineCount, + goalCount, + developmentGoalCount, + monitoringGoalCount, + links, + gitRepo, + additionalProperties.toUnmodifiable(), + ) + } + + /** Links to the project. */ + @JsonDeserialize(builder = Links.Builder::class) + @NoAutoDetect + class Links + private constructor( + private val app: JsonField, + private val additionalProperties: Map, + ) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + fun app(): String = app.getRequired("app") + + @JsonProperty("app") @ExcludeMissing fun _app() = app + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): Links = apply { + if (!validated) { + app() + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Links && + this.app == other.app && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = Objects.hash(app, additionalProperties) + } + return hashCode + } + + override fun toString() = "Links{app=$app, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var app: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(links: Links) = apply { + this.app = links.app + additionalProperties(links.additionalProperties) + } + + fun app(app: String) = app(JsonField.of(app)) + + @JsonProperty("app") + @ExcludeMissing + fun app(app: JsonField) = apply { this.app = app } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): Links = Links(app, additionalProperties.toUnmodifiable()) + } + } + + class Source + @JsonCreator + private constructor( + private val value: JsonField, + ) : Enum { + + @com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Source && this.value == other.value + } + + override fun hashCode() = value.hashCode() + + override fun toString() = value.toString() + + companion object { + + @JvmField val WEB = Source(JsonField.of("web")) + + @JvmField val API = Source(JsonField.of("api")) + + @JvmField val NULL = Source(JsonField.of("null")) + + @JvmStatic fun of(value: String) = Source(JsonField.of(value)) + } + + enum class Known { + WEB, + API, + NULL, + } + + enum class Value { + WEB, + API, + NULL, + _UNKNOWN, + } + + fun value(): Value = + when (this) { + WEB -> Value.WEB + API -> Value.API + NULL -> Value.NULL + else -> Value._UNKNOWN + } + + fun known(): Known = + when (this) { + WEB -> Known.WEB + API -> Known.API + NULL -> Known.NULL + else -> throw OpenlayerInvalidDataException("Unknown Source: $value") + } + + fun asString(): String = _value().asStringOrThrow() + } + + class TaskType + @JsonCreator + private constructor( + private val value: JsonField, + ) : Enum { + + @com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is TaskType && this.value == other.value + } + + override fun hashCode() = value.hashCode() + + override fun toString() = value.toString() + + companion object { + + @JvmField val LLM_BASE = TaskType(JsonField.of("llm-base")) + + @JvmField val TABULAR_CLASSIFICATION = TaskType(JsonField.of("tabular-classification")) + + @JvmField val TABULAR_REGRESSION = TaskType(JsonField.of("tabular-regression")) + + @JvmField val TEXT_CLASSIFICATION = TaskType(JsonField.of("text-classification")) + + @JvmStatic fun of(value: String) = TaskType(JsonField.of(value)) + } + + enum class Known { + LLM_BASE, + TABULAR_CLASSIFICATION, + TABULAR_REGRESSION, + TEXT_CLASSIFICATION, + } + + enum class Value { + LLM_BASE, + TABULAR_CLASSIFICATION, + TABULAR_REGRESSION, + TEXT_CLASSIFICATION, + _UNKNOWN, + } + + fun value(): Value = + when (this) { + LLM_BASE -> Value.LLM_BASE + TABULAR_CLASSIFICATION -> Value.TABULAR_CLASSIFICATION + TABULAR_REGRESSION -> Value.TABULAR_REGRESSION + TEXT_CLASSIFICATION -> Value.TEXT_CLASSIFICATION + else -> Value._UNKNOWN + } + + fun known(): Known = + when (this) { + LLM_BASE -> Known.LLM_BASE + TABULAR_CLASSIFICATION -> Known.TABULAR_CLASSIFICATION + TABULAR_REGRESSION -> Known.TABULAR_REGRESSION + TEXT_CLASSIFICATION -> Known.TEXT_CLASSIFICATION + else -> throw OpenlayerInvalidDataException("Unknown TaskType: $value") + } + + fun asString(): String = _value().asStringOrThrow() + } + + @JsonDeserialize(builder = GitRepo.Builder::class) + @NoAutoDetect + class GitRepo + private constructor( + private val id: JsonField, + private val gitId: JsonField, + private val dateConnected: JsonField, + private val dateUpdated: JsonField, + private val branch: JsonField, + private val name: JsonField, + private val private_: JsonField, + private val slug: JsonField, + private val url: JsonField, + private val rootDir: JsonField, + private val projectId: JsonField, + private val gitAccountId: JsonField, + private val additionalProperties: Map, + ) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + fun id(): String = id.getRequired("id") + + fun gitId(): Long = gitId.getRequired("gitId") + + fun dateConnected(): OffsetDateTime = dateConnected.getRequired("dateConnected") + + fun dateUpdated(): OffsetDateTime = dateUpdated.getRequired("dateUpdated") + + fun branch(): Optional = Optional.ofNullable(branch.getNullable("branch")) + + fun name(): String = name.getRequired("name") + + fun private_(): Boolean = private_.getRequired("private") + + fun slug(): String = slug.getRequired("slug") + + fun url(): String = url.getRequired("url") + + fun rootDir(): Optional = Optional.ofNullable(rootDir.getNullable("rootDir")) + + fun projectId(): String = projectId.getRequired("projectId") + + fun gitAccountId(): String = gitAccountId.getRequired("gitAccountId") + + @JsonProperty("id") @ExcludeMissing fun _id() = id + + @JsonProperty("gitId") @ExcludeMissing fun _gitId() = gitId + + @JsonProperty("dateConnected") @ExcludeMissing fun _dateConnected() = dateConnected + + @JsonProperty("dateUpdated") @ExcludeMissing fun _dateUpdated() = dateUpdated + + @JsonProperty("branch") @ExcludeMissing fun _branch() = branch + + @JsonProperty("name") @ExcludeMissing fun _name() = name + + @JsonProperty("private") @ExcludeMissing fun _private_() = private_ + + @JsonProperty("slug") @ExcludeMissing fun _slug() = slug + + @JsonProperty("url") @ExcludeMissing fun _url() = url + + @JsonProperty("rootDir") @ExcludeMissing fun _rootDir() = rootDir + + @JsonProperty("projectId") @ExcludeMissing fun _projectId() = projectId + + @JsonProperty("gitAccountId") @ExcludeMissing fun _gitAccountId() = gitAccountId + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): GitRepo = apply { + if (!validated) { + id() + gitId() + dateConnected() + dateUpdated() + branch() + name() + private_() + slug() + url() + rootDir() + projectId() + gitAccountId() + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is GitRepo && + this.id == other.id && + this.gitId == other.gitId && + this.dateConnected == other.dateConnected && + this.dateUpdated == other.dateUpdated && + this.branch == other.branch && + this.name == other.name && + this.private_ == other.private_ && + this.slug == other.slug && + this.url == other.url && + this.rootDir == other.rootDir && + this.projectId == other.projectId && + this.gitAccountId == other.gitAccountId && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + id, + gitId, + dateConnected, + dateUpdated, + branch, + name, + private_, + slug, + url, + rootDir, + projectId, + gitAccountId, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "GitRepo{id=$id, gitId=$gitId, dateConnected=$dateConnected, dateUpdated=$dateUpdated, branch=$branch, name=$name, private_=$private_, slug=$slug, url=$url, rootDir=$rootDir, projectId=$projectId, gitAccountId=$gitAccountId, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var id: JsonField = JsonMissing.of() + private var gitId: JsonField = JsonMissing.of() + private var dateConnected: JsonField = JsonMissing.of() + private var dateUpdated: JsonField = JsonMissing.of() + private var branch: JsonField = JsonMissing.of() + private var name: JsonField = JsonMissing.of() + private var private_: JsonField = JsonMissing.of() + private var slug: JsonField = JsonMissing.of() + private var url: JsonField = JsonMissing.of() + private var rootDir: JsonField = JsonMissing.of() + private var projectId: JsonField = JsonMissing.of() + private var gitAccountId: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(gitRepo: GitRepo) = apply { + this.id = gitRepo.id + this.gitId = gitRepo.gitId + this.dateConnected = gitRepo.dateConnected + this.dateUpdated = gitRepo.dateUpdated + this.branch = gitRepo.branch + this.name = gitRepo.name + this.private_ = gitRepo.private_ + this.slug = gitRepo.slug + this.url = gitRepo.url + this.rootDir = gitRepo.rootDir + this.projectId = gitRepo.projectId + this.gitAccountId = gitRepo.gitAccountId + additionalProperties(gitRepo.additionalProperties) + } + + fun id(id: String) = id(JsonField.of(id)) + + @JsonProperty("id") + @ExcludeMissing + fun id(id: JsonField) = apply { this.id = id } + + fun gitId(gitId: Long) = gitId(JsonField.of(gitId)) + + @JsonProperty("gitId") + @ExcludeMissing + fun gitId(gitId: JsonField) = apply { this.gitId = gitId } + + fun dateConnected(dateConnected: OffsetDateTime) = + dateConnected(JsonField.of(dateConnected)) + + @JsonProperty("dateConnected") + @ExcludeMissing + fun dateConnected(dateConnected: JsonField) = apply { + this.dateConnected = dateConnected + } + + fun dateUpdated(dateUpdated: OffsetDateTime) = dateUpdated(JsonField.of(dateUpdated)) + + @JsonProperty("dateUpdated") + @ExcludeMissing + fun dateUpdated(dateUpdated: JsonField) = apply { + this.dateUpdated = dateUpdated + } + + fun branch(branch: String) = branch(JsonField.of(branch)) + + @JsonProperty("branch") + @ExcludeMissing + fun branch(branch: JsonField) = apply { this.branch = branch } + + fun name(name: String) = name(JsonField.of(name)) + + @JsonProperty("name") + @ExcludeMissing + fun name(name: JsonField) = apply { this.name = name } + + fun private_(private_: Boolean) = private_(JsonField.of(private_)) + + @JsonProperty("private") + @ExcludeMissing + fun private_(private_: JsonField) = apply { this.private_ = private_ } + + fun slug(slug: String) = slug(JsonField.of(slug)) + + @JsonProperty("slug") + @ExcludeMissing + fun slug(slug: JsonField) = apply { this.slug = slug } + + fun url(url: String) = url(JsonField.of(url)) + + @JsonProperty("url") + @ExcludeMissing + fun url(url: JsonField) = apply { this.url = url } + + fun rootDir(rootDir: String) = rootDir(JsonField.of(rootDir)) + + @JsonProperty("rootDir") + @ExcludeMissing + fun rootDir(rootDir: JsonField) = apply { this.rootDir = rootDir } + + fun projectId(projectId: String) = projectId(JsonField.of(projectId)) + + @JsonProperty("projectId") + @ExcludeMissing + fun projectId(projectId: JsonField) = apply { this.projectId = projectId } + + fun gitAccountId(gitAccountId: String) = gitAccountId(JsonField.of(gitAccountId)) + + @JsonProperty("gitAccountId") + @ExcludeMissing + fun gitAccountId(gitAccountId: JsonField) = apply { + this.gitAccountId = gitAccountId + } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): GitRepo = + GitRepo( + id, + gitId, + dateConnected, + dateUpdated, + branch, + name, + private_, + slug, + url, + rootDir, + projectId, + gitAccountId, + additionalProperties.toUnmodifiable(), + ) + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateParams.kt new file mode 100644 index 0000000..cab7c08 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateParams.kt @@ -0,0 +1,449 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.fasterxml.jackson.annotation.JsonAnyGetter +import com.fasterxml.jackson.annotation.JsonAnySetter +import com.fasterxml.jackson.annotation.JsonCreator +import com.fasterxml.jackson.annotation.JsonProperty +import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import com.openlayer.api.models.* +import java.util.Objects +import java.util.Optional + +class ProjectInferencePipelineCreateParams +constructor( + private val projectId: String, + private val description: String?, + private val name: String, + private val additionalQueryParams: Map>, + private val additionalHeaders: Map>, + private val additionalBodyProperties: Map, +) { + + fun projectId(): String = projectId + + fun description(): Optional = Optional.ofNullable(description) + + fun name(): String = name + + @JvmSynthetic + internal fun getBody(): ProjectInferencePipelineCreateBody { + return ProjectInferencePipelineCreateBody( + description, + name, + additionalBodyProperties, + ) + } + + @JvmSynthetic internal fun getQueryParams(): Map> = additionalQueryParams + + @JvmSynthetic internal fun getHeaders(): Map> = additionalHeaders + + fun getPathParam(index: Int): String { + return when (index) { + 0 -> projectId + else -> "" + } + } + + @JsonDeserialize(builder = ProjectInferencePipelineCreateBody.Builder::class) + @NoAutoDetect + class ProjectInferencePipelineCreateBody + internal constructor( + private val description: String?, + private val name: String?, + private val additionalProperties: Map, + ) { + + private var hashCode: Int = 0 + + /** The inference pipeline description. */ + @JsonProperty("description") fun description(): String? = description + + /** The inference pipeline name. */ + @JsonProperty("name") fun name(): String? = name + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is ProjectInferencePipelineCreateBody && + this.description == other.description && + this.name == other.name && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + description, + name, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "ProjectInferencePipelineCreateBody{description=$description, name=$name, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var description: String? = null + private var name: String? = null + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from( + projectInferencePipelineCreateBody: ProjectInferencePipelineCreateBody + ) = apply { + this.description = projectInferencePipelineCreateBody.description + this.name = projectInferencePipelineCreateBody.name + additionalProperties(projectInferencePipelineCreateBody.additionalProperties) + } + + /** The inference pipeline description. */ + @JsonProperty("description") + fun description(description: String) = apply { this.description = description } + + /** The inference pipeline name. */ + @JsonProperty("name") fun name(name: String) = apply { this.name = name } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): ProjectInferencePipelineCreateBody = + ProjectInferencePipelineCreateBody( + description, + checkNotNull(name) { "`name` is required but was not set" }, + additionalProperties.toUnmodifiable(), + ) + } + } + + fun _additionalQueryParams(): Map> = additionalQueryParams + + fun _additionalHeaders(): Map> = additionalHeaders + + fun _additionalBodyProperties(): Map = additionalBodyProperties + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is ProjectInferencePipelineCreateParams && + this.projectId == other.projectId && + this.description == other.description && + this.name == other.name && + this.additionalQueryParams == other.additionalQueryParams && + this.additionalHeaders == other.additionalHeaders && + this.additionalBodyProperties == other.additionalBodyProperties + } + + override fun hashCode(): Int { + return Objects.hash( + projectId, + description, + name, + additionalQueryParams, + additionalHeaders, + additionalBodyProperties, + ) + } + + override fun toString() = + "ProjectInferencePipelineCreateParams{projectId=$projectId, description=$description, name=$name, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + + fun toBuilder() = Builder().from(this) + + companion object { + + @JvmStatic fun builder() = Builder() + } + + @NoAutoDetect + class Builder { + + private var projectId: String? = null + private var description: String? = null + private var name: String? = null + private var additionalQueryParams: MutableMap> = mutableMapOf() + private var additionalHeaders: MutableMap> = mutableMapOf() + private var additionalBodyProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from( + projectInferencePipelineCreateParams: ProjectInferencePipelineCreateParams + ) = apply { + this.projectId = projectInferencePipelineCreateParams.projectId + this.description = projectInferencePipelineCreateParams.description + this.name = projectInferencePipelineCreateParams.name + additionalQueryParams(projectInferencePipelineCreateParams.additionalQueryParams) + additionalHeaders(projectInferencePipelineCreateParams.additionalHeaders) + additionalBodyProperties(projectInferencePipelineCreateParams.additionalBodyProperties) + } + + fun projectId(projectId: String) = apply { this.projectId = projectId } + + /** The inference pipeline description. */ + fun description(description: String) = apply { this.description = description } + + /** The inference pipeline name. */ + fun name(name: String) = apply { this.name = name } + + fun additionalQueryParams(additionalQueryParams: Map>) = apply { + this.additionalQueryParams.clear() + putAllQueryParams(additionalQueryParams) + } + + fun putQueryParam(name: String, value: String) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putQueryParams(name: String, values: Iterable) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllQueryParams(additionalQueryParams: Map>) = apply { + additionalQueryParams.forEach(this::putQueryParams) + } + + fun removeQueryParam(name: String) = apply { + this.additionalQueryParams.put(name, mutableListOf()) + } + + fun additionalHeaders(additionalHeaders: Map>) = apply { + this.additionalHeaders.clear() + putAllHeaders(additionalHeaders) + } + + fun putHeader(name: String, value: String) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putHeaders(name: String, values: Iterable) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllHeaders(additionalHeaders: Map>) = apply { + additionalHeaders.forEach(this::putHeaders) + } + + fun removeHeader(name: String) = apply { this.additionalHeaders.put(name, mutableListOf()) } + + fun additionalBodyProperties(additionalBodyProperties: Map) = apply { + this.additionalBodyProperties.clear() + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun putAdditionalBodyProperty(key: String, value: JsonValue) = apply { + this.additionalBodyProperties.put(key, value) + } + + fun putAllAdditionalBodyProperties(additionalBodyProperties: Map) = + apply { + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun build(): ProjectInferencePipelineCreateParams = + ProjectInferencePipelineCreateParams( + checkNotNull(projectId) { "`projectId` is required but was not set" }, + description, + checkNotNull(name) { "`name` is required but was not set" }, + additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalHeaders.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalBodyProperties.toUnmodifiable(), + ) + } + + @JsonDeserialize(builder = Links.Builder::class) + @NoAutoDetect + class Links + private constructor( + private val app: String?, + private val additionalProperties: Map, + ) { + + private var hashCode: Int = 0 + + @JsonProperty("app") fun app(): String? = app + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Links && + this.app == other.app && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = Objects.hash(app, additionalProperties) + } + return hashCode + } + + override fun toString() = "Links{app=$app, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var app: String? = null + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(links: Links) = apply { + this.app = links.app + additionalProperties(links.additionalProperties) + } + + @JsonProperty("app") fun app(app: String) = apply { this.app = app } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): Links = + Links( + checkNotNull(app) { "`app` is required but was not set" }, + additionalProperties.toUnmodifiable() + ) + } + } + + class Status + @JsonCreator + private constructor( + private val value: JsonField, + ) : Enum { + + @com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Status && this.value == other.value + } + + override fun hashCode() = value.hashCode() + + override fun toString() = value.toString() + + companion object { + + @JvmField val QUEUED = Status(JsonField.of("queued")) + + @JvmField val RUNNING = Status(JsonField.of("running")) + + @JvmField val PAUSED = Status(JsonField.of("paused")) + + @JvmField val FAILED = Status(JsonField.of("failed")) + + @JvmField val COMPLETED = Status(JsonField.of("completed")) + + @JvmField val UNKNOWN = Status(JsonField.of("unknown")) + + @JvmStatic fun of(value: String) = Status(JsonField.of(value)) + } + + enum class Known { + QUEUED, + RUNNING, + PAUSED, + FAILED, + COMPLETED, + UNKNOWN, + } + + enum class Value { + QUEUED, + RUNNING, + PAUSED, + FAILED, + COMPLETED, + UNKNOWN, + _UNKNOWN, + } + + fun value(): Value = + when (this) { + QUEUED -> Value.QUEUED + RUNNING -> Value.RUNNING + PAUSED -> Value.PAUSED + FAILED -> Value.FAILED + COMPLETED -> Value.COMPLETED + UNKNOWN -> Value.UNKNOWN + else -> Value._UNKNOWN + } + + fun known(): Known = + when (this) { + QUEUED -> Known.QUEUED + RUNNING -> Known.RUNNING + PAUSED -> Known.PAUSED + FAILED -> Known.FAILED + COMPLETED -> Known.COMPLETED + UNKNOWN -> Known.UNKNOWN + else -> throw OpenlayerInvalidDataException("Unknown Status: $value") + } + + fun asString(): String = _value().asStringOrThrow() + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateResponse.kt new file mode 100644 index 0000000..acd34bb --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateResponse.kt @@ -0,0 +1,613 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.fasterxml.jackson.annotation.JsonAnyGetter +import com.fasterxml.jackson.annotation.JsonAnySetter +import com.fasterxml.jackson.annotation.JsonCreator +import com.fasterxml.jackson.annotation.JsonProperty +import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import java.time.OffsetDateTime +import java.util.Objects +import java.util.Optional + +@JsonDeserialize(builder = ProjectInferencePipelineCreateResponse.Builder::class) +@NoAutoDetect +class ProjectInferencePipelineCreateResponse +private constructor( + private val id: JsonField, + private val projectId: JsonField, + private val name: JsonField, + private val dateCreated: JsonField, + private val dateUpdated: JsonField, + private val dateLastSampleReceived: JsonField, + private val description: JsonField, + private val dateLastEvaluated: JsonField, + private val dateOfNextEvaluation: JsonField, + private val passingGoalCount: JsonField, + private val failingGoalCount: JsonField, + private val totalGoalCount: JsonField, + private val status: JsonField, + private val statusMessage: JsonField, + private val links: JsonField, + private val additionalProperties: Map, +) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + /** The inference pipeline id. */ + fun id(): String = id.getRequired("id") + + /** The project id. */ + fun projectId(): String = projectId.getRequired("projectId") + + /** The inference pipeline name. */ + fun name(): String = name.getRequired("name") + + /** The creation date. */ + fun dateCreated(): OffsetDateTime = dateCreated.getRequired("dateCreated") + + /** The last updated date. */ + fun dateUpdated(): OffsetDateTime = dateUpdated.getRequired("dateUpdated") + + /** The last data sample received date. */ + fun dateLastSampleReceived(): Optional = + Optional.ofNullable(dateLastSampleReceived.getNullable("dateLastSampleReceived")) + + /** The inference pipeline description. */ + fun description(): Optional = + Optional.ofNullable(description.getNullable("description")) + + /** The last test evaluation date. */ + fun dateLastEvaluated(): Optional = + Optional.ofNullable(dateLastEvaluated.getNullable("dateLastEvaluated")) + + /** The next test evaluation date. */ + fun dateOfNextEvaluation(): Optional = + Optional.ofNullable(dateOfNextEvaluation.getNullable("dateOfNextEvaluation")) + + /** The number of tests passing. */ + fun passingGoalCount(): Long = passingGoalCount.getRequired("passingGoalCount") + + /** The number of tests failing. */ + fun failingGoalCount(): Long = failingGoalCount.getRequired("failingGoalCount") + + /** The total number of tests. */ + fun totalGoalCount(): Long = totalGoalCount.getRequired("totalGoalCount") + + /** The status of test evaluation for the inference pipeline. */ + fun status(): Status = status.getRequired("status") + + /** The status message of test evaluation for the inference pipeline. */ + fun statusMessage(): Optional = + Optional.ofNullable(statusMessage.getNullable("statusMessage")) + + fun links(): Links = links.getRequired("links") + + /** The inference pipeline id. */ + @JsonProperty("id") @ExcludeMissing fun _id() = id + + /** The project id. */ + @JsonProperty("projectId") @ExcludeMissing fun _projectId() = projectId + + /** The inference pipeline name. */ + @JsonProperty("name") @ExcludeMissing fun _name() = name + + /** The creation date. */ + @JsonProperty("dateCreated") @ExcludeMissing fun _dateCreated() = dateCreated + + /** The last updated date. */ + @JsonProperty("dateUpdated") @ExcludeMissing fun _dateUpdated() = dateUpdated + + /** The last data sample received date. */ + @JsonProperty("dateLastSampleReceived") + @ExcludeMissing + fun _dateLastSampleReceived() = dateLastSampleReceived + + /** The inference pipeline description. */ + @JsonProperty("description") @ExcludeMissing fun _description() = description + + /** The last test evaluation date. */ + @JsonProperty("dateLastEvaluated") @ExcludeMissing fun _dateLastEvaluated() = dateLastEvaluated + + /** The next test evaluation date. */ + @JsonProperty("dateOfNextEvaluation") + @ExcludeMissing + fun _dateOfNextEvaluation() = dateOfNextEvaluation + + /** The number of tests passing. */ + @JsonProperty("passingGoalCount") @ExcludeMissing fun _passingGoalCount() = passingGoalCount + + /** The number of tests failing. */ + @JsonProperty("failingGoalCount") @ExcludeMissing fun _failingGoalCount() = failingGoalCount + + /** The total number of tests. */ + @JsonProperty("totalGoalCount") @ExcludeMissing fun _totalGoalCount() = totalGoalCount + + /** The status of test evaluation for the inference pipeline. */ + @JsonProperty("status") @ExcludeMissing fun _status() = status + + /** The status message of test evaluation for the inference pipeline. */ + @JsonProperty("statusMessage") @ExcludeMissing fun _statusMessage() = statusMessage + + @JsonProperty("links") @ExcludeMissing fun _links() = links + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): ProjectInferencePipelineCreateResponse = apply { + if (!validated) { + id() + projectId() + name() + dateCreated() + dateUpdated() + dateLastSampleReceived() + description() + dateLastEvaluated() + dateOfNextEvaluation() + passingGoalCount() + failingGoalCount() + totalGoalCount() + status() + statusMessage() + links().validate() + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is ProjectInferencePipelineCreateResponse && + this.id == other.id && + this.projectId == other.projectId && + this.name == other.name && + this.dateCreated == other.dateCreated && + this.dateUpdated == other.dateUpdated && + this.dateLastSampleReceived == other.dateLastSampleReceived && + this.description == other.description && + this.dateLastEvaluated == other.dateLastEvaluated && + this.dateOfNextEvaluation == other.dateOfNextEvaluation && + this.passingGoalCount == other.passingGoalCount && + this.failingGoalCount == other.failingGoalCount && + this.totalGoalCount == other.totalGoalCount && + this.status == other.status && + this.statusMessage == other.statusMessage && + this.links == other.links && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + id, + projectId, + name, + dateCreated, + dateUpdated, + dateLastSampleReceived, + description, + dateLastEvaluated, + dateOfNextEvaluation, + passingGoalCount, + failingGoalCount, + totalGoalCount, + status, + statusMessage, + links, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "ProjectInferencePipelineCreateResponse{id=$id, projectId=$projectId, name=$name, dateCreated=$dateCreated, dateUpdated=$dateUpdated, dateLastSampleReceived=$dateLastSampleReceived, description=$description, dateLastEvaluated=$dateLastEvaluated, dateOfNextEvaluation=$dateOfNextEvaluation, passingGoalCount=$passingGoalCount, failingGoalCount=$failingGoalCount, totalGoalCount=$totalGoalCount, status=$status, statusMessage=$statusMessage, links=$links, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var id: JsonField = JsonMissing.of() + private var projectId: JsonField = JsonMissing.of() + private var name: JsonField = JsonMissing.of() + private var dateCreated: JsonField = JsonMissing.of() + private var dateUpdated: JsonField = JsonMissing.of() + private var dateLastSampleReceived: JsonField = JsonMissing.of() + private var description: JsonField = JsonMissing.of() + private var dateLastEvaluated: JsonField = JsonMissing.of() + private var dateOfNextEvaluation: JsonField = JsonMissing.of() + private var passingGoalCount: JsonField = JsonMissing.of() + private var failingGoalCount: JsonField = JsonMissing.of() + private var totalGoalCount: JsonField = JsonMissing.of() + private var status: JsonField = JsonMissing.of() + private var statusMessage: JsonField = JsonMissing.of() + private var links: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from( + projectInferencePipelineCreateResponse: ProjectInferencePipelineCreateResponse + ) = apply { + this.id = projectInferencePipelineCreateResponse.id + this.projectId = projectInferencePipelineCreateResponse.projectId + this.name = projectInferencePipelineCreateResponse.name + this.dateCreated = projectInferencePipelineCreateResponse.dateCreated + this.dateUpdated = projectInferencePipelineCreateResponse.dateUpdated + this.dateLastSampleReceived = + projectInferencePipelineCreateResponse.dateLastSampleReceived + this.description = projectInferencePipelineCreateResponse.description + this.dateLastEvaluated = projectInferencePipelineCreateResponse.dateLastEvaluated + this.dateOfNextEvaluation = projectInferencePipelineCreateResponse.dateOfNextEvaluation + this.passingGoalCount = projectInferencePipelineCreateResponse.passingGoalCount + this.failingGoalCount = projectInferencePipelineCreateResponse.failingGoalCount + this.totalGoalCount = projectInferencePipelineCreateResponse.totalGoalCount + this.status = projectInferencePipelineCreateResponse.status + this.statusMessage = projectInferencePipelineCreateResponse.statusMessage + this.links = projectInferencePipelineCreateResponse.links + additionalProperties(projectInferencePipelineCreateResponse.additionalProperties) + } + + /** The inference pipeline id. */ + fun id(id: String) = id(JsonField.of(id)) + + /** The inference pipeline id. */ + @JsonProperty("id") @ExcludeMissing fun id(id: JsonField) = apply { this.id = id } + + /** The project id. */ + fun projectId(projectId: String) = projectId(JsonField.of(projectId)) + + /** The project id. */ + @JsonProperty("projectId") + @ExcludeMissing + fun projectId(projectId: JsonField) = apply { this.projectId = projectId } + + /** The inference pipeline name. */ + fun name(name: String) = name(JsonField.of(name)) + + /** The inference pipeline name. */ + @JsonProperty("name") + @ExcludeMissing + fun name(name: JsonField) = apply { this.name = name } + + /** The creation date. */ + fun dateCreated(dateCreated: OffsetDateTime) = dateCreated(JsonField.of(dateCreated)) + + /** The creation date. */ + @JsonProperty("dateCreated") + @ExcludeMissing + fun dateCreated(dateCreated: JsonField) = apply { + this.dateCreated = dateCreated + } + + /** The last updated date. */ + fun dateUpdated(dateUpdated: OffsetDateTime) = dateUpdated(JsonField.of(dateUpdated)) + + /** The last updated date. */ + @JsonProperty("dateUpdated") + @ExcludeMissing + fun dateUpdated(dateUpdated: JsonField) = apply { + this.dateUpdated = dateUpdated + } + + /** The last data sample received date. */ + fun dateLastSampleReceived(dateLastSampleReceived: OffsetDateTime) = + dateLastSampleReceived(JsonField.of(dateLastSampleReceived)) + + /** The last data sample received date. */ + @JsonProperty("dateLastSampleReceived") + @ExcludeMissing + fun dateLastSampleReceived(dateLastSampleReceived: JsonField) = apply { + this.dateLastSampleReceived = dateLastSampleReceived + } + + /** The inference pipeline description. */ + fun description(description: String) = description(JsonField.of(description)) + + /** The inference pipeline description. */ + @JsonProperty("description") + @ExcludeMissing + fun description(description: JsonField) = apply { this.description = description } + + /** The last test evaluation date. */ + fun dateLastEvaluated(dateLastEvaluated: OffsetDateTime) = + dateLastEvaluated(JsonField.of(dateLastEvaluated)) + + /** The last test evaluation date. */ + @JsonProperty("dateLastEvaluated") + @ExcludeMissing + fun dateLastEvaluated(dateLastEvaluated: JsonField) = apply { + this.dateLastEvaluated = dateLastEvaluated + } + + /** The next test evaluation date. */ + fun dateOfNextEvaluation(dateOfNextEvaluation: OffsetDateTime) = + dateOfNextEvaluation(JsonField.of(dateOfNextEvaluation)) + + /** The next test evaluation date. */ + @JsonProperty("dateOfNextEvaluation") + @ExcludeMissing + fun dateOfNextEvaluation(dateOfNextEvaluation: JsonField) = apply { + this.dateOfNextEvaluation = dateOfNextEvaluation + } + + /** The number of tests passing. */ + fun passingGoalCount(passingGoalCount: Long) = + passingGoalCount(JsonField.of(passingGoalCount)) + + /** The number of tests passing. */ + @JsonProperty("passingGoalCount") + @ExcludeMissing + fun passingGoalCount(passingGoalCount: JsonField) = apply { + this.passingGoalCount = passingGoalCount + } + + /** The number of tests failing. */ + fun failingGoalCount(failingGoalCount: Long) = + failingGoalCount(JsonField.of(failingGoalCount)) + + /** The number of tests failing. */ + @JsonProperty("failingGoalCount") + @ExcludeMissing + fun failingGoalCount(failingGoalCount: JsonField) = apply { + this.failingGoalCount = failingGoalCount + } + + /** The total number of tests. */ + fun totalGoalCount(totalGoalCount: Long) = totalGoalCount(JsonField.of(totalGoalCount)) + + /** The total number of tests. */ + @JsonProperty("totalGoalCount") + @ExcludeMissing + fun totalGoalCount(totalGoalCount: JsonField) = apply { + this.totalGoalCount = totalGoalCount + } + + /** The status of test evaluation for the inference pipeline. */ + fun status(status: Status) = status(JsonField.of(status)) + + /** The status of test evaluation for the inference pipeline. */ + @JsonProperty("status") + @ExcludeMissing + fun status(status: JsonField) = apply { this.status = status } + + /** The status message of test evaluation for the inference pipeline. */ + fun statusMessage(statusMessage: String) = statusMessage(JsonField.of(statusMessage)) + + /** The status message of test evaluation for the inference pipeline. */ + @JsonProperty("statusMessage") + @ExcludeMissing + fun statusMessage(statusMessage: JsonField) = apply { + this.statusMessage = statusMessage + } + + fun links(links: Links) = links(JsonField.of(links)) + + @JsonProperty("links") + @ExcludeMissing + fun links(links: JsonField) = apply { this.links = links } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): ProjectInferencePipelineCreateResponse = + ProjectInferencePipelineCreateResponse( + id, + projectId, + name, + dateCreated, + dateUpdated, + dateLastSampleReceived, + description, + dateLastEvaluated, + dateOfNextEvaluation, + passingGoalCount, + failingGoalCount, + totalGoalCount, + status, + statusMessage, + links, + additionalProperties.toUnmodifiable(), + ) + } + + @JsonDeserialize(builder = Links.Builder::class) + @NoAutoDetect + class Links + private constructor( + private val app: JsonField, + private val additionalProperties: Map, + ) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + fun app(): String = app.getRequired("app") + + @JsonProperty("app") @ExcludeMissing fun _app() = app + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): Links = apply { + if (!validated) { + app() + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Links && + this.app == other.app && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = Objects.hash(app, additionalProperties) + } + return hashCode + } + + override fun toString() = "Links{app=$app, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var app: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(links: Links) = apply { + this.app = links.app + additionalProperties(links.additionalProperties) + } + + fun app(app: String) = app(JsonField.of(app)) + + @JsonProperty("app") + @ExcludeMissing + fun app(app: JsonField) = apply { this.app = app } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): Links = Links(app, additionalProperties.toUnmodifiable()) + } + } + + class Status + @JsonCreator + private constructor( + private val value: JsonField, + ) : Enum { + + @com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is Status && this.value == other.value + } + + override fun hashCode() = value.hashCode() + + override fun toString() = value.toString() + + companion object { + + @JvmField val QUEUED = Status(JsonField.of("queued")) + + @JvmField val RUNNING = Status(JsonField.of("running")) + + @JvmField val PAUSED = Status(JsonField.of("paused")) + + @JvmField val FAILED = Status(JsonField.of("failed")) + + @JvmField val COMPLETED = Status(JsonField.of("completed")) + + @JvmField val UNKNOWN = Status(JsonField.of("unknown")) + + @JvmStatic fun of(value: String) = Status(JsonField.of(value)) + } + + enum class Known { + QUEUED, + RUNNING, + PAUSED, + FAILED, + COMPLETED, + UNKNOWN, + } + + enum class Value { + QUEUED, + RUNNING, + PAUSED, + FAILED, + COMPLETED, + UNKNOWN, + _UNKNOWN, + } + + fun value(): Value = + when (this) { + QUEUED -> Value.QUEUED + RUNNING -> Value.RUNNING + PAUSED -> Value.PAUSED + FAILED -> Value.FAILED + COMPLETED -> Value.COMPLETED + UNKNOWN -> Value.UNKNOWN + else -> Value._UNKNOWN + } + + fun known(): Known = + when (this) { + QUEUED -> Known.QUEUED + RUNNING -> Known.RUNNING + PAUSED -> Known.PAUSED + FAILED -> Known.FAILED + COMPLETED -> Known.COMPLETED + UNKNOWN -> Known.UNKNOWN + else -> throw OpenlayerInvalidDataException("Unknown Status: $value") + } + + fun asString(): String = _value().asStringOrThrow() + } +} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectInferencePipelineListParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineListParams.kt similarity index 87% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectInferencePipelineListParams.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineListParams.kt index 3b5c238..1b909ab 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectInferencePipelineListParams.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineListParams.kt @@ -1,17 +1,17 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.models.* import java.util.Objects import java.util.Optional -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.toUnmodifiable -import org.openlayer.models.* class ProjectInferencePipelineListParams constructor( - private val id: String, + private val projectId: String, private val name: String?, private val page: Long?, private val perPage: Long?, @@ -20,7 +20,7 @@ constructor( private val additionalBodyProperties: Map, ) { - fun id(): String = id + fun projectId(): String = projectId fun name(): Optional = Optional.ofNullable(name) @@ -42,7 +42,7 @@ constructor( fun getPathParam(index: Int): String { return when (index) { - 0 -> id + 0 -> projectId else -> "" } } @@ -59,7 +59,7 @@ constructor( } return other is ProjectInferencePipelineListParams && - this.id == other.id && + this.projectId == other.projectId && this.name == other.name && this.page == other.page && this.perPage == other.perPage && @@ -70,7 +70,7 @@ constructor( override fun hashCode(): Int { return Objects.hash( - id, + projectId, name, page, perPage, @@ -81,7 +81,7 @@ constructor( } override fun toString() = - "ProjectInferencePipelineListParams{id=$id, name=$name, page=$page, perPage=$perPage, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + "ProjectInferencePipelineListParams{projectId=$projectId, name=$name, page=$page, perPage=$perPage, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" fun toBuilder() = Builder().from(this) @@ -93,7 +93,7 @@ constructor( @NoAutoDetect class Builder { - private var id: String? = null + private var projectId: String? = null private var name: String? = null private var page: Long? = null private var perPage: Long? = null @@ -104,7 +104,7 @@ constructor( @JvmSynthetic internal fun from(projectInferencePipelineListParams: ProjectInferencePipelineListParams) = apply { - this.id = projectInferencePipelineListParams.id + this.projectId = projectInferencePipelineListParams.projectId this.name = projectInferencePipelineListParams.name this.page = projectInferencePipelineListParams.page this.perPage = projectInferencePipelineListParams.perPage @@ -115,7 +115,7 @@ constructor( ) } - fun id(id: String) = apply { this.id = id } + fun projectId(projectId: String) = apply { this.projectId = projectId } /** Filter list of items by name. */ fun name(name: String) = apply { this.name = name } @@ -182,7 +182,7 @@ constructor( fun build(): ProjectInferencePipelineListParams = ProjectInferencePipelineListParams( - checkNotNull(id) { "`id` is required but was not set" }, + checkNotNull(projectId) { "`projectId` is required but was not set" }, name, page, perPage, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectInferencePipelineListResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineListResponse.kt similarity index 87% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectInferencePipelineListResponse.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineListResponse.kt index 7663bb5..cb9e840 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectInferencePipelineListResponse.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectInferencePipelineListResponse.kt @@ -1,23 +1,23 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import com.fasterxml.jackson.annotation.JsonAnyGetter import com.fasterxml.jackson.annotation.JsonAnySetter import com.fasterxml.jackson.annotation.JsonCreator import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException import java.time.OffsetDateTime import java.util.Objects import java.util.Optional -import org.openlayer.core.Enum -import org.openlayer.core.ExcludeMissing -import org.openlayer.core.JsonField -import org.openlayer.core.JsonMissing -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.toUnmodifiable -import org.openlayer.errors.OpenlayerInvalidDataException @JsonDeserialize(builder = ProjectInferencePipelineListResponse.Builder::class) @NoAutoDetect @@ -314,10 +314,8 @@ private constructor( private val passingGoalCount: JsonField, private val failingGoalCount: JsonField, private val totalGoalCount: JsonField, - private val referenceDatasetUri: JsonField, private val status: JsonField, private val statusMessage: JsonField, - private val storageType: JsonField, private val links: JsonField, private val additionalProperties: Map, ) { @@ -366,10 +364,6 @@ private constructor( /** The total number of tests. */ fun totalGoalCount(): Long = totalGoalCount.getRequired("totalGoalCount") - /** The reference dataset URI. */ - fun referenceDatasetUri(): Optional = - Optional.ofNullable(referenceDatasetUri.getNullable("referenceDatasetUri")) - /** The status of test evaluation for the inference pipeline. */ fun status(): Status = status.getRequired("status") @@ -377,10 +371,6 @@ private constructor( fun statusMessage(): Optional = Optional.ofNullable(statusMessage.getNullable("statusMessage")) - /** The storage type. */ - fun storageType(): Optional = - Optional.ofNullable(storageType.getNullable("storageType")) - fun links(): Links = links.getRequired("links") /** The inference pipeline id. */ @@ -425,20 +415,12 @@ private constructor( /** The total number of tests. */ @JsonProperty("totalGoalCount") @ExcludeMissing fun _totalGoalCount() = totalGoalCount - /** The reference dataset URI. */ - @JsonProperty("referenceDatasetUri") - @ExcludeMissing - fun _referenceDatasetUri() = referenceDatasetUri - /** The status of test evaluation for the inference pipeline. */ @JsonProperty("status") @ExcludeMissing fun _status() = status /** The status message of test evaluation for the inference pipeline. */ @JsonProperty("statusMessage") @ExcludeMissing fun _statusMessage() = statusMessage - /** The storage type. */ - @JsonProperty("storageType") @ExcludeMissing fun _storageType() = storageType - @JsonProperty("links") @ExcludeMissing fun _links() = links @JsonAnyGetter @@ -459,10 +441,8 @@ private constructor( passingGoalCount() failingGoalCount() totalGoalCount() - referenceDatasetUri() status() statusMessage() - storageType() links().validate() validated = true } @@ -488,10 +468,8 @@ private constructor( this.passingGoalCount == other.passingGoalCount && this.failingGoalCount == other.failingGoalCount && this.totalGoalCount == other.totalGoalCount && - this.referenceDatasetUri == other.referenceDatasetUri && this.status == other.status && this.statusMessage == other.statusMessage && - this.storageType == other.storageType && this.links == other.links && this.additionalProperties == other.additionalProperties } @@ -512,10 +490,8 @@ private constructor( passingGoalCount, failingGoalCount, totalGoalCount, - referenceDatasetUri, status, statusMessage, - storageType, links, additionalProperties, ) @@ -524,7 +500,7 @@ private constructor( } override fun toString() = - "Item{id=$id, projectId=$projectId, name=$name, dateCreated=$dateCreated, dateUpdated=$dateUpdated, dateLastSampleReceived=$dateLastSampleReceived, description=$description, dateLastEvaluated=$dateLastEvaluated, dateOfNextEvaluation=$dateOfNextEvaluation, passingGoalCount=$passingGoalCount, failingGoalCount=$failingGoalCount, totalGoalCount=$totalGoalCount, referenceDatasetUri=$referenceDatasetUri, status=$status, statusMessage=$statusMessage, storageType=$storageType, links=$links, additionalProperties=$additionalProperties}" + "Item{id=$id, projectId=$projectId, name=$name, dateCreated=$dateCreated, dateUpdated=$dateUpdated, dateLastSampleReceived=$dateLastSampleReceived, description=$description, dateLastEvaluated=$dateLastEvaluated, dateOfNextEvaluation=$dateOfNextEvaluation, passingGoalCount=$passingGoalCount, failingGoalCount=$failingGoalCount, totalGoalCount=$totalGoalCount, status=$status, statusMessage=$statusMessage, links=$links, additionalProperties=$additionalProperties}" companion object { @@ -545,10 +521,8 @@ private constructor( private var passingGoalCount: JsonField = JsonMissing.of() private var failingGoalCount: JsonField = JsonMissing.of() private var totalGoalCount: JsonField = JsonMissing.of() - private var referenceDatasetUri: JsonField = JsonMissing.of() private var status: JsonField = JsonMissing.of() private var statusMessage: JsonField = JsonMissing.of() - private var storageType: JsonField = JsonMissing.of() private var links: JsonField = JsonMissing.of() private var additionalProperties: MutableMap = mutableMapOf() @@ -566,10 +540,8 @@ private constructor( this.passingGoalCount = item.passingGoalCount this.failingGoalCount = item.failingGoalCount this.totalGoalCount = item.totalGoalCount - this.referenceDatasetUri = item.referenceDatasetUri this.status = item.status this.statusMessage = item.statusMessage - this.storageType = item.storageType this.links = item.links additionalProperties(item.additionalProperties) } @@ -693,17 +665,6 @@ private constructor( this.totalGoalCount = totalGoalCount } - /** The reference dataset URI. */ - fun referenceDatasetUri(referenceDatasetUri: String) = - referenceDatasetUri(JsonField.of(referenceDatasetUri)) - - /** The reference dataset URI. */ - @JsonProperty("referenceDatasetUri") - @ExcludeMissing - fun referenceDatasetUri(referenceDatasetUri: JsonField) = apply { - this.referenceDatasetUri = referenceDatasetUri - } - /** The status of test evaluation for the inference pipeline. */ fun status(status: Status) = status(JsonField.of(status)) @@ -722,16 +683,6 @@ private constructor( this.statusMessage = statusMessage } - /** The storage type. */ - fun storageType(storageType: StorageType) = storageType(JsonField.of(storageType)) - - /** The storage type. */ - @JsonProperty("storageType") - @ExcludeMissing - fun storageType(storageType: JsonField) = apply { - this.storageType = storageType - } - fun links(links: Links) = links(JsonField.of(links)) @JsonProperty("links") @@ -766,10 +717,8 @@ private constructor( passingGoalCount, failingGoalCount, totalGoalCount, - referenceDatasetUri, status, statusMessage, - storageType, links, additionalProperties.toUnmodifiable(), ) @@ -944,74 +893,5 @@ private constructor( fun asString(): String = _value().asStringOrThrow() } - - class StorageType - @JsonCreator - private constructor( - private val value: JsonField, - ) : Enum { - - @com.fasterxml.jackson.annotation.JsonValue fun _value(): JsonField = value - - override fun equals(other: Any?): Boolean { - if (this === other) { - return true - } - - return other is StorageType && this.value == other.value - } - - override fun hashCode() = value.hashCode() - - override fun toString() = value.toString() - - companion object { - - @JvmField val LOCAL = StorageType(JsonField.of("local")) - - @JvmField val S3 = StorageType(JsonField.of("s3")) - - @JvmField val GCS = StorageType(JsonField.of("gcs")) - - @JvmField val AZURE = StorageType(JsonField.of("azure")) - - @JvmStatic fun of(value: String) = StorageType(JsonField.of(value)) - } - - enum class Known { - LOCAL, - S3, - GCS, - AZURE, - } - - enum class Value { - LOCAL, - S3, - GCS, - AZURE, - _UNKNOWN, - } - - fun value(): Value = - when (this) { - LOCAL -> Value.LOCAL - S3 -> Value.S3 - GCS -> Value.GCS - AZURE -> Value.AZURE - else -> Value._UNKNOWN - } - - fun known(): Known = - when (this) { - LOCAL -> Known.LOCAL - S3 -> Known.S3 - GCS -> Known.GCS - AZURE -> Known.AZURE - else -> throw OpenlayerInvalidDataException("Unknown StorageType: $value") - } - - fun asString(): String = _value().asStringOrThrow() - } } } diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectListParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectListParams.kt similarity index 96% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectListParams.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectListParams.kt index ce56d43..b493cd2 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectListParams.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectListParams.kt @@ -1,17 +1,17 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import com.fasterxml.jackson.annotation.JsonCreator +import com.openlayer.api.core.Enum +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException +import com.openlayer.api.models.* import java.util.Objects import java.util.Optional -import org.openlayer.core.Enum -import org.openlayer.core.JsonField -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.toUnmodifiable -import org.openlayer.errors.OpenlayerInvalidDataException -import org.openlayer.models.* class ProjectListParams constructor( diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectListResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectListResponse.kt similarity index 86% rename from openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectListResponse.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectListResponse.kt index 7b1bac6..69c6387 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/models/ProjectListResponse.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/ProjectListResponse.kt @@ -1,23 +1,23 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import com.fasterxml.jackson.annotation.JsonAnyGetter import com.fasterxml.jackson.annotation.JsonAnySetter import com.fasterxml.jackson.annotation.JsonCreator import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.Enum +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.errors.OpenlayerInvalidDataException import java.time.OffsetDateTime import java.util.Objects import java.util.Optional -import org.openlayer.core.Enum -import org.openlayer.core.ExcludeMissing -import org.openlayer.core.JsonField -import org.openlayer.core.JsonMissing -import org.openlayer.core.JsonValue -import org.openlayer.core.NoAutoDetect -import org.openlayer.core.toUnmodifiable -import org.openlayer.errors.OpenlayerInvalidDataException @JsonDeserialize(builder = ProjectListResponse.Builder::class) @NoAutoDetect @@ -307,7 +307,6 @@ private constructor( private val dateCreated: JsonField, private val dateUpdated: JsonField, private val description: JsonField, - private val sample: JsonField, private val source: JsonField, private val taskType: JsonField, private val versionCount: JsonField, @@ -315,11 +314,7 @@ private constructor( private val goalCount: JsonField, private val developmentGoalCount: JsonField, private val monitoringGoalCount: JsonField, - private val unreadNotificationCount: JsonField, private val links: JsonField, - private val slackChannelNotificationsEnabled: JsonField, - private val slackChannelName: JsonField, - private val slackChannelId: JsonField, private val gitRepo: JsonField, private val additionalProperties: Map, ) { @@ -351,9 +346,6 @@ private constructor( fun description(): Optional = Optional.ofNullable(description.getNullable("description")) - /** Whether the project is a sample project or a user-created project. */ - fun sample(): Boolean = sample.getRequired("sample") - /** The source of the project. */ fun source(): Optional = Optional.ofNullable(source.getNullable("source")) @@ -376,27 +368,9 @@ private constructor( /** The number of tests in the monitoring mode of the project. */ fun monitoringGoalCount(): Long = monitoringGoalCount.getRequired("monitoringGoalCount") - /** The number of unread notifications in the project. */ - fun unreadNotificationCount(): Optional = - Optional.ofNullable(unreadNotificationCount.getNullable("unreadNotificationCount")) - /** Links to the project. */ fun links(): Links = links.getRequired("links") - /** Whether slack channel notifications are enabled for the project. */ - fun slackChannelNotificationsEnabled(): Optional = - Optional.ofNullable( - slackChannelNotificationsEnabled.getNullable("slackChannelNotificationsEnabled") - ) - - /** The slack channel connected to the project. */ - fun slackChannelName(): Optional = - Optional.ofNullable(slackChannelName.getNullable("slackChannelName")) - - /** The slack channel id connected to the project. */ - fun slackChannelId(): Optional = - Optional.ofNullable(slackChannelId.getNullable("slackChannelId")) - fun gitRepo(): Optional = Optional.ofNullable(gitRepo.getNullable("gitRepo")) /** The project id. */ @@ -420,9 +394,6 @@ private constructor( /** The project description. */ @JsonProperty("description") @ExcludeMissing fun _description() = description - /** Whether the project is a sample project or a user-created project. */ - @JsonProperty("sample") @ExcludeMissing fun _sample() = sample - /** The source of the project. */ @JsonProperty("source") @ExcludeMissing fun _source() = source @@ -450,25 +421,9 @@ private constructor( @ExcludeMissing fun _monitoringGoalCount() = monitoringGoalCount - /** The number of unread notifications in the project. */ - @JsonProperty("unreadNotificationCount") - @ExcludeMissing - fun _unreadNotificationCount() = unreadNotificationCount - /** Links to the project. */ @JsonProperty("links") @ExcludeMissing fun _links() = links - /** Whether slack channel notifications are enabled for the project. */ - @JsonProperty("slackChannelNotificationsEnabled") - @ExcludeMissing - fun _slackChannelNotificationsEnabled() = slackChannelNotificationsEnabled - - /** The slack channel connected to the project. */ - @JsonProperty("slackChannelName") @ExcludeMissing fun _slackChannelName() = slackChannelName - - /** The slack channel id connected to the project. */ - @JsonProperty("slackChannelId") @ExcludeMissing fun _slackChannelId() = slackChannelId - @JsonProperty("gitRepo") @ExcludeMissing fun _gitRepo() = gitRepo @JsonAnyGetter @@ -484,7 +439,6 @@ private constructor( dateCreated() dateUpdated() description() - sample() source() taskType() versionCount() @@ -492,11 +446,7 @@ private constructor( goalCount() developmentGoalCount() monitoringGoalCount() - unreadNotificationCount() links().validate() - slackChannelNotificationsEnabled() - slackChannelName() - slackChannelId() gitRepo().map { it.validate() } validated = true } @@ -517,7 +467,6 @@ private constructor( this.dateCreated == other.dateCreated && this.dateUpdated == other.dateUpdated && this.description == other.description && - this.sample == other.sample && this.source == other.source && this.taskType == other.taskType && this.versionCount == other.versionCount && @@ -525,11 +474,7 @@ private constructor( this.goalCount == other.goalCount && this.developmentGoalCount == other.developmentGoalCount && this.monitoringGoalCount == other.monitoringGoalCount && - this.unreadNotificationCount == other.unreadNotificationCount && this.links == other.links && - this.slackChannelNotificationsEnabled == other.slackChannelNotificationsEnabled && - this.slackChannelName == other.slackChannelName && - this.slackChannelId == other.slackChannelId && this.gitRepo == other.gitRepo && this.additionalProperties == other.additionalProperties } @@ -545,7 +490,6 @@ private constructor( dateCreated, dateUpdated, description, - sample, source, taskType, versionCount, @@ -553,11 +497,7 @@ private constructor( goalCount, developmentGoalCount, monitoringGoalCount, - unreadNotificationCount, links, - slackChannelNotificationsEnabled, - slackChannelName, - slackChannelId, gitRepo, additionalProperties, ) @@ -566,7 +506,7 @@ private constructor( } override fun toString() = - "Item{id=$id, workspaceId=$workspaceId, creatorId=$creatorId, name=$name, dateCreated=$dateCreated, dateUpdated=$dateUpdated, description=$description, sample=$sample, source=$source, taskType=$taskType, versionCount=$versionCount, inferencePipelineCount=$inferencePipelineCount, goalCount=$goalCount, developmentGoalCount=$developmentGoalCount, monitoringGoalCount=$monitoringGoalCount, unreadNotificationCount=$unreadNotificationCount, links=$links, slackChannelNotificationsEnabled=$slackChannelNotificationsEnabled, slackChannelName=$slackChannelName, slackChannelId=$slackChannelId, gitRepo=$gitRepo, additionalProperties=$additionalProperties}" + "Item{id=$id, workspaceId=$workspaceId, creatorId=$creatorId, name=$name, dateCreated=$dateCreated, dateUpdated=$dateUpdated, description=$description, source=$source, taskType=$taskType, versionCount=$versionCount, inferencePipelineCount=$inferencePipelineCount, goalCount=$goalCount, developmentGoalCount=$developmentGoalCount, monitoringGoalCount=$monitoringGoalCount, links=$links, gitRepo=$gitRepo, additionalProperties=$additionalProperties}" companion object { @@ -582,7 +522,6 @@ private constructor( private var dateCreated: JsonField = JsonMissing.of() private var dateUpdated: JsonField = JsonMissing.of() private var description: JsonField = JsonMissing.of() - private var sample: JsonField = JsonMissing.of() private var source: JsonField = JsonMissing.of() private var taskType: JsonField = JsonMissing.of() private var versionCount: JsonField = JsonMissing.of() @@ -590,11 +529,7 @@ private constructor( private var goalCount: JsonField = JsonMissing.of() private var developmentGoalCount: JsonField = JsonMissing.of() private var monitoringGoalCount: JsonField = JsonMissing.of() - private var unreadNotificationCount: JsonField = JsonMissing.of() private var links: JsonField = JsonMissing.of() - private var slackChannelNotificationsEnabled: JsonField = JsonMissing.of() - private var slackChannelName: JsonField = JsonMissing.of() - private var slackChannelId: JsonField = JsonMissing.of() private var gitRepo: JsonField = JsonMissing.of() private var additionalProperties: MutableMap = mutableMapOf() @@ -607,7 +542,6 @@ private constructor( this.dateCreated = item.dateCreated this.dateUpdated = item.dateUpdated this.description = item.description - this.sample = item.sample this.source = item.source this.taskType = item.taskType this.versionCount = item.versionCount @@ -615,11 +549,7 @@ private constructor( this.goalCount = item.goalCount this.developmentGoalCount = item.developmentGoalCount this.monitoringGoalCount = item.monitoringGoalCount - this.unreadNotificationCount = item.unreadNotificationCount this.links = item.links - this.slackChannelNotificationsEnabled = item.slackChannelNotificationsEnabled - this.slackChannelName = item.slackChannelName - this.slackChannelId = item.slackChannelId this.gitRepo = item.gitRepo additionalProperties(item.additionalProperties) } @@ -688,14 +618,6 @@ private constructor( this.description = description } - /** Whether the project is a sample project or a user-created project. */ - fun sample(sample: Boolean) = sample(JsonField.of(sample)) - - /** Whether the project is a sample project or a user-created project. */ - @JsonProperty("sample") - @ExcludeMissing - fun sample(sample: JsonField) = apply { this.sample = sample } - /** The source of the project. */ fun source(source: Source) = source(JsonField.of(source)) @@ -763,17 +685,6 @@ private constructor( this.monitoringGoalCount = monitoringGoalCount } - /** The number of unread notifications in the project. */ - fun unreadNotificationCount(unreadNotificationCount: Long) = - unreadNotificationCount(JsonField.of(unreadNotificationCount)) - - /** The number of unread notifications in the project. */ - @JsonProperty("unreadNotificationCount") - @ExcludeMissing - fun unreadNotificationCount(unreadNotificationCount: JsonField) = apply { - this.unreadNotificationCount = unreadNotificationCount - } - /** Links to the project. */ fun links(links: Links) = links(JsonField.of(links)) @@ -782,39 +693,6 @@ private constructor( @ExcludeMissing fun links(links: JsonField) = apply { this.links = links } - /** Whether slack channel notifications are enabled for the project. */ - fun slackChannelNotificationsEnabled(slackChannelNotificationsEnabled: Boolean) = - slackChannelNotificationsEnabled(JsonField.of(slackChannelNotificationsEnabled)) - - /** Whether slack channel notifications are enabled for the project. */ - @JsonProperty("slackChannelNotificationsEnabled") - @ExcludeMissing - fun slackChannelNotificationsEnabled( - slackChannelNotificationsEnabled: JsonField - ) = apply { this.slackChannelNotificationsEnabled = slackChannelNotificationsEnabled } - - /** The slack channel connected to the project. */ - fun slackChannelName(slackChannelName: String) = - slackChannelName(JsonField.of(slackChannelName)) - - /** The slack channel connected to the project. */ - @JsonProperty("slackChannelName") - @ExcludeMissing - fun slackChannelName(slackChannelName: JsonField) = apply { - this.slackChannelName = slackChannelName - } - - /** The slack channel id connected to the project. */ - fun slackChannelId(slackChannelId: String) = - slackChannelId(JsonField.of(slackChannelId)) - - /** The slack channel id connected to the project. */ - @JsonProperty("slackChannelId") - @ExcludeMissing - fun slackChannelId(slackChannelId: JsonField) = apply { - this.slackChannelId = slackChannelId - } - fun gitRepo(gitRepo: GitRepo) = gitRepo(JsonField.of(gitRepo)) @JsonProperty("gitRepo") @@ -844,7 +722,6 @@ private constructor( dateCreated, dateUpdated, description, - sample, source, taskType, versionCount, @@ -852,11 +729,7 @@ private constructor( goalCount, developmentGoalCount, monitoringGoalCount, - unreadNotificationCount, links, - slackChannelNotificationsEnabled, - slackChannelName, - slackChannelId, gitRepo, additionalProperties.toUnmodifiable(), ) diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateParams.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateParams.kt new file mode 100644 index 0000000..e5085a5 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateParams.kt @@ -0,0 +1,156 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import com.openlayer.api.models.* +import java.util.Objects +import java.util.Optional + +class StoragePresignedUrlCreateParams +constructor( + private val objectName: String, + private val additionalQueryParams: Map>, + private val additionalHeaders: Map>, + private val additionalBodyProperties: Map, +) { + + fun objectName(): String = objectName + + @JvmSynthetic + internal fun getBody(): Optional> { + return Optional.ofNullable(additionalBodyProperties.ifEmpty { null }) + } + + @JvmSynthetic + internal fun getQueryParams(): Map> { + val params = mutableMapOf>() + this.objectName.let { params.put("objectName", listOf(it.toString())) } + params.putAll(additionalQueryParams) + return params.toUnmodifiable() + } + + @JvmSynthetic internal fun getHeaders(): Map> = additionalHeaders + + fun _additionalQueryParams(): Map> = additionalQueryParams + + fun _additionalHeaders(): Map> = additionalHeaders + + fun _additionalBodyProperties(): Map = additionalBodyProperties + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is StoragePresignedUrlCreateParams && + this.objectName == other.objectName && + this.additionalQueryParams == other.additionalQueryParams && + this.additionalHeaders == other.additionalHeaders && + this.additionalBodyProperties == other.additionalBodyProperties + } + + override fun hashCode(): Int { + return Objects.hash( + objectName, + additionalQueryParams, + additionalHeaders, + additionalBodyProperties, + ) + } + + override fun toString() = + "StoragePresignedUrlCreateParams{objectName=$objectName, additionalQueryParams=$additionalQueryParams, additionalHeaders=$additionalHeaders, additionalBodyProperties=$additionalBodyProperties}" + + fun toBuilder() = Builder().from(this) + + companion object { + + @JvmStatic fun builder() = Builder() + } + + @NoAutoDetect + class Builder { + + private var objectName: String? = null + private var additionalQueryParams: MutableMap> = mutableMapOf() + private var additionalHeaders: MutableMap> = mutableMapOf() + private var additionalBodyProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(storagePresignedUrlCreateParams: StoragePresignedUrlCreateParams) = + apply { + this.objectName = storagePresignedUrlCreateParams.objectName + additionalQueryParams(storagePresignedUrlCreateParams.additionalQueryParams) + additionalHeaders(storagePresignedUrlCreateParams.additionalHeaders) + additionalBodyProperties(storagePresignedUrlCreateParams.additionalBodyProperties) + } + + /** The name of the object. */ + fun objectName(objectName: String) = apply { this.objectName = objectName } + + fun additionalQueryParams(additionalQueryParams: Map>) = apply { + this.additionalQueryParams.clear() + putAllQueryParams(additionalQueryParams) + } + + fun putQueryParam(name: String, value: String) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putQueryParams(name: String, values: Iterable) = apply { + this.additionalQueryParams.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllQueryParams(additionalQueryParams: Map>) = apply { + additionalQueryParams.forEach(this::putQueryParams) + } + + fun removeQueryParam(name: String) = apply { + this.additionalQueryParams.put(name, mutableListOf()) + } + + fun additionalHeaders(additionalHeaders: Map>) = apply { + this.additionalHeaders.clear() + putAllHeaders(additionalHeaders) + } + + fun putHeader(name: String, value: String) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.add(value) + } + + fun putHeaders(name: String, values: Iterable) = apply { + this.additionalHeaders.getOrPut(name) { mutableListOf() }.addAll(values) + } + + fun putAllHeaders(additionalHeaders: Map>) = apply { + additionalHeaders.forEach(this::putHeaders) + } + + fun removeHeader(name: String) = apply { this.additionalHeaders.put(name, mutableListOf()) } + + fun additionalBodyProperties(additionalBodyProperties: Map) = apply { + this.additionalBodyProperties.clear() + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun putAdditionalBodyProperty(key: String, value: JsonValue) = apply { + this.additionalBodyProperties.put(key, value) + } + + fun putAllAdditionalBodyProperties(additionalBodyProperties: Map) = + apply { + this.additionalBodyProperties.putAll(additionalBodyProperties) + } + + fun build(): StoragePresignedUrlCreateParams = + StoragePresignedUrlCreateParams( + checkNotNull(objectName) { "`objectName` is required but was not set" }, + additionalQueryParams.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalHeaders.mapValues { it.value.toUnmodifiable() }.toUnmodifiable(), + additionalBodyProperties.toUnmodifiable(), + ) + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateResponse.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateResponse.kt new file mode 100644 index 0000000..57c2fca --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateResponse.kt @@ -0,0 +1,152 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.fasterxml.jackson.annotation.JsonAnyGetter +import com.fasterxml.jackson.annotation.JsonAnySetter +import com.fasterxml.jackson.annotation.JsonProperty +import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.ExcludeMissing +import com.openlayer.api.core.JsonField +import com.openlayer.api.core.JsonMissing +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.NoAutoDetect +import com.openlayer.api.core.toUnmodifiable +import java.util.Objects + +@JsonDeserialize(builder = StoragePresignedUrlCreateResponse.Builder::class) +@NoAutoDetect +class StoragePresignedUrlCreateResponse +private constructor( + private val url: JsonField, + private val fields: JsonValue, + private val storageUri: JsonField, + private val additionalProperties: Map, +) { + + private var validated: Boolean = false + + private var hashCode: Int = 0 + + /** The presigned url. */ + fun url(): String = url.getRequired("url") + + /** The storage URI to send back to the backend after the upload was completed. */ + fun storageUri(): String = storageUri.getRequired("storageUri") + + /** The presigned url. */ + @JsonProperty("url") @ExcludeMissing fun _url() = url + + /** Fields to include in the body of the upload. Only needed by s3. */ + @JsonProperty("fields") @ExcludeMissing fun _fields() = fields + + /** The storage URI to send back to the backend after the upload was completed. */ + @JsonProperty("storageUri") @ExcludeMissing fun _storageUri() = storageUri + + @JsonAnyGetter + @ExcludeMissing + fun _additionalProperties(): Map = additionalProperties + + fun validate(): StoragePresignedUrlCreateResponse = apply { + if (!validated) { + url() + storageUri() + validated = true + } + } + + fun toBuilder() = Builder().from(this) + + override fun equals(other: Any?): Boolean { + if (this === other) { + return true + } + + return other is StoragePresignedUrlCreateResponse && + this.url == other.url && + this.fields == other.fields && + this.storageUri == other.storageUri && + this.additionalProperties == other.additionalProperties + } + + override fun hashCode(): Int { + if (hashCode == 0) { + hashCode = + Objects.hash( + url, + fields, + storageUri, + additionalProperties, + ) + } + return hashCode + } + + override fun toString() = + "StoragePresignedUrlCreateResponse{url=$url, fields=$fields, storageUri=$storageUri, additionalProperties=$additionalProperties}" + + companion object { + + @JvmStatic fun builder() = Builder() + } + + class Builder { + + private var url: JsonField = JsonMissing.of() + private var fields: JsonValue = JsonMissing.of() + private var storageUri: JsonField = JsonMissing.of() + private var additionalProperties: MutableMap = mutableMapOf() + + @JvmSynthetic + internal fun from(storagePresignedUrlCreateResponse: StoragePresignedUrlCreateResponse) = + apply { + this.url = storagePresignedUrlCreateResponse.url + this.fields = storagePresignedUrlCreateResponse.fields + this.storageUri = storagePresignedUrlCreateResponse.storageUri + additionalProperties(storagePresignedUrlCreateResponse.additionalProperties) + } + + /** The presigned url. */ + fun url(url: String) = url(JsonField.of(url)) + + /** The presigned url. */ + @JsonProperty("url") + @ExcludeMissing + fun url(url: JsonField) = apply { this.url = url } + + /** Fields to include in the body of the upload. Only needed by s3. */ + @JsonProperty("fields") + @ExcludeMissing + fun fields(fields: JsonValue) = apply { this.fields = fields } + + /** The storage URI to send back to the backend after the upload was completed. */ + fun storageUri(storageUri: String) = storageUri(JsonField.of(storageUri)) + + /** The storage URI to send back to the backend after the upload was completed. */ + @JsonProperty("storageUri") + @ExcludeMissing + fun storageUri(storageUri: JsonField) = apply { this.storageUri = storageUri } + + fun additionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.clear() + this.additionalProperties.putAll(additionalProperties) + } + + @JsonAnySetter + fun putAdditionalProperty(key: String, value: JsonValue) = apply { + this.additionalProperties.put(key, value) + } + + fun putAllAdditionalProperties(additionalProperties: Map) = apply { + this.additionalProperties.putAll(additionalProperties) + } + + fun build(): StoragePresignedUrlCreateResponse = + StoragePresignedUrlCreateResponse( + url, + fields, + storageUri, + additionalProperties.toUnmodifiable(), + ) + } +} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/Handlers.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/Handlers.kt similarity index 73% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/Handlers.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/Handlers.kt index 7f8fa7c..4d849f4 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/Handlers.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/Handlers.kt @@ -1,24 +1,25 @@ @file:JvmName("Handlers") -package org.openlayer.services +package com.openlayer.api.services import com.fasterxml.jackson.databind.json.JsonMapper import com.fasterxml.jackson.module.kotlin.jacksonTypeRef +import com.openlayer.api.core.http.BinaryResponseContent +import com.openlayer.api.core.http.HttpResponse +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.BadRequestException +import com.openlayer.api.errors.InternalServerException +import com.openlayer.api.errors.NotFoundException +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.errors.OpenlayerException +import com.openlayer.api.errors.PermissionDeniedException +import com.openlayer.api.errors.RateLimitException +import com.openlayer.api.errors.UnauthorizedException +import com.openlayer.api.errors.UnexpectedStatusCodeException +import com.openlayer.api.errors.UnprocessableEntityException import java.io.InputStream import java.io.OutputStream -import org.openlayer.core.http.BinaryResponseContent -import org.openlayer.core.http.HttpResponse -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.BadRequestException -import org.openlayer.errors.InternalServerException -import org.openlayer.errors.NotFoundException -import org.openlayer.errors.OpenlayerError -import org.openlayer.errors.OpenlayerException -import org.openlayer.errors.PermissionDeniedException -import org.openlayer.errors.RateLimitException -import org.openlayer.errors.UnauthorizedException -import org.openlayer.errors.UnexpectedStatusCodeException -import org.openlayer.errors.UnprocessableEntityException +import java.util.Optional @JvmSynthetic internal fun emptyHandler(): Handler = EmptyHandler @@ -38,7 +39,18 @@ private object StringHandler : Handler { private object BinaryHandler : Handler { override fun handle(response: HttpResponse): BinaryResponseContent { - return BinaryResponseContentImpl(response) + return object : BinaryResponseContent { + override fun contentType(): Optional = + Optional.ofNullable(response.headers().get("Content-Type").firstOrNull()) + + override fun body(): InputStream = response.body() + + override fun close() = response.close() + + override fun writeTo(outputStream: OutputStream) { + response.body().copyTo(outputStream) + } + } } } @@ -107,24 +119,3 @@ internal fun Handler.withErrorHandler(errorHandler: Handler json( diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/CommitServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/CommitServiceAsync.kt similarity index 67% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/async/CommitServiceAsync.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/CommitServiceAsync.kt index 10a5d88..92fd5e9 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/CommitServiceAsync.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/CommitServiceAsync.kt @@ -2,9 +2,9 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.services.async +package com.openlayer.api.services.async -import org.openlayer.services.async.commits.TestResultServiceAsync +import com.openlayer.api.services.async.commits.TestResultServiceAsync interface CommitServiceAsync { diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/CommitServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/CommitServiceAsyncImpl.kt similarity index 54% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/async/CommitServiceAsyncImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/CommitServiceAsyncImpl.kt index 567dd1a..ef73e6d 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/CommitServiceAsyncImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/CommitServiceAsyncImpl.kt @@ -1,13 +1,13 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.async +package com.openlayer.api.services.async -import org.openlayer.core.ClientOptions -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.services.async.commits.TestResultServiceAsync -import org.openlayer.services.async.commits.TestResultServiceAsyncImpl -import org.openlayer.services.errorHandler +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.services.async.commits.TestResultServiceAsync +import com.openlayer.api.services.async.commits.TestResultServiceAsyncImpl +import com.openlayer.api.services.errorHandler class CommitServiceAsyncImpl constructor( diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/InferencePipelineServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/InferencePipelineServiceAsync.kt new file mode 100644 index 0000000..84e6d9a --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/InferencePipelineServiceAsync.kt @@ -0,0 +1,46 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.async + +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.InferencePipelineDeleteParams +import com.openlayer.api.models.InferencePipelineRetrieveParams +import com.openlayer.api.models.InferencePipelineRetrieveResponse +import com.openlayer.api.models.InferencePipelineUpdateParams +import com.openlayer.api.models.InferencePipelineUpdateResponse +import com.openlayer.api.services.async.inferencePipelines.DataServiceAsync +import com.openlayer.api.services.async.inferencePipelines.RowServiceAsync +import com.openlayer.api.services.async.inferencePipelines.TestResultServiceAsync +import java.util.concurrent.CompletableFuture + +interface InferencePipelineServiceAsync { + + fun data(): DataServiceAsync + + fun rows(): RowServiceAsync + + fun testResults(): TestResultServiceAsync + + /** Retrieve inference pipeline. */ + @JvmOverloads + fun retrieve( + params: InferencePipelineRetrieveParams, + requestOptions: RequestOptions = RequestOptions.none() + ): CompletableFuture + + /** Update inference pipeline. */ + @JvmOverloads + fun update( + params: InferencePipelineUpdateParams, + requestOptions: RequestOptions = RequestOptions.none() + ): CompletableFuture + + /** Delete inference pipeline. */ + @JvmOverloads + fun delete( + params: InferencePipelineDeleteParams, + requestOptions: RequestOptions = RequestOptions.none() + ): CompletableFuture +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/InferencePipelineServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/InferencePipelineServiceAsyncImpl.kt new file mode 100644 index 0000000..c5fd091 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/InferencePipelineServiceAsyncImpl.kt @@ -0,0 +1,133 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.async + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.InferencePipelineDeleteParams +import com.openlayer.api.models.InferencePipelineRetrieveParams +import com.openlayer.api.models.InferencePipelineRetrieveResponse +import com.openlayer.api.models.InferencePipelineUpdateParams +import com.openlayer.api.models.InferencePipelineUpdateResponse +import com.openlayer.api.services.async.inferencePipelines.DataServiceAsync +import com.openlayer.api.services.async.inferencePipelines.DataServiceAsyncImpl +import com.openlayer.api.services.async.inferencePipelines.RowServiceAsync +import com.openlayer.api.services.async.inferencePipelines.RowServiceAsyncImpl +import com.openlayer.api.services.async.inferencePipelines.TestResultServiceAsync +import com.openlayer.api.services.async.inferencePipelines.TestResultServiceAsyncImpl +import com.openlayer.api.services.emptyHandler +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler +import java.util.concurrent.CompletableFuture + +class InferencePipelineServiceAsyncImpl +constructor( + private val clientOptions: ClientOptions, +) : InferencePipelineServiceAsync { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val data: DataServiceAsync by lazy { DataServiceAsyncImpl(clientOptions) } + + private val rows: RowServiceAsync by lazy { RowServiceAsyncImpl(clientOptions) } + + private val testResults: TestResultServiceAsync by lazy { + TestResultServiceAsyncImpl(clientOptions) + } + + override fun data(): DataServiceAsync = data + + override fun rows(): RowServiceAsync = rows + + override fun testResults(): TestResultServiceAsync = testResults + + private val retrieveHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** Retrieve inference pipeline. */ + override fun retrieve( + params: InferencePipelineRetrieveParams, + requestOptions: RequestOptions + ): CompletableFuture { + val request = + HttpRequest.builder() + .method(HttpMethod.GET) + .addPathSegments("inference-pipelines", params.getPathParam(0)) + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .build() + return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response + -> + response + .use { retrieveHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } + + private val updateHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** Update inference pipeline. */ + override fun update( + params: InferencePipelineUpdateParams, + requestOptions: RequestOptions + ): CompletableFuture { + val request = + HttpRequest.builder() + .method(HttpMethod.PUT) + .addPathSegments("inference-pipelines", params.getPathParam(0)) + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .body(json(clientOptions.jsonMapper, params.getBody())) + .build() + return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response + -> + response + .use { updateHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } + + private val deleteHandler: Handler = emptyHandler().withErrorHandler(errorHandler) + + /** Delete inference pipeline. */ + override fun delete( + params: InferencePipelineDeleteParams, + requestOptions: RequestOptions + ): CompletableFuture { + val request = + HttpRequest.builder() + .method(HttpMethod.DELETE) + .addPathSegments("inference-pipelines", params.getPathParam(0)) + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .apply { params.getBody().ifPresent { body(json(clientOptions.jsonMapper, it)) } } + .build() + return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response + -> + response.use { deleteHandler.handle(it) } + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/ProjectServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/ProjectServiceAsync.kt new file mode 100644 index 0000000..bc149ca --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/ProjectServiceAsync.kt @@ -0,0 +1,35 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.async + +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.ProjectCreateParams +import com.openlayer.api.models.ProjectCreateResponse +import com.openlayer.api.models.ProjectListParams +import com.openlayer.api.models.ProjectListResponse +import com.openlayer.api.services.async.projects.CommitServiceAsync +import com.openlayer.api.services.async.projects.InferencePipelineServiceAsync +import java.util.concurrent.CompletableFuture + +interface ProjectServiceAsync { + + fun commits(): CommitServiceAsync + + fun inferencePipelines(): InferencePipelineServiceAsync + + /** Create a project in your workspace. */ + @JvmOverloads + fun create( + params: ProjectCreateParams, + requestOptions: RequestOptions = RequestOptions.none() + ): CompletableFuture + + /** List your workspace's projects. */ + @JvmOverloads + fun list( + params: ProjectListParams, + requestOptions: RequestOptions = RequestOptions.none() + ): CompletableFuture +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/ProjectServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/ProjectServiceAsyncImpl.kt new file mode 100644 index 0000000..b49f449 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/ProjectServiceAsyncImpl.kt @@ -0,0 +1,100 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.async + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.ProjectCreateParams +import com.openlayer.api.models.ProjectCreateResponse +import com.openlayer.api.models.ProjectListParams +import com.openlayer.api.models.ProjectListResponse +import com.openlayer.api.services.async.projects.CommitServiceAsync +import com.openlayer.api.services.async.projects.CommitServiceAsyncImpl +import com.openlayer.api.services.async.projects.InferencePipelineServiceAsync +import com.openlayer.api.services.async.projects.InferencePipelineServiceAsyncImpl +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler +import java.util.concurrent.CompletableFuture + +class ProjectServiceAsyncImpl +constructor( + private val clientOptions: ClientOptions, +) : ProjectServiceAsync { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val commits: CommitServiceAsync by lazy { CommitServiceAsyncImpl(clientOptions) } + + private val inferencePipelines: InferencePipelineServiceAsync by lazy { + InferencePipelineServiceAsyncImpl(clientOptions) + } + + override fun commits(): CommitServiceAsync = commits + + override fun inferencePipelines(): InferencePipelineServiceAsync = inferencePipelines + + private val createHandler: Handler = + jsonHandler(clientOptions.jsonMapper).withErrorHandler(errorHandler) + + /** Create a project in your workspace. */ + override fun create( + params: ProjectCreateParams, + requestOptions: RequestOptions + ): CompletableFuture { + val request = + HttpRequest.builder() + .method(HttpMethod.POST) + .addPathSegments("projects") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .body(json(clientOptions.jsonMapper, params.getBody())) + .build() + return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response + -> + response + .use { createHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } + + private val listHandler: Handler = + jsonHandler(clientOptions.jsonMapper).withErrorHandler(errorHandler) + + /** List your workspace's projects. */ + override fun list( + params: ProjectListParams, + requestOptions: RequestOptions + ): CompletableFuture { + val request = + HttpRequest.builder() + .method(HttpMethod.GET) + .addPathSegments("projects") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .build() + return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response + -> + response + .use { listHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/StorageServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/StorageServiceAsync.kt new file mode 100644 index 0000000..6a59073 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/StorageServiceAsync.kt @@ -0,0 +1,12 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.async + +import com.openlayer.api.services.async.storage.PresignedUrlServiceAsync + +interface StorageServiceAsync { + + fun presignedUrl(): PresignedUrlServiceAsync +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/StorageServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/StorageServiceAsyncImpl.kt new file mode 100644 index 0000000..2dd732c --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/StorageServiceAsyncImpl.kt @@ -0,0 +1,24 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.async + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.services.async.storage.PresignedUrlServiceAsync +import com.openlayer.api.services.async.storage.PresignedUrlServiceAsyncImpl +import com.openlayer.api.services.errorHandler + +class StorageServiceAsyncImpl +constructor( + private val clientOptions: ClientOptions, +) : StorageServiceAsync { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val presignedUrl: PresignedUrlServiceAsync by lazy { + PresignedUrlServiceAsyncImpl(clientOptions) + } + + override fun presignedUrl(): PresignedUrlServiceAsync = presignedUrl +} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/commits/TestResultServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/commits/TestResultServiceAsync.kt similarity index 59% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/async/commits/TestResultServiceAsync.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/commits/TestResultServiceAsync.kt index f4f1596..dde3ea2 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/commits/TestResultServiceAsync.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/commits/TestResultServiceAsync.kt @@ -2,16 +2,16 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.services.async.commits +package com.openlayer.api.services.async.commits +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.CommitTestResultListParams +import com.openlayer.api.models.CommitTestResultListResponse import java.util.concurrent.CompletableFuture -import org.openlayer.core.RequestOptions -import org.openlayer.models.CommitTestResultListParams -import org.openlayer.models.CommitTestResultListResponse interface TestResultServiceAsync { - /** List the test results for a commit (project version). */ + /** List the test results for a project commit (project version). */ @JvmOverloads fun list( params: CommitTestResultListParams, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/commits/TestResultServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/commits/TestResultServiceAsyncImpl.kt similarity index 69% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/async/commits/TestResultServiceAsyncImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/commits/TestResultServiceAsyncImpl.kt index a4fd2b0..ac4c25f 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/commits/TestResultServiceAsyncImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/commits/TestResultServiceAsyncImpl.kt @@ -1,19 +1,19 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.async.commits +package com.openlayer.api.services.async.commits +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.CommitTestResultListParams +import com.openlayer.api.models.CommitTestResultListResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler import java.util.concurrent.CompletableFuture -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.CommitTestResultListParams -import org.openlayer.models.CommitTestResultListResponse -import org.openlayer.services.errorHandler -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler class TestResultServiceAsyncImpl constructor( @@ -26,7 +26,7 @@ constructor( jsonHandler(clientOptions.jsonMapper) .withErrorHandler(errorHandler) - /** List the test results for a commit (project version). */ + /** List the test results for a project commit (project version). */ override fun list( params: CommitTestResultListParams, requestOptions: RequestOptions diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/DataServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/DataServiceAsync.kt similarity index 58% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/DataServiceAsync.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/DataServiceAsync.kt index d38c9de..4f079ec 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/DataServiceAsync.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/DataServiceAsync.kt @@ -2,16 +2,16 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.services.async.inferencePipelines +package com.openlayer.api.services.async.inferencePipelines +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.InferencePipelineDataStreamParams +import com.openlayer.api.models.InferencePipelineDataStreamResponse import java.util.concurrent.CompletableFuture -import org.openlayer.core.RequestOptions -import org.openlayer.models.InferencePipelineDataStreamParams -import org.openlayer.models.InferencePipelineDataStreamResponse interface DataServiceAsync { - /** Stream production data to an inference pipeline in Openlayer. */ + /** Publish an inference data point to an inference pipeline. */ @JvmOverloads fun stream( params: InferencePipelineDataStreamParams, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/DataServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/DataServiceAsyncImpl.kt similarity index 68% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/DataServiceAsyncImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/DataServiceAsyncImpl.kt index 0a525dd..bbbf784 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/DataServiceAsyncImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/DataServiceAsyncImpl.kt @@ -1,20 +1,20 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.async.inferencePipelines +package com.openlayer.api.services.async.inferencePipelines +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.InferencePipelineDataStreamParams +import com.openlayer.api.models.InferencePipelineDataStreamResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler import java.util.concurrent.CompletableFuture -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.InferencePipelineDataStreamParams -import org.openlayer.models.InferencePipelineDataStreamResponse -import org.openlayer.services.errorHandler -import org.openlayer.services.json -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler class DataServiceAsyncImpl constructor( @@ -27,7 +27,7 @@ constructor( jsonHandler(clientOptions.jsonMapper) .withErrorHandler(errorHandler) - /** Stream production data to an inference pipeline in Openlayer. */ + /** Publish an inference data point to an inference pipeline. */ override fun stream( params: InferencePipelineDataStreamParams, requestOptions: RequestOptions diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/RowServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/RowServiceAsync.kt new file mode 100644 index 0000000..4522c37 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/RowServiceAsync.kt @@ -0,0 +1,20 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.async.inferencePipelines + +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.InferencePipelineRowUpdateParams +import com.openlayer.api.models.InferencePipelineRowUpdateResponse +import java.util.concurrent.CompletableFuture + +interface RowServiceAsync { + + /** Update an inference data point in an inference pipeline. */ + @JvmOverloads + fun update( + params: InferencePipelineRowUpdateParams, + requestOptions: RequestOptions = RequestOptions.none() + ): CompletableFuture +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/RowServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/RowServiceAsyncImpl.kt new file mode 100644 index 0000000..9304fa7 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/RowServiceAsyncImpl.kt @@ -0,0 +1,56 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.async.inferencePipelines + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.InferencePipelineRowUpdateParams +import com.openlayer.api.models.InferencePipelineRowUpdateResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler +import java.util.concurrent.CompletableFuture + +class RowServiceAsyncImpl +constructor( + private val clientOptions: ClientOptions, +) : RowServiceAsync { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val updateHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** Update an inference data point in an inference pipeline. */ + override fun update( + params: InferencePipelineRowUpdateParams, + requestOptions: RequestOptions + ): CompletableFuture { + val request = + HttpRequest.builder() + .method(HttpMethod.PUT) + .addPathSegments("inference-pipelines", params.getPathParam(0), "rows") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .body(json(clientOptions.jsonMapper, params.getBody())) + .build() + return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response + -> + response + .use { updateHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/TestResultServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/TestResultServiceAsync.kt similarity index 58% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/TestResultServiceAsync.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/TestResultServiceAsync.kt index 6bc53cc..5d526af 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/TestResultServiceAsync.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/TestResultServiceAsync.kt @@ -2,16 +2,16 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.services.async.inferencePipelines +package com.openlayer.api.services.async.inferencePipelines +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.InferencePipelineTestResultListParams +import com.openlayer.api.models.InferencePipelineTestResultListResponse import java.util.concurrent.CompletableFuture -import org.openlayer.core.RequestOptions -import org.openlayer.models.InferencePipelineTestResultListParams -import org.openlayer.models.InferencePipelineTestResultListResponse interface TestResultServiceAsync { - /** List the test results under an inference pipeline. */ + /** List the latest test results for an inference pipeline. */ @JvmOverloads fun list( params: InferencePipelineTestResultListParams, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/TestResultServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/TestResultServiceAsyncImpl.kt similarity index 69% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/TestResultServiceAsyncImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/TestResultServiceAsyncImpl.kt index 1bc0866..0b4305b 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/inferencePipelines/TestResultServiceAsyncImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/inferencePipelines/TestResultServiceAsyncImpl.kt @@ -1,19 +1,19 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.async.inferencePipelines +package com.openlayer.api.services.async.inferencePipelines +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.InferencePipelineTestResultListParams +import com.openlayer.api.models.InferencePipelineTestResultListResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler import java.util.concurrent.CompletableFuture -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.InferencePipelineTestResultListParams -import org.openlayer.models.InferencePipelineTestResultListResponse -import org.openlayer.services.errorHandler -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler class TestResultServiceAsyncImpl constructor( @@ -26,7 +26,7 @@ constructor( jsonHandler(clientOptions.jsonMapper) .withErrorHandler(errorHandler) - /** List the test results under an inference pipeline. */ + /** List the latest test results for an inference pipeline. */ override fun list( params: InferencePipelineTestResultListParams, requestOptions: RequestOptions diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/CommitServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/CommitServiceAsync.kt similarity index 60% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/CommitServiceAsync.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/CommitServiceAsync.kt index 1875026..cc723f2 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/CommitServiceAsync.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/CommitServiceAsync.kt @@ -2,16 +2,16 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.services.async.projects +package com.openlayer.api.services.async.projects +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.ProjectCommitListParams +import com.openlayer.api.models.ProjectCommitListResponse import java.util.concurrent.CompletableFuture -import org.openlayer.core.RequestOptions -import org.openlayer.models.ProjectCommitListParams -import org.openlayer.models.ProjectCommitListResponse interface CommitServiceAsync { - /** List the commits (project versions) under a project. */ + /** List the commits (project versions) in a project. */ @JvmOverloads fun list( params: ProjectCommitListParams, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/CommitServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/CommitServiceAsyncImpl.kt similarity index 69% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/CommitServiceAsyncImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/CommitServiceAsyncImpl.kt index f9f3d2f..9fb60aa 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/CommitServiceAsyncImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/CommitServiceAsyncImpl.kt @@ -1,19 +1,19 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.async.projects +package com.openlayer.api.services.async.projects +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.ProjectCommitListParams +import com.openlayer.api.models.ProjectCommitListResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler import java.util.concurrent.CompletableFuture -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.ProjectCommitListParams -import org.openlayer.models.ProjectCommitListResponse -import org.openlayer.services.errorHandler -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler class CommitServiceAsyncImpl constructor( @@ -26,7 +26,7 @@ constructor( jsonHandler(clientOptions.jsonMapper) .withErrorHandler(errorHandler) - /** List the commits (project versions) under a project. */ + /** List the commits (project versions) in a project. */ override fun list( params: ProjectCommitListParams, requestOptions: RequestOptions diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/InferencePipelineServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/InferencePipelineServiceAsync.kt new file mode 100644 index 0000000..a0a6c63 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/InferencePipelineServiceAsync.kt @@ -0,0 +1,29 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.async.projects + +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.ProjectInferencePipelineCreateParams +import com.openlayer.api.models.ProjectInferencePipelineCreateResponse +import com.openlayer.api.models.ProjectInferencePipelineListParams +import com.openlayer.api.models.ProjectInferencePipelineListResponse +import java.util.concurrent.CompletableFuture + +interface InferencePipelineServiceAsync { + + /** Create an inference pipeline in a project. */ + @JvmOverloads + fun create( + params: ProjectInferencePipelineCreateParams, + requestOptions: RequestOptions = RequestOptions.none() + ): CompletableFuture + + /** List the inference pipelines in a project. */ + @JvmOverloads + fun list( + params: ProjectInferencePipelineListParams, + requestOptions: RequestOptions = RequestOptions.none() + ): CompletableFuture +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/InferencePipelineServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/InferencePipelineServiceAsyncImpl.kt new file mode 100644 index 0000000..262589d --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/projects/InferencePipelineServiceAsyncImpl.kt @@ -0,0 +1,88 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.async.projects + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.ProjectInferencePipelineCreateParams +import com.openlayer.api.models.ProjectInferencePipelineCreateResponse +import com.openlayer.api.models.ProjectInferencePipelineListParams +import com.openlayer.api.models.ProjectInferencePipelineListResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler +import java.util.concurrent.CompletableFuture + +class InferencePipelineServiceAsyncImpl +constructor( + private val clientOptions: ClientOptions, +) : InferencePipelineServiceAsync { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val createHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** Create an inference pipeline in a project. */ + override fun create( + params: ProjectInferencePipelineCreateParams, + requestOptions: RequestOptions + ): CompletableFuture { + val request = + HttpRequest.builder() + .method(HttpMethod.POST) + .addPathSegments("projects", params.getPathParam(0), "inference-pipelines") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .body(json(clientOptions.jsonMapper, params.getBody())) + .build() + return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response + -> + response + .use { createHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } + + private val listHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** List the inference pipelines in a project. */ + override fun list( + params: ProjectInferencePipelineListParams, + requestOptions: RequestOptions + ): CompletableFuture { + val request = + HttpRequest.builder() + .method(HttpMethod.GET) + .addPathSegments("projects", params.getPathParam(0), "inference-pipelines") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .build() + return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response + -> + response + .use { listHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/storage/PresignedUrlServiceAsync.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/storage/PresignedUrlServiceAsync.kt new file mode 100644 index 0000000..933abd8 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/storage/PresignedUrlServiceAsync.kt @@ -0,0 +1,20 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.async.storage + +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.StoragePresignedUrlCreateParams +import com.openlayer.api.models.StoragePresignedUrlCreateResponse +import java.util.concurrent.CompletableFuture + +interface PresignedUrlServiceAsync { + + /** Retrieve a presigned url to post storage artifacts. */ + @JvmOverloads + fun create( + params: StoragePresignedUrlCreateParams, + requestOptions: RequestOptions = RequestOptions.none() + ): CompletableFuture +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/storage/PresignedUrlServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/storage/PresignedUrlServiceAsyncImpl.kt new file mode 100644 index 0000000..65a6972 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/async/storage/PresignedUrlServiceAsyncImpl.kt @@ -0,0 +1,56 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.async.storage + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.StoragePresignedUrlCreateParams +import com.openlayer.api.models.StoragePresignedUrlCreateResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler +import java.util.concurrent.CompletableFuture + +class PresignedUrlServiceAsyncImpl +constructor( + private val clientOptions: ClientOptions, +) : PresignedUrlServiceAsync { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val createHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** Retrieve a presigned url to post storage artifacts. */ + override fun create( + params: StoragePresignedUrlCreateParams, + requestOptions: RequestOptions + ): CompletableFuture { + val request = + HttpRequest.builder() + .method(HttpMethod.POST) + .addPathSegments("storage", "presigned-url") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .apply { params.getBody().ifPresent { body(json(clientOptions.jsonMapper, it)) } } + .build() + return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response + -> + response + .use { createHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/CommitService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/CommitService.kt similarity index 65% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/CommitService.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/CommitService.kt index 8aa2c72..86553e1 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/CommitService.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/CommitService.kt @@ -2,9 +2,9 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.services.blocking +package com.openlayer.api.services.blocking -import org.openlayer.services.blocking.commits.TestResultService +import com.openlayer.api.services.blocking.commits.TestResultService interface CommitService { diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/CommitServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/CommitServiceImpl.kt similarity index 52% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/CommitServiceImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/CommitServiceImpl.kt index cf56a53..cae0abd 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/CommitServiceImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/CommitServiceImpl.kt @@ -1,13 +1,13 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.blocking +package com.openlayer.api.services.blocking -import org.openlayer.core.ClientOptions -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.services.blocking.commits.TestResultService -import org.openlayer.services.blocking.commits.TestResultServiceImpl -import org.openlayer.services.errorHandler +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.services.blocking.commits.TestResultService +import com.openlayer.api.services.blocking.commits.TestResultServiceImpl +import com.openlayer.api.services.errorHandler class CommitServiceImpl constructor( diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/InferencePipelineService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/InferencePipelineService.kt new file mode 100644 index 0000000..8b22b53 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/InferencePipelineService.kt @@ -0,0 +1,45 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.blocking + +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.InferencePipelineDeleteParams +import com.openlayer.api.models.InferencePipelineRetrieveParams +import com.openlayer.api.models.InferencePipelineRetrieveResponse +import com.openlayer.api.models.InferencePipelineUpdateParams +import com.openlayer.api.models.InferencePipelineUpdateResponse +import com.openlayer.api.services.blocking.inferencePipelines.DataService +import com.openlayer.api.services.blocking.inferencePipelines.RowService +import com.openlayer.api.services.blocking.inferencePipelines.TestResultService + +interface InferencePipelineService { + + fun data(): DataService + + fun rows(): RowService + + fun testResults(): TestResultService + + /** Retrieve inference pipeline. */ + @JvmOverloads + fun retrieve( + params: InferencePipelineRetrieveParams, + requestOptions: RequestOptions = RequestOptions.none() + ): InferencePipelineRetrieveResponse + + /** Update inference pipeline. */ + @JvmOverloads + fun update( + params: InferencePipelineUpdateParams, + requestOptions: RequestOptions = RequestOptions.none() + ): InferencePipelineUpdateResponse + + /** Delete inference pipeline. */ + @JvmOverloads + fun delete( + params: InferencePipelineDeleteParams, + requestOptions: RequestOptions = RequestOptions.none() + ) +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/InferencePipelineServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/InferencePipelineServiceImpl.kt new file mode 100644 index 0000000..efc4fb6 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/InferencePipelineServiceImpl.kt @@ -0,0 +1,124 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.InferencePipelineDeleteParams +import com.openlayer.api.models.InferencePipelineRetrieveParams +import com.openlayer.api.models.InferencePipelineRetrieveResponse +import com.openlayer.api.models.InferencePipelineUpdateParams +import com.openlayer.api.models.InferencePipelineUpdateResponse +import com.openlayer.api.services.blocking.inferencePipelines.DataService +import com.openlayer.api.services.blocking.inferencePipelines.DataServiceImpl +import com.openlayer.api.services.blocking.inferencePipelines.RowService +import com.openlayer.api.services.blocking.inferencePipelines.RowServiceImpl +import com.openlayer.api.services.blocking.inferencePipelines.TestResultService +import com.openlayer.api.services.blocking.inferencePipelines.TestResultServiceImpl +import com.openlayer.api.services.emptyHandler +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler + +class InferencePipelineServiceImpl +constructor( + private val clientOptions: ClientOptions, +) : InferencePipelineService { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val data: DataService by lazy { DataServiceImpl(clientOptions) } + + private val rows: RowService by lazy { RowServiceImpl(clientOptions) } + + private val testResults: TestResultService by lazy { TestResultServiceImpl(clientOptions) } + + override fun data(): DataService = data + + override fun rows(): RowService = rows + + override fun testResults(): TestResultService = testResults + + private val retrieveHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** Retrieve inference pipeline. */ + override fun retrieve( + params: InferencePipelineRetrieveParams, + requestOptions: RequestOptions + ): InferencePipelineRetrieveResponse { + val request = + HttpRequest.builder() + .method(HttpMethod.GET) + .addPathSegments("inference-pipelines", params.getPathParam(0)) + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .build() + return clientOptions.httpClient.execute(request, requestOptions).let { response -> + response + .use { retrieveHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } + + private val updateHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** Update inference pipeline. */ + override fun update( + params: InferencePipelineUpdateParams, + requestOptions: RequestOptions + ): InferencePipelineUpdateResponse { + val request = + HttpRequest.builder() + .method(HttpMethod.PUT) + .addPathSegments("inference-pipelines", params.getPathParam(0)) + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .body(json(clientOptions.jsonMapper, params.getBody())) + .build() + return clientOptions.httpClient.execute(request, requestOptions).let { response -> + response + .use { updateHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } + + private val deleteHandler: Handler = emptyHandler().withErrorHandler(errorHandler) + + /** Delete inference pipeline. */ + override fun delete(params: InferencePipelineDeleteParams, requestOptions: RequestOptions) { + val request = + HttpRequest.builder() + .method(HttpMethod.DELETE) + .addPathSegments("inference-pipelines", params.getPathParam(0)) + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .apply { params.getBody().ifPresent { body(json(clientOptions.jsonMapper, it)) } } + .build() + clientOptions.httpClient.execute(request, requestOptions).let { response -> + response.use { deleteHandler.handle(it) } + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/ProjectService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/ProjectService.kt new file mode 100644 index 0000000..a9e58d1 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/ProjectService.kt @@ -0,0 +1,34 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.blocking + +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.ProjectCreateParams +import com.openlayer.api.models.ProjectCreateResponse +import com.openlayer.api.models.ProjectListParams +import com.openlayer.api.models.ProjectListResponse +import com.openlayer.api.services.blocking.projects.CommitService +import com.openlayer.api.services.blocking.projects.InferencePipelineService + +interface ProjectService { + + fun commits(): CommitService + + fun inferencePipelines(): InferencePipelineService + + /** Create a project in your workspace. */ + @JvmOverloads + fun create( + params: ProjectCreateParams, + requestOptions: RequestOptions = RequestOptions.none() + ): ProjectCreateResponse + + /** List your workspace's projects. */ + @JvmOverloads + fun list( + params: ProjectListParams, + requestOptions: RequestOptions = RequestOptions.none() + ): ProjectListResponse +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/ProjectServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/ProjectServiceImpl.kt new file mode 100644 index 0000000..e441602 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/ProjectServiceImpl.kt @@ -0,0 +1,97 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.ProjectCreateParams +import com.openlayer.api.models.ProjectCreateResponse +import com.openlayer.api.models.ProjectListParams +import com.openlayer.api.models.ProjectListResponse +import com.openlayer.api.services.blocking.projects.CommitService +import com.openlayer.api.services.blocking.projects.CommitServiceImpl +import com.openlayer.api.services.blocking.projects.InferencePipelineService +import com.openlayer.api.services.blocking.projects.InferencePipelineServiceImpl +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler + +class ProjectServiceImpl +constructor( + private val clientOptions: ClientOptions, +) : ProjectService { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val commits: CommitService by lazy { CommitServiceImpl(clientOptions) } + + private val inferencePipelines: InferencePipelineService by lazy { + InferencePipelineServiceImpl(clientOptions) + } + + override fun commits(): CommitService = commits + + override fun inferencePipelines(): InferencePipelineService = inferencePipelines + + private val createHandler: Handler = + jsonHandler(clientOptions.jsonMapper).withErrorHandler(errorHandler) + + /** Create a project in your workspace. */ + override fun create( + params: ProjectCreateParams, + requestOptions: RequestOptions + ): ProjectCreateResponse { + val request = + HttpRequest.builder() + .method(HttpMethod.POST) + .addPathSegments("projects") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .body(json(clientOptions.jsonMapper, params.getBody())) + .build() + return clientOptions.httpClient.execute(request, requestOptions).let { response -> + response + .use { createHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } + + private val listHandler: Handler = + jsonHandler(clientOptions.jsonMapper).withErrorHandler(errorHandler) + + /** List your workspace's projects. */ + override fun list( + params: ProjectListParams, + requestOptions: RequestOptions + ): ProjectListResponse { + val request = + HttpRequest.builder() + .method(HttpMethod.GET) + .addPathSegments("projects") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .build() + return clientOptions.httpClient.execute(request, requestOptions).let { response -> + response + .use { listHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/StorageService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/StorageService.kt new file mode 100644 index 0000000..bd8b0a0 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/StorageService.kt @@ -0,0 +1,12 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.blocking + +import com.openlayer.api.services.blocking.storage.PresignedUrlService + +interface StorageService { + + fun presignedUrl(): PresignedUrlService +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/StorageServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/StorageServiceImpl.kt new file mode 100644 index 0000000..25ff043 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/StorageServiceImpl.kt @@ -0,0 +1,22 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.services.blocking.storage.PresignedUrlService +import com.openlayer.api.services.blocking.storage.PresignedUrlServiceImpl +import com.openlayer.api.services.errorHandler + +class StorageServiceImpl +constructor( + private val clientOptions: ClientOptions, +) : StorageService { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val presignedUrl: PresignedUrlService by lazy { PresignedUrlServiceImpl(clientOptions) } + + override fun presignedUrl(): PresignedUrlService = presignedUrl +} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/commits/TestResultService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/commits/TestResultService.kt similarity index 55% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/commits/TestResultService.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/commits/TestResultService.kt index b9fb6aa..5ad32ef 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/commits/TestResultService.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/commits/TestResultService.kt @@ -2,15 +2,15 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.services.blocking.commits +package com.openlayer.api.services.blocking.commits -import org.openlayer.core.RequestOptions -import org.openlayer.models.CommitTestResultListParams -import org.openlayer.models.CommitTestResultListResponse +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.CommitTestResultListParams +import com.openlayer.api.models.CommitTestResultListResponse interface TestResultService { - /** List the test results for a commit (project version). */ + /** List the test results for a project commit (project version). */ @JvmOverloads fun list( params: CommitTestResultListParams, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/commits/TestResultServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/commits/TestResultServiceImpl.kt similarity index 67% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/commits/TestResultServiceImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/commits/TestResultServiceImpl.kt index 4074e01..01739b4 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/commits/TestResultServiceImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/commits/TestResultServiceImpl.kt @@ -1,18 +1,18 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.blocking.commits +package com.openlayer.api.services.blocking.commits -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.CommitTestResultListParams -import org.openlayer.models.CommitTestResultListResponse -import org.openlayer.services.errorHandler -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.CommitTestResultListParams +import com.openlayer.api.models.CommitTestResultListResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler class TestResultServiceImpl constructor( @@ -25,7 +25,7 @@ constructor( jsonHandler(clientOptions.jsonMapper) .withErrorHandler(errorHandler) - /** List the test results for a commit (project version). */ + /** List the test results for a project commit (project version). */ override fun list( params: CommitTestResultListParams, requestOptions: RequestOptions diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/DataService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/DataService.kt similarity index 54% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/DataService.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/DataService.kt index 44ba3d7..bbfd2cf 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/DataService.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/DataService.kt @@ -2,15 +2,15 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.services.blocking.inferencePipelines +package com.openlayer.api.services.blocking.inferencePipelines -import org.openlayer.core.RequestOptions -import org.openlayer.models.InferencePipelineDataStreamParams -import org.openlayer.models.InferencePipelineDataStreamResponse +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.InferencePipelineDataStreamParams +import com.openlayer.api.models.InferencePipelineDataStreamResponse interface DataService { - /** Stream production data to an inference pipeline in Openlayer. */ + /** Publish an inference data point to an inference pipeline. */ @JvmOverloads fun stream( params: InferencePipelineDataStreamParams, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/DataServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/DataServiceImpl.kt similarity index 67% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/DataServiceImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/DataServiceImpl.kt index 06e6b2e..41c4268 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/DataServiceImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/DataServiceImpl.kt @@ -1,19 +1,19 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.blocking.inferencePipelines +package com.openlayer.api.services.blocking.inferencePipelines -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.InferencePipelineDataStreamParams -import org.openlayer.models.InferencePipelineDataStreamResponse -import org.openlayer.services.errorHandler -import org.openlayer.services.json -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.InferencePipelineDataStreamParams +import com.openlayer.api.models.InferencePipelineDataStreamResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler class DataServiceImpl constructor( @@ -26,7 +26,7 @@ constructor( jsonHandler(clientOptions.jsonMapper) .withErrorHandler(errorHandler) - /** Stream production data to an inference pipeline in Openlayer. */ + /** Publish an inference data point to an inference pipeline. */ override fun stream( params: InferencePipelineDataStreamParams, requestOptions: RequestOptions diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/RowService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/RowService.kt new file mode 100644 index 0000000..3548f85 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/RowService.kt @@ -0,0 +1,19 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.blocking.inferencePipelines + +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.InferencePipelineRowUpdateParams +import com.openlayer.api.models.InferencePipelineRowUpdateResponse + +interface RowService { + + /** Update an inference data point in an inference pipeline. */ + @JvmOverloads + fun update( + params: InferencePipelineRowUpdateParams, + requestOptions: RequestOptions = RequestOptions.none() + ): InferencePipelineRowUpdateResponse +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/RowServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/RowServiceImpl.kt new file mode 100644 index 0000000..d5f73a0 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/RowServiceImpl.kt @@ -0,0 +1,54 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking.inferencePipelines + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.InferencePipelineRowUpdateParams +import com.openlayer.api.models.InferencePipelineRowUpdateResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler + +class RowServiceImpl +constructor( + private val clientOptions: ClientOptions, +) : RowService { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val updateHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** Update an inference data point in an inference pipeline. */ + override fun update( + params: InferencePipelineRowUpdateParams, + requestOptions: RequestOptions + ): InferencePipelineRowUpdateResponse { + val request = + HttpRequest.builder() + .method(HttpMethod.PUT) + .addPathSegments("inference-pipelines", params.getPathParam(0), "rows") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .body(json(clientOptions.jsonMapper, params.getBody())) + .build() + return clientOptions.httpClient.execute(request, requestOptions).let { response -> + response + .use { updateHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/TestResultService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/TestResultService.kt similarity index 54% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/TestResultService.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/TestResultService.kt index 74c6cc0..24e0ca5 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/TestResultService.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/TestResultService.kt @@ -2,15 +2,15 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.services.blocking.inferencePipelines +package com.openlayer.api.services.blocking.inferencePipelines -import org.openlayer.core.RequestOptions -import org.openlayer.models.InferencePipelineTestResultListParams -import org.openlayer.models.InferencePipelineTestResultListResponse +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.InferencePipelineTestResultListParams +import com.openlayer.api.models.InferencePipelineTestResultListResponse interface TestResultService { - /** List the test results under an inference pipeline. */ + /** List the latest test results for an inference pipeline. */ @JvmOverloads fun list( params: InferencePipelineTestResultListParams, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/TestResultServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/TestResultServiceImpl.kt similarity index 67% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/TestResultServiceImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/TestResultServiceImpl.kt index 7d13d13..675b14f 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/inferencePipelines/TestResultServiceImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/inferencePipelines/TestResultServiceImpl.kt @@ -1,18 +1,18 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.blocking.inferencePipelines +package com.openlayer.api.services.blocking.inferencePipelines -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.InferencePipelineTestResultListParams -import org.openlayer.models.InferencePipelineTestResultListResponse -import org.openlayer.services.errorHandler -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.InferencePipelineTestResultListParams +import com.openlayer.api.models.InferencePipelineTestResultListResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler class TestResultServiceImpl constructor( @@ -25,7 +25,7 @@ constructor( jsonHandler(clientOptions.jsonMapper) .withErrorHandler(errorHandler) - /** List the test results under an inference pipeline. */ + /** List the latest test results for an inference pipeline. */ override fun list( params: InferencePipelineTestResultListParams, requestOptions: RequestOptions diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/CommitService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/CommitService.kt similarity index 55% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/CommitService.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/CommitService.kt index 9c143ef..c9fb11e 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/CommitService.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/CommitService.kt @@ -2,15 +2,15 @@ @file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 -package org.openlayer.services.blocking.projects +package com.openlayer.api.services.blocking.projects -import org.openlayer.core.RequestOptions -import org.openlayer.models.ProjectCommitListParams -import org.openlayer.models.ProjectCommitListResponse +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.ProjectCommitListParams +import com.openlayer.api.models.ProjectCommitListResponse interface CommitService { - /** List the commits (project versions) under a project. */ + /** List the commits (project versions) in a project. */ @JvmOverloads fun list( params: ProjectCommitListParams, diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/CommitServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/CommitServiceImpl.kt similarity index 67% rename from openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/CommitServiceImpl.kt rename to openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/CommitServiceImpl.kt index 33558b0..6cb0342 100644 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/CommitServiceImpl.kt +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/CommitServiceImpl.kt @@ -1,18 +1,18 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.blocking.projects +package com.openlayer.api.services.blocking.projects -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.ProjectCommitListParams -import org.openlayer.models.ProjectCommitListResponse -import org.openlayer.services.errorHandler -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.ProjectCommitListParams +import com.openlayer.api.models.ProjectCommitListResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler class CommitServiceImpl constructor( @@ -25,7 +25,7 @@ constructor( jsonHandler(clientOptions.jsonMapper) .withErrorHandler(errorHandler) - /** List the commits (project versions) under a project. */ + /** List the commits (project versions) in a project. */ override fun list( params: ProjectCommitListParams, requestOptions: RequestOptions diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/InferencePipelineService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/InferencePipelineService.kt new file mode 100644 index 0000000..93989fb --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/InferencePipelineService.kt @@ -0,0 +1,28 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.blocking.projects + +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.ProjectInferencePipelineCreateParams +import com.openlayer.api.models.ProjectInferencePipelineCreateResponse +import com.openlayer.api.models.ProjectInferencePipelineListParams +import com.openlayer.api.models.ProjectInferencePipelineListResponse + +interface InferencePipelineService { + + /** Create an inference pipeline in a project. */ + @JvmOverloads + fun create( + params: ProjectInferencePipelineCreateParams, + requestOptions: RequestOptions = RequestOptions.none() + ): ProjectInferencePipelineCreateResponse + + /** List the inference pipelines in a project. */ + @JvmOverloads + fun list( + params: ProjectInferencePipelineListParams, + requestOptions: RequestOptions = RequestOptions.none() + ): ProjectInferencePipelineListResponse +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/InferencePipelineServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/InferencePipelineServiceImpl.kt new file mode 100644 index 0000000..cb8655e --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/projects/InferencePipelineServiceImpl.kt @@ -0,0 +1,85 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking.projects + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.ProjectInferencePipelineCreateParams +import com.openlayer.api.models.ProjectInferencePipelineCreateResponse +import com.openlayer.api.models.ProjectInferencePipelineListParams +import com.openlayer.api.models.ProjectInferencePipelineListResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler + +class InferencePipelineServiceImpl +constructor( + private val clientOptions: ClientOptions, +) : InferencePipelineService { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val createHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** Create an inference pipeline in a project. */ + override fun create( + params: ProjectInferencePipelineCreateParams, + requestOptions: RequestOptions + ): ProjectInferencePipelineCreateResponse { + val request = + HttpRequest.builder() + .method(HttpMethod.POST) + .addPathSegments("projects", params.getPathParam(0), "inference-pipelines") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .body(json(clientOptions.jsonMapper, params.getBody())) + .build() + return clientOptions.httpClient.execute(request, requestOptions).let { response -> + response + .use { createHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } + + private val listHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** List the inference pipelines in a project. */ + override fun list( + params: ProjectInferencePipelineListParams, + requestOptions: RequestOptions + ): ProjectInferencePipelineListResponse { + val request = + HttpRequest.builder() + .method(HttpMethod.GET) + .addPathSegments("projects", params.getPathParam(0), "inference-pipelines") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .build() + return clientOptions.httpClient.execute(request, requestOptions).let { response -> + response + .use { listHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/storage/PresignedUrlService.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/storage/PresignedUrlService.kt new file mode 100644 index 0000000..6cc179e --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/storage/PresignedUrlService.kt @@ -0,0 +1,19 @@ +// File generated from our OpenAPI spec by Stainless. + +@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 + +package com.openlayer.api.services.blocking.storage + +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.models.StoragePresignedUrlCreateParams +import com.openlayer.api.models.StoragePresignedUrlCreateResponse + +interface PresignedUrlService { + + /** Retrieve a presigned url to post storage artifacts. */ + @JvmOverloads + fun create( + params: StoragePresignedUrlCreateParams, + requestOptions: RequestOptions = RequestOptions.none() + ): StoragePresignedUrlCreateResponse +} diff --git a/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/storage/PresignedUrlServiceImpl.kt b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/storage/PresignedUrlServiceImpl.kt new file mode 100644 index 0000000..dabbfe5 --- /dev/null +++ b/openlayer-java-core/src/main/kotlin/com/openlayer/api/services/blocking/storage/PresignedUrlServiceImpl.kt @@ -0,0 +1,54 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking.storage + +import com.openlayer.api.core.ClientOptions +import com.openlayer.api.core.RequestOptions +import com.openlayer.api.core.http.HttpMethod +import com.openlayer.api.core.http.HttpRequest +import com.openlayer.api.core.http.HttpResponse.Handler +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.models.StoragePresignedUrlCreateParams +import com.openlayer.api.models.StoragePresignedUrlCreateResponse +import com.openlayer.api.services.errorHandler +import com.openlayer.api.services.json +import com.openlayer.api.services.jsonHandler +import com.openlayer.api.services.withErrorHandler + +class PresignedUrlServiceImpl +constructor( + private val clientOptions: ClientOptions, +) : PresignedUrlService { + + private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) + + private val createHandler: Handler = + jsonHandler(clientOptions.jsonMapper) + .withErrorHandler(errorHandler) + + /** Retrieve a presigned url to post storage artifacts. */ + override fun create( + params: StoragePresignedUrlCreateParams, + requestOptions: RequestOptions + ): StoragePresignedUrlCreateResponse { + val request = + HttpRequest.builder() + .method(HttpMethod.POST) + .addPathSegments("storage", "presigned-url") + .putAllQueryParams(clientOptions.queryParams) + .putAllQueryParams(params.getQueryParams()) + .putAllHeaders(clientOptions.headers) + .putAllHeaders(params.getHeaders()) + .apply { params.getBody().ifPresent { body(json(clientOptions.jsonMapper, it)) } } + .build() + return clientOptions.httpClient.execute(request, requestOptions).let { response -> + response + .use { createHandler.handle(it) } + .apply { + if (requestOptions.responseValidation ?: clientOptions.responseValidation) { + validate() + } + } + } + } +} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/InferencePipelineServiceAsync.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/InferencePipelineServiceAsync.kt deleted file mode 100644 index 12b92b1..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/InferencePipelineServiceAsync.kt +++ /dev/null @@ -1,15 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 - -package org.openlayer.services.async - -import org.openlayer.services.async.inferencePipelines.DataServiceAsync -import org.openlayer.services.async.inferencePipelines.TestResultServiceAsync - -interface InferencePipelineServiceAsync { - - fun data(): DataServiceAsync - - fun testResults(): TestResultServiceAsync -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/InferencePipelineServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/InferencePipelineServiceAsyncImpl.kt deleted file mode 100644 index 57e7721..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/InferencePipelineServiceAsyncImpl.kt +++ /dev/null @@ -1,30 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -package org.openlayer.services.async - -import org.openlayer.core.ClientOptions -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.services.async.inferencePipelines.DataServiceAsync -import org.openlayer.services.async.inferencePipelines.DataServiceAsyncImpl -import org.openlayer.services.async.inferencePipelines.TestResultServiceAsync -import org.openlayer.services.async.inferencePipelines.TestResultServiceAsyncImpl -import org.openlayer.services.errorHandler - -class InferencePipelineServiceAsyncImpl -constructor( - private val clientOptions: ClientOptions, -) : InferencePipelineServiceAsync { - - private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) - - private val data: DataServiceAsync by lazy { DataServiceAsyncImpl(clientOptions) } - - private val testResults: TestResultServiceAsync by lazy { - TestResultServiceAsyncImpl(clientOptions) - } - - override fun data(): DataServiceAsync = data - - override fun testResults(): TestResultServiceAsync = testResults -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/ProjectServiceAsync.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/ProjectServiceAsync.kt deleted file mode 100644 index b3fa807..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/ProjectServiceAsync.kt +++ /dev/null @@ -1,26 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 - -package org.openlayer.services.async - -import java.util.concurrent.CompletableFuture -import org.openlayer.core.RequestOptions -import org.openlayer.models.ProjectListParams -import org.openlayer.models.ProjectListResponse -import org.openlayer.services.async.projects.CommitServiceAsync -import org.openlayer.services.async.projects.InferencePipelineServiceAsync - -interface ProjectServiceAsync { - - fun commits(): CommitServiceAsync - - fun inferencePipelines(): InferencePipelineServiceAsync - - /** List the projects in a user's workspace. */ - @JvmOverloads - fun list( - params: ProjectListParams, - requestOptions: RequestOptions = RequestOptions.none() - ): CompletableFuture -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/ProjectServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/ProjectServiceAsyncImpl.kt deleted file mode 100644 index 9cb3d2b..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/ProjectServiceAsyncImpl.kt +++ /dev/null @@ -1,67 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -package org.openlayer.services.async - -import java.util.concurrent.CompletableFuture -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.ProjectListParams -import org.openlayer.models.ProjectListResponse -import org.openlayer.services.async.projects.CommitServiceAsync -import org.openlayer.services.async.projects.CommitServiceAsyncImpl -import org.openlayer.services.async.projects.InferencePipelineServiceAsync -import org.openlayer.services.async.projects.InferencePipelineServiceAsyncImpl -import org.openlayer.services.errorHandler -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler - -class ProjectServiceAsyncImpl -constructor( - private val clientOptions: ClientOptions, -) : ProjectServiceAsync { - - private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) - - private val commits: CommitServiceAsync by lazy { CommitServiceAsyncImpl(clientOptions) } - - private val inferencePipelines: InferencePipelineServiceAsync by lazy { - InferencePipelineServiceAsyncImpl(clientOptions) - } - - override fun commits(): CommitServiceAsync = commits - - override fun inferencePipelines(): InferencePipelineServiceAsync = inferencePipelines - - private val listHandler: Handler = - jsonHandler(clientOptions.jsonMapper).withErrorHandler(errorHandler) - - /** List the projects in a user's workspace. */ - override fun list( - params: ProjectListParams, - requestOptions: RequestOptions - ): CompletableFuture { - val request = - HttpRequest.builder() - .method(HttpMethod.GET) - .addPathSegments("projects") - .putAllQueryParams(clientOptions.queryParams) - .putAllQueryParams(params.getQueryParams()) - .putAllHeaders(clientOptions.headers) - .putAllHeaders(params.getHeaders()) - .build() - return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response - -> - response - .use { listHandler.handle(it) } - .apply { - if (requestOptions.responseValidation ?: clientOptions.responseValidation) { - validate() - } - } - } - } -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/InferencePipelineServiceAsync.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/InferencePipelineServiceAsync.kt deleted file mode 100644 index 32d2e12..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/InferencePipelineServiceAsync.kt +++ /dev/null @@ -1,20 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 - -package org.openlayer.services.async.projects - -import java.util.concurrent.CompletableFuture -import org.openlayer.core.RequestOptions -import org.openlayer.models.ProjectInferencePipelineListParams -import org.openlayer.models.ProjectInferencePipelineListResponse - -interface InferencePipelineServiceAsync { - - /** List the inference pipelines in a project. */ - @JvmOverloads - fun list( - params: ProjectInferencePipelineListParams, - requestOptions: RequestOptions = RequestOptions.none() - ): CompletableFuture -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/InferencePipelineServiceAsyncImpl.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/InferencePipelineServiceAsyncImpl.kt deleted file mode 100644 index 9a5fe84..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/async/projects/InferencePipelineServiceAsyncImpl.kt +++ /dev/null @@ -1,54 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -package org.openlayer.services.async.projects - -import java.util.concurrent.CompletableFuture -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.ProjectInferencePipelineListParams -import org.openlayer.models.ProjectInferencePipelineListResponse -import org.openlayer.services.errorHandler -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler - -class InferencePipelineServiceAsyncImpl -constructor( - private val clientOptions: ClientOptions, -) : InferencePipelineServiceAsync { - - private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) - - private val listHandler: Handler = - jsonHandler(clientOptions.jsonMapper) - .withErrorHandler(errorHandler) - - /** List the inference pipelines in a project. */ - override fun list( - params: ProjectInferencePipelineListParams, - requestOptions: RequestOptions - ): CompletableFuture { - val request = - HttpRequest.builder() - .method(HttpMethod.GET) - .addPathSegments("projects", params.getPathParam(0), "inference-pipelines") - .putAllQueryParams(clientOptions.queryParams) - .putAllQueryParams(params.getQueryParams()) - .putAllHeaders(clientOptions.headers) - .putAllHeaders(params.getHeaders()) - .build() - return clientOptions.httpClient.executeAsync(request, requestOptions).thenApply { response - -> - response - .use { listHandler.handle(it) } - .apply { - if (requestOptions.responseValidation ?: clientOptions.responseValidation) { - validate() - } - } - } - } -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/InferencePipelineService.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/InferencePipelineService.kt deleted file mode 100644 index 5d9bf22..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/InferencePipelineService.kt +++ /dev/null @@ -1,15 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 - -package org.openlayer.services.blocking - -import org.openlayer.services.blocking.inferencePipelines.DataService -import org.openlayer.services.blocking.inferencePipelines.TestResultService - -interface InferencePipelineService { - - fun data(): DataService - - fun testResults(): TestResultService -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/InferencePipelineServiceImpl.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/InferencePipelineServiceImpl.kt deleted file mode 100644 index bfcbe42..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/InferencePipelineServiceImpl.kt +++ /dev/null @@ -1,28 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -package org.openlayer.services.blocking - -import org.openlayer.core.ClientOptions -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.services.blocking.inferencePipelines.DataService -import org.openlayer.services.blocking.inferencePipelines.DataServiceImpl -import org.openlayer.services.blocking.inferencePipelines.TestResultService -import org.openlayer.services.blocking.inferencePipelines.TestResultServiceImpl -import org.openlayer.services.errorHandler - -class InferencePipelineServiceImpl -constructor( - private val clientOptions: ClientOptions, -) : InferencePipelineService { - - private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) - - private val data: DataService by lazy { DataServiceImpl(clientOptions) } - - private val testResults: TestResultService by lazy { TestResultServiceImpl(clientOptions) } - - override fun data(): DataService = data - - override fun testResults(): TestResultService = testResults -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/ProjectService.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/ProjectService.kt deleted file mode 100644 index da82905..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/ProjectService.kt +++ /dev/null @@ -1,25 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 - -package org.openlayer.services.blocking - -import org.openlayer.core.RequestOptions -import org.openlayer.models.ProjectListParams -import org.openlayer.models.ProjectListResponse -import org.openlayer.services.blocking.projects.CommitService -import org.openlayer.services.blocking.projects.InferencePipelineService - -interface ProjectService { - - fun commits(): CommitService - - fun inferencePipelines(): InferencePipelineService - - /** List the projects in a user's workspace. */ - @JvmOverloads - fun list( - params: ProjectListParams, - requestOptions: RequestOptions = RequestOptions.none() - ): ProjectListResponse -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/ProjectServiceImpl.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/ProjectServiceImpl.kt deleted file mode 100644 index 234a84e..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/ProjectServiceImpl.kt +++ /dev/null @@ -1,65 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -package org.openlayer.services.blocking - -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.ProjectListParams -import org.openlayer.models.ProjectListResponse -import org.openlayer.services.blocking.projects.CommitService -import org.openlayer.services.blocking.projects.CommitServiceImpl -import org.openlayer.services.blocking.projects.InferencePipelineService -import org.openlayer.services.blocking.projects.InferencePipelineServiceImpl -import org.openlayer.services.errorHandler -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler - -class ProjectServiceImpl -constructor( - private val clientOptions: ClientOptions, -) : ProjectService { - - private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) - - private val commits: CommitService by lazy { CommitServiceImpl(clientOptions) } - - private val inferencePipelines: InferencePipelineService by lazy { - InferencePipelineServiceImpl(clientOptions) - } - - override fun commits(): CommitService = commits - - override fun inferencePipelines(): InferencePipelineService = inferencePipelines - - private val listHandler: Handler = - jsonHandler(clientOptions.jsonMapper).withErrorHandler(errorHandler) - - /** List the projects in a user's workspace. */ - override fun list( - params: ProjectListParams, - requestOptions: RequestOptions - ): ProjectListResponse { - val request = - HttpRequest.builder() - .method(HttpMethod.GET) - .addPathSegments("projects") - .putAllQueryParams(clientOptions.queryParams) - .putAllQueryParams(params.getQueryParams()) - .putAllHeaders(clientOptions.headers) - .putAllHeaders(params.getHeaders()) - .build() - return clientOptions.httpClient.execute(request, requestOptions).let { response -> - response - .use { listHandler.handle(it) } - .apply { - if (requestOptions.responseValidation ?: clientOptions.responseValidation) { - validate() - } - } - } - } -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/InferencePipelineService.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/InferencePipelineService.kt deleted file mode 100644 index 2d6c42a..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/InferencePipelineService.kt +++ /dev/null @@ -1,19 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -@file:Suppress("OVERLOADS_INTERFACE") // See https://youtrack.jetbrains.com/issue/KT-36102 - -package org.openlayer.services.blocking.projects - -import org.openlayer.core.RequestOptions -import org.openlayer.models.ProjectInferencePipelineListParams -import org.openlayer.models.ProjectInferencePipelineListResponse - -interface InferencePipelineService { - - /** List the inference pipelines in a project. */ - @JvmOverloads - fun list( - params: ProjectInferencePipelineListParams, - requestOptions: RequestOptions = RequestOptions.none() - ): ProjectInferencePipelineListResponse -} diff --git a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/InferencePipelineServiceImpl.kt b/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/InferencePipelineServiceImpl.kt deleted file mode 100644 index 0d22af4..0000000 --- a/openlayer-java-core/src/main/kotlin/org/openlayer/services/blocking/projects/InferencePipelineServiceImpl.kt +++ /dev/null @@ -1,52 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -package org.openlayer.services.blocking.projects - -import org.openlayer.core.ClientOptions -import org.openlayer.core.RequestOptions -import org.openlayer.core.http.HttpMethod -import org.openlayer.core.http.HttpRequest -import org.openlayer.core.http.HttpResponse.Handler -import org.openlayer.errors.OpenlayerError -import org.openlayer.models.ProjectInferencePipelineListParams -import org.openlayer.models.ProjectInferencePipelineListResponse -import org.openlayer.services.errorHandler -import org.openlayer.services.jsonHandler -import org.openlayer.services.withErrorHandler - -class InferencePipelineServiceImpl -constructor( - private val clientOptions: ClientOptions, -) : InferencePipelineService { - - private val errorHandler: Handler = errorHandler(clientOptions.jsonMapper) - - private val listHandler: Handler = - jsonHandler(clientOptions.jsonMapper) - .withErrorHandler(errorHandler) - - /** List the inference pipelines in a project. */ - override fun list( - params: ProjectInferencePipelineListParams, - requestOptions: RequestOptions - ): ProjectInferencePipelineListResponse { - val request = - HttpRequest.builder() - .method(HttpMethod.GET) - .addPathSegments("projects", params.getPathParam(0), "inference-pipelines") - .putAllQueryParams(clientOptions.queryParams) - .putAllQueryParams(params.getQueryParams()) - .putAllHeaders(clientOptions.headers) - .putAllHeaders(params.getHeaders()) - .build() - return clientOptions.httpClient.execute(request, requestOptions).let { response -> - response - .use { listHandler.handle(it) } - .apply { - if (requestOptions.responseValidation ?: clientOptions.responseValidation) { - validate() - } - } - } - } -} diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/TestServerExtension.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/TestServerExtension.kt similarity index 98% rename from openlayer-java-core/src/test/kotlin/org/openlayer/TestServerExtension.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/TestServerExtension.kt index 01e0651..0d72bda 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/TestServerExtension.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/TestServerExtension.kt @@ -1,4 +1,4 @@ -package org.openlayer +package com.openlayer.api import java.lang.RuntimeException import java.net.URL diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/core/http/HttpRequestTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/core/http/HttpRequestTest.kt similarity index 95% rename from openlayer-java-core/src/test/kotlin/org/openlayer/core/http/HttpRequestTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/core/http/HttpRequestTest.kt index 5ddca6e..fe7fc1c 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/core/http/HttpRequestTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/core/http/HttpRequestTest.kt @@ -1,4 +1,4 @@ -package org.openlayer.core.http +package com.openlayer.api.core.http import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/core/http/RetryingHttpClientTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/core/http/RetryingHttpClientTest.kt similarity index 98% rename from openlayer-java-core/src/test/kotlin/org/openlayer/core/http/RetryingHttpClientTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/core/http/RetryingHttpClientTest.kt index dc8258b..ce97799 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/core/http/RetryingHttpClientTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/core/http/RetryingHttpClientTest.kt @@ -1,13 +1,13 @@ -package org.openlayer.core.http +package com.openlayer.api.core.http import com.github.tomakehurst.wiremock.client.WireMock.* import com.github.tomakehurst.wiremock.junit5.WireMockRuntimeInfo import com.github.tomakehurst.wiremock.junit5.WireMockTest import com.github.tomakehurst.wiremock.stubbing.Scenario +import com.openlayer.api.client.okhttp.OkHttpClient import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test -import org.openlayer.client.okhttp.OkHttpClient @WireMockTest internal class RetryingHttpClientTest { diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/core/http/SerializerTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/core/http/SerializerTest.kt similarity index 98% rename from openlayer-java-core/src/test/kotlin/org/openlayer/core/http/SerializerTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/core/http/SerializerTest.kt index 6b50f24..a2f9465 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/core/http/SerializerTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/core/http/SerializerTest.kt @@ -1,13 +1,13 @@ -package org.openlayer.core.http +package com.openlayer.api.core.http import com.fasterxml.jackson.annotation.JsonAnyGetter import com.fasterxml.jackson.annotation.JsonAnySetter import com.fasterxml.jackson.annotation.JsonProperty import com.fasterxml.jackson.databind.annotation.JsonDeserialize +import com.openlayer.api.core.* import java.util.* import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test -import org.openlayer.core.* internal class SerializerTest { @JsonDeserialize(builder = ClassWithBooleanFieldPrefixedWithIs.Builder::class) diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/CommitTestResultListParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/CommitTestResultListParamsTest.kt similarity index 77% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/CommitTestResultListParamsTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/CommitTestResultListParamsTest.kt index cfdf441..a011d78 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/CommitTestResultListParamsTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/CommitTestResultListParamsTest.kt @@ -1,17 +1,17 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models +import com.openlayer.api.models.* import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test -import org.openlayer.models.* class CommitTestResultListParamsTest { @Test fun createCommitTestResultListParams() { CommitTestResultListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .projectVersionId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .includeArchived(true) .page(123L) .perPage(100L) @@ -24,7 +24,7 @@ class CommitTestResultListParamsTest { fun getQueryParams() { val params = CommitTestResultListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .projectVersionId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .includeArchived(true) .page(123L) .perPage(100L) @@ -43,7 +43,9 @@ class CommitTestResultListParamsTest { @Test fun getQueryParamsWithoutOptionalFields() { val params = - CommitTestResultListParams.builder().id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e").build() + CommitTestResultListParams.builder() + .projectVersionId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() val expected = mutableMapOf>() assertThat(params.getQueryParams()).isEqualTo(expected) } @@ -51,9 +53,11 @@ class CommitTestResultListParamsTest { @Test fun getPathParam() { val params = - CommitTestResultListParams.builder().id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e").build() + CommitTestResultListParams.builder() + .projectVersionId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() assertThat(params).isNotNull - // path param "id" + // path param "projectVersionId" assertThat(params.getPathParam(0)).isEqualTo("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") // out-of-bound path param assertThat(params.getPathParam(1)).isEqualTo("") diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/CommitTestResultListResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/CommitTestResultListResponseTest.kt similarity index 99% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/CommitTestResultListResponseTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/CommitTestResultListResponseTest.kt index 9a27418..05c6717 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/CommitTestResultListResponseTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/CommitTestResultListResponseTest.kt @@ -1,11 +1,11 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models +import com.openlayer.api.core.JsonValue import java.time.OffsetDateTime import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test -import org.openlayer.core.JsonValue class CommitTestResultListResponseTest { diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineDataStreamParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineDataStreamParamsTest.kt similarity index 93% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineDataStreamParamsTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineDataStreamParamsTest.kt index 466b844..de558c5 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineDataStreamParamsTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineDataStreamParamsTest.kt @@ -1,18 +1,18 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models +import com.openlayer.api.core.JsonValue +import com.openlayer.api.models.* import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test -import org.openlayer.core.JsonValue -import org.openlayer.models.* class InferencePipelineDataStreamParamsTest { @Test fun createInferencePipelineDataStreamParams() { InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -46,7 +46,7 @@ class InferencePipelineDataStreamParamsTest { fun getBody() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -111,7 +111,7 @@ class InferencePipelineDataStreamParamsTest { fun getBodyWithoutOptionalFields() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -139,7 +139,7 @@ class InferencePipelineDataStreamParamsTest { fun getPathParam() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -150,7 +150,7 @@ class InferencePipelineDataStreamParamsTest { .rows(listOf(InferencePipelineDataStreamParams.Row.builder().build())) .build() assertThat(params).isNotNull - // path param "id" + // path param "inferencePipelineId" assertThat(params.getPathParam(0)).isEqualTo("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") // out-of-bound path param assertThat(params.getPathParam(1)).isEqualTo("") diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineDataStreamResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineDataStreamResponseTest.kt similarity index 95% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineDataStreamResponseTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineDataStreamResponseTest.kt index 5721590..5d5c07f 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineDataStreamResponseTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineDataStreamResponseTest.kt @@ -1,6 +1,6 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineDeleteParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineDeleteParamsTest.kt new file mode 100644 index 0000000..8ee3a33 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineDeleteParamsTest.kt @@ -0,0 +1,30 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.models.* +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class InferencePipelineDeleteParamsTest { + + @Test + fun createInferencePipelineDeleteParams() { + InferencePipelineDeleteParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() + } + + @Test + fun getPathParam() { + val params = + InferencePipelineDeleteParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() + assertThat(params).isNotNull + // path param "inferencePipelineId" + assertThat(params.getPathParam(0)).isEqualTo("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + // out-of-bound path param + assertThat(params.getPathParam(1)).isEqualTo("") + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRetrieveParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRetrieveParamsTest.kt new file mode 100644 index 0000000..663b546 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRetrieveParamsTest.kt @@ -0,0 +1,30 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.models.* +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class InferencePipelineRetrieveParamsTest { + + @Test + fun createInferencePipelineRetrieveParams() { + InferencePipelineRetrieveParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() + } + + @Test + fun getPathParam() { + val params = + InferencePipelineRetrieveParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() + assertThat(params).isNotNull + // path param "inferencePipelineId" + assertThat(params.getPathParam(0)).isEqualTo("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + // out-of-bound path param + assertThat(params.getPathParam(1)).isEqualTo("") + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRetrieveResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRetrieveResponseTest.kt new file mode 100644 index 0000000..e259f06 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRetrieveResponseTest.kt @@ -0,0 +1,71 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import java.time.OffsetDateTime +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class InferencePipelineRetrieveResponseTest { + + @Test + fun createInferencePipelineRetrieveResponse() { + val inferencePipelineRetrieveResponse = + InferencePipelineRetrieveResponse.builder() + .id("3fa85f64-5717-4562-b3fc-2c963f66afa6") + .dateCreated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateLastEvaluated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateLastSampleReceived(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateOfNextEvaluation(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateUpdated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .description("This pipeline is used for production.") + .failingGoalCount(123L) + .links( + InferencePipelineRetrieveResponse.Links.builder() + .app( + "https://app.openlayer.com/myWorkspace/3fa85f64-5717-4562-b3fc-2c963f66afa6/inference-pipeline/3fa85f64-5717-4562-b3fc-2c963f66afa6" + ) + .build() + ) + .name("production") + .passingGoalCount(123L) + .projectId("3fa85f64-5717-4562-b3fc-2c963f66afa6") + .status(InferencePipelineRetrieveResponse.Status.QUEUED) + .statusMessage("Tests successfully evaluated") + .totalGoalCount(123L) + .build() + assertThat(inferencePipelineRetrieveResponse).isNotNull + assertThat(inferencePipelineRetrieveResponse.id()) + .isEqualTo("3fa85f64-5717-4562-b3fc-2c963f66afa6") + assertThat(inferencePipelineRetrieveResponse.dateCreated()) + .isEqualTo(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(inferencePipelineRetrieveResponse.dateLastEvaluated()) + .contains(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(inferencePipelineRetrieveResponse.dateLastSampleReceived()) + .contains(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(inferencePipelineRetrieveResponse.dateOfNextEvaluation()) + .contains(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(inferencePipelineRetrieveResponse.dateUpdated()) + .isEqualTo(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(inferencePipelineRetrieveResponse.description()) + .contains("This pipeline is used for production.") + assertThat(inferencePipelineRetrieveResponse.failingGoalCount()).isEqualTo(123L) + assertThat(inferencePipelineRetrieveResponse.links()) + .isEqualTo( + InferencePipelineRetrieveResponse.Links.builder() + .app( + "https://app.openlayer.com/myWorkspace/3fa85f64-5717-4562-b3fc-2c963f66afa6/inference-pipeline/3fa85f64-5717-4562-b3fc-2c963f66afa6" + ) + .build() + ) + assertThat(inferencePipelineRetrieveResponse.name()).isEqualTo("production") + assertThat(inferencePipelineRetrieveResponse.passingGoalCount()).isEqualTo(123L) + assertThat(inferencePipelineRetrieveResponse.projectId()) + .isEqualTo("3fa85f64-5717-4562-b3fc-2c963f66afa6") + assertThat(inferencePipelineRetrieveResponse.status()) + .isEqualTo(InferencePipelineRetrieveResponse.Status.QUEUED) + assertThat(inferencePipelineRetrieveResponse.statusMessage()) + .contains("Tests successfully evaluated") + assertThat(inferencePipelineRetrieveResponse.totalGoalCount()).isEqualTo(123L) + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateParamsTest.kt new file mode 100644 index 0000000..f4a70bf --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateParamsTest.kt @@ -0,0 +1,124 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.core.JsonValue +import com.openlayer.api.models.* +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class InferencePipelineRowUpdateParamsTest { + + @Test + fun createInferencePipelineRowUpdateParams() { + InferencePipelineRowUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .row(JsonValue.from(mapOf())) + .config( + InferencePipelineRowUpdateParams.Config.builder() + .groundTruthColumnName("ground_truth") + .humanFeedbackColumnName("human_feedback") + .inferenceIdColumnName("id") + .latencyColumnName("latency") + .timestampColumnName("timestamp") + .build() + ) + .inferenceId("inferenceId") + .build() + } + + @Test + fun getQueryParams() { + val params = + InferencePipelineRowUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .row(JsonValue.from(mapOf())) + .config( + InferencePipelineRowUpdateParams.Config.builder() + .groundTruthColumnName("ground_truth") + .humanFeedbackColumnName("human_feedback") + .inferenceIdColumnName("id") + .latencyColumnName("latency") + .timestampColumnName("timestamp") + .build() + ) + .inferenceId("inferenceId") + .build() + val expected = mutableMapOf>() + expected.put("inferenceId", listOf("inferenceId")) + assertThat(params.getQueryParams()).isEqualTo(expected) + } + + @Test + fun getQueryParamsWithoutOptionalFields() { + val params = + InferencePipelineRowUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .row(JsonValue.from(mapOf())) + .inferenceId("inferenceId") + .build() + val expected = mutableMapOf>() + expected.put("inferenceId", listOf("inferenceId")) + assertThat(params.getQueryParams()).isEqualTo(expected) + } + + @Test + fun getBody() { + val params = + InferencePipelineRowUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .row(JsonValue.from(mapOf())) + .config( + InferencePipelineRowUpdateParams.Config.builder() + .groundTruthColumnName("ground_truth") + .humanFeedbackColumnName("human_feedback") + .inferenceIdColumnName("id") + .latencyColumnName("latency") + .timestampColumnName("timestamp") + .build() + ) + .inferenceId("inferenceId") + .build() + val body = params.getBody() + assertThat(body).isNotNull + assertThat(body.row()).isEqualTo(JsonValue.from(mapOf())) + assertThat(body.config()) + .isEqualTo( + InferencePipelineRowUpdateParams.Config.builder() + .groundTruthColumnName("ground_truth") + .humanFeedbackColumnName("human_feedback") + .inferenceIdColumnName("id") + .latencyColumnName("latency") + .timestampColumnName("timestamp") + .build() + ) + } + + @Test + fun getBodyWithoutOptionalFields() { + val params = + InferencePipelineRowUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .row(JsonValue.from(mapOf())) + .inferenceId("inferenceId") + .build() + val body = params.getBody() + assertThat(body).isNotNull + assertThat(body.row()).isEqualTo(JsonValue.from(mapOf())) + } + + @Test + fun getPathParam() { + val params = + InferencePipelineRowUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .row(JsonValue.from(mapOf())) + .inferenceId("inferenceId") + .build() + assertThat(params).isNotNull + // path param "inferencePipelineId" + assertThat(params.getPathParam(0)).isEqualTo("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + // out-of-bound path param + assertThat(params.getPathParam(1)).isEqualTo("") + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateResponseTest.kt new file mode 100644 index 0000000..427675b --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineRowUpdateResponseTest.kt @@ -0,0 +1,20 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class InferencePipelineRowUpdateResponseTest { + + @Test + fun createInferencePipelineRowUpdateResponse() { + val inferencePipelineRowUpdateResponse = + InferencePipelineRowUpdateResponse.builder() + .success(InferencePipelineRowUpdateResponse.Success.TRUE) + .build() + assertThat(inferencePipelineRowUpdateResponse).isNotNull + assertThat(inferencePipelineRowUpdateResponse.success()) + .isEqualTo(InferencePipelineRowUpdateResponse.Success.TRUE) + } +} diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineTestResultListParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineTestResultListParamsTest.kt similarity index 81% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineTestResultListParamsTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineTestResultListParamsTest.kt index 7871212..6de2ac0 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineTestResultListParamsTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineTestResultListParamsTest.kt @@ -1,18 +1,17 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models +import com.openlayer.api.models.* import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test -import org.openlayer.models.* class InferencePipelineTestResultListParamsTest { @Test fun createInferencePipelineTestResultListParams() { InferencePipelineTestResultListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") - .includeArchived(true) + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .page(123L) .perPage(100L) .status(InferencePipelineTestResultListParams.Status.RUNNING) @@ -24,15 +23,13 @@ class InferencePipelineTestResultListParamsTest { fun getQueryParams() { val params = InferencePipelineTestResultListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") - .includeArchived(true) + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .page(123L) .perPage(100L) .status(InferencePipelineTestResultListParams.Status.RUNNING) .type(InferencePipelineTestResultListParams.Type.INTEGRITY) .build() val expected = mutableMapOf>() - expected.put("includeArchived", listOf("true")) expected.put("page", listOf("123")) expected.put("perPage", listOf("100")) expected.put( @@ -50,7 +47,7 @@ class InferencePipelineTestResultListParamsTest { fun getQueryParamsWithoutOptionalFields() { val params = InferencePipelineTestResultListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .build() val expected = mutableMapOf>() assertThat(params.getQueryParams()).isEqualTo(expected) @@ -60,10 +57,10 @@ class InferencePipelineTestResultListParamsTest { fun getPathParam() { val params = InferencePipelineTestResultListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .build() assertThat(params).isNotNull - // path param "id" + // path param "inferencePipelineId" assertThat(params.getPathParam(0)).isEqualTo("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") // out-of-bound path param assertThat(params.getPathParam(1)).isEqualTo("") diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineTestResultListResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineTestResultListResponseTest.kt similarity index 99% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineTestResultListResponseTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineTestResultListResponseTest.kt index e372b2f..d9eadbb 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/InferencePipelineTestResultListResponseTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineTestResultListResponseTest.kt @@ -1,11 +1,11 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models +import com.openlayer.api.core.JsonValue import java.time.OffsetDateTime import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test -import org.openlayer.core.JsonValue class InferencePipelineTestResultListResponseTest { diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineUpdateParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineUpdateParamsTest.kt new file mode 100644 index 0000000..ffecf85 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineUpdateParamsTest.kt @@ -0,0 +1,59 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.models.* +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class InferencePipelineUpdateParamsTest { + + @Test + fun createInferencePipelineUpdateParams() { + InferencePipelineUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .description("This pipeline is used for production.") + .name("production") + .referenceDatasetUri("referenceDatasetUri") + .build() + } + + @Test + fun getBody() { + val params = + InferencePipelineUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .description("This pipeline is used for production.") + .name("production") + .referenceDatasetUri("referenceDatasetUri") + .build() + val body = params.getBody() + assertThat(body).isNotNull + assertThat(body.description()).isEqualTo("This pipeline is used for production.") + assertThat(body.name()).isEqualTo("production") + assertThat(body.referenceDatasetUri()).isEqualTo("referenceDatasetUri") + } + + @Test + fun getBodyWithoutOptionalFields() { + val params = + InferencePipelineUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() + val body = params.getBody() + assertThat(body).isNotNull + } + + @Test + fun getPathParam() { + val params = + InferencePipelineUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() + assertThat(params).isNotNull + // path param "inferencePipelineId" + assertThat(params.getPathParam(0)).isEqualTo("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + // out-of-bound path param + assertThat(params.getPathParam(1)).isEqualTo("") + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineUpdateResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineUpdateResponseTest.kt new file mode 100644 index 0000000..35af791 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/InferencePipelineUpdateResponseTest.kt @@ -0,0 +1,71 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import java.time.OffsetDateTime +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class InferencePipelineUpdateResponseTest { + + @Test + fun createInferencePipelineUpdateResponse() { + val inferencePipelineUpdateResponse = + InferencePipelineUpdateResponse.builder() + .id("3fa85f64-5717-4562-b3fc-2c963f66afa6") + .dateCreated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateLastEvaluated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateLastSampleReceived(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateOfNextEvaluation(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateUpdated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .description("This pipeline is used for production.") + .failingGoalCount(123L) + .links( + InferencePipelineUpdateResponse.Links.builder() + .app( + "https://app.openlayer.com/myWorkspace/3fa85f64-5717-4562-b3fc-2c963f66afa6/inference-pipeline/3fa85f64-5717-4562-b3fc-2c963f66afa6" + ) + .build() + ) + .name("production") + .passingGoalCount(123L) + .projectId("3fa85f64-5717-4562-b3fc-2c963f66afa6") + .status(InferencePipelineUpdateResponse.Status.QUEUED) + .statusMessage("Tests successfully evaluated") + .totalGoalCount(123L) + .build() + assertThat(inferencePipelineUpdateResponse).isNotNull + assertThat(inferencePipelineUpdateResponse.id()) + .isEqualTo("3fa85f64-5717-4562-b3fc-2c963f66afa6") + assertThat(inferencePipelineUpdateResponse.dateCreated()) + .isEqualTo(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(inferencePipelineUpdateResponse.dateLastEvaluated()) + .contains(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(inferencePipelineUpdateResponse.dateLastSampleReceived()) + .contains(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(inferencePipelineUpdateResponse.dateOfNextEvaluation()) + .contains(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(inferencePipelineUpdateResponse.dateUpdated()) + .isEqualTo(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(inferencePipelineUpdateResponse.description()) + .contains("This pipeline is used for production.") + assertThat(inferencePipelineUpdateResponse.failingGoalCount()).isEqualTo(123L) + assertThat(inferencePipelineUpdateResponse.links()) + .isEqualTo( + InferencePipelineUpdateResponse.Links.builder() + .app( + "https://app.openlayer.com/myWorkspace/3fa85f64-5717-4562-b3fc-2c963f66afa6/inference-pipeline/3fa85f64-5717-4562-b3fc-2c963f66afa6" + ) + .build() + ) + assertThat(inferencePipelineUpdateResponse.name()).isEqualTo("production") + assertThat(inferencePipelineUpdateResponse.passingGoalCount()).isEqualTo(123L) + assertThat(inferencePipelineUpdateResponse.projectId()) + .isEqualTo("3fa85f64-5717-4562-b3fc-2c963f66afa6") + assertThat(inferencePipelineUpdateResponse.status()) + .isEqualTo(InferencePipelineUpdateResponse.Status.QUEUED) + assertThat(inferencePipelineUpdateResponse.statusMessage()) + .contains("Tests successfully evaluated") + assertThat(inferencePipelineUpdateResponse.totalGoalCount()).isEqualTo(123L) + } +} diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectCommitListParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCommitListParamsTest.kt similarity index 71% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectCommitListParamsTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCommitListParamsTest.kt index bb52fa3..17d2e0a 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectCommitListParamsTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCommitListParamsTest.kt @@ -1,17 +1,17 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models +import com.openlayer.api.models.* import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test -import org.openlayer.models.* class ProjectCommitListParamsTest { @Test fun createProjectCommitListParams() { ProjectCommitListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .page(123L) .perPage(100L) .build() @@ -21,7 +21,7 @@ class ProjectCommitListParamsTest { fun getQueryParams() { val params = ProjectCommitListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .page(123L) .perPage(100L) .build() @@ -34,7 +34,9 @@ class ProjectCommitListParamsTest { @Test fun getQueryParamsWithoutOptionalFields() { val params = - ProjectCommitListParams.builder().id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e").build() + ProjectCommitListParams.builder() + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() val expected = mutableMapOf>() assertThat(params.getQueryParams()).isEqualTo(expected) } @@ -42,9 +44,11 @@ class ProjectCommitListParamsTest { @Test fun getPathParam() { val params = - ProjectCommitListParams.builder().id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e").build() + ProjectCommitListParams.builder() + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() assertThat(params).isNotNull - // path param "id" + // path param "projectId" assertThat(params.getPathParam(0)).isEqualTo("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") // out-of-bound path param assertThat(params.getPathParam(1)).isEqualTo("") diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectCommitListResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCommitListResponseTest.kt similarity index 97% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectCommitListResponseTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCommitListResponseTest.kt index cd1982f..5793bd5 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectCommitListResponseTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCommitListResponseTest.kt @@ -1,6 +1,6 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import java.time.OffsetDateTime import org.assertj.core.api.Assertions.assertThat @@ -38,7 +38,7 @@ class ProjectCommitListResponseTest { .dateCreated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) .gitCommitRef("main") .gitCommitSha(123L) - .gitCommitUrl("string") + .gitCommitUrl("gitCommitUrl") .build() ) .dateArchived(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) @@ -94,7 +94,7 @@ class ProjectCommitListResponseTest { .dateCreated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) .gitCommitRef("main") .gitCommitSha(123L) - .gitCommitUrl("string") + .gitCommitUrl("gitCommitUrl") .build() ) .dateArchived(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCreateParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCreateParamsTest.kt new file mode 100644 index 0000000..0a0a757 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCreateParamsTest.kt @@ -0,0 +1,47 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.models.* +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class ProjectCreateParamsTest { + + @Test + fun createProjectCreateParams() { + ProjectCreateParams.builder() + .name("My Project") + .taskType(ProjectCreateParams.TaskType.LLM_BASE) + .description("My project description.") + .build() + } + + @Test + fun getBody() { + val params = + ProjectCreateParams.builder() + .name("My Project") + .taskType(ProjectCreateParams.TaskType.LLM_BASE) + .description("My project description.") + .build() + val body = params.getBody() + assertThat(body).isNotNull + assertThat(body.name()).isEqualTo("My Project") + assertThat(body.taskType()).isEqualTo(ProjectCreateParams.TaskType.LLM_BASE) + assertThat(body.description()).isEqualTo("My project description.") + } + + @Test + fun getBodyWithoutOptionalFields() { + val params = + ProjectCreateParams.builder() + .name("My Project") + .taskType(ProjectCreateParams.TaskType.LLM_BASE) + .build() + val body = params.getBody() + assertThat(body).isNotNull + assertThat(body.name()).isEqualTo("My Project") + assertThat(body.taskType()).isEqualTo(ProjectCreateParams.TaskType.LLM_BASE) + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCreateResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCreateResponseTest.kt new file mode 100644 index 0000000..1fc43bb --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectCreateResponseTest.kt @@ -0,0 +1,99 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import java.time.OffsetDateTime +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class ProjectCreateResponseTest { + + @Test + fun createProjectCreateResponse() { + val projectCreateResponse = + ProjectCreateResponse.builder() + .id("3fa85f64-5717-4562-b3fc-2c963f66afa6") + .creatorId("589ece63-49a2-41b4-98e1-10547761d4b0") + .dateCreated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateUpdated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .developmentGoalCount(123L) + .goalCount(123L) + .inferencePipelineCount(123L) + .links( + ProjectCreateResponse.Links.builder() + .app( + "https://app.openlayer.com/myWorkspace/3fa85f64-5717-4562-b3fc-2c963f66afa6" + ) + .build() + ) + .monitoringGoalCount(123L) + .name("My Project") + .source(ProjectCreateResponse.Source.WEB) + .taskType(ProjectCreateResponse.TaskType.LLM_BASE) + .versionCount(123L) + .workspaceId("055fddb1-261f-4654-8598-f6347ee46a09") + .description("My project description.") + .gitRepo( + ProjectCreateResponse.GitRepo.builder() + .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .dateConnected(OffsetDateTime.parse("2019-12-27T18:11:19.117Z")) + .dateUpdated(OffsetDateTime.parse("2019-12-27T18:11:19.117Z")) + .gitAccountId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .gitId(123L) + .name("name") + .private_(true) + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .slug("slug") + .url("url") + .branch("branch") + .rootDir("rootDir") + .build() + ) + .build() + assertThat(projectCreateResponse).isNotNull + assertThat(projectCreateResponse.id()).isEqualTo("3fa85f64-5717-4562-b3fc-2c963f66afa6") + assertThat(projectCreateResponse.creatorId()) + .contains("589ece63-49a2-41b4-98e1-10547761d4b0") + assertThat(projectCreateResponse.dateCreated()) + .isEqualTo(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(projectCreateResponse.dateUpdated()) + .isEqualTo(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(projectCreateResponse.developmentGoalCount()).isEqualTo(123L) + assertThat(projectCreateResponse.goalCount()).isEqualTo(123L) + assertThat(projectCreateResponse.inferencePipelineCount()).isEqualTo(123L) + assertThat(projectCreateResponse.links()) + .isEqualTo( + ProjectCreateResponse.Links.builder() + .app( + "https://app.openlayer.com/myWorkspace/3fa85f64-5717-4562-b3fc-2c963f66afa6" + ) + .build() + ) + assertThat(projectCreateResponse.monitoringGoalCount()).isEqualTo(123L) + assertThat(projectCreateResponse.name()).isEqualTo("My Project") + assertThat(projectCreateResponse.source()).contains(ProjectCreateResponse.Source.WEB) + assertThat(projectCreateResponse.taskType()) + .isEqualTo(ProjectCreateResponse.TaskType.LLM_BASE) + assertThat(projectCreateResponse.versionCount()).isEqualTo(123L) + assertThat(projectCreateResponse.workspaceId()) + .contains("055fddb1-261f-4654-8598-f6347ee46a09") + assertThat(projectCreateResponse.description()).contains("My project description.") + assertThat(projectCreateResponse.gitRepo()) + .contains( + ProjectCreateResponse.GitRepo.builder() + .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .dateConnected(OffsetDateTime.parse("2019-12-27T18:11:19.117Z")) + .dateUpdated(OffsetDateTime.parse("2019-12-27T18:11:19.117Z")) + .gitAccountId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .gitId(123L) + .name("name") + .private_(true) + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .slug("slug") + .url("url") + .branch("branch") + .rootDir("rootDir") + .build() + ) + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateParamsTest.kt new file mode 100644 index 0000000..0e96084 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateParamsTest.kt @@ -0,0 +1,59 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.models.* +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class ProjectInferencePipelineCreateParamsTest { + + @Test + fun createProjectInferencePipelineCreateParams() { + ProjectInferencePipelineCreateParams.builder() + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .description("This pipeline is used for production.") + .name("production") + .build() + } + + @Test + fun getBody() { + val params = + ProjectInferencePipelineCreateParams.builder() + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .description("This pipeline is used for production.") + .name("production") + .build() + val body = params.getBody() + assertThat(body).isNotNull + assertThat(body.description()).isEqualTo("This pipeline is used for production.") + assertThat(body.name()).isEqualTo("production") + } + + @Test + fun getBodyWithoutOptionalFields() { + val params = + ProjectInferencePipelineCreateParams.builder() + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .name("production") + .build() + val body = params.getBody() + assertThat(body).isNotNull + assertThat(body.name()).isEqualTo("production") + } + + @Test + fun getPathParam() { + val params = + ProjectInferencePipelineCreateParams.builder() + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .name("production") + .build() + assertThat(params).isNotNull + // path param "projectId" + assertThat(params.getPathParam(0)).isEqualTo("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + // out-of-bound path param + assertThat(params.getPathParam(1)).isEqualTo("") + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateResponseTest.kt new file mode 100644 index 0000000..2398c71 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineCreateResponseTest.kt @@ -0,0 +1,71 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import java.time.OffsetDateTime +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class ProjectInferencePipelineCreateResponseTest { + + @Test + fun createProjectInferencePipelineCreateResponse() { + val projectInferencePipelineCreateResponse = + ProjectInferencePipelineCreateResponse.builder() + .id("3fa85f64-5717-4562-b3fc-2c963f66afa6") + .dateCreated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateLastEvaluated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateLastSampleReceived(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateOfNextEvaluation(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .dateUpdated(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + .description("This pipeline is used for production.") + .failingGoalCount(123L) + .links( + ProjectInferencePipelineCreateResponse.Links.builder() + .app( + "https://app.openlayer.com/myWorkspace/3fa85f64-5717-4562-b3fc-2c963f66afa6/inference-pipeline/3fa85f64-5717-4562-b3fc-2c963f66afa6" + ) + .build() + ) + .name("production") + .passingGoalCount(123L) + .projectId("3fa85f64-5717-4562-b3fc-2c963f66afa6") + .status(ProjectInferencePipelineCreateResponse.Status.QUEUED) + .statusMessage("Tests successfully evaluated") + .totalGoalCount(123L) + .build() + assertThat(projectInferencePipelineCreateResponse).isNotNull + assertThat(projectInferencePipelineCreateResponse.id()) + .isEqualTo("3fa85f64-5717-4562-b3fc-2c963f66afa6") + assertThat(projectInferencePipelineCreateResponse.dateCreated()) + .isEqualTo(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(projectInferencePipelineCreateResponse.dateLastEvaluated()) + .contains(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(projectInferencePipelineCreateResponse.dateLastSampleReceived()) + .contains(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(projectInferencePipelineCreateResponse.dateOfNextEvaluation()) + .contains(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(projectInferencePipelineCreateResponse.dateUpdated()) + .isEqualTo(OffsetDateTime.parse("2024-03-22T11:31:01.185Z")) + assertThat(projectInferencePipelineCreateResponse.description()) + .contains("This pipeline is used for production.") + assertThat(projectInferencePipelineCreateResponse.failingGoalCount()).isEqualTo(123L) + assertThat(projectInferencePipelineCreateResponse.links()) + .isEqualTo( + ProjectInferencePipelineCreateResponse.Links.builder() + .app( + "https://app.openlayer.com/myWorkspace/3fa85f64-5717-4562-b3fc-2c963f66afa6/inference-pipeline/3fa85f64-5717-4562-b3fc-2c963f66afa6" + ) + .build() + ) + assertThat(projectInferencePipelineCreateResponse.name()).isEqualTo("production") + assertThat(projectInferencePipelineCreateResponse.passingGoalCount()).isEqualTo(123L) + assertThat(projectInferencePipelineCreateResponse.projectId()) + .isEqualTo("3fa85f64-5717-4562-b3fc-2c963f66afa6") + assertThat(projectInferencePipelineCreateResponse.status()) + .isEqualTo(ProjectInferencePipelineCreateResponse.Status.QUEUED) + assertThat(projectInferencePipelineCreateResponse.statusMessage()) + .contains("Tests successfully evaluated") + assertThat(projectInferencePipelineCreateResponse.totalGoalCount()).isEqualTo(123L) + } +} diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectInferencePipelineListParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineListParamsTest.kt similarity index 75% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectInferencePipelineListParamsTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineListParamsTest.kt index d4538e1..671b802 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectInferencePipelineListParamsTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineListParamsTest.kt @@ -1,18 +1,18 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models +import com.openlayer.api.models.* import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test -import org.openlayer.models.* class ProjectInferencePipelineListParamsTest { @Test fun createProjectInferencePipelineListParams() { ProjectInferencePipelineListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") - .name("string") + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .name("name") .page(123L) .perPage(100L) .build() @@ -22,13 +22,13 @@ class ProjectInferencePipelineListParamsTest { fun getQueryParams() { val params = ProjectInferencePipelineListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") - .name("string") + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .name("name") .page(123L) .perPage(100L) .build() val expected = mutableMapOf>() - expected.put("name", listOf("string")) + expected.put("name", listOf("name")) expected.put("page", listOf("123")) expected.put("perPage", listOf("100")) assertThat(params.getQueryParams()).isEqualTo(expected) @@ -38,7 +38,7 @@ class ProjectInferencePipelineListParamsTest { fun getQueryParamsWithoutOptionalFields() { val params = ProjectInferencePipelineListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .build() val expected = mutableMapOf>() assertThat(params.getQueryParams()).isEqualTo(expected) @@ -48,10 +48,10 @@ class ProjectInferencePipelineListParamsTest { fun getPathParam() { val params = ProjectInferencePipelineListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .build() assertThat(params).isNotNull - // path param "id" + // path param "projectId" assertThat(params.getPathParam(0)).isEqualTo("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") // out-of-bound path param assertThat(params.getPathParam(1)).isEqualTo("") diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectInferencePipelineListResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineListResponseTest.kt similarity index 91% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectInferencePipelineListResponseTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineListResponseTest.kt index 70d97a9..37bb0ca 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectInferencePipelineListResponseTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectInferencePipelineListResponseTest.kt @@ -1,6 +1,6 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import java.time.OffsetDateTime import org.assertj.core.api.Assertions.assertThat @@ -47,10 +47,6 @@ class ProjectInferencePipelineListResponseTest { .status(ProjectInferencePipelineListResponse.Item.Status.QUEUED) .statusMessage("Tests successfully evaluated") .totalGoalCount(123L) - .referenceDatasetUri("s3://...") - .storageType( - ProjectInferencePipelineListResponse.Item.StorageType.LOCAL - ) .build() ) ) @@ -90,8 +86,6 @@ class ProjectInferencePipelineListResponseTest { .status(ProjectInferencePipelineListResponse.Item.Status.QUEUED) .statusMessage("Tests successfully evaluated") .totalGoalCount(123L) - .referenceDatasetUri("s3://...") - .storageType(ProjectInferencePipelineListResponse.Item.StorageType.LOCAL) .build() ) } diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectListParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectListParamsTest.kt similarity index 87% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectListParamsTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectListParamsTest.kt index 0659e48..daf73e7 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectListParamsTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectListParamsTest.kt @@ -1,17 +1,17 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models +import com.openlayer.api.models.* import org.assertj.core.api.Assertions.assertThat import org.junit.jupiter.api.Test -import org.openlayer.models.* class ProjectListParamsTest { @Test fun createProjectListParams() { ProjectListParams.builder() - .name("string") + .name("name") .page(123L) .perPage(100L) .taskType(ProjectListParams.TaskType.LLM_BASE) @@ -22,13 +22,13 @@ class ProjectListParamsTest { fun getQueryParams() { val params = ProjectListParams.builder() - .name("string") + .name("name") .page(123L) .perPage(100L) .taskType(ProjectListParams.TaskType.LLM_BASE) .build() val expected = mutableMapOf>() - expected.put("name", listOf("string")) + expected.put("name", listOf("name")) expected.put("page", listOf("123")) expected.put("perPage", listOf("100")) expected.put("taskType", listOf(ProjectListParams.TaskType.LLM_BASE.toString())) diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectListResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectListResponseTest.kt similarity index 83% rename from openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectListResponseTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectListResponseTest.kt index cf56860..c30dee9 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/models/ProjectListResponseTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/ProjectListResponseTest.kt @@ -1,6 +1,6 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.models +package com.openlayer.api.models import java.time.OffsetDateTime import org.assertj.core.api.Assertions.assertThat @@ -40,7 +40,6 @@ class ProjectListResponseTest { ) .monitoringGoalCount(123L) .name("My Project") - .sample(true) .source(ProjectListResponse.Item.Source.WEB) .taskType(ProjectListResponse.Item.TaskType.LLM_BASE) .versionCount(123L) @@ -53,19 +52,15 @@ class ProjectListResponseTest { .dateUpdated(OffsetDateTime.parse("2019-12-27T18:11:19.117Z")) .gitAccountId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .gitId(123L) - .name("string") + .name("name") .private_(true) .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") - .slug("string") - .url("string") - .branch("string") - .rootDir("string") + .slug("slug") + .url("url") + .branch("branch") + .rootDir("rootDir") .build() ) - .slackChannelId("C01B2PZQX1Z") - .slackChannelName("#my-project") - .slackChannelNotificationsEnabled(true) - .unreadNotificationCount(123L) .build() ) ) @@ -100,7 +95,6 @@ class ProjectListResponseTest { ) .monitoringGoalCount(123L) .name("My Project") - .sample(true) .source(ProjectListResponse.Item.Source.WEB) .taskType(ProjectListResponse.Item.TaskType.LLM_BASE) .versionCount(123L) @@ -113,19 +107,15 @@ class ProjectListResponseTest { .dateUpdated(OffsetDateTime.parse("2019-12-27T18:11:19.117Z")) .gitAccountId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .gitId(123L) - .name("string") + .name("name") .private_(true) .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") - .slug("string") - .url("string") - .branch("string") - .rootDir("string") + .slug("slug") + .url("url") + .branch("branch") + .rootDir("rootDir") .build() ) - .slackChannelId("C01B2PZQX1Z") - .slackChannelName("#my-project") - .slackChannelNotificationsEnabled(true) - .unreadNotificationCount(123L) .build() ) } diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateParamsTest.kt new file mode 100644 index 0000000..6ae03e8 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateParamsTest.kt @@ -0,0 +1,31 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.models.* +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class StoragePresignedUrlCreateParamsTest { + + @Test + fun createStoragePresignedUrlCreateParams() { + StoragePresignedUrlCreateParams.builder().objectName("objectName").build() + } + + @Test + fun getQueryParams() { + val params = StoragePresignedUrlCreateParams.builder().objectName("objectName").build() + val expected = mutableMapOf>() + expected.put("objectName", listOf("objectName")) + assertThat(params.getQueryParams()).isEqualTo(expected) + } + + @Test + fun getQueryParamsWithoutOptionalFields() { + val params = StoragePresignedUrlCreateParams.builder().objectName("objectName").build() + val expected = mutableMapOf>() + expected.put("objectName", listOf("objectName")) + assertThat(params.getQueryParams()).isEqualTo(expected) + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateResponseTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateResponseTest.kt new file mode 100644 index 0000000..c6dd2f5 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/models/StoragePresignedUrlCreateResponseTest.kt @@ -0,0 +1,25 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.models + +import com.openlayer.api.core.JsonValue +import org.assertj.core.api.Assertions.assertThat +import org.junit.jupiter.api.Test + +class StoragePresignedUrlCreateResponseTest { + + @Test + fun createStoragePresignedUrlCreateResponse() { + val storagePresignedUrlCreateResponse = + StoragePresignedUrlCreateResponse.builder() + .storageUri("storageUri") + .url("url") + .fields(JsonValue.from(mapOf())) + .build() + assertThat(storagePresignedUrlCreateResponse).isNotNull + assertThat(storagePresignedUrlCreateResponse.storageUri()).isEqualTo("storageUri") + assertThat(storagePresignedUrlCreateResponse.url()).isEqualTo("url") + assertThat(storagePresignedUrlCreateResponse._fields()) + .isEqualTo(JsonValue.from(mapOf())) + } +} diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/services/ErrorHandlingTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/ErrorHandlingTest.kt similarity index 94% rename from openlayer-java-core/src/test/kotlin/org/openlayer/services/ErrorHandlingTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/services/ErrorHandlingTest.kt index 6c4e09f..4dfd4b0 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/services/ErrorHandlingTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/ErrorHandlingTest.kt @@ -1,6 +1,6 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services +package com.openlayer.api.services import com.fasterxml.jackson.databind.json.JsonMapper import com.github.tomakehurst.wiremock.client.WireMock.anyUrl @@ -13,28 +13,28 @@ import com.github.tomakehurst.wiremock.junit5.WireMockRuntimeInfo import com.github.tomakehurst.wiremock.junit5.WireMockTest import com.google.common.collect.ImmutableListMultimap import com.google.common.collect.ListMultimap +import com.openlayer.api.client.OpenlayerClient +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.core.JsonString +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.jsonMapper +import com.openlayer.api.errors.BadRequestException +import com.openlayer.api.errors.InternalServerException +import com.openlayer.api.errors.NotFoundException +import com.openlayer.api.errors.OpenlayerError +import com.openlayer.api.errors.OpenlayerException +import com.openlayer.api.errors.PermissionDeniedException +import com.openlayer.api.errors.RateLimitException +import com.openlayer.api.errors.UnauthorizedException +import com.openlayer.api.errors.UnexpectedStatusCodeException +import com.openlayer.api.errors.UnprocessableEntityException +import com.openlayer.api.models.* import org.assertj.core.api.Assertions.assertThat import org.assertj.core.api.Assertions.assertThatThrownBy import org.assertj.core.api.InstanceOfAssertFactories import org.assertj.guava.api.Assertions.assertThat import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test -import org.openlayer.client.OpenlayerClient -import org.openlayer.client.okhttp.OpenlayerOkHttpClient -import org.openlayer.core.JsonString -import org.openlayer.core.JsonValue -import org.openlayer.core.jsonMapper -import org.openlayer.errors.BadRequestException -import org.openlayer.errors.InternalServerException -import org.openlayer.errors.NotFoundException -import org.openlayer.errors.OpenlayerError -import org.openlayer.errors.OpenlayerException -import org.openlayer.errors.PermissionDeniedException -import org.openlayer.errors.RateLimitException -import org.openlayer.errors.UnauthorizedException -import org.openlayer.errors.UnexpectedStatusCodeException -import org.openlayer.errors.UnprocessableEntityException -import org.openlayer.models.* @WireMockTest class ErrorHandlingTest { @@ -59,7 +59,7 @@ class ErrorHandlingTest { fun dataStream200() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -103,7 +103,7 @@ class ErrorHandlingTest { fun dataStream400() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -148,7 +148,7 @@ class ErrorHandlingTest { fun dataStream401() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -193,7 +193,7 @@ class ErrorHandlingTest { fun dataStream403() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -238,7 +238,7 @@ class ErrorHandlingTest { fun dataStream404() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -283,7 +283,7 @@ class ErrorHandlingTest { fun dataStream422() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -332,7 +332,7 @@ class ErrorHandlingTest { fun dataStream429() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -377,7 +377,7 @@ class ErrorHandlingTest { fun dataStream500() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -422,7 +422,7 @@ class ErrorHandlingTest { fun unexpectedStatusCode() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -472,7 +472,7 @@ class ErrorHandlingTest { fun invalidBody() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() @@ -516,7 +516,7 @@ class ErrorHandlingTest { fun invalidErrorBody() { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/services/ServiceParamsTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/ServiceParamsTest.kt similarity index 91% rename from openlayer-java-core/src/test/kotlin/org/openlayer/services/ServiceParamsTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/services/ServiceParamsTest.kt index a636b68..4378175 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/services/ServiceParamsTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/ServiceParamsTest.kt @@ -1,6 +1,6 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services +package com.openlayer.api.services import com.fasterxml.jackson.databind.json.JsonMapper import com.github.tomakehurst.wiremock.client.WireMock.anyUrl @@ -15,14 +15,14 @@ import com.github.tomakehurst.wiremock.client.WireMock.stubFor import com.github.tomakehurst.wiremock.client.WireMock.verify import com.github.tomakehurst.wiremock.junit5.WireMockRuntimeInfo import com.github.tomakehurst.wiremock.junit5.WireMockTest +import com.openlayer.api.client.OpenlayerClient +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.core.JsonString +import com.openlayer.api.core.JsonValue +import com.openlayer.api.core.jsonMapper +import com.openlayer.api.models.* import org.junit.jupiter.api.BeforeEach import org.junit.jupiter.api.Test -import org.openlayer.client.OpenlayerClient -import org.openlayer.client.okhttp.OpenlayerOkHttpClient -import org.openlayer.core.JsonString -import org.openlayer.core.JsonValue -import org.openlayer.core.jsonMapper -import org.openlayer.models.* @WireMockTest class ServiceParamsTest { @@ -56,7 +56,7 @@ class ServiceParamsTest { val params = InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/CommitServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/CommitServiceTest.kt similarity index 58% rename from openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/CommitServiceTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/CommitServiceTest.kt index 25e1b88..4a62862 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/CommitServiceTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/CommitServiceTest.kt @@ -1,9 +1,9 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.blocking +package com.openlayer.api.services.blocking +import com.openlayer.api.TestServerExtension +import com.openlayer.api.models.* import org.junit.jupiter.api.extension.ExtendWith -import org.openlayer.TestServerExtension -import org.openlayer.models.* @ExtendWith(TestServerExtension::class) class CommitServiceTest diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/InferencePipelineServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/InferencePipelineServiceTest.kt new file mode 100644 index 0000000..d4ca7e1 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/InferencePipelineServiceTest.kt @@ -0,0 +1,67 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking + +import com.openlayer.api.TestServerExtension +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.models.* +import org.junit.jupiter.api.Test +import org.junit.jupiter.api.extension.ExtendWith + +@ExtendWith(TestServerExtension::class) +class InferencePipelineServiceTest { + + @Test + fun callRetrieve() { + val client = + OpenlayerOkHttpClient.builder() + .baseUrl(TestServerExtension.BASE_URL) + .apiKey("My API Key") + .build() + val inferencePipelineService = client.inferencePipelines() + val inferencePipelineRetrieveResponse = + inferencePipelineService.retrieve( + InferencePipelineRetrieveParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() + ) + println(inferencePipelineRetrieveResponse) + inferencePipelineRetrieveResponse.validate() + } + + @Test + fun callUpdate() { + val client = + OpenlayerOkHttpClient.builder() + .baseUrl(TestServerExtension.BASE_URL) + .apiKey("My API Key") + .build() + val inferencePipelineService = client.inferencePipelines() + val inferencePipelineUpdateResponse = + inferencePipelineService.update( + InferencePipelineUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .description("This pipeline is used for production.") + .name("production") + .referenceDatasetUri("referenceDatasetUri") + .build() + ) + println(inferencePipelineUpdateResponse) + inferencePipelineUpdateResponse.validate() + } + + @Test + fun callDelete() { + val client = + OpenlayerOkHttpClient.builder() + .baseUrl(TestServerExtension.BASE_URL) + .apiKey("My API Key") + .build() + val inferencePipelineService = client.inferencePipelines() + inferencePipelineService.delete( + InferencePipelineDeleteParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .build() + ) + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/ProjectServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/ProjectServiceTest.kt new file mode 100644 index 0000000..a87bdef --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/ProjectServiceTest.kt @@ -0,0 +1,54 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking + +import com.openlayer.api.TestServerExtension +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.models.* +import org.junit.jupiter.api.Test +import org.junit.jupiter.api.extension.ExtendWith + +@ExtendWith(TestServerExtension::class) +class ProjectServiceTest { + + @Test + fun callCreate() { + val client = + OpenlayerOkHttpClient.builder() + .baseUrl(TestServerExtension.BASE_URL) + .apiKey("My API Key") + .build() + val projectService = client.projects() + val projectCreateResponse = + projectService.create( + ProjectCreateParams.builder() + .name("My Project") + .taskType(ProjectCreateParams.TaskType.LLM_BASE) + .description("My project description.") + .build() + ) + println(projectCreateResponse) + projectCreateResponse.validate() + } + + @Test + fun callList() { + val client = + OpenlayerOkHttpClient.builder() + .baseUrl(TestServerExtension.BASE_URL) + .apiKey("My API Key") + .build() + val projectService = client.projects() + val projectListResponse = + projectService.list( + ProjectListParams.builder() + .name("name") + .page(123L) + .perPage(100L) + .taskType(ProjectListParams.TaskType.LLM_BASE) + .build() + ) + println(projectListResponse) + projectListResponse.validate() + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/StorageServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/StorageServiceTest.kt new file mode 100644 index 0000000..5c66b4e --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/StorageServiceTest.kt @@ -0,0 +1,9 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking + +import com.openlayer.api.TestServerExtension +import com.openlayer.api.models.* +import org.junit.jupiter.api.extension.ExtendWith + +@ExtendWith(TestServerExtension::class) class StorageServiceTest diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/commits/TestResultServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/commits/TestResultServiceTest.kt similarity index 79% rename from openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/commits/TestResultServiceTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/commits/TestResultServiceTest.kt index c432336..1f87370 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/commits/TestResultServiceTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/commits/TestResultServiceTest.kt @@ -1,12 +1,12 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.blocking.commits +package com.openlayer.api.services.blocking.commits +import com.openlayer.api.TestServerExtension +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.models.* import org.junit.jupiter.api.Test import org.junit.jupiter.api.extension.ExtendWith -import org.openlayer.TestServerExtension -import org.openlayer.client.okhttp.OpenlayerOkHttpClient -import org.openlayer.models.* @ExtendWith(TestServerExtension::class) class TestResultServiceTest { @@ -22,7 +22,7 @@ class TestResultServiceTest { val commitTestResultListResponse = testResultService.list( CommitTestResultListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .projectVersionId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .includeArchived(true) .page(123L) .perPage(100L) diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/inferencePipelines/DataServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/inferencePipelines/DataServiceTest.kt similarity index 87% rename from openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/inferencePipelines/DataServiceTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/inferencePipelines/DataServiceTest.kt index 69a5a11..0b70b54 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/inferencePipelines/DataServiceTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/inferencePipelines/DataServiceTest.kt @@ -1,13 +1,13 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.blocking.inferencePipelines +package com.openlayer.api.services.blocking.inferencePipelines +import com.openlayer.api.TestServerExtension +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.core.JsonValue +import com.openlayer.api.models.* import org.junit.jupiter.api.Test import org.junit.jupiter.api.extension.ExtendWith -import org.openlayer.TestServerExtension -import org.openlayer.client.okhttp.OpenlayerOkHttpClient -import org.openlayer.core.JsonValue -import org.openlayer.models.* @ExtendWith(TestServerExtension::class) class DataServiceTest { @@ -23,7 +23,7 @@ class DataServiceTest { val inferencePipelineDataStreamResponse = dataService.stream( InferencePipelineDataStreamParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .config( InferencePipelineDataStreamParams.Config.ofLlmData( InferencePipelineDataStreamParams.Config.LlmData.builder() diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/inferencePipelines/RowServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/inferencePipelines/RowServiceTest.kt new file mode 100644 index 0000000..8347fd9 --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/inferencePipelines/RowServiceTest.kt @@ -0,0 +1,43 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking.inferencePipelines + +import com.openlayer.api.TestServerExtension +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.core.JsonValue +import com.openlayer.api.models.* +import org.junit.jupiter.api.Test +import org.junit.jupiter.api.extension.ExtendWith + +@ExtendWith(TestServerExtension::class) +class RowServiceTest { + + @Test + fun callUpdate() { + val client = + OpenlayerOkHttpClient.builder() + .baseUrl(TestServerExtension.BASE_URL) + .apiKey("My API Key") + .build() + val rowService = client.inferencePipelines().rows() + val inferencePipelineRowUpdateResponse = + rowService.update( + InferencePipelineRowUpdateParams.builder() + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .row(JsonValue.from(mapOf())) + .config( + InferencePipelineRowUpdateParams.Config.builder() + .groundTruthColumnName("ground_truth") + .humanFeedbackColumnName("human_feedback") + .inferenceIdColumnName("id") + .latencyColumnName("latency") + .timestampColumnName("timestamp") + .build() + ) + .inferenceId("inferenceId") + .build() + ) + println(inferencePipelineRowUpdateResponse) + inferencePipelineRowUpdateResponse.validate() + } +} diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/inferencePipelines/TestResultServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/inferencePipelines/TestResultServiceTest.kt similarity index 78% rename from openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/inferencePipelines/TestResultServiceTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/inferencePipelines/TestResultServiceTest.kt index 0434c8e..67a11f1 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/inferencePipelines/TestResultServiceTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/inferencePipelines/TestResultServiceTest.kt @@ -1,12 +1,12 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.blocking.inferencePipelines +package com.openlayer.api.services.blocking.inferencePipelines +import com.openlayer.api.TestServerExtension +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.models.* import org.junit.jupiter.api.Test import org.junit.jupiter.api.extension.ExtendWith -import org.openlayer.TestServerExtension -import org.openlayer.client.okhttp.OpenlayerOkHttpClient -import org.openlayer.models.* @ExtendWith(TestServerExtension::class) class TestResultServiceTest { @@ -22,8 +22,7 @@ class TestResultServiceTest { val inferencePipelineTestResultListResponse = testResultService.list( InferencePipelineTestResultListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") - .includeArchived(true) + .inferencePipelineId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .page(123L) .perPage(100L) .status(InferencePipelineTestResultListParams.Status.RUNNING) diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/projects/CommitServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/projects/CommitServiceTest.kt similarity index 75% rename from openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/projects/CommitServiceTest.kt rename to openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/projects/CommitServiceTest.kt index 24c188f..83a9c12 100644 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/projects/CommitServiceTest.kt +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/projects/CommitServiceTest.kt @@ -1,12 +1,12 @@ // File generated from our OpenAPI spec by Stainless. -package org.openlayer.services.blocking.projects +package com.openlayer.api.services.blocking.projects +import com.openlayer.api.TestServerExtension +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.models.* import org.junit.jupiter.api.Test import org.junit.jupiter.api.extension.ExtendWith -import org.openlayer.TestServerExtension -import org.openlayer.client.okhttp.OpenlayerOkHttpClient -import org.openlayer.models.* @ExtendWith(TestServerExtension::class) class CommitServiceTest { @@ -22,7 +22,7 @@ class CommitServiceTest { val projectCommitListResponse = commitService.list( ProjectCommitListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") .page(123L) .perPage(100L) .build() diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/projects/InferencePipelineServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/projects/InferencePipelineServiceTest.kt new file mode 100644 index 0000000..ed1ee7c --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/projects/InferencePipelineServiceTest.kt @@ -0,0 +1,54 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking.projects + +import com.openlayer.api.TestServerExtension +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.models.* +import org.junit.jupiter.api.Test +import org.junit.jupiter.api.extension.ExtendWith + +@ExtendWith(TestServerExtension::class) +class InferencePipelineServiceTest { + + @Test + fun callCreate() { + val client = + OpenlayerOkHttpClient.builder() + .baseUrl(TestServerExtension.BASE_URL) + .apiKey("My API Key") + .build() + val inferencePipelineService = client.projects().inferencePipelines() + val projectInferencePipelineCreateResponse = + inferencePipelineService.create( + ProjectInferencePipelineCreateParams.builder() + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .description("This pipeline is used for production.") + .name("production") + .build() + ) + println(projectInferencePipelineCreateResponse) + projectInferencePipelineCreateResponse.validate() + } + + @Test + fun callList() { + val client = + OpenlayerOkHttpClient.builder() + .baseUrl(TestServerExtension.BASE_URL) + .apiKey("My API Key") + .build() + val inferencePipelineService = client.projects().inferencePipelines() + val projectInferencePipelineListResponse = + inferencePipelineService.list( + ProjectInferencePipelineListParams.builder() + .projectId("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") + .name("name") + .page(123L) + .perPage(100L) + .build() + ) + println(projectInferencePipelineListResponse) + projectInferencePipelineListResponse.validate() + } +} diff --git a/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/storage/PresignedUrlServiceTest.kt b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/storage/PresignedUrlServiceTest.kt new file mode 100644 index 0000000..558cb7c --- /dev/null +++ b/openlayer-java-core/src/test/kotlin/com/openlayer/api/services/blocking/storage/PresignedUrlServiceTest.kt @@ -0,0 +1,29 @@ +// File generated from our OpenAPI spec by Stainless. + +package com.openlayer.api.services.blocking.storage + +import com.openlayer.api.TestServerExtension +import com.openlayer.api.client.okhttp.OpenlayerOkHttpClient +import com.openlayer.api.models.* +import org.junit.jupiter.api.Test +import org.junit.jupiter.api.extension.ExtendWith + +@ExtendWith(TestServerExtension::class) +class PresignedUrlServiceTest { + + @Test + fun callCreate() { + val client = + OpenlayerOkHttpClient.builder() + .baseUrl(TestServerExtension.BASE_URL) + .apiKey("My API Key") + .build() + val presignedUrlService = client.storage().presignedUrl() + val storagePresignedUrlCreateResponse = + presignedUrlService.create( + StoragePresignedUrlCreateParams.builder().objectName("objectName").build() + ) + println(storagePresignedUrlCreateResponse) + storagePresignedUrlCreateResponse.validate() + } +} diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/client/OpenlayerClientTest.kt b/openlayer-java-core/src/test/kotlin/org/openlayer/client/OpenlayerClientTest.kt deleted file mode 100644 index 8259b0a..0000000 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/client/OpenlayerClientTest.kt +++ /dev/null @@ -1,5 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -package org.openlayer.client - -class OpenlayerClientTest diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/InferencePipelineServiceTest.kt b/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/InferencePipelineServiceTest.kt deleted file mode 100644 index 8f419a4..0000000 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/InferencePipelineServiceTest.kt +++ /dev/null @@ -1,9 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -package org.openlayer.services.blocking - -import org.junit.jupiter.api.extension.ExtendWith -import org.openlayer.TestServerExtension -import org.openlayer.models.* - -@ExtendWith(TestServerExtension::class) class InferencePipelineServiceTest diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/ProjectServiceTest.kt b/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/ProjectServiceTest.kt deleted file mode 100644 index cb284db..0000000 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/ProjectServiceTest.kt +++ /dev/null @@ -1,34 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -package org.openlayer.services.blocking - -import org.junit.jupiter.api.Test -import org.junit.jupiter.api.extension.ExtendWith -import org.openlayer.TestServerExtension -import org.openlayer.client.okhttp.OpenlayerOkHttpClient -import org.openlayer.models.* - -@ExtendWith(TestServerExtension::class) -class ProjectServiceTest { - - @Test - fun callList() { - val client = - OpenlayerOkHttpClient.builder() - .baseUrl(TestServerExtension.BASE_URL) - .apiKey("My API Key") - .build() - val projectService = client.projects() - val projectListResponse = - projectService.list( - ProjectListParams.builder() - .name("string") - .page(123L) - .perPage(100L) - .taskType(ProjectListParams.TaskType.LLM_BASE) - .build() - ) - println(projectListResponse) - projectListResponse.validate() - } -} diff --git a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/projects/InferencePipelineServiceTest.kt b/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/projects/InferencePipelineServiceTest.kt deleted file mode 100644 index 9f7399f..0000000 --- a/openlayer-java-core/src/test/kotlin/org/openlayer/services/blocking/projects/InferencePipelineServiceTest.kt +++ /dev/null @@ -1,34 +0,0 @@ -// File generated from our OpenAPI spec by Stainless. - -package org.openlayer.services.blocking.projects - -import org.junit.jupiter.api.Test -import org.junit.jupiter.api.extension.ExtendWith -import org.openlayer.TestServerExtension -import org.openlayer.client.okhttp.OpenlayerOkHttpClient -import org.openlayer.models.* - -@ExtendWith(TestServerExtension::class) -class InferencePipelineServiceTest { - - @Test - fun callList() { - val client = - OpenlayerOkHttpClient.builder() - .baseUrl(TestServerExtension.BASE_URL) - .apiKey("My API Key") - .build() - val inferencePipelineService = client.projects().inferencePipelines() - val projectInferencePipelineListResponse = - inferencePipelineService.list( - ProjectInferencePipelineListParams.builder() - .id("182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e") - .name("string") - .page(123L) - .perPage(100L) - .build() - ) - println(projectInferencePipelineListResponse) - projectInferencePipelineListResponse.validate() - } -} diff --git a/scripts/mock b/scripts/mock index fe89a1d..d2814ae 100755 --- a/scripts/mock +++ b/scripts/mock @@ -21,7 +21,7 @@ echo "==> Starting mock server with URL ${URL}" # Run prism mock on the given spec if [ "$1" == "--daemon" ]; then - npm exec --package=@stoplight/prism-cli@~5.8 -- prism mock "$URL" &> .prism.log & + npm exec --package=@stainless-api/prism-cli@5.8.5 -- prism mock "$URL" &> .prism.log & # Wait for server to come online echo -n "Waiting for server" @@ -37,5 +37,5 @@ if [ "$1" == "--daemon" ]; then echo else - npm exec --package=@stoplight/prism-cli@~5.8 -- prism mock "$URL" + npm exec --package=@stainless-api/prism-cli@5.8.5 -- prism mock "$URL" fi