From 6e4ade909d9b3a0a4a8dd8c11a4b1984b84f09e4 Mon Sep 17 00:00:00 2001 From: Alexander Kiryukhin Date: Thu, 5 Sep 2019 22:43:32 +0300 Subject: Fully refactored high level API --- uploads.go | 154 +++++++++++++++++++++++-------------------------------------- 1 file changed, 58 insertions(+), 96 deletions(-) (limited to 'uploads.go') diff --git a/uploads.go b/uploads.go index b6f30dc..51b5a40 100644 --- a/uploads.go +++ b/uploads.go @@ -9,7 +9,8 @@ import ( "net/http" "net/url" "os" - "path" + + "github.com/neonxp/tamtam/schemes" ) type uploads struct { @@ -20,145 +21,106 @@ func newUploads(client *client) *uploads { return &uploads{client: client} } -//GetUploadURL returns url to upload files -func (a *uploads) GetUploadURL(uploadType UploadType) (*UploadEndpoint, error) { - result := new(UploadEndpoint) - values := url.Values{} - values.Set("type", string(uploadType)) - body, err := a.client.request(http.MethodPost, "uploads", values, nil) - if err != nil { - return result, err - } - defer func() { - if err := body.Close(); err != nil { - log.Println(err) - } - }() - return result, json.NewDecoder(body).Decode(result) -} - //UploadMedia uploads file to TamTam server -func (a *uploads) UploadMedia(endpoint *UploadEndpoint, filename string) (*UploadedInfo, error) { - bodyBuf := &bytes.Buffer{} - bodyWriter := multipart.NewWriter(bodyBuf) - - fileWriter, err := bodyWriter.CreateFormFile("data", filename) - if err != nil { - return nil, err - } - +func (a *uploads) UploadMediaFromFile(uploadType schemes.UploadType, filename string) (*schemes.UploadedInfo, error) { fh, err := os.Open(filename) if err != nil { return nil, err } - defer func() { - if err := fh.Close(); err != nil { - log.Println(err) - } - }() - _, err = io.Copy(fileWriter, fh) - if err != nil { - return nil, err - } - - if err := bodyWriter.Close(); err != nil { - return nil, err - } - contentType := bodyWriter.FormDataContentType() - resp, err := http.Post(endpoint.Url, contentType, bodyBuf) - if err != nil { - return nil, err - } - defer func() { - if err := resp.Body.Close(); err != nil { - log.Println(err) - } - }() - result := new(UploadedInfo) - return result, json.NewDecoder(resp.Body).Decode(result) + defer fh.Close() + return a.UploadMediaFromReader(uploadType, fh) } //UploadMediaFromUrl uploads file from remote server to TamTam server -func (a *uploads) UploadMediaFromUrl(endpoint *UploadEndpoint, u url.URL) (*UploadedInfo, error) { +func (a *uploads) UploadMediaFromUrl(uploadType schemes.UploadType, u url.URL) (*schemes.UploadedInfo, error) { respFile, err := http.Get(u.String()) if err != nil { return nil, err } defer respFile.Body.Close() - bodyBuf := &bytes.Buffer{} - bodyWriter := multipart.NewWriter(bodyBuf) - fileWriter, err := bodyWriter.CreateFormFile("data", path.Base(u.Path)) + return a.UploadMediaFromReader(uploadType, respFile.Body) +} + +func (a *uploads) UploadMediaFromReader(uploadType schemes.UploadType, reader io.Reader) (*schemes.UploadedInfo, error) { + result := new(schemes.UploadedInfo) + return result, a.uploadMediaFromReader(uploadType, reader, result) +} + +//UploadPhotoFromFile uploads photos to TamTam server +func (a *uploads) UploadPhotoFromFile(filename string) (*schemes.PhotoTokens, error) { + fh, err := os.Open(filename) if err != nil { return nil, err } - _, err = io.Copy(fileWriter, respFile.Body) + defer fh.Close() + result := new(schemes.PhotoTokens) + return result, a.uploadMediaFromReader(schemes.PHOTO, fh, result) +} + +//UploadPhotoFromUrl uploads photo from remote server to TamTam server +func (a *uploads) UploadPhotoFromUrl(u url.URL) (*schemes.PhotoTokens, error) { + respFile, err := http.Get(u.String()) if err != nil { return nil, err } + defer respFile.Body.Close() + result := new(schemes.PhotoTokens) + return result, a.uploadMediaFromReader(schemes.PHOTO, respFile.Body, result) +} - if err := bodyWriter.Close(); err != nil { - return nil, err - } - contentType := bodyWriter.FormDataContentType() - if err := bodyWriter.Close(); err != nil { - return nil, err - } - resp, err := http.Post(endpoint.Url, contentType, bodyBuf) +//UploadPhotoFromReader uploads photo from reader +func (a *uploads) UploadPhotoFromReader(reader io.Reader) (*schemes.PhotoTokens, error) { + result := new(schemes.PhotoTokens) + return result, a.uploadMediaFromReader(schemes.PHOTO, reader, result) +} + +func (a *uploads) getUploadURL(uploadType schemes.UploadType) (*schemes.UploadEndpoint, error) { + result := new(schemes.UploadEndpoint) + values := url.Values{} + values.Set("type", string(uploadType)) + body, err := a.client.request(http.MethodPost, "uploads", values, nil) if err != nil { - return nil, err + return result, err } defer func() { - if err := resp.Body.Close(); err != nil { + if err := body.Close(); err != nil { log.Println(err) } }() - result := new(UploadedInfo) - return result, json.NewDecoder(resp.Body).Decode(result) + return result, json.NewDecoder(body).Decode(result) } -//UploadPhoto uploads photos to TamTam server -func (a *uploads) UploadPhoto(filename string) (*PhotoTokens, error) { - bodyBuf := &bytes.Buffer{} - bodyWriter := multipart.NewWriter(bodyBuf) - - fileWriter, err := bodyWriter.CreateFormFile("data", filename) +func (a *uploads) uploadMediaFromReader(uploadType schemes.UploadType, reader io.Reader, result interface{}) error { + endpoint, err := a.getUploadURL(uploadType) if err != nil { - return nil, err + return err } - - fh, err := os.Open(filename) + bodyBuf := &bytes.Buffer{} + bodyWriter := multipart.NewWriter(bodyBuf) + fileWriter, err := bodyWriter.CreateFormFile("data", "file") if err != nil { - return nil, err + return err } - defer func() { - if err := fh.Close(); err != nil { - log.Println(err) - } - }() - _, err = io.Copy(fileWriter, fh) + _, err = io.Copy(fileWriter, reader) if err != nil { - return nil, err + return err } if err := bodyWriter.Close(); err != nil { - return nil, err - } - - endpoint, err := a.GetUploadURL(PHOTO) - if err != nil { - return nil, err + return err } contentType := bodyWriter.FormDataContentType() - + if err := bodyWriter.Close(); err != nil { + return err + } resp, err := http.Post(endpoint.Url, contentType, bodyBuf) if err != nil { - return nil, err + return err } defer func() { if err := resp.Body.Close(); err != nil { log.Println(err) } }() - result := new(PhotoTokens) - return result, json.NewDecoder(resp.Body).Decode(result) + return json.NewDecoder(resp.Body).Decode(result) } -- cgit v1.2.3