working commit

This commit is contained in:
2026-02-02 14:08:38 +02:00
parent 8e9c270972
commit c973fccc86
3 changed files with 45 additions and 12 deletions
+3 -1
View File
@@ -7,6 +7,8 @@ import (
"mstore/app/router" "mstore/app/router"
) )
const zeroContentLength = "0"
func (hand *Handler) FileExists(rctx *router.Context) { func (hand *Handler) FileExists(rctx *router.Context) {
hand.logg.Debugf("Handle FileExists") hand.logg.Debugf("Handle FileExists")
@@ -25,7 +27,7 @@ func (hand *Handler) FileExists(rctx *router.Context) {
rctx.SetHeader("X-Content-Type", res.ContentType) rctx.SetHeader("X-Content-Type", res.ContentType)
rctx.SetHeader("X-Content-Length", res.ContentLength) rctx.SetHeader("X-Content-Length", res.ContentLength)
rctx.SetHeader("X-Content-Digest", res.ContentDigest) rctx.SetHeader("X-Content-Digest", res.ContentDigest)
rctx.SetHeader("Content-Length", "0") rctx.SetHeader("Content-Length", zeroContentLength)
rctx.SetStatus(code) rctx.SetStatus(code)
} }
+25 -11
View File
@@ -81,16 +81,17 @@ func (cli *Client) FileExists(ctx context.Context, ref string) (bool, error) {
return res, err return res, err
} }
func (cli *Client) GetFile(ctx context.Context, ref, filename string) error { func (cli *Client) GetFile(ctx context.Context, ref, filename string) (int64, error) {
var err error var err error
var size int64
ref, err = convertFileLink(ref) ref, err = convertFileLink(ref)
if err != nil { if err != nil {
return err return size, err
} }
req, err := http.NewRequestWithContext(ctx, http.MethodGet, ref, nil) req, err := http.NewRequestWithContext(ctx, http.MethodGet, ref, nil)
if err != nil { if err != nil {
return err return size, err
} }
transport := &http.Transport{ transport := &http.Transport{
TLSClientConfig: &tls.Config{ TLSClientConfig: &tls.Config{
@@ -102,29 +103,42 @@ func (cli *Client) GetFile(ctx context.Context, ref, filename string) error {
} }
resp, err := client.Do(req) resp, err := client.Do(req)
if err != nil { if err != nil {
return err return size, err
} }
defer resp.Body.Close() defer resp.Body.Close()
contentLength := resp.Header.Get("Content-Length")
if contentLength == "" {
err = fmt.Errorf("Empty Content-Length received")
return size, err
}
if resp.StatusCode != http.StatusOK { if resp.StatusCode != http.StatusOK {
err := fmt.Errorf("Received wrong status code: %s", resp.Status) err := fmt.Errorf("Received wrong status code: %s", resp.Status)
return err return size, err
}
declSize, err := strconv.ParseInt(contentLength, 10, 64)
if err != nil {
err = fmt.Errorf("Wrong Content-Length value: %v", err)
return size, err
} }
dirname := filepath.Dir(filename) dirname := filepath.Dir(filename)
err = os.MkdirAll(dirname, 0750) err = os.MkdirAll(dirname, 0750)
if err != nil { if err != nil {
return err return size, err
} }
file, err := os.OpenFile(filename, os.O_WRONLY|os.O_CREATE, 0640) file, err := os.OpenFile(filename, os.O_WRONLY|os.O_CREATE, 0640)
if err != nil { if err != nil {
return err return size, err
} }
_, err = io.Copy(file, resp.Body) size, err = io.Copy(file, resp.Body)
if err != nil { if err != nil {
return err return size, err
} }
return err if size != declSize {
err := fmt.Errorf("Mismatch Content-Length and recorded filesize")
return size, err
}
return size, err
} }
func (cli *Client) PutFile(ctx context.Context, filename, ref string) error { func (cli *Client) PutFile(ctx context.Context, filename, ref string) error {
+17
View File
@@ -57,6 +57,7 @@ func TestService(t *testing.T) {
time.Sleep(1 * time.Second) time.Sleep(1 * time.Second)
} }
{ {
// ServiceHello
fmt.Printf("=== ServiceHello ===\n") fmt.Printf("=== ServiceHello ===\n")
cli := NewClient() cli := NewClient()
ctx := context.Background() ctx := context.Background()
@@ -67,6 +68,7 @@ func TestService(t *testing.T) {
require.True(t, helloRes) require.True(t, helloRes)
} }
{ {
// PutFile
tmpdir := t.TempDir() tmpdir := t.TempDir()
tmpfile := filepath.Join(tmpdir, "foo.bin") tmpfile := filepath.Join(tmpdir, "foo.bin")
@@ -86,4 +88,19 @@ func TestService(t *testing.T) {
require.NoError(t, err) require.NoError(t, err)
} }
{
// GetFile
fmt.Printf("=== GetFil ===\n")
cli := NewClient()
ctx := context.Background()
ctx, _ = context.WithTimeout(ctx, 1*time.Second)
tmpdir := t.TempDir()
tmpfile := filepath.Join(tmpdir, "foo.bin")
_, err = cli.GetFile(ctx, srvaddr+"/foo.bin", tmpfile)
require.NoError(t, err)
}
} }