musala/cmd/trello2mail/trello.go

237 lines
4.4 KiB
Go

package main
import "github.com/davecgh/go-spew/spew"
import (
"bytes"
"fmt"
// "github.com/adlio/trello"
trello "github.com/glenux/contrib-trello"
"github.com/russross/blackfriday/v2"
"log"
"net/url"
"os"
"os/exec"
"path"
"strings"
"text/template"
)
type TrelloCtx struct {
Token string
ApiKey string
Client *trello.Client
}
type TrelloBoard struct {
Ctx *TrelloCtx
Ptr *trello.Board
Starred bool
Closed bool
Name string
}
func runcmd(command string) string {
shell := "/bin/sh"
flag := "-c"
out, err := exec.Command(shell, flag, command).Output()
if err != nil {
panic(err)
}
return string(out)
}
func MessageForApiKey() string {
/*
url := strings.Join([]string{
"https://trello.com/1/authorize?expiration=never",
"name=Trello-To-Mail",
"scope=read",
"response_type=token",
fmt.Sprintf("key=%s", apiKey),
}, "&")
*/
url := "https://trello.com/app-key/"
text := strings.Join([]string{
"Wrong or empty TRELLO_API_KEY value. Please visit:",
url,
"Then enable developper account.",
"When you have your user api key, set TRELLO_API_KEY=<your-api-key>",
}, "\n\n")
return text
}
func MessageForToken(apiKey string) string {
url := strings.Join([]string{
"https://trello.com/1/authorize?expiration=never",
"name=Trello-To-Mail",
"scope=read",
"response_type=token",
fmt.Sprintf("key=%s", apiKey),
}, "&")
text := strings.Join([]string{
"Wrong TRELLO_TOKEN value. Please visit:",
url,
"When you have your access token, set TRELLO_TOKEN=<your-token>",
}, "\n\n")
return text
}
func NewTrello(apiKey string, token string) *TrelloCtx {
if len(apiKey) == 0 {
fmt.Println(MessageForApiKey())
return nil
}
if len(token) == 0 {
fmt.Println(MessageForToken(apiKey))
return nil
}
ctx := TrelloCtx{}
ctx.ApiKey = apiKey
ctx.Token = token
client := trello.NewClient(apiKey, token)
ctx.Client = client
return &ctx
}
func (ctx *TrelloCtx) GetBoards() []TrelloBoard {
var result []TrelloBoard
token, err := ctx.Client.GetToken(ctx.Token, trello.Defaults())
if err != nil {
log.Panic(err)
}
member, err := ctx.Client.GetMember(token.IDMember, trello.Defaults())
if err != nil {
log.Panic(err)
}
boards, err := member.GetBoards(trello.Defaults())
if err != nil {
log.Panic(err)
}
for _, board := range boards {
result = append(result, TrelloBoard{
Ctx: ctx,
Starred: board.Starred,
Closed: board.Closed,
Ptr: board,
Name: board.Name,
})
}
return result
}
func (ctx *TrelloCtx) GetBoard(boardURL string) TrelloBoard {
parsedURL, err := url.Parse(boardURL)
if err != nil {
panic(err)
}
boardId := strings.Split(parsedURL.Path, "/")[2]
board, err := ctx.Client.GetBoard(boardId, trello.Defaults())
if err != nil {
log.Panic(err)
}
// fmt.Printf("%#v\n", board)
spew.Dump(board)
return TrelloBoard{
Ctx: ctx,
Starred: board.Starred,
Closed: board.Closed,
Ptr: board,
Name: board.Name,
}
}
type CardData struct {
Name string
URL string
}
type ListData struct {
Name string
Cards []CardData
}
type BoardData struct {
Name string
URL string
Lists []ListData
}
func (board *TrelloBoard) ExportData() BoardData {
var boardData = BoardData{
Name: board.Ptr.Name,
URL: board.Ptr.ShortURL,
Lists: make([]ListData, 0),
}
// get lists
lists, err := board.Ptr.GetLists(trello.Defaults())
if err != nil {
log.Panic(err)
}
// fill in reverse order
for listIdx := len(lists) - 1; listIdx >= 0; listIdx -= 1 {
list := lists[listIdx]
listData := ListData{
Name: list.Name,
Cards: make([]CardData, 0),
}
cards, err := list.GetCards(trello.Defaults())
if err != nil {
log.Panic(err)
}
for _, card := range cards {
cardData := CardData{
Name: card.Name,
URL: card.URL,
}
listData.Cards = append(listData.Cards, cardData)
}
boardData.Lists = append(boardData.Lists, listData)
}
return boardData
}
func (board *TrelloBoard) ExportToMarkdown() string {
var buf bytes.Buffer
data := board.ExportData()
wd, err := os.Getwd()
t, err := template.ParseFiles(path.Join(wd, "templates/markdown.tmpl"))
if err != nil {
log.Panic("Unable to parse template files")
}
if err := t.Execute(&buf, data); err != nil {
log.Panicf("Template execution: %s", err)
}
return buf.String()
}
func (board *TrelloBoard) ExportToHtml() string {
markdown := board.ExportToMarkdown()
html := blackfriday.Run([]byte(markdown))
return string(html)
}