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 5 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
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

:::
:::.
::::
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
---
149 changes: 149 additions & 0 deletions doc/1/getting-started/java/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,149 @@
---
code: false
type: page
title: Java
description: Java Getting started
order: 99
---

# Getting Started

In this tutorial you will learn how to install the Kuzzle **Jvm SDK**.
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved
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 it to your classpath.
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

::: 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 on Android using gradle
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

In your app build.gradle add the following line and sync.
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

### Maven:
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

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

### Gradle:
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

```groovy
implementation 'io.kuzzle:sdk-jvm:1.0.0'
```

### Ivy:
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

```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

This program initializes the Kuzzle Server storage by creating a index, and a collection inside it
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved
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!
```

Congratulations, you performed your first connection to Kuzzle Server via a Java program.
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved
You now know how to:

- Instantiate Kuzzle SDK and connect to Kuzzle Server using a specific protocol (here `websocket`)
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved
- Create a index
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved
- 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 some data.
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

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:
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

<<< ./snippets/document.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 yellow-taxi collection!
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved
```

You can perform other actions such as [delete](/sdk/jvm/1/controllers/document/delete), [replace](/sdk/jvm/1/controllers/document/replace) or [search](/sdk/jvm/1/controllers/document/search) documents. There are also other ways to interact with Kuzzle like our [Admin Console](/core/2/guides/essentials/admin-console), the [Kuzzle HTTP API](/core/2/api/essentials/connecting-to-kuzzle) or by using your [own protocol](/core/2/protocols/essentials/getting-started).
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

Now you know how to:

- Store documents in a Kuzzle Server, and access those
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

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

Time to use realtime with Kuzzle. Create a new file `GettingStartedRealtime.java` with the following code:
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

<<< ./snippets/realtime.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: [Document content as ConcurrentHashMap]
Copy link
Contributor

Choose a reason for hiding this comment

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

hm... can the snippet serialize the document content and print it so that example gives a view of the actual notification content?

```

You should see document content as a `ConcurrentHashMap`.
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

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:
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

- discover what this SDK has to offer by browsing other sections of this documentation
- learn how to use [Koncorde](/core/2/guides/cookbooks/realtime-api) to create incredibly fine-grained and blazing-fast subscriptions
- follow our guide to learn how to perform [basic authentication](/core/2/guides/essentials/user-authentication#local-strategy)
- follow our guide to learn how to [manage users and how to set up fine-grained access control](/core/2/guides/essentials/security)
Copy link
Contributor

Choose a reason for hiding this comment

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

Those are Kuzzle topics rather than SDK ones

Copy link
Contributor Author

Choose a reason for hiding this comment

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

You r right, Ive copied this part from others SDK getting started, we should probably make it more accurate

46 changes: 46 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,46 @@
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"
Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved

Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved
Copy link
Member

Choose a reason for hiding this comment

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

Suggested change

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!
48 changes: 48 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,48 @@
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"

Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved
Copy link
Member

Choose a reason for hiding this comment

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

Suggested change

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();
}
}
10 changes: 10 additions & 0 deletions doc/1/getting-started/java/snippets/firstconnection-java.test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
name: java-gettingstarted#firstconnection
description: First connection
hooks:
before: curl -X DELETE kuzzle:7512/nyc-open-data
after:
template: empty
expected:
- Connected!
- Index nyc-open-data created!
- Collection yellow-taxi created!
64 changes: 64 additions & 0 deletions doc/1/getting-started/java/snippets/realtime-java.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
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"

Yoann-Abbes marked this conversation as resolved.
Show resolved Hide resolved
Copy link
Member

Choose a reason for hiding this comment

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

Suggested change

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();
}

// Subscribes to notifications for drivers having a "B" driver license.
ConcurrentHashMap<String, Object> filters = new ConcurrentHashMap<>();
ConcurrentHashMap<String, Object> equals = new ConcurrentHashMap<>();
equals.put("license", "B");
filters.put("equals", equals);

try {
// Sends the subscription
kuzzle.getRealtimeController()
.subscribe("nyc-open-data", "yellow-taxi", filters, notification -> {
ConcurrentHashMap<String, Object> content = ((ConcurrentHashMap<String, Object>)(notification.getResult()));
System.out.println("New created document notification: " + content);
}).get();
System.out.println("Successfully subscribed!");
} catch (Exception e) {
e.printStackTrace();
}

// Writes a new document. This triggers a notification
// sent to our subscription.
ConcurrentHashMap<String, Object> content = new ConcurrentHashMap<>();
content.put("name", "John");
content.put("birthday", "1995-11-27");
content.put("license", "B");

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();
}
}
10 changes: 10 additions & 0 deletions doc/1/getting-started/java/snippets/realtime-java.test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
name: java-gettingstarted#realtime
description: Realtime interactions
hooks:
before: curl -X POST kuzzle:7512/nyc-open-data/_create ; curl -X PUT kuzzle:7512/nyc-open-data/yellow-taxi/
after:
template: empty
expected:
- Connected!
- Successfully subscribed!
- ^New created document notification:.*$
Loading