This library is deprecated. No new development will be taking place. We recommend that you use either NodeJS, Python or REST API.
Use this library to develop a bot for Viber platform. The library is available on GitHub as well as maven central.
This library is released under the terms of the Apache 2.0 license. See License for more information.
- Java >= 8
- An Active Viber account on a platform which supports Public Accounts/ bots (iOS/Android). This account will automatically be set as the account administrator during the account creation process.
- Active Public Account/ bot.
- Account authentication token - unique account identifier used to validate your account in all API requests. Once your account is created your authentication token will appear in the account’s “edit info” screen (for admins only). Each request posted to Viber by the account will need to contain the token.
- Webhook - Please use a server endpoint URL that supports HTTPS. If you deploy on your own custom server, you'll need a trusted (ca.pem) certificate, not self-signed. Read our blog post on how to test your bot locally.
This library is released on maven central.
compile group: 'com.viber', name: 'viber-bot', version: '1.0.11'
<dependency>
<groupId>com.viber</groupId>
<artifactId>viber-bot</artifactId>
<version>1.0.11</version>
</dependency>
All public APIs are documented with JavaDocs which can be found in the GitHub repository.
We've created two sample projects to help you get started:
- Spring-Boot Sample using spring-boot-starter-web package.
- NanoHTTPd Sample with a tiny embedded HTTP server, called NanoHTTPd.
public void botExample() {
ViberBot bot = new ViberBot(new BotProfile("SampleBot", "http://viber.com/avatar.jpg"), "YOUR_AUTH_TOKEN_HERE");
bot.onMessageReceived((event, message, response) -> response.send(message));
// somewhere else in your web server of choice:
bot.incoming(Request.fromJsonString("..."));
}
You can chose to use any web server or framework you like. All you need to do is call the API with:
bot.incoming(Request.fromJsonString("...")); // or
bot.incoming(Request.fromInputStream(inputStream));
The Viber bot library is thread-safe and highly concurrent. You do not have to worry about synchronizing anything.
All calls to ViberBot#incoming()
go through a BlockingQueue
, and ordering is retained.
All I/O calls are directly executed on the same thread they were initially called on.
Yes. You can pass a system property to control the I/O thread pool:
com.viber.bot.executor.strategy=[DIRECT|THREAD]
(default is DIRECT)
com.viber.bot.executor.threads=N
(default is getRuntime().availableProcessors()
)
- Note: This will not change the way you use the library. You still don't have to synchronize anything.
Well funny you ask. Yes we do. But a word of warning - messages sent to your router callback will also be emitted to the ViberBot#onMessageReceived
event.
public void botTextRouterExample() {
bot.onTextMessage("(hi|hello)", (event, message, response) -> response.send("Hi " + event.getSender().getName()));
}
Join the conversation on Gitter.