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

Add Java and Kotlin Getting started #23

Merged
merged 55 commits into from
Dec 1, 2020
Merged
Show file tree
Hide file tree
Changes from 41 commits
Commits
Show all changes
55 commits
Select commit Hold shift + click to select a range
e01f407
getting started
Yoann-Abbes Nov 12, 2020
891d3d7
fix cast
Yoann-Abbes Nov 12, 2020
cf40ae0
@kblondel requested changes
Yoann-Abbes Nov 17, 2020
51e51f5
link bintray
Yoann-Abbes Nov 17, 2020
fe1b1d5
update getting started
Yoann-Abbes Nov 17, 2020
5409318
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
14ea4ba
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
5132317
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
ba9b572
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
c4d255b
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
935e839
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
ed14ed2
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
a53b351
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
abd0aff
Update doc/1/getting-started/java/snippets/document-java.java
Yoann-Abbes Nov 18, 2020
3be54bd
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
4f4ef5b
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
f251ad4
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
1a5629d
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
9e47bd2
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
d4a122e
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
abd319f
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
f246fcb
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
fbf6b78
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
b289bb2
update getting started kt
Yoann-Abbes Nov 18, 2020
b76c2e1
update snippets getting started
Yoann-Abbes Nov 18, 2020
a7687ca
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
9dfacfc
update getting started
Yoann-Abbes Nov 18, 2020
b15f6b8
update document:search signature
Yoann-Abbes Nov 18, 2020
3d94b3f
typo
Yoann-Abbes Nov 18, 2020
13dea72
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 18, 2020
94737fd
remove congrats
Yoann-Abbes Nov 18, 2020
00331d8
fix getting started gradle
Yoann-Abbes Nov 19, 2020
3cf3601
fix getting started gradle
Yoann-Abbes Nov 19, 2020
06645f8
search overload
Yoann-Abbes Nov 25, 2020
60ea453
Update doc/1/getting-started/java/snippets/document-java.java
Yoann-Abbes Nov 27, 2020
5d850f7
Update doc/1/getting-started/java/snippets/firstconnection-java.java
Yoann-Abbes Nov 27, 2020
0e4d1e1
Update doc/1/getting-started/java/snippets/realtime-java.java
Yoann-Abbes Nov 27, 2020
92c03ed
Update doc/1/getting-started/kotlin/snippets/document-kotlin.kt
Yoann-Abbes Nov 27, 2020
22f3628
Update doc/1/getting-started/kotlin/snippets/firstconnection-kotlin.kt
Yoann-Abbes Nov 27, 2020
9575ebc
Update doc/1/getting-started/kotlin/snippets/realtime-kotlin.kt
Yoann-Abbes Nov 27, 2020
2540279
fix tab
Yoann-Abbes Nov 27, 2020
ce017bd
update getting started java
Yoann-Abbes Nov 27, 2020
a5cff10
Update doc/1/getting-started/kotlin/index.md
Yoann-Abbes Nov 27, 2020
48a6996
Update doc/1/getting-started/java/index.md
Yoann-Abbes Nov 27, 2020
661d0aa
update getting started kt
Yoann-Abbes Nov 27, 2020
0a56e04
Update doc/1/getting-started/kotlin/index.md
Yoann-Abbes Nov 27, 2020
8742683
fix tokenexpired
Yoann-Abbes Nov 27, 2020
5c0d8be
Update doc/1/getting-started/kotlin/snippets/realtime-kotlin.kt
Yoann-Abbes Dec 1, 2020
d1d6642
@abouthinon requested changes
Yoann-Abbes Dec 1, 2020
e4b5475
Update doc/1/getting-started/java/snippets/firstconnection-java.java
Yoann-Abbes Dec 1, 2020
a294526
Update doc/1/getting-started/java/snippets/realtime-java.java
Yoann-Abbes Dec 1, 2020
8da633c
Update doc/1/getting-started/kotlin/snippets/document-kotlin.kt
Yoann-Abbes Dec 1, 2020
a029905
Update doc/1/getting-started/kotlin/snippets/realtime-kotlin.kt
Yoann-Abbes Dec 1, 2020
ce905f0
Update doc/1/getting-started/kotlin/snippets/document-kotlin.kt
Yoann-Abbes Dec 1, 2020
b62e09b
Update doc/1/getting-started/kotlin/snippets/firstconnection-kotlin.kt
Yoann-Abbes Dec 1, 2020
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
1 change: 1 addition & 0 deletions .ci/doc/templates/empty.tpl.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
[snippet-code]
8 changes: 8 additions & 0 deletions doc/1/controllers/bulk/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
---
code: true
type: branch
title: Bulk
description: Bulk Controller
---

# Bulk Controller
19 changes: 9 additions & 10 deletions doc/1/controllers/document/search/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -39,28 +39,27 @@ You can restrict the scroll session maximum duration under the `services.storage
public CompletableFuture<SearchResult> search(
String index,
String collection,
ConcurrentHashMap<String, Object> searchQuery,
String scroll,
Integer from,
Integer size) throws NotConnectedException, InternalException
ConcurrentHashMap<String, Object> searchQuery) throws NotConnectedException, InternalException

public CompletableFuture<SearchResult> search(
String index,
String collection,
ConcurrentHashMap<String, Object> searchQuery,
String scroll,
Integer from) throws NotConnectedException, InternalException
String scroll) throws NotConnectedException, InternalException

public CompletableFuture<SearchResult> search(
String index,
String collection,
ConcurrentHashMap<String, Object> searchQuery,
String scroll) throws NotConnectedException, InternalException
String scroll,
Integer size) throws NotConnectedException, InternalException

public CompletableFuture<SearchResult> search(
String index,
String collection,
ConcurrentHashMap<String, Object> searchQuery)
ConcurrentHashMap<String, Object> searchQuery
Integer size,
Integer from)
throws NotConnectedException, InternalException
```

Expand Down Expand Up @@ -102,8 +101,8 @@ Returns a [SearchResult](/sdk/jvm/1/core-classes/search-result) object.
collection: String,
searchQuery: ConcurrentHashMap<String?, Any?>,
scroll: String? = null,
from: Int = 0,
size: Int? = null): CompletableFuture<SearchResult>
size: Int? = null,
from: Int = 0): CompletableFuture<SearchResult>
```

| Arguments | Type | Description |
Expand Down
3 changes: 1 addition & 2 deletions doc/1/core-classes/search-result/next/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,6 @@ Above that limit, any call to `next` throws an Exception.

<<< ./snippets/fromsize-java.java


:::
::: tab Kotlin

Expand Down Expand Up @@ -143,4 +142,4 @@ Above that limit, any call to `next` throws an Exception.
<<< ./snippets/fromsize-kotlin.kt

:::
:::.
::::
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
SearchResult results = kuzzle.getDocumentController().search(
"nyc-open-data",
"yellow-taxi",
searchQuery, null, 1, 5).get();
searchQuery, 1, 5).get();

// Fetch the matched items by advancing through the result pages
ArrayList<ConcurrentHashMap<String, Object>> matched = new ArrayList<>();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,8 @@ ConcurrentHashMap<String, Any?>().apply {
}

var result: SearchResult? = kuzzle
.documentController
.search("nyc-open-data", "yellow-taxi", searchQuery, null, 1, 5).get();
.documentController
.search("nyc-open-data", "yellow-taxi", searchQuery, 5, 1).get();

// Fetch the matched items by advancing through the result pages
val matched: ArrayList<ConcurrentHashMap<String, Any>> = ArrayList<ConcurrentHashMap<String, Any>>();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
SearchResult results = kuzzle.getDocumentController().search(
"nyc-open-data",
"yellow-taxi",
searchQuery, "1s", 0, 10).get();
searchQuery, "1s", 10).get();

// Fetch the matched items by advancing through the result pages
ArrayList<ConcurrentHashMap<String, Object>> matched = new ArrayList<>();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,8 @@ ConcurrentHashMap<String, Any?>().apply {
put("query", query)
}
var result: SearchResult? = kuzzle
.documentController
.search("nyc-open-data", "yellow-taxi", searchQuery, "1s", 0, 10).get();
.documentController
.search("nyc-open-data", "yellow-taxi", searchQuery, "1s", 10).get();

// Fetch the matched items by advancing through the result pages
val matched: ArrayList<ConcurrentHashMap<String, Any>> = ArrayList<ConcurrentHashMap<String, Any>>();
Expand Down
6 changes: 6 additions & 0 deletions doc/1/getting-started/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
code: false
type: branch
order: 0
title: Getting Started
---
173 changes: 173 additions & 0 deletions doc/1/getting-started/java/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,173 @@
---
code: false
type: page
title: Java
description: Java Getting started
order: 99
---

# Getting Started

In this tutorial you will learn how to install and use the **JVM SDK** for Kuzzle.
This page shows examples of scripts that **store** documents in Kuzzle, and of scripts that subcribe to real-time **notifications** for each new document created.

::: success
Before proceeding, please make sure your system meets the following requirements:

- **Oracle JDK or OpenJDK** version 8 or higher ([OpenJDK installation instructions](https://openjdk.java.net/install/))
- A running Kuzzle Server ([Kuzzle installation guide](/core/2/guides/essentials/installing-kuzzle))

:::


::: info
Having trouble? Get in touch with us on [Discord](http://join.discord.kuzzle.io)!
:::

## Installation

You can find the SDK JARs directly on [bintray](https://bintray.com/kuzzle/maven/sdk-jvm). Download and add them to your classpath.

::: info
The following examples are made to be executed without any IDE.
If you're using Eclipse, IntelliJ or another Java IDE, you need to add the SDK as a project dependency in your classpath.
:::

### Installing for Android projects using gradle

To build the project, add the following lines:

### Maven

```xml
<dependency>
<groupId>io.kuzzle</groupId>
<artifactId>sdk-jvm</artifactId>
<version>1.0.0</version>
<type>pom</type>
</dependency>
```

### Gradle

```groovy
repositories {
maven() {
url "https://dl.bintray.com/kuzzle/maven"
}
}
dependencies {
compile 'io.kuzzle:sdk-jvm:1.0.0'
}
```

### Ivy

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

## First connection

Initialize a new Java project, create a `GettingStartedFirstConnection.java` file and start by adding the code below:

<<< ./snippets/firstconnection-java.java

::: info
If you're not yet familiar with how Kuzzle structures its storage, check our [detailed guide][https://docs.kuzzle.io/core/2/guides/essentials/store-access-data/)
:::

This program initializes the Kuzzle Server storage by creating an index and a collection.
Run the program with the following command:

```bash
$ javac -classpath ./path/to/the/sdk.jar GettingStartedFirstConnection.java
$ java -classpath .:./path/to/the/sdk.jar GettingStartedFirstConnection
Connected!
Index nyc-open-data created!
Collection yellow-taxi created!
```

You now know how to:

- Instantiate the Kuzzle SDK and connect to a Kuzzle Server using a specific network protocol (here `websocket`)
- Create an index
- Create a collection within an existing index

## Create your first document

Now that you successfully connected to your Kuzzle Server instance, and created an index and a collection, it's time to manipulate documents.

Here is how Kuzzle structures its storage space:

- indexes contain collections
- collections contain documents
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should probably come earlier, before we make the user create an index and a collection. It'd probably be better to also link to a more detailed guide page, such as https://docs.kuzzle.io/core/2/guides/essentials/store-access-data/

That would give something like this (to be moved to the previous chapter):

Suggested change
Here is how Kuzzle structures its storage space:
- indexes contain collections
- collections contain documents
::: info
If you're not yet familiar with how Kuzzle structures its storage, check our [detailed guide][https://docs.kuzzle.io/core/2/guides/essentials/store-access-data/)
:::


Create a `GettingStartedStorage.java` file in the playground and add this code:

<<< ./snippets/document-java.java

As you did before, build and run your program:

```bash
$ javac -classpath ./path/to/the/sdk.jar GettingStartedStorage.java
$ java -classpath .:./path/to/the/sdk.jar GettingStartedStorage
Connected!
New document added to the yellow-taxi collection!
```

Many other actions are available to manipulate stored documents. You can check the exhaustive list in the [Document Controller documentation](https://docs.kuzzle.io/sdk/jvm/1/controllers/document).

Now you know how to:

- Store documents in a Kuzzle Server, and access to those

## Subscribe to realtime document notifications (pub/sub)

Time to use Kuzzle's realtime capabilities. Create a new file `GettingStartedRealtime.java` with the following code:

<<< ./snippets/realtime-java.java

This program subscribes to changes made to documents with a `license` field set to `B`, within the `yellow-taxi` collection. Whenever a document matching the provided filters changes, a new notification is received from Kuzzle.

Build and run your program:

```bash
$ javac -classpath ./path/to/the/sdk.jar GettingStartedRealtime.java
$ java -classpath .:./path/to/the/sdk.jar GettingStartedRealtime
Connected!
Successfully subscribing!
New document added to yellow-taxi collection!
New created document notification:

{
_source={
birthday=1995-11-27,
license=B,
name=John,
_kuzzle_info={
createdAt=1605694059151,author=-1
}
},
_id=9PDS2nUBeGNr7nwl8j2Q,
_version=1
}

```

You should see the document content as a `ConcurrentHashMap`.

Now, you know how to:

- Create realtime filters
- Subscribe to notifications

## Where do we go from here?

Now that you're more familiar with the JVM SDK, you can dive even deeper to learn how to leverage its full capabilities:

- discover what this SDK has to offer by browsing other sections of this documentation
- learn how to use [pagination strategies](/sdk/jvm/1/core-classes/search-result/next/#pagination-strategies) with the [document:search](/sdk/jvm/1/controllers/document/search/) API action.
- discover others [Kuzzle guides](core/2/guides/essentials/introduction/)
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved
45 changes: 45 additions & 0 deletions doc/1/getting-started/java/snippets/document-java.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
import io.kuzzle.sdk.*;
import io.kuzzle.sdk.protocol.WebSocket;

import java.util.concurrent.ConcurrentHashMap;

public class SnippetTest {
private static Kuzzle kuzzle;

public static void main(String[] args) {

try {
// Creates a WebSocket connection.
// Replace "kuzzle" with
// your Kuzzle host name (e.g. "localhost")
WebSocket ws = new WebSocket("kuzzle");

// Instantiates a Kuzzle client
kuzzle = new Kuzzle(ws);

// Connects to the server.
kuzzle.connect();
System.out.println("Connected!");
} catch(Exception e){
e.printStackTrace();
}

// New document content
ConcurrentHashMap<String, Object> content = new ConcurrentHashMap<>();
content.put("name", "John");
content.put("birthday", "1995-11-27");
content.put("license", "B");

// Stores the document in the "yellow-taxi" collection.
try {
kuzzle.getDocumentController()
.create( "nyc-open-data", "yellow-taxi", content).get();
System.out.println("New document added to the yellow-taxi collection!");
} catch(Exception e){
e.printStackTrace();
}

// Disconnects the SDK.
kuzzle.disconnect();
}
}
9 changes: 9 additions & 0 deletions doc/1/getting-started/java/snippets/document-java.test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
name: java-gettingstarted#storage
description: Data manipulation
hooks:
before: curl -X POST kuzzle:7512/nyc-open-data/_create ; curl -X PUT kuzzle:7512/nyc-open-data/yellow-taxi/; curl -X DELETE kuzzle:7512/nyc-open-data/yellow-taxi/some-id
after:
template: empty
expected:
- Connected!
- New document added to the yellow-taxi collection!
47 changes: 47 additions & 0 deletions doc/1/getting-started/java/snippets/firstconnection-java.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
import io.kuzzle.sdk.*;
import io.kuzzle.sdk.protocol.WebSocket;

import java.util.concurrent.ConcurrentHashMap;

public class SnippetTest {
private static Kuzzle kuzzle;

public static void main(String[] args) {

try {
// Creates a WebSocket connection.
// Replace "kuzzle" with
// your Kuzzle hostname like "localhost"
WebSocket ws = new WebSocket("kuzzle");

// Instantiates a Kuzzle client
kuzzle = new Kuzzle(ws);

// Connects to the server.
kuzzle.connect();
System.out.println("Connected!");
} catch(Exception e){
e.printStackTrace();
}

// Freshly installed Kuzzle servers are empty: we need to create
// a new index.
try {
kuzzle.getIndexController().create("nyc-open-data").get();
System.out.println("Index nyc-open-data created!");
} catch(Exception e){
e.printStackTrace();
}

// Creates a collection
try {
kuzzle.getCollectionController().create("nyc-open-data", "yellow-taxi").get();
System.out.println("Collection yellow-taxi created!");
} catch(Exception e){
e.printStackTrace();
}

// Disconnects the SDK
kuzzle.disconnect();
}
}
Loading