First commit
This commit is contained in:
commit
8b9084ec06
6 changed files with 130 additions and 0 deletions
4
Makefile
Normal file
4
Makefile
Normal file
|
@ -0,0 +1,4 @@
|
|||
all: broker
|
||||
|
||||
broker:
|
||||
go build -o clessy-broker ./broker
|
9
broker/action.go
Normal file
9
broker/action.go
Normal file
|
@ -0,0 +1,9 @@
|
|||
package broker
|
||||
|
||||
import (
|
||||
"../tg"
|
||||
)
|
||||
|
||||
func executeClientCommand(action tg.ClientCommand) {
|
||||
|
||||
}
|
67
broker/clients.go
Normal file
67
broker/clients.go
Normal file
|
@ -0,0 +1,67 @@
|
|||
package main
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"log"
|
||||
"net"
|
||||
|
||||
"../tg"
|
||||
)
|
||||
|
||||
var clients []net.Conn
|
||||
|
||||
func startClientsServer(bind string) {
|
||||
listener, err := net.Listen("tcp", bind)
|
||||
assert(err)
|
||||
|
||||
// Accept loop
|
||||
for {
|
||||
c, err := listener.Accept()
|
||||
if err != nil {
|
||||
log.Printf("Can't accept client: %s\n", err.Error())
|
||||
continue
|
||||
}
|
||||
clients = append(clients, c)
|
||||
go handleClient(c)
|
||||
}
|
||||
}
|
||||
|
||||
func handleClient(c net.Conn) {
|
||||
b := bufio.NewReader(c)
|
||||
defer c.Close()
|
||||
|
||||
// Start reading messages
|
||||
for {
|
||||
bytes, _, err := b.ReadLine()
|
||||
if err != nil {
|
||||
break
|
||||
}
|
||||
var cmd tg.ClientCommand
|
||||
err = json.Unmarshal(bytes, &cmd)
|
||||
if err != nil {
|
||||
log.Printf("Can't parse JSON: %s\r\n", err.Error())
|
||||
continue
|
||||
}
|
||||
executeClientCommand(cmd)
|
||||
}
|
||||
removeCon(c)
|
||||
}
|
||||
|
||||
func removeCon(c net.Conn) {
|
||||
for i, con := range Clients {
|
||||
if c == con {
|
||||
clients = append(clients[:i], clients[i+1:]...)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func broadcast(message string) {
|
||||
for _, c := range clients {
|
||||
_, err := fmt.Fprintf(c, message+"\r\n")
|
||||
if err != nil {
|
||||
removeCon(c)
|
||||
}
|
||||
}
|
||||
}
|
43
broker/main.go
Normal file
43
broker/main.go
Normal file
|
@ -0,0 +1,43 @@
|
|||
package main
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"flag"
|
||||
"net/http"
|
||||
"os"
|
||||
)
|
||||
|
||||
type Config struct {
|
||||
BindServer string /* Address:Port to bind for Telegram */
|
||||
BindClients string /* Address:Port to bind for clients */
|
||||
Token string /* Telegram bot token */
|
||||
WebhookURL string /* Webhook URL */
|
||||
}
|
||||
|
||||
func assert(err error) {
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
}
|
||||
|
||||
func main() {
|
||||
cfgpath := flag.String("config", "config.json", "Path to configuration file")
|
||||
flag.Parse()
|
||||
|
||||
file, err := os.Open(*cfgpath)
|
||||
assert(err)
|
||||
|
||||
var config Config
|
||||
err = json.NewDecoder(file).Decode(&config)
|
||||
assert(err)
|
||||
|
||||
// Setup webhook handler
|
||||
go func() {
|
||||
http.HandlerFunc(config.Token, webhook)
|
||||
err := http.ListenAndServe(config.BindServer, nil)
|
||||
assert(err)
|
||||
}()
|
||||
|
||||
// Create server for clients
|
||||
startClientsServer(config.BindClients)
|
||||
}
|
3
config.json.sample
Normal file
3
config.json.sample
Normal file
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
|
||||
}
|
4
tg/command.go
Normal file
4
tg/command.go
Normal file
|
@ -0,0 +1,4 @@
|
|||
package tg
|
||||
|
||||
type ClientCommand struct {
|
||||
}
|
Reference in a new issue