forked from mymmrac/telego
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdoc.go
97 lines (71 loc) · 2.71 KB
/
doc.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/*
Package telego provides one-to-one Telegram Bot API method & types.
Telego features all methods and types described in official Telegram documentation (https://core.telegram.org/bots/api).
It achieves this by generating methods and types from docs (generation is in internal/generator package).
The main goal was and is to create a one-to-one library, so that if you know how Telegram bots work, you will
immediately know how to implement that in Go using Telego.
# One-to-one implementation
All types named and contain the same information as documented by Telegram, for methods it's exactly the same.
However, some minor differences may be present (like use of interfaces or combined types).
Also, all generated codes have the same description as in Telegram docs, so there is actually no need to go to docs (but
still, be careful as it is not a full copy of docs due to text only limitation).
Telego was also created to simplify work with a Telegram API, so some additional methods for more convenient usage
located in long_polling.go and webhook.go and telegoutil package.
When you are working with things like chat ID which can be an integer or string Telego provides combined types:
type ChatID struct {
ID int64
Username string
}
or input files that can be URL, file ID or actual file data:
type InputFile struct {
File telegoapi.NamedReader
FileID string
URL string
}
you will specify only one of the fields and Telego will figure out what to do with that.
For more flexibility, file data for InputFile are provided via simple interface:
type NamedReader interface {
io.Reader
Name() string
}
os.File already implements this interface, so you can use it directly.
# Example
Most of the examples can be seen in examples folder.
Simple echo bot:
package main
import (
"fmt"
"os"
"github.com/mymmrac/telego"
tu "github.com/mymmrac/telego/telegoutil"
)
func main() {
botToken := os.Getenv("TOKEN")
// Create Bot with debug on
bot, err := telego.NewBot(botToken, telego.WithDefaultDebugLogger())
if err != nil {
fmt.Println(err)
return
}
// Get updates channel
updates, _ := bot.UpdatesViaLongPolling(nil)
// Stop reviving updates from updates channel
defer bot.StopLongPolling()
// Loop through all updates when they came
for update := range updates {
// Check if update contains message
if update.Message != nil {
// Get chat ID from message
chatID := tu.ID(update.Message.Chat.ID)
// Copy sent message back to user
_, _ = bot.CopyMessage(&telego.CopyMessageParams{
ChatID: chatID,
FromChatID: chatID,
MessageID: update.Message.MessageID,
})
}
}
}
This bot will send the same messages as you sent to him.
*/
package telego