Todos los métodos se explican bastante por sí mismos, y leer la página de Godoc debería explicar todo. Si algo no está claro, abra un problema o envíe una solicitud de extracción.
Hay más tutoriales e información de alto nivel en el sitio web, Go-Telegram-Bot-api.dev.
El alcance de este proyecto es solo proporcionar un envoltorio alrededor de la API sin ninguna característica adicional. Hay otros proyectos para crear algo con complementos y manejadores de comandos sin tener que diseñar todo eso usted mismo.
Únase al grupo de desarrollo si desea hacer preguntas o discutir el desarrollo.
Primero, asegúrese de que la biblioteca esté instalada y actualizada ejecutándose go get -u github.com/go-telegram-bot-api/telegram-bot-api/v5
Este es un bot muy simple que solo muestra cualquier actualización obtenida, luego la responde a ese chat.
package main
import (
"log"
tgbotapi "github.com/go-telegram-bot-api/telegram-bot-api/v5"
)
func main () {
bot , err := tgbotapi . NewBotAPI ( "MyAwesomeBotToken" )
if err != nil {
log . Panic ( err )
}
bot . Debug = true
log . Printf ( "Authorized on account %s" , bot . Self . UserName )
u := tgbotapi . NewUpdate ( 0 )
u . Timeout = 60
updates := bot . GetUpdatesChan ( u )
for update := range updates {
if update . Message != nil { // If we got a message
log . Printf ( "[%s] %s" , update . Message . From . UserName , update . Message . Text )
msg := tgbotapi . NewMessage ( update . Message . Chat . ID , update . Message . Text )
msg . ReplyToMessageID = update . Message . MessageID
bot . Send ( msg )
}
}
}Si necesita usar Webhooks (si desea ejecutar en Google App Engine), puede usar un método ligeramente diferente.
package main
import (
"log"
"net/http"
"github.com/go-telegram-bot-api/telegram-bot-api/v5"
)
func main () {
bot , err := tgbotapi . NewBotAPI ( "MyAwesomeBotToken" )
if err != nil {
log . Fatal ( err )
}
bot . Debug = true
log . Printf ( "Authorized on account %s" , bot . Self . UserName )
wh , _ := tgbotapi . NewWebhookWithCert ( "https://www.example.com:8443/" + bot . Token , "cert.pem" )
_ , err = bot . Request ( wh )
if err != nil {
log . Fatal ( err )
}
info , err := bot . GetWebhookInfo ()
if err != nil {
log . Fatal ( err )
}
if info . LastErrorDate != 0 {
log . Printf ( "Telegram callback failed: %s" , info . LastErrorMessage )
}
updates := bot . ListenForWebhook ( "/" + bot . Token )
go http . ListenAndServeTLS ( "0.0.0.0:8443" , "cert.pem" , "key.pem" , nil )
for update := range updates {
log . Printf ( "%+v n " , update )
}
}Si lo necesita, puede generar un certificado autofirmado, ya que esto requiere HTTPS / TLS. El ejemplo anterior le dice a Telegram que este es su certificado y que se debe confiar, a pesar de que no está firmado correctamente.
openssl req -x509 -newkey rsa:2048 -keyout key.pem -out cert.pem -days 3560 -subj "//O=OrgCN=Test" -nodes
Ahora que Let's Cintpt está disponible, es posible que desee generar su certificado TLS gratuito allí.