[lxc-devel] [lxd/master] Stream multi-part file responses

stgraber on Github lxc-bot at linuxcontainers.org
Thu Jun 25 21:04:08 UTC 2020


A non-text attachment was scrubbed...
Name: not available
Type: text/x-mailbox
Size: 491 bytes
Desc: not available
URL: <http://lists.linuxcontainers.org/pipermail/lxc-devel/attachments/20200625/67dc2687/attachment.bin>
-------------- next part --------------
From f895b0c937a27d27ac82cfd34492f4b0d0b09054 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?St=C3=A9phane=20Graber?= <stgraber at ubuntu.com>
Date: Thu, 25 Jun 2020 17:02:39 -0400
Subject: [PATCH 1/2] client: Handle unknown image sizes
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

Signed-off-by: Stéphane Graber <stgraber at ubuntu.com>
---
 client/lxd_images.go | 18 ++++++++++++++----
 1 file changed, 14 insertions(+), 4 deletions(-)

diff --git a/client/lxd_images.go b/client/lxd_images.go
index 0203b0ebbf..1d1932dcc3 100644
--- a/client/lxd_images.go
+++ b/client/lxd_images.go
@@ -180,15 +180,25 @@ func lxdDownloadImage(fingerprint string, uri string, userAgent string, client *
 	// Handle the data
 	body := response.Body
 	if req.ProgressHandler != nil {
-		body = &ioprogress.ProgressReader{
+		reader := &ioprogress.ProgressReader{
 			ReadCloser: response.Body,
 			Tracker: &ioprogress.ProgressTracker{
 				Length: response.ContentLength,
-				Handler: func(percent int64, speed int64) {
-					req.ProgressHandler(ioprogress.ProgressData{Text: fmt.Sprintf("%d%% (%s/s)", percent, units.GetByteSizeString(speed, 2))})
-				},
 			},
 		}
+
+		if response.ContentLength > 0 {
+			reader.Tracker.Handler = func(percent int64, speed int64) {
+				req.ProgressHandler(ioprogress.ProgressData{Text: fmt.Sprintf("%d%% (%s/s)", percent, units.GetByteSizeString(speed, 2))})
+			}
+		} else {
+			reader.Tracker.Handler = func(received int64, speed int64) {
+				req.ProgressHandler(ioprogress.ProgressData{Text: fmt.Sprintf("%s (%s/s)", units.GetByteSizeString(received, 2), units.GetByteSizeString(speed, 2))})
+
+			}
+		}
+
+		body = reader
 	}
 
 	// Hashing

From 6575b2dd9b9ec386b1ab12943fee513870f9dffe Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?St=C3=A9phane=20Graber?= <stgraber at ubuntu.com>
Date: Thu, 25 Jun 2020 17:02:59 -0400
Subject: [PATCH 2/2] lxd/response: Stream multi-part responses
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

Signed-off-by: Stéphane Graber <stgraber at ubuntu.com>
---
 lxd/response/response.go | 16 +++++++---------
 1 file changed, 7 insertions(+), 9 deletions(-)

diff --git a/lxd/response/response.go b/lxd/response/response.go
index 5270c489f3..302c4eae09 100644
--- a/lxd/response/response.go
+++ b/lxd/response/response.go
@@ -301,9 +301,12 @@ func (r *fileResponse) Render(w http.ResponseWriter) error {
 		return nil
 	}
 
-	// Now the complex multipart answer
-	body := &bytes.Buffer{}
-	mw := multipart.NewWriter(body)
+	// Now the complex multipart answer.
+	mw := multipart.NewWriter(w)
+	defer mw.Close()
+
+	w.Header().Set("Content-Type", mw.FormDataContentType())
+	w.Header().Set("Transfer-Encoding", "chunked")
 
 	for _, entry := range r.files {
 		var rd io.Reader
@@ -329,13 +332,8 @@ func (r *fileResponse) Render(w http.ResponseWriter) error {
 			return err
 		}
 	}
-	mw.Close()
-
-	w.Header().Set("Content-Type", mw.FormDataContentType())
-	w.Header().Set("Content-Length", fmt.Sprintf("%d", body.Len()))
 
-	_, err := io.Copy(w, body)
-	return err
+	return nil
 }
 
 func (r *fileResponse) String() string {


More information about the lxc-devel mailing list