Skip to content

Commit

Permalink
Merge branch 'develop'
Browse files Browse the repository at this point in the history
  • Loading branch information
thebaer committed May 11, 2015
2 parents af5d662 + a542b7d commit b23ff44
Showing 1 changed file with 77 additions and 2 deletions.
79 changes: 77 additions & 2 deletions writeas/cli.go
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ func main() {
Flags: []cli.Flag{
cli.BoolFlag{
Name: "tor, t",
Usage: "Post to Tor hidden service",
Usage: "Post via Tor hidden service",
},
cli.IntFlag{
Name: "tor-port",
Expand All @@ -72,7 +72,23 @@ func main() {
Flags: []cli.Flag{
cli.BoolFlag{
Name: "tor, t",
Usage: "Delete from Tor hidden service",
Usage: "Delete via Tor hidden service",
},
cli.IntFlag{
Name: "tor-port",
Usage: "Use a different port to connect to Tor",
Value: 9150,
},
},
},
{
Name: "update",
Usage: "Update (overwrite) a post",
Action: cmdUpdate,
Flags: []cli.Flag{
cli.BoolFlag{
Name: "tor, t",
Usage: "Update via Tor hidden service",
},
cli.IntFlag{
Name: "tor-port",
Expand Down Expand Up @@ -207,6 +223,35 @@ func cmdDelete(c *cli.Context) {
DoDelete(friendlyId, token, tor)
}

func cmdUpdate(c *cli.Context) {
friendlyId := c.Args().Get(0)
token := c.Args().Get(1)
if friendlyId == "" {
fmt.Println("usage: writeas update <postId> [<token>]")
os.Exit(1)
}

if token == "" {
// Search for the token locally
token = tokenFromID(friendlyId)
if token == "" {
fmt.Println("Couldn't find an edit token locally. Did you create this post here?")
fmt.Printf("If you have an edit token, use: writeas update %s <token>\n", friendlyId)
os.Exit(1)
}
}

// Read post body
fullPost := readStdIn()

tor := c.Bool("tor") || c.Bool("t")
if c.Int("tor-port") != 0 {
torPort = c.Int("tor-port")
}

DoUpdate(fullPost, friendlyId, token, tor)
}

func cmdGet(c *cli.Context) {
friendlyId := c.Args().Get(0)
if friendlyId == "" {
Expand Down Expand Up @@ -310,6 +355,7 @@ func DoPost(post []byte, encrypt, tor bool) {
if encrypt {
data.Add("e", "")
}
data.Add("font", "mono")

urlStr, client := client(false, tor, "", "")

Expand Down Expand Up @@ -339,6 +385,35 @@ func DoPost(post []byte, encrypt, tor bool) {
}
}

func DoUpdate(post []byte, friendlyId, token string, tor bool) {
urlStr, client := client(false, tor, "", fmt.Sprintf("id=%s&t=%s", friendlyId, token))

data := url.Values{}
data.Set("w", string(post))

r, _ := http.NewRequest("POST", urlStr, bytes.NewBufferString(data.Encode()))
r.Header.Add("Content-Type", "application/x-www-form-urlencoded")
r.Header.Add("Content-Length", strconv.Itoa(len(data.Encode())))

resp, err := client.Do(r)
check(err)
defer resp.Body.Close()

if resp.StatusCode == http.StatusOK {
if tor {
fmt.Println("Post updated via hidden service.")
} else {
fmt.Println("Post updated.")
}
} else {
if DEBUG {
fmt.Printf("Problem updating: %s\n", resp.Status)
} else {
fmt.Printf("Post doesn't exist, or bad edit token given.\n")
}
}
}

func DoDelete(friendlyId, token string, tor bool) {
urlStr, client := client(false, tor, "", fmt.Sprintf("id=%s&t=%s", friendlyId, token))

Expand Down

0 comments on commit b23ff44

Please sign in to comment.