Golang bindings for the Telegram Bot API
Go to file
Jqs7 69bb4a9c33 update log message 2015-06-30 11:28:55 +08:00
LICENSE.txt add license 2015-06-26 21:53:55 -05:00
README.md fix import in example in README 2015-06-26 21:46:06 -05:00
bot.go fix all golint errors, add info about audio uploads 2015-06-26 01:53:20 -05:00
helpers.go fix all golint errors, add info about audio uploads 2015-06-26 01:53:20 -05:00
methods.go fix all golint errors, add info about audio uploads 2015-06-26 01:53:20 -05:00
types.go fix all golint errors, add info about audio uploads 2015-06-26 01:53:20 -05:00
updates.go update log message 2015-06-30 11:28:55 +08:00

README.md

Golang Telegram bindings for the Bot API

GoDoc

All methods have been added, and all features should be available. If you want a feature that hasn't been added yet or something is broken, open an issue and I'll see what I can do.

Example

This is a very simple bot that just displays any gotten updates, then replies it to that chat.

package main

import (
	"log"
	"github.com/Syfaro/telegram-bot-api"
)

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, err := bot.UpdatesChan(u)

	for update := range updates {
		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.SendMessage(msg)
	}
}