all repos — honk @ master

my fork of honk

toys/saytheday.go (view raw)

 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
package main

import (
	"flag"
	"fmt"
	"io/ioutil"
	"log"
	"net/http"
	"net/url"
	"os"
	"strings"
	"time"
)

func lookandsay(n int) string {
	s := "1"

	numbers := []string{"0", "1", "2", "3", "4", "5", "6", "7", "8", "9"}
	var buf strings.Builder
	for i := 2; i <= n; i++ {
		count := 1
		prev := s[0]
		for j := 1; j < len(s); j++ {
			d := s[j]
			if d == prev {
				count++
			} else {
				buf.WriteString(numbers[count])
				buf.WriteByte(prev)
				count = 1
				prev = d
			}
		}
		buf.WriteString(numbers[count])
		buf.WriteByte(prev)
		s = buf.String()
		buf.Reset()
	}
	return s
}

func honkahonk(server, token, noise string) {
	form := make(url.Values)
	form.Add("token", token)
	form.Add("action", "honk")
	form.Add("noise", noise)
	apiurl := fmt.Sprintf("https://%s/api", server)
	req, err := http.NewRequest("POST", apiurl, strings.NewReader(form.Encode()))
	if err != nil {
		log.Fatal(err)
	}
	req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
	resp, err := http.DefaultClient.Do(req)
	if err != nil {
		log.Fatal(err)
	}
	defer resp.Body.Close()
	answer, err := ioutil.ReadAll(resp.Body)
	if err != nil {
		log.Fatal(err)
	}
	if resp.StatusCode != 200 {
		log.Fatalf("status: %d: %s", resp.StatusCode, answer)
	}
}

func main() {
	server := ""
	token := ""
	flag.StringVar(&server, "server", server, "server to connnect")
	flag.StringVar(&token, "token", token, "auth token to use")
	flag.Parse()

	if server == "" || token == "" {
		flag.Usage()
		os.Exit(1)
	}

	day := time.Now().Day()
	say := lookandsay(day)

	honkahonk(server, token, say)
}