Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .release-please-manifest.json
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
{
".": "0.3.0"
".": "0.3.1"
}
6 changes: 3 additions & 3 deletions .stats.yml
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
configured_endpoints: 25
openapi_spec_hash: 4eff18b3478c98a9b257ac27fdeb6b49
config_hash: b415187e3925c414fb2597cdd0a11859
configured_endpoints: 26
openapi_spec_hash: 6f6cb98b7755d18274dd51e857508336
config_hash: cc9a32249c08143687799eb8de187d6a
8 changes: 8 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,13 @@
# Changelog

## 0.3.1 (2026-01-12)

Full Changelog: [v0.3.0...v0.3.1](https://github.com/openlayer-ai/openlayer-java/compare/v0.3.0...v0.3.1)

### Chores

* **closes OPEN-8576:** expose delete project endpoint ([2084dab](https://github.com/openlayer-ai/openlayer-java/commit/2084dabf6b839d9454718259b20a106a5fb41a4a))

## 0.3.0 (2026-01-09)

Full Changelog: [v0.2.0...v0.3.0](https://github.com/openlayer-ai/openlayer-java/compare/v0.2.0...v0.3.0)
Expand Down
10 changes: 5 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@

<!-- x-release-please-start-version -->

[![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.3.0)
[![javadoc](https://javadoc.io/badge2/com.openlayer.api/openlayer-java/0.3.0/javadoc.svg)](https://javadoc.io/doc/com.openlayer.api/openlayer-java/0.3.0)
[![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.3.1)
[![javadoc](https://javadoc.io/badge2/com.openlayer.api/openlayer-java/0.3.1/javadoc.svg)](https://javadoc.io/doc/com.openlayer.api/openlayer-java/0.3.1)

<!-- x-release-please-end -->

Expand All @@ -13,7 +13,7 @@ It is generated with [Stainless](https://www.stainless.com/).

<!-- x-release-please-start-version -->

The REST API documentation can be found on [openlayer.com](https://openlayer.com/docs/api-reference/rest/overview). Javadocs are available on [javadoc.io](https://javadoc.io/doc/com.openlayer.api/openlayer-java/0.3.0).
The REST API documentation can be found on [openlayer.com](https://openlayer.com/docs/api-reference/rest/overview). Javadocs are available on [javadoc.io](https://javadoc.io/doc/com.openlayer.api/openlayer-java/0.3.1).

<!-- x-release-please-end -->

Expand All @@ -24,7 +24,7 @@ The REST API documentation can be found on [openlayer.com](https://openlayer.com
### Gradle

```kotlin
implementation("com.openlayer.api:openlayer-java:0.3.0")
implementation("com.openlayer.api:openlayer-java:0.3.1")
```

### Maven
Expand All @@ -33,7 +33,7 @@ implementation("com.openlayer.api:openlayer-java:0.3.0")
<dependency>
<groupId>com.openlayer.api</groupId>
<artifactId>openlayer-java</artifactId>
<version>0.3.0</version>
<version>0.3.1</version>
</dependency>
```

Expand Down
2 changes: 1 addition & 1 deletion build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ repositories {

allprojects {
group = "com.openlayer.api"
version = "0.3.0" // x-release-please-version
version = "0.3.1" // x-release-please-version
}

subprojects {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,229 @@
// File generated from our OpenAPI spec by Stainless.

package com.openlayer.api.models.projects

import com.openlayer.api.core.JsonValue
import com.openlayer.api.core.Params
import com.openlayer.api.core.http.Headers
import com.openlayer.api.core.http.QueryParams
import com.openlayer.api.core.toImmutable
import java.util.Objects
import java.util.Optional
import kotlin.jvm.optionals.getOrNull

/** Delete a project by its ID. */
class ProjectDeleteParams
private constructor(
private val projectId: String?,
private val additionalHeaders: Headers,
private val additionalQueryParams: QueryParams,
private val additionalBodyProperties: Map<String, JsonValue>,
) : Params {

fun projectId(): Optional<String> = Optional.ofNullable(projectId)

/** Additional body properties to send with the request. */
fun _additionalBodyProperties(): Map<String, JsonValue> = additionalBodyProperties

/** Additional headers to send with the request. */
fun _additionalHeaders(): Headers = additionalHeaders

/** Additional query param to send with the request. */
fun _additionalQueryParams(): QueryParams = additionalQueryParams

fun toBuilder() = Builder().from(this)

companion object {

@JvmStatic fun none(): ProjectDeleteParams = builder().build()

/** Returns a mutable builder for constructing an instance of [ProjectDeleteParams]. */
@JvmStatic fun builder() = Builder()
}

/** A builder for [ProjectDeleteParams]. */
class Builder internal constructor() {

private var projectId: String? = null
private var additionalHeaders: Headers.Builder = Headers.builder()
private var additionalQueryParams: QueryParams.Builder = QueryParams.builder()
private var additionalBodyProperties: MutableMap<String, JsonValue> = mutableMapOf()

@JvmSynthetic
internal fun from(projectDeleteParams: ProjectDeleteParams) = apply {
projectId = projectDeleteParams.projectId
additionalHeaders = projectDeleteParams.additionalHeaders.toBuilder()
additionalQueryParams = projectDeleteParams.additionalQueryParams.toBuilder()
additionalBodyProperties = projectDeleteParams.additionalBodyProperties.toMutableMap()
}

fun projectId(projectId: String?) = apply { this.projectId = projectId }

/** Alias for calling [Builder.projectId] with `projectId.orElse(null)`. */
fun projectId(projectId: Optional<String>) = projectId(projectId.getOrNull())

fun additionalHeaders(additionalHeaders: Headers) = apply {
this.additionalHeaders.clear()
putAllAdditionalHeaders(additionalHeaders)
}

fun additionalHeaders(additionalHeaders: Map<String, Iterable<String>>) = apply {
this.additionalHeaders.clear()
putAllAdditionalHeaders(additionalHeaders)
}

fun putAdditionalHeader(name: String, value: String) = apply {
additionalHeaders.put(name, value)
}

fun putAdditionalHeaders(name: String, values: Iterable<String>) = apply {
additionalHeaders.put(name, values)
}

fun putAllAdditionalHeaders(additionalHeaders: Headers) = apply {
this.additionalHeaders.putAll(additionalHeaders)
}

fun putAllAdditionalHeaders(additionalHeaders: Map<String, Iterable<String>>) = apply {
this.additionalHeaders.putAll(additionalHeaders)
}

fun replaceAdditionalHeaders(name: String, value: String) = apply {
additionalHeaders.replace(name, value)
}

fun replaceAdditionalHeaders(name: String, values: Iterable<String>) = apply {
additionalHeaders.replace(name, values)
}

fun replaceAllAdditionalHeaders(additionalHeaders: Headers) = apply {
this.additionalHeaders.replaceAll(additionalHeaders)
}

fun replaceAllAdditionalHeaders(additionalHeaders: Map<String, Iterable<String>>) = apply {
this.additionalHeaders.replaceAll(additionalHeaders)
}

fun removeAdditionalHeaders(name: String) = apply { additionalHeaders.remove(name) }

fun removeAllAdditionalHeaders(names: Set<String>) = apply {
additionalHeaders.removeAll(names)
}

fun additionalQueryParams(additionalQueryParams: QueryParams) = apply {
this.additionalQueryParams.clear()
putAllAdditionalQueryParams(additionalQueryParams)
}

fun additionalQueryParams(additionalQueryParams: Map<String, Iterable<String>>) = apply {
this.additionalQueryParams.clear()
putAllAdditionalQueryParams(additionalQueryParams)
}

fun putAdditionalQueryParam(key: String, value: String) = apply {
additionalQueryParams.put(key, value)
}

fun putAdditionalQueryParams(key: String, values: Iterable<String>) = apply {
additionalQueryParams.put(key, values)
}

fun putAllAdditionalQueryParams(additionalQueryParams: QueryParams) = apply {
this.additionalQueryParams.putAll(additionalQueryParams)
}

fun putAllAdditionalQueryParams(additionalQueryParams: Map<String, Iterable<String>>) =
apply {
this.additionalQueryParams.putAll(additionalQueryParams)
}

fun replaceAdditionalQueryParams(key: String, value: String) = apply {
additionalQueryParams.replace(key, value)
}

fun replaceAdditionalQueryParams(key: String, values: Iterable<String>) = apply {
additionalQueryParams.replace(key, values)
}

fun replaceAllAdditionalQueryParams(additionalQueryParams: QueryParams) = apply {
this.additionalQueryParams.replaceAll(additionalQueryParams)
}

fun replaceAllAdditionalQueryParams(additionalQueryParams: Map<String, Iterable<String>>) =
apply {
this.additionalQueryParams.replaceAll(additionalQueryParams)
}

fun removeAdditionalQueryParams(key: String) = apply { additionalQueryParams.remove(key) }

fun removeAllAdditionalQueryParams(keys: Set<String>) = apply {
additionalQueryParams.removeAll(keys)
}

fun additionalBodyProperties(additionalBodyProperties: Map<String, JsonValue>) = apply {
this.additionalBodyProperties.clear()
putAllAdditionalBodyProperties(additionalBodyProperties)
}

fun putAdditionalBodyProperty(key: String, value: JsonValue) = apply {
additionalBodyProperties.put(key, value)
}

fun putAllAdditionalBodyProperties(additionalBodyProperties: Map<String, JsonValue>) =
apply {
this.additionalBodyProperties.putAll(additionalBodyProperties)
}

fun removeAdditionalBodyProperty(key: String) = apply {
additionalBodyProperties.remove(key)
}

fun removeAllAdditionalBodyProperties(keys: Set<String>) = apply {
keys.forEach(::removeAdditionalBodyProperty)
}

/**
* Returns an immutable instance of [ProjectDeleteParams].
*
* Further updates to this [Builder] will not mutate the returned instance.
*/
fun build(): ProjectDeleteParams =
ProjectDeleteParams(
projectId,
additionalHeaders.build(),
additionalQueryParams.build(),
additionalBodyProperties.toImmutable(),
)
}

fun _body(): Optional<Map<String, JsonValue>> =
Optional.ofNullable(additionalBodyProperties.ifEmpty { null })

fun _pathParam(index: Int): String =
when (index) {
0 -> projectId ?: ""
else -> ""
}

override fun _headers(): Headers = additionalHeaders

override fun _queryParams(): QueryParams = additionalQueryParams

override fun equals(other: Any?): Boolean {
if (this === other) {
return true
}

return other is ProjectDeleteParams &&
projectId == other.projectId &&
additionalHeaders == other.additionalHeaders &&
additionalQueryParams == other.additionalQueryParams &&
additionalBodyProperties == other.additionalBodyProperties
}

override fun hashCode(): Int =
Objects.hash(projectId, additionalHeaders, additionalQueryParams, additionalBodyProperties)

override fun toString() =
"ProjectDeleteParams{projectId=$projectId, additionalHeaders=$additionalHeaders, additionalQueryParams=$additionalQueryParams, additionalBodyProperties=$additionalBodyProperties}"
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,11 @@ package com.openlayer.api.services.async

import com.openlayer.api.core.ClientOptions
import com.openlayer.api.core.RequestOptions
import com.openlayer.api.core.http.HttpResponse
import com.openlayer.api.core.http.HttpResponseFor
import com.openlayer.api.models.projects.ProjectCreateParams
import com.openlayer.api.models.projects.ProjectCreateResponse
import com.openlayer.api.models.projects.ProjectDeleteParams
import com.openlayer.api.models.projects.ProjectListParams
import com.openlayer.api.models.projects.ProjectListResponse
import com.openlayer.api.services.async.projects.CommitServiceAsync
Expand Down Expand Up @@ -63,6 +65,38 @@ interface ProjectServiceAsync {
fun list(requestOptions: RequestOptions): CompletableFuture<ProjectListResponse> =
list(ProjectListParams.none(), requestOptions)

/** Delete a project by its ID. */
fun delete(projectId: String): CompletableFuture<Void?> =
delete(projectId, ProjectDeleteParams.none())

/** @see delete */
fun delete(
projectId: String,
params: ProjectDeleteParams = ProjectDeleteParams.none(),
requestOptions: RequestOptions = RequestOptions.none(),
): CompletableFuture<Void?> =
delete(params.toBuilder().projectId(projectId).build(), requestOptions)

/** @see delete */
fun delete(
projectId: String,
params: ProjectDeleteParams = ProjectDeleteParams.none(),
): CompletableFuture<Void?> = delete(projectId, params, RequestOptions.none())

/** @see delete */
fun delete(
params: ProjectDeleteParams,
requestOptions: RequestOptions = RequestOptions.none(),
): CompletableFuture<Void?>

/** @see delete */
fun delete(params: ProjectDeleteParams): CompletableFuture<Void?> =
delete(params, RequestOptions.none())

/** @see delete */
fun delete(projectId: String, requestOptions: RequestOptions): CompletableFuture<Void?> =
delete(projectId, ProjectDeleteParams.none(), requestOptions)

/**
* A view of [ProjectServiceAsync] that provides access to raw HTTP responses for each method.
*/
Expand Down Expand Up @@ -122,5 +156,43 @@ interface ProjectServiceAsync {
requestOptions: RequestOptions
): CompletableFuture<HttpResponseFor<ProjectListResponse>> =
list(ProjectListParams.none(), requestOptions)

/**
* Returns a raw HTTP response for `delete /projects/{projectId}`, but is otherwise the same
* as [ProjectServiceAsync.delete].
*/
fun delete(projectId: String): CompletableFuture<HttpResponse> =
delete(projectId, ProjectDeleteParams.none())

/** @see delete */
fun delete(
projectId: String,
params: ProjectDeleteParams = ProjectDeleteParams.none(),
requestOptions: RequestOptions = RequestOptions.none(),
): CompletableFuture<HttpResponse> =
delete(params.toBuilder().projectId(projectId).build(), requestOptions)

/** @see delete */
fun delete(
projectId: String,
params: ProjectDeleteParams = ProjectDeleteParams.none(),
): CompletableFuture<HttpResponse> = delete(projectId, params, RequestOptions.none())

/** @see delete */
fun delete(
params: ProjectDeleteParams,
requestOptions: RequestOptions = RequestOptions.none(),
): CompletableFuture<HttpResponse>

/** @see delete */
fun delete(params: ProjectDeleteParams): CompletableFuture<HttpResponse> =
delete(params, RequestOptions.none())

/** @see delete */
fun delete(
projectId: String,
requestOptions: RequestOptions,
): CompletableFuture<HttpResponse> =
delete(projectId, ProjectDeleteParams.none(), requestOptions)
}
}
Loading