Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release 1.2.0 #46

Merged
merged 4 commits into from
Mar 11, 2021
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: 2 additions & 0 deletions .ci/doc/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
./java-protect/libs/*.jar
./kotlin-protect/libs/*.jar
9 changes: 8 additions & 1 deletion .ci/doc/java-project/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,19 @@ sourceCompatibility = 1.8

repositories {
mavenCentral()
jcenter()
}

dependencies {
testCompile group: 'junit', name: 'junit', version: '4.12'
compile fileTree(dir: 'libs', include: ['*.jar'])
compile 'io.ktor:ktor-client-websockets:1.5.2'
compile 'io.ktor:ktor-client-okhttp:1.5.2'
compile 'io.ktor:ktor-client-cio:1.5.2'
compile 'io.ktor:ktor-client-json:1.5.2'
compile 'io.ktor:ktor-client-gson:1.5.2'
compile 'io.ktor:ktor-client-serialization:1.5.2'
compile 'com.google.code.gson:gson:2.8.5'
compile fileTree(dir: 'libs', include: ['*.jar'])
}

jar {
Expand Down
9 changes: 8 additions & 1 deletion .ci/doc/kotlin-project/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,19 @@ sourceCompatibility = 1.8

repositories {
mavenCentral()
jcenter()
}

dependencies {
testCompile group: 'junit', name: 'junit', version: '4.12'
compile fileTree(dir: 'libs', include: ['*.jar'])
compile 'io.ktor:ktor-client-websockets:1.5.2'
compile 'io.ktor:ktor-client-okhttp:1.5.2'
compile 'io.ktor:ktor-client-cio:1.5.2'
compile 'io.ktor:ktor-client-json:1.5.2'
compile 'io.ktor:ktor-client-gson:1.5.2'
compile 'io.ktor:ktor-client-serialization:1.5.2'
compile 'com.google.code.gson:gson:2.8.5'
compile fileTree(dir: 'libs', include: ['*.jar'])
}

jar {
Expand Down
4 changes: 2 additions & 2 deletions .ci/doc/test-snippet.sh
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ set -e

if [ ${1: -3} == ".kt" ]
then
cp /mnt/build/libs/sdk-jvm-[0-9+].[0-9+].[0-9+].jar /mnt/.ci/doc/kotlin-project/libs/ && cp $1 /mnt/.ci/doc/kotlin-project/src/main/java/SnippetTest.kt && cd /mnt/.ci/doc/kotlin-project/ && ./gradlew build && java -classpath 'libs/sdk-jvm-1.0.0.jar:' -jar build/libs/project-1.jar
cp /mnt/build/libs/sdk-jvm-[0-9+].[0-9+].[0-9+]-without-dependencies.jar /mnt/.ci/doc/kotlin-project/libs/ && cp $1 /mnt/.ci/doc/kotlin-project/src/main/java/SnippetTest.kt && cd /mnt/.ci/doc/kotlin-project/ && ./gradlew build && java -classpath 'libs/sdk-jvm-1.2.0-without-dependencies.jar:' -jar build/libs/project-1.jar
else
cp /mnt/build/libs/sdk-jvm-[0-9+].[0-9+].[0-9+].jar /mnt/.ci/doc/java-project/libs/ && cp $1 /mnt/.ci/doc/java-project/src/main/java/SnippetTest.java && cd /mnt/.ci/doc/java-project/ && ./gradlew build && java -classpath 'libs/sdk-jvm-1.0.0.jar:' -jar build/libs/project-1.jar
cp /mnt/build/libs/sdk-jvm-[0-9+].[0-9+].[0-9+]-without-dependencies.jar /mnt/.ci/doc/java-project/libs/ && cp $1 /mnt/.ci/doc/java-project/src/main/java/SnippetTest.java && cd /mnt/.ci/doc/java-project/ && ./gradlew build && java -classpath 'libs/jvm-1.2.0-without-dependencies.jar:' -jar build/libs/project-1.jar
fi
37 changes: 33 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ https://bintray.com/kuzzle/maven
<dependency>
<groupId>io.kuzzle</groupId>
<artifactId>sdk-jvm</artifactId>
<version>1.0.0</version>
<version>1.2.0</version>
<type>pom</type>
</dependency>
```
Expand All @@ -54,19 +54,48 @@ https://bintray.com/kuzzle/maven
### Gradle

```groovy
compile 'io.kuzzle:sdk-jvm:1.0.0'
compile 'io.kuzzle:sdk-jvm:1.2.0'
```

For amd64:

```groovy
compile 'io.kuzzle:sdk-jvm:1.0.0'
compile 'io.kuzzle:sdk-jvm:1.2.0'
```

### Ivy

```html
<dependency org='io.kuzzle' name='sdk-jvm' rev='1.0.0'>
<dependency org='io.kuzzle' name='sdk-jvm' rev='1.2.0'>
<artifact name='sdk-jvm' ext='pom' ></artifact>
</dependency>
```

This SDK has 2 jar files that you can use:
* `sdk-jvm-<version>.jar`: this is the fat jar version, containing the SDK and all its dependencies.
* `sdk-jvm-<version>-without-dependencies.jar`: this is the thin jar version of the SDK, without any dependencies included in it.

Depending on your project, you might need one or the other version of the SDK: if you already use some of the dependencies needed by the SDK, then you need to use the thin jar version. Otherwise, you may use the fat jar one.

⚠️ Warning
If you are using the fat jar, you might have duplicate dependencies issues in a Kotlin Android Studio project. Add the following lines to your `build.gradle` file:

```groovy
configurations {
cleanedAnnotations
compile.exclude group: 'org.jetbrains'
compile.exclude group: 'org.jetbrains.kotlin'
}
```

If you are using the thin jar, make sure to add the following dependencies:

```groovy
implementation("io.ktor:ktor-client-websockets:1.5.2")
implementation("io.ktor:ktor-client-okhttp:1.5.2")
implementation("io.ktor:ktor-client-cio:1.5.2")
implementation("io.ktor:ktor-client-json:1.5.2")
implementation("io.ktor:ktor-client-gson:1.5.2")
implementation("io.ktor:ktor-client-serialization:1.5.2")
implementation("com.google.code.gson:gson:2.8.5")
```
65 changes: 50 additions & 15 deletions build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ plugins {

val artifactName = "sdk-jvm"
val artifactGroup = "io.kuzzle"
val artifactVersion = "1.1.0"
val artifactVersion = "1.2.0"

val pomUrl = "https://github.com/kuzzleio/sdk-jvm"
val pomScmUrl = "https://github.com/kuzzleio/sdk-jvm"
Expand All @@ -36,10 +36,36 @@ val pomDeveloperName = "kuzzle"

publishing {
publications {
create<MavenPublication>("kuzzle-sdk-jvm") {
create<MavenPublication>("kuzzle-sdk-jvm-fat") {
groupId = artifactGroup
artifactId = artifactName
version = artifactVersion
version = "1.2.0"
from(components["java"])

pom.withXml {
asNode().apply {
appendNode("description", pomDesc)
appendNode("name", rootProject.name)
appendNode("url", pomUrl)
appendNode("licenses").appendNode("license").apply {
appendNode("name", pomLicenseName)
appendNode("url", pomLicenseUrl)
appendNode("distribution", pomLicenseDist)
}
appendNode("developers").appendNode("developer").apply {
appendNode("id", pomDeveloperId)
appendNode("name", pomDeveloperName)
}
appendNode("scm").apply {
appendNode("url", pomScmUrl)
}
}
}
}
create<MavenPublication>("kuzzle-sdk-jvm-thin") {
groupId = artifactGroup
artifactId = artifactName
version = "${artifactVersion}-without-dependencies"
from(components["java"])

pom.withXml {
Expand Down Expand Up @@ -70,7 +96,7 @@ bintray {
key = System.getenv("BINTRAY_KEY")
publish = true

setPublications("kuzzle-sdk-jvm")
setPublications("kuzzle-sdk-jvm-fat", "kuzzle-sdk-jvm-thin")

pkg.apply {
repo = "maven"
Expand All @@ -94,8 +120,8 @@ bintray {
}

group = "io.kuzzle.sdk"
version = "1.1.0"
val ktorVersion = "1.3.2"
version = "1.2.0"
val ktorVersion = "1.5.2"

repositories {
jcenter()
Expand All @@ -113,11 +139,11 @@ dependencies {

testImplementation("org.jetbrains.kotlin:kotlin-test-junit")
testImplementation("io.mockk:mockk:1.8.13")
testImplementation("io.ktor:ktor-client-mock:$ktorVersion")
testImplementation("io.ktor:ktor-client-mock:1.3.2")
testImplementation("io.ktor:ktor-client-mock-jvm:$ktorVersion")
testImplementation("io.ktor:ktor-client-json-jvm:$ktorVersion")
testImplementation("io.ktor:ktor-client-mock-js:$ktorVersion")
testImplementation("io.ktor:ktor-client-mock-native:$ktorVersion")
testImplementation("io.ktor:ktor-client-mock-js:1.3.2")
testImplementation("io.ktor:ktor-client-mock-native:1.3.2")

}

Expand Down Expand Up @@ -149,12 +175,21 @@ application {
}

tasks.withType<Jar> {
archiveClassifier.set("without-dependencies")
}

tasks {
register("fatJar", Jar::class.java) {
archiveClassifier.set("")
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
manifest {
attributes(
mapOf(
"Main-Class" to application.mainClassName
)
)
attributes("Main-Class" to application.mainClassName)
}
from(configurations.compileClasspath.get().map { if (it.isDirectory()) it else zipTree(it) })
from(configurations.runtimeClasspath.get()
.onEach { println("Add from dependencies: ${it.name}") }
.map { if (it.isDirectory) it else zipTree(it) })
val sourcesMain = sourceSets.main.get()
sourcesMain.allSource.forEach { println("Add from sources: ${it.name}") }
from(sourcesMain.output)
}
}
37 changes: 17 additions & 20 deletions doc/1/controllers/document/m-update/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,26 +17,23 @@ Updates multiple documents.
## Arguments

```java
public CompletableFuture<Map<String, ArrayList<Object>>> mUpdate(
String index,
String collection,
ArrayList<Map<String, Object>> documents)
throws NotConnectedException, InternalException

public CompletableFuture<Map<String, ArrayList<Object>>> mUpdate(
String index,
String collection,
ArrayList<Map<String, Object>> documents,
Boolean waitForRefresh)
throws NotConnectedException, InternalException

public CompletableFuture<Map<String, ArrayList<Object>>> mUpdate(
String index,
String collection,
ArrayList<Map<String, Object>> documents,
Boolean waitForRefresh,
Integer retryOnConflict)
throws NotConnectedException, InternalException
public CompletableFuture<ConcurrentHashMap<String, ArrayList<Object>>> mUpdate(
String index,
String collection,
ArrayList<ConcurrentHashMap<String, Object>> documents) throws NotConnectedException, InternalException

public CompletableFuture<ConcurrentHashMap<String, ArrayList<Object>>> mUpdate(
String index,
String collection,
ArrayList<ConcurrentHashMap<String, Object>> documents,
Boolean waitForRefresh) throws NotConnectedException, InternalException

public CompletableFuture<ConcurrentHashMap<String, ArrayList<Object>>> mUpdate(
String index,
String collection,
ArrayList<ConcurrentHashMap<String, Object>> documents,
Boolean waitForRefresh,
Integer retryOnConflict) throws NotConnectedException, InternalException
```

| Arguments | Type | Description |
Expand Down
24 changes: 12 additions & 12 deletions doc/1/controllers/document/update-by-query/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,10 +30,10 @@ An empty or null query will match all documents in the collection.

```java
public CompletableFuture<Map<String, ArrayList<Object>>> updateByQuery(
String index,
String collection,
Map<String, Object> searchQuery,
Map<String, Object> changes) throws NotConnectedException, InternalException
String index,
String collection,
Map<String, Object> searchQuery,
Map<String, Object> changes) throws NotConnectedException, InternalException

public CompletableFuture<Map<String, ArrayList<Object>>> updateByQuery(
String index,
Expand Down Expand Up @@ -125,14 +125,14 @@ With the [Koncorde Filters DSL](/core/2/api/koncorde-filters-syntax) syntax.

```kotlin
fun updateByQuery(
index: String,
collection: String,
searchQuery: Map<String, Any?>,
changes: Map<String, Any?>,
waitForRefresh: Boolean? = null,
retryOnConflict: Int? = null,
source: Boolean? = null,
lang: Lang = Lang.ELASTICSEARCH): CompletableFuture<Map<String, ArrayList<Any?>>>
index: String,
collection: String,
searchQuery: Map<String, Any?>,
changes: Map<String, Any?>,
waitForRefresh: Boolean? = null,
retryOnConflict: Int? = null,
source: Boolean? = null,
lang: Lang = Lang.ELASTICSEARCH): CompletableFuture<Map<String, ArrayList<Any?>>>
```

| Argument | Type | Description |
Expand Down
Loading