add the toys collection
This commit is contained in:
parent
12d6e57d73
commit
cc15ab0675
|
@ -0,0 +1,8 @@
|
||||||
|
|
||||||
|
all: gettoken saytheday
|
||||||
|
|
||||||
|
gettoken: gettoken.go
|
||||||
|
go build gettoken.go
|
||||||
|
|
||||||
|
saytheday: saytheday.go
|
||||||
|
go build saytheday.go
|
|
@ -0,0 +1,3 @@
|
||||||
|
These are all standalone programs, meant to be compiled individually.
|
||||||
|
|
||||||
|
A little of this, a little of that.
|
|
@ -0,0 +1,53 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"flag"
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
server := ""
|
||||||
|
username := ""
|
||||||
|
password := ""
|
||||||
|
|
||||||
|
flag.StringVar(&server, "server", server, "server to connnect")
|
||||||
|
flag.StringVar(&username, "username", username, "username to use")
|
||||||
|
flag.StringVar(&password, "password", password, "password to use")
|
||||||
|
flag.Parse()
|
||||||
|
|
||||||
|
if server == "" || username == "" || password == "" {
|
||||||
|
flag.Usage()
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
form := make(url.Values)
|
||||||
|
form.Add("username", username)
|
||||||
|
form.Add("password", password)
|
||||||
|
form.Add("gettoken", "1")
|
||||||
|
loginurl := fmt.Sprintf("https://%s/dologin", server)
|
||||||
|
req, err := http.NewRequest("POST", loginurl, 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)
|
||||||
|
}
|
||||||
|
fmt.Println(string(answer))
|
||||||
|
}
|
|
@ -0,0 +1,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)
|
||||||
|
}
|
Loading…
Reference in New Issue