upd
This commit is contained in:
parent
09439ce697
commit
a465276246
22
bot.go
22
bot.go
@ -1,21 +1,21 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"time"
|
||||
"log"
|
||||
"fmt"
|
||||
tb "gopkg.in/tucnak/telebot.v2"
|
||||
"log"
|
||||
"time"
|
||||
)
|
||||
|
||||
var (
|
||||
b *tb.Bot
|
||||
b *tb.Bot
|
||||
)
|
||||
|
||||
func StartBot() {
|
||||
// Registering bot
|
||||
b, err := tb.NewBot(tb.Settings{
|
||||
Token: cfg.Telegram.Token,
|
||||
URL: cfg.Telegram.URL,
|
||||
URL: cfg.Telegram.URL,
|
||||
Poller: &tb.LongPoller{Timeout: 10 * time.Second},
|
||||
})
|
||||
|
||||
@ -35,14 +35,14 @@ func StartBot() {
|
||||
|
||||
func botPhoto(m *tb.Message) {
|
||||
fmt.Println("OnPhoto :", m.Text)
|
||||
// photos only
|
||||
// photos only
|
||||
}
|
||||
|
||||
func botHello(m *tb.Message) {
|
||||
if !m.Private() {
|
||||
return
|
||||
}
|
||||
// fmt.Println("Hello payload :", m.Payload) // <PAYLOAD>
|
||||
// fmt.Println("Hello payload :", m.Payload) // <PAYLOAD>
|
||||
PrintText(m)
|
||||
b.Send(m.Sender, "hello world")
|
||||
}
|
||||
@ -50,16 +50,16 @@ func botHello(m *tb.Message) {
|
||||
func botChannelPost(m *tb.Message) {
|
||||
fmt.Println("OnChannelPost :", m.Text)
|
||||
PrintText(m)
|
||||
// channel posts only
|
||||
// channel posts only
|
||||
}
|
||||
|
||||
func botQuery(q *tb.Query) {
|
||||
fmt.Println("Query ?")
|
||||
// incoming inline queries
|
||||
// incoming inline queries
|
||||
}
|
||||
|
||||
func botText(m *tb.Message) {
|
||||
PrintText(m)
|
||||
// all the text messages that weren't
|
||||
// captured by existing handlers
|
||||
PrintText(m)
|
||||
// all the text messages that weren't
|
||||
// captured by existing handlers
|
||||
}
|
72
main.go
72
main.go
@ -1,49 +1,49 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"time"
|
||||
"log"
|
||||
"flag"
|
||||
"fmt"
|
||||
"database/sql"
|
||||
"flag"
|
||||
"fmt"
|
||||
_ "github.com/go-sql-driver/mysql"
|
||||
"gopkg.in/gcfg.v1"
|
||||
tb "gopkg.in/tucnak/telebot.v2"
|
||||
"log"
|
||||
"time"
|
||||
)
|
||||
|
||||
type Config struct {
|
||||
Telegram struct {
|
||||
URL string
|
||||
Token string
|
||||
URL string
|
||||
Token string
|
||||
}
|
||||
SQL struct {
|
||||
Driver string
|
||||
Type string
|
||||
Address string
|
||||
Username string
|
||||
Password string
|
||||
Database string
|
||||
Driver string
|
||||
Type string
|
||||
Address string
|
||||
Username string
|
||||
Password string
|
||||
Database string
|
||||
}
|
||||
Rabbit struct {
|
||||
User string
|
||||
Password string
|
||||
Host string
|
||||
Queue string
|
||||
User string
|
||||
Password string
|
||||
Host string
|
||||
Queue string
|
||||
}
|
||||
Bot struct {
|
||||
Admin uint64
|
||||
Guildname string
|
||||
Guild string
|
||||
Admin uint64
|
||||
Guildname string
|
||||
Guild string
|
||||
}
|
||||
}
|
||||
|
||||
var (
|
||||
config = flag.String("config", "chirpnest.cfg", "config file path")
|
||||
initdb = flag.Bool("initdb", false, "initialize bot database")
|
||||
config = flag.String("config", "chirpnest.cfg", "config file path")
|
||||
initdb = flag.Bool("initdb", false, "initialize bot database")
|
||||
|
||||
db *sql.DB
|
||||
db *sql.DB
|
||||
|
||||
cfg Config
|
||||
cfg Config
|
||||
)
|
||||
|
||||
func PrintText(m *tb.Message) {
|
||||
@ -55,7 +55,7 @@ func main() {
|
||||
log.Println("Starting Chirpnest...")
|
||||
|
||||
// Parsing config
|
||||
flag.Parse()
|
||||
flag.Parse()
|
||||
|
||||
err := gcfg.ReadFileInto(&cfg, *config)
|
||||
if err != nil {
|
||||
@ -64,12 +64,12 @@ func main() {
|
||||
|
||||
// Connecting to DB
|
||||
switch cfg.SQL.Driver {
|
||||
case "mysql":
|
||||
db, err = sql.Open("mysql",cfg.SQL.Username + ":" + cfg.SQL.Password + "@" + cfg.SQL.Type + "(" + cfg.SQL.Address + ")/" + cfg.SQL.Database)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
defer db.Close()
|
||||
case "mysql":
|
||||
db, err = sql.Open("mysql", cfg.SQL.Username+":"+cfg.SQL.Password+"@"+cfg.SQL.Type+"("+cfg.SQL.Address+")/"+cfg.SQL.Database)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
defer db.Close()
|
||||
|
||||
}
|
||||
|
||||
@ -81,17 +81,17 @@ func main() {
|
||||
log.Println("SQL connection initialized")
|
||||
}
|
||||
|
||||
if (*initdb) {
|
||||
if *initdb {
|
||||
initDB()
|
||||
}
|
||||
|
||||
go StartBot()
|
||||
|
||||
fmt.Println("Started !")
|
||||
fmt.Println("Started !")
|
||||
|
||||
// Main loop
|
||||
for {
|
||||
time.Sleep(1 * time.Second)
|
||||
}
|
||||
// Main loop
|
||||
for {
|
||||
time.Sleep(1 * time.Second)
|
||||
}
|
||||
|
||||
}
|
49
mq.go
Normal file
49
mq.go
Normal file
@ -0,0 +1,49 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"log"
|
||||
|
||||
"github.com/streadway/amqp"
|
||||
)
|
||||
|
||||
func MQMainReceive() {
|
||||
conn, err := amqp.Dial("amqp://shoopea:UmDd5g4WRa2MzqOHsG2T@localhost:5672/chatwars")
|
||||
failOnError(err, "MQMainReceive : Failed to connect to RabbitMQ")
|
||||
defer conn.Close()
|
||||
|
||||
ch, err := conn.Channel()
|
||||
failOnError(err, "MQMainReceive : Failed to open a channel")
|
||||
defer ch.Close()
|
||||
|
||||
q, err := ch.QueueDeclare(
|
||||
"msg", // name
|
||||
false, // durable
|
||||
false, // delete when unused
|
||||
false, // exclusive
|
||||
false, // no-wait
|
||||
nil, // arguments
|
||||
)
|
||||
failOnError(err, "MQMainReceive : Failed to declare a queue")
|
||||
|
||||
msgs, err := ch.Consume(
|
||||
q.Name, // queue
|
||||
"", // consumer
|
||||
true, // auto-ack
|
||||
false, // exclusive
|
||||
false, // no-local
|
||||
false, // no-wait
|
||||
nil, // args
|
||||
)
|
||||
failOnError(err, "MQMainReceive : Failed to register a consumer")
|
||||
|
||||
forever := make(chan bool)
|
||||
|
||||
go func() {
|
||||
for d := range msgs {
|
||||
log.Printf("MQMainReceive : Received a message: %s", d.Body)
|
||||
}
|
||||
}()
|
||||
|
||||
<-forever
|
||||
|
||||
}
|
7
sql.go
7
sql.go
@ -2,10 +2,8 @@ package main
|
||||
|
||||
import (
|
||||
"log"
|
||||
|
||||
)
|
||||
|
||||
|
||||
func initDB() {
|
||||
log.Println("Setting up database...")
|
||||
|
||||
@ -52,7 +50,7 @@ func initDB() {
|
||||
}
|
||||
|
||||
log.Println("Database cleaned up")
|
||||
_, err = db.Exec( `CREATE TABLE user (
|
||||
_, err = db.Exec(`CREATE TABLE user (
|
||||
id BIGINT UNSIGNED NOT NULL,
|
||||
user_id VARCHAR(32) NOT NULL,
|
||||
name VARCHAR(80) NOT NULL,
|
||||
@ -66,7 +64,7 @@ func initDB() {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
_, err = db.Exec( `CREATE TABLE msg (
|
||||
_, err = db.Exec(`CREATE TABLE msg (
|
||||
id BIGINT UNSIGNED NOT NULL,
|
||||
user_id BIGINT UNSIGNED NOT NULL,
|
||||
direction ENUM('incoming', 'outgoing'),
|
||||
@ -79,4 +77,3 @@ func initDB() {
|
||||
|
||||
log.Println("Database set up")
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user