Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oklahomer/go-sarah-line
https://github.com/oklahomer/go-sarah-line
Last synced: 14 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/oklahomer/go-sarah-line
- Owner: oklahomer
- Created: 2016-12-28T11:40:05.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2020-01-13T06:48:33.000Z (almost 5 years ago)
- Last Synced: 2024-11-02T03:42:26.584Z (2 months ago)
- Language: Go
- Size: 20.5 KB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
This is a [sarah](https://github.com/oklahomer/go-sarah) ```Adapter``` implementation for [LINE Messaging API](https://developers.line.me/messaging-api/overview).
# Recommended storage
## Idea of user's conversational state: UserContext
One outstanding feature that ```Sarah``` offers is the ability to store user's conversational context, ```sarah.UserContext```, initiated by ```sarah.Command```.
With this feature, ```sarah.Command``` developer can let messaging user stay in the ```sarah.Command```'s conversation without adding any change to ```sarah.Bot```'s logic.When a ```sarah.Command``` returns ```sarah.CommandResponose``` with ```sarah.UserContext```,
```Sarah``` considers the user is in the middle of ```sarah.Command's``` conversational context and stores this context information in designated ```sarah.Storage```.
When the user sends the next input within a pre-configured timeout window, the input is passed to the function defined by stored ```sarah.UserContext```.This is how a ```sarah.Command``` turns typical one-response-per-input bot interaction to conversational one so users can input a series of arguments in a more user-friendly conversational manner.
See [UserContextStorage](https://github.com/oklahomer/go-sarah/wiki/UserContextStorage) for details.
## Customized sarah.UserContextStorage
Pre-defined default storage is provided and can be initialized via ```sarah.NewUserContextStorage```, but developers may replace it with preferred storage since ```sarah.UserContextStorage``` is merely an interface.
A use of alternative storage is indeed recommended for production environment for two reasons:- Default storage internally uses a map to store ```sarah.UserContext``` in the process memory space, which means all stored contexts are vanished on process restart.
- While some chat services such as Slack and Gitter let bot initiate a connection against chat server, LINE Messaging API lets LINE initiate HTTP request against bot server.
With this model, to handle a larger amount of HTTP requests, the bot may consist of multiple server instances.
Therefore multiple ```sarah.Bot``` processes over multiple server instances must be capable of sharing ```sarah.UserContextStorage``` to let the user continue her conversation.Currently [go-sarah-rediscontext](https://github.com/oklahomer/go-sarah-rediscontext) is provided as one solution to store serialized ```sarah.UserContext``` in Redis.
One limitation to using external KVS is that arguments to the callback function must be serializable;
while default storage does not require so because it casually stores callback functions in Golang's map structure.Other implementations for different storage middleware should be available by implementing ```sarah.UserContextStorage``` interface.
# Getting Started
Below is a minimal sample that describes how to setup and start LINE Adapter.
For more detailed description how to register ```sarah.Command``` and behaviors, see [Sarah's README.md](https://github.com/oklahomer/go-sarah) and its [example code](https://github.com/oklahomer/go-sarah/tree/master/examples).```go
package mainimport (
"context"
"fmt"
"io/ioutil"
"os"
"os/signal"
"syscall""github.com/oklahomer/go-sarah-line"
"github.com/oklahomer/go-sarah/v2"
"gopkg.in/yaml.v2"
)func main() {
// Setup configuration
configBuf, _ := ioutil.ReadFile("/path/to/adapter/config.yaml")
lineConfig := line.NewConfig()
yaml.Unmarshal(configBuf, lineConfig)// Setup bot
lineAdapter, _ := line.NewAdapter(lineConfig)
storage := sarah.NewUserContextStorage(sarah.NewCacheConfig())
lineBot, _ := sarah.NewBot(lineAdapter, sarah.BotWithStorage(storage))
// Start
sarah.RegisterBot(lineBot)
config := sarah.NewConfig()
ctx, cancel := context.WithCancel(context.Background())
err := sarah.Run(ctx, config)
if err != nil {
panic(fmt.Errorf("failed to run: %s", err.Error()))
}
// Stop when signal is sent.
c := make(chan os.Signal, 1)
signal.Notify(c, syscall.SIGTERM)
select {
case <-c:
cancel()
}
}
```