Name Last Update
..
src Loading commit data...
README.md Loading commit data...
build.gradle Loading commit data...

line-bot-spring-boot

This is a Spring Boot auto-configuration for the LINE Messaging API.

Synopsis

package com.example.bot.spring.echo;

import java.util.List;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

import com.linecorp.bot.model.event.Event;
import com.linecorp.bot.model.event.MessageEvent;
import com.linecorp.bot.model.event.message.TextMessageContent;
import com.linecorp.bot.model.message.TextMessage;
import com.linecorp.bot.spring.boot.annotation.EventMapping;
import com.linecorp.bot.spring.boot.annotation.LineMessageHandler;

@SpringBootApplication
@LineMessageHandler
public class EchoApplication {
    public static void main(String[] args) {
        SpringApplication.run(EchoApplication.class, args);
    }

    @EventMapping
    public TextMessage handleTextMessageEvent(MessageEvent<TextMessageContent> event) {
        System.out.println("event: " + event);
        return new TextMessage(event.getMessage().getText());
    }

    @EventMapping
    public void handleDefaultMessageEvent(Event event) {
        System.out.println("event: " + event);
    }
}

Usage

Add this library as a dependency of your project.

You can then get parsed messages like the following:

@LineMessageHandler
public class EchoApplication {
    @EventMapping
    public TextMessage handleTextMessageEvent(MessageEvent<TextMessageContent> event) throws Exception {
        System.out.println("event: " + event);
        return new TextMessage(event.getMessage().getText());
    }
}

Method with @EventMapping on @LineMessageHandler annotated class is treated as message event handler.

The event handler method should be only one argument with some type implements Event.

When webhook is reached, SDK call decide which method should be called based on the arguments type.

All methods detected by SDK is logged into start up time as follows.

c.l.b.s.b.s.LineMessageHandlerSupport    : Mapped "[MessageEvent<TextMessageContent>]" onto public java.util.List<com.linecorp.bot.model.message.TextMessage> com.example.bot.spring.echo.EchoApplication.handleTextMessageEvent(com.linecorp.bot.model.event.MessageEvent<com.linecorp.bot.model.event.message.TextMessageContent>) throws java.lang.Exception
c.l.b.s.b.s.LineMessageHandlerSupport    : Mapped "[Event]" onto public void com.example.bot.spring.echo.EchoApplication.handleDefaultMessageEvent(com.linecorp.bot.model.event.Event)

Configuration

The Messaging API SDK is automatically configured by the system properties. The parameters are shown below.

Parameter Description
line.bot.channelToken Channel access token for the server
line.bot.channelSecret Channel secret for the server
line.bot.channelTokenSupplyMode The way to fix channel access token. (default: FIXED)
LINE Partners should change this value to SUPPLIER and create custom ChannelTokenSupplier bean.
line.bot.connectTimeout Connection timeout in milliseconds
line.bot.readTimeout Read timeout in milliseconds
line.bot.writeTimeout Write timeout in milliseconds
line.bot.handler.enabled Enable @EventMapping mechanism. (default: true)
line.bot.handler.path Path to waiting webhook. (default: /callback)