Refer to the compatibility matrix to see which version of the Zulip server this library is compatible with.
Here’s how to get started with the Zulip Java client and starting making API requests.
Add the zulip-java-client
dependency to your project.
<dependency>
<groupId>com.github.jamesnetherton</groupId>
<artifactId>zulip-java-client</artifactId>
<version>0.7.3</version>
</dependency>
Create a Zulip
instance by passing the user email address, API key and the base URL of the Zulip server.
Zulip zulip = new Zulip("[email protected]", "your-api-key", "http://yourdomain.zulip.com")
Now you can start interacting with the Zulip APIs.
long messageId = zulip.messages()
.sendStreamMessage("Hello World!", "Test Stream", "Test Topic")
.execute();
When you are finished, it’s good practice to close the Zulip client.
zulip.close();
There are a few ways of customising the Zulip client configuration if you need to configure a proxy server or disable SSL certificate validation.
Zulip zulip = new Zulip.Builder()
.site(...)
.email(...)
.apiKey(...)
.insecure(...)
.build();
There is the option to use a zuliprc
file as the configuration source.
Load zuliprc from the user home directory.
ZulipConfiguration configuration = ZulipConfiguration.fromZuliprc();
Zulip zulip = new Zulip(configuration);
Load zuliprc from a specified file.
ZulipConfiguration configuration = ZulipConfiguration.fromZuliprc(new File("/path/to/zuliprc"));
Zulip zulip = new Zulip(configuration);
The zuliprc file has the following format.
key=API key from the web interface
email=your email address
site=your Zulip server base URL
insecure=whether to disable SSL certificate validation (true or false)
Or instantiate the ZulipConfiguration
directly.
ZulipConfiguration configuration = new ZulipConfiguration("http://a.site.com", "[email protected]", "an-api-key");
Zulip zulip = new Zulip(configuration);
Each API has a request builder object which is used to set the various parameter values expected by the API endpoint.
Mandatory values will always be part of the API request method signature, while optional values can be provided through the 'with' builder methods.
Here’s an example of this with the edit message API.
zulip.messages().editMessage(1) (1)
.withContent("edited content") (2)
.withPropagateMode(PropagateMode.CHANGE_ONE)
.withSendNotificationToNewThread(true)
.withSendNotificationToOldThread(true)
.withStreamId(1)
.withTopic("different topic")
.execute(); (3)
-
The zulip client object exposes methods which aggregate the REST APIs together under logical groups such as messages, streams & users. The
editMessage
API expects one mandatory parameter - the message id. -
Then follows a number of optional API parameters.
-
The request builder is completed and sent to the Zulip server with the
execute()
method. This MUST be called in order for the request to be sent.
Zulip API error responses are thrown as ZulipClientException
. The exception object contains details about the error such as the code and a descriptive message.
try {
zulip.messages.send(..);
} catch (ZulipClientException e) {
System.out.println(e.getMessage());
System.out.println(e.getCode());
}
If you exceed the API request rate limit, then the exception cause will be set to ZulipRateLimitExceeded
. It contains a method which enables you to get the time at which the rate limit is reset. Note that the value is a Unix epoch value.
try {
zulip.messages.send(..);
} catch (ZulipClientException e) {
Throwable cause = e.getCause();
if (cause instanceof ZulipRateLimitExceededException) {
ZulipRateLimitExceededException rle = (ZulipRateLimitExceededException) cause;
System.out.println(rle.getReteLimitReset());
}
}
There is some limited and experimental support for the Zulip real-time events API.
At present it is only possible to consume events whenever new messages are posted.
To consume messages posted to all streams.
EventPoller eventPoller = zulip.events().captureMessageEvents(new MessageEventListener() {
@Override
public void onEvent(Message event) {
System.out.println(event.getContent());
}
});
eventPoller.start();
// Do useful app work
eventPoller.stop();
To filter messages you may use one or more narrow expressions.
EventPoller eventPoller = zulip.events().captureMessageEvents(new MessageEventListener() {
@Override
public void onEvent(Message event) {
System.out.println(event.getContent());
}
}, Narrow.of("stream", "my-stream-name"));
eventPoller.start();
// Do useful app work
eventPoller.stop();