working commit
This commit is contained in:
+3
-1
@@ -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
@@ -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 {
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user