1
0
Fork 0
mirror of https://github.com/vbatts/imgsrv.git synced 2024-11-27 10:35:41 +00:00

client upload works again

This commit is contained in:
Vincent Batts 2013-10-10 10:31:27 -04:00
parent 96a4b57924
commit adbdffbfb4
3 changed files with 27 additions and 29 deletions

View file

@ -1,17 +1,18 @@
package client package client
import ( import (
"io/ioutil"
"net/http"
"net/url"
"log"
"os"
"mime/multipart"
"bytes" "bytes"
"path" "errors"
"io" "io"
"io/ioutil"
"mime/multipart"
"net/http"
"os"
"path"
) )
var ErrorNotOK = errors.New("HTTP Response was not 200 OK")
func NewfileUploadRequest(uri, file_path string, params map[string]string) (*http.Request, error) { func NewfileUploadRequest(uri, file_path string, params map[string]string) (*http.Request, error) {
file, err := os.Open(file_path) file, err := os.Open(file_path)
if err != nil { if err != nil {
@ -30,13 +31,13 @@ func NewfileUploadRequest(uri, file_path string, params map[string]string) (*htt
for key, val := range params { for key, val := range params {
_ = writer.WriteField(key, val) _ = writer.WriteField(key, val)
} }
_ = writer.WriteField("returnUrl", "true")
contentType := writer.FormDataContentType() contentType := writer.FormDataContentType()
err = writer.Close() err = writer.Close()
if err != nil { if err != nil {
return nil, err return nil, err
} }
log.Println(uri)
req, err := http.NewRequest("POST", uri, body) req, err := http.NewRequest("POST", uri, body)
req.Header.Add("Content-Type", contentType) req.Header.Add("Content-Type", contentType)
return req, err return req, err
@ -53,23 +54,14 @@ func PutFileFromPath(uri, file_path string, params map[string]string) (path stri
if err != nil { if err != nil {
return "", err return "", err
} }
log.Printf("%#v",resp)
defer resp.Body.Close() defer resp.Body.Close()
bytes, err := ioutil.ReadAll(resp.Body) bytes, err := ioutil.ReadAll(resp.Body)
if err != nil { if err != nil {
return "", err return "", err
} }
return string(bytes), nil if resp.StatusCode != 200 {
return string(bytes), ErrorNotOK
} }
func hurr() { return string(bytes), nil
values := make(url.Values)
values.Set("email", "anything@email.com")
values.Set("name", "bob")
values.Set("count", "1")
r, err := http.PostForm("http://example.com/form", values)
if err != nil {
return
}
_ = r
} }

View file

@ -89,13 +89,12 @@ func main() {
log.Println(err) log.Println(err)
return return
} }
//log.Printf("POSTing: %s\n", url.String())
url_path, err := client.PutFileFromPath(url.String(), PutFile, params) url_path, err := client.PutFileFromPath(url.String(), PutFile, params)
if err != nil { if err != nil {
log.Println(err) log.Println(err)
return return
} }
log.Printf("uploaded: %s%s\n", DefaultConfig.RemoteHost, url_path) fmt.Printf("%s%s\n", DefaultConfig.RemoteHost, url_path)
} }
} }

View file

@ -729,12 +729,15 @@ func routeUpload(w http.ResponseWriter, r *http.Request) {
return return
} }
useRandName := false useRandName := false
returnUrl := false
log.Printf("%q", r.MultipartForm.Value) log.Printf("%q", r.MultipartForm.Value)
for k, v := range r.MultipartForm.Value { for k, v := range r.MultipartForm.Value {
if k == "keywords" { if k == "keywords" {
info.Keywords = append(info.Keywords, strings.Split(v[0], ",")...) info.Keywords = append(info.Keywords, strings.Split(v[0], ",")...)
} else if k == "rand" { } else if k == "rand" {
useRandName = true useRandName = true
} else if k == "returnUrl" {
returnUrl = true
} else { } else {
log.Printf("WARN: not sure what to do with param [%s = %s]", k, v) log.Printf("WARN: not sure what to do with param [%s = %s]", k, v)
} }
@ -781,6 +784,10 @@ func routeUpload(w http.ResponseWriter, r *http.Request) {
n) n)
} }
if returnUrl {
fmt.Fprintf(w, "/v/%s", filename)
return
}
http.Redirect(w, r, fmt.Sprintf("/v/%s", filename), 302) http.Redirect(w, r, fmt.Sprintf("/v/%s", filename), 302)
} else { } else {
httplog.LogRequest(r, 404) httplog.LogRequest(r, 404)