working commit

This commit is contained in:
2026-02-11 13:47:10 +02:00
parent 75bd5a952b
commit 2e3dbe8f7c
8 changed files with 101 additions and 25 deletions
+4 -1
View File
@@ -108,6 +108,9 @@ func (hand *Handler) DeleteFile(rctx *router.Context) {
func (hand *Handler) ListFiles(rctx *router.Context) { func (hand *Handler) ListFiles(rctx *router.Context) {
filepath, _ := rctx.GetSubpath("filepath") filepath, _ := rctx.GetSubpath("filepath")
if filepath == "" {
filepath = "/"
}
params := &operator.ListFilesParams{ params := &operator.ListFilesParams{
Filepath: filepath, Filepath: filepath,
} }
@@ -119,5 +122,5 @@ func (hand *Handler) ListFiles(rctx *router.Context) {
rctx.SetStatus(code) rctx.SetStatus(code)
return return
} }
rctx.SendJSON(code, res) rctx.SendJSON(code, res.Files)
} }
-3
View File
@@ -10,8 +10,6 @@
package handler package handler
import ( import (
"net/http"
"mstore/app/operator" "mstore/app/operator"
"mstore/app/router" "mstore/app/router"
) )
@@ -19,6 +17,5 @@ import (
func (hand *Handler) SendHello(rctx *router.Context) { func (hand *Handler) SendHello(rctx *router.Context) {
params := &operator.SendHelloParams{} params := &operator.SendHelloParams{}
res, _ := hand.oper.SendHello(params) res, _ := hand.oper.SendHello(params)
rctx.SetStatus(http.StatusOK)
hand.SendResult(rctx, res) hand.SendResult(rctx, res)
} }
+3 -3
View File
@@ -253,13 +253,13 @@ type ListFilesParams struct {
Filepath string Filepath string
} }
type ListFilesResult struct { type ListFilesResult struct {
FileDescrs []descr.File Files []descr.File `json:"files,omitempty"`
} }
func (oper *Operator) ListFiles(ctx context.Context, param *ListFilesParams) (int, *ListFilesResult, error) { func (oper *Operator) ListFiles(ctx context.Context, param *ListFilesParams) (int, *ListFilesResult, error) {
var err error var err error
res := &ListFilesResult{ res := &ListFilesResult{
FileDescrs: make([]descr.File, 0), Files: make([]descr.File, 0),
} }
// TODO: convert file path to a unified and secure state // TODO: convert file path to a unified and secure state
@@ -276,7 +276,7 @@ func (oper *Operator) ListFiles(ctx context.Context, param *ListFilesParams) (in
return code, res, err return code, res, err
} }
for _, item := range fileDescrs { for _, item := range fileDescrs {
res.FileDescrs = append(res.FileDescrs, item) res.Files = append(res.Files, item)
} }
code := http.StatusOK code := http.StatusOK
return code, res, err return code, res, err
+8 -7
View File
@@ -70,15 +70,16 @@ func (svc *Service) Build() error {
svc.rout.Use(router.NewCorsMiddleware()) svc.rout.Use(router.NewCorsMiddleware())
svc.rout.Use(svc.hand.AuthMiddleware) svc.rout.Use(svc.hand.AuthMiddleware)
svc.rout.Get("/v3/api/service/hello", svc.hand.SendHello) svc.rout.Get(`/v3/api/service/hello`, svc.hand.SendHello)
svc.rout.Head("/v3/api/file/{filepath}", svc.hand.FileExists) svc.rout.Head(`/v3/api/file/{filepath}`, svc.hand.FileExists)
svc.rout.Put("/v3/api/file/{filepath}", svc.hand.PutFile) svc.rout.Put(`/v3/api/file/{filepath}`, svc.hand.PutFile)
svc.rout.Get("/v3/api/file/{filepath}", svc.hand.GetFile) svc.rout.Get(`/v3/api/file/{filepath}`, svc.hand.GetFile)
svc.rout.Delete("/v3/api/file/{filepath}", svc.hand.DeleteFile) svc.rout.Delete(`/v3/api/file/{filepath}`, svc.hand.DeleteFile)
svc.rout.Get("/v3/api/files/{filepath}", svc.hand.ListFiles) svc.rout.Get(`/v3/api/files/{filepath}`, svc.hand.ListFiles)
svc.rout.Get(`/v3/api/files/`, svc.hand.ListFiles)
svc.rout.Get("/v2/", svc.hand.GetVersion) svc.rout.Get(`/v2/`, svc.hand.GetVersion)
svc.rout.Head(`/v2/{name}/manifests/{reference}`, svc.hand.ManifestExists) svc.rout.Head(`/v2/{name}/manifests/{reference}`, svc.hand.ManifestExists)
svc.rout.Put(`/v2/{name}/manifests/{reference}`, svc.hand.PutManifest) svc.rout.Put(`/v2/{name}/manifests/{reference}`, svc.hand.PutManifest)
+9 -1
View File
@@ -12,6 +12,7 @@ package client
import ( import (
"context" "context"
"crypto/tls" "crypto/tls"
"fmt"
"net/http" "net/http"
"net/url" "net/url"
"time" "time"
@@ -32,7 +33,10 @@ func convertServiceURI(ref string) (string, error) {
if err != nil { if err != nil {
return res, err return res, err
} }
uri.Path = serviceAPI uri.Path, err = url.JoinPath(serviceAPI, uri.Path)
if err != nil {
return res, err
}
uri.Scheme = serviceScheme uri.Scheme = serviceScheme
res = uri.String() res = uri.String()
return res, err return res, err
@@ -42,11 +46,15 @@ func (cli *Client) ServiceHello(ctx context.Context, serviceuri string, timeout
var res bool var res bool
var err error var err error
ctx, _ = context.WithTimeout(ctx, timeout) ctx, _ = context.WithTimeout(ctx, timeout)
serviceuri, _, _, err = repackServiceURI(serviceuri) serviceuri, _, _, err = repackServiceURI(serviceuri)
fmt.Printf("%s\n", serviceuri)
if err != nil { if err != nil {
return res, err return res, err
} }
serviceuri, err = convertServiceURI(serviceuri) serviceuri, err = convertServiceURI(serviceuri)
fmt.Printf("%s\n", serviceuri)
if err != nil { if err != nil {
return res, err return res, err
} }
+63 -8
View File
@@ -10,7 +10,9 @@
package client package client
import ( import (
"bytes"
"context" "context"
"encoding/json"
"fmt" "fmt"
"io" "io"
"net/http" "net/http"
@@ -18,6 +20,7 @@ import (
"path/filepath" "path/filepath"
"strconv" "strconv"
"mstore/app/descr"
"mstore/pkg/auxhttp" "mstore/pkg/auxhttp"
) )
@@ -58,7 +61,6 @@ func (cli *Client) PutFile(ctx context.Context, filename, fileuri string) error
if err != nil { if err != nil {
return err return err
} }
fileuri, err = convertFileURI(fileuri) fileuri, err = convertFileURI(fileuri)
if err != nil { if err != nil {
return err return err
@@ -81,6 +83,7 @@ func (cli *Client) PutFile(ctx context.Context, filename, fileuri string) error
req.ContentLength = filesize req.ContentLength = filesize
req.Header.Set("Content-Type", "application/octet-stream") req.Header.Set("Content-Type", "application/octet-stream")
req.Header.Set("Content-Size", strconv.FormatInt(filesize, 10))
if username != "" && password != "" { if username != "" && password != "" {
basic := auxhttp.EncodeBasicAuth(username, password) basic := auxhttp.EncodeBasicAuth(username, password)
req.Header.Add("Authorization", basic) req.Header.Add("Authorization", basic)
@@ -108,22 +111,18 @@ func (cli *Client) GetFile(ctx context.Context, fileuri, filename string) (int64
if err != nil { if err != nil {
return size, err return size, err
} }
fileuri, err = convertFileURI(fileuri) fileuri, err = convertFileURI(fileuri)
if err != nil { if err != nil {
return size, err return size, err
} }
req, err := http.NewRequestWithContext(ctx, http.MethodGet, fileuri, nil) req, err := http.NewRequestWithContext(ctx, http.MethodGet, fileuri, nil)
if err != nil { if err != nil {
return size, err return size, err
} }
if username != "" && password != "" { if username != "" && password != "" {
basic := auxhttp.EncodeBasicAuth(username, password) basic := auxhttp.EncodeBasicAuth(username, password)
req.Header.Add("Authorization", basic) req.Header.Add("Authorization", basic)
} }
client := makeHTTPClient() client := makeHTTPClient()
resp, err := client.Do(req) resp, err := client.Do(req)
if err != nil { if err != nil {
@@ -172,7 +171,6 @@ func (cli *Client) DeleteFile(ctx context.Context, fileuri, filename string) err
if err != nil { if err != nil {
return err return err
} }
fileuri, err = convertFileURI(fileuri) fileuri, err = convertFileURI(fileuri)
if err != nil { if err != nil {
return err return err
@@ -185,17 +183,74 @@ func (cli *Client) DeleteFile(ctx context.Context, fileuri, filename string) err
basic := auxhttp.EncodeBasicAuth(username, password) basic := auxhttp.EncodeBasicAuth(username, password)
req.Header.Add("Authorization", basic) req.Header.Add("Authorization", basic)
} }
client := makeHTTPClient() client := makeHTTPClient()
resp, err := client.Do(req) resp, err := client.Do(req)
if err != nil { if err != nil {
return err return err
} }
defer resp.Body.Close() defer resp.Body.Close()
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 err
} }
return err return err
} }
func (cli *Client) ListFiles(ctx context.Context, catalogURI string) ([]descr.File, error) {
var err error
res := make([]descr.File, 0)
catalogURI, username, password, err := repackServiceURI(catalogURI)
if err != nil {
return res, err
}
catalogURI, err = convertFilesURI(catalogURI)
if err != nil {
return res, err
}
req, err := http.NewRequestWithContext(ctx, http.MethodGet, catalogURI, nil)
if err != nil {
return res, err
}
if username != "" && password != "" {
basic := auxhttp.EncodeBasicAuth(username, password)
req.Header.Add("Authorization", basic)
}
client := makeHTTPClient()
resp, err := client.Do(req)
if err != nil {
return res, err
}
defer resp.Body.Close()
contentLength := resp.Header.Get("Content-Length")
if contentLength == "" {
err = fmt.Errorf("Empty Content-Length received")
return res, err
}
if resp.StatusCode != http.StatusOK {
err := fmt.Errorf("Received wrong status code: %s", resp.Status)
return res, err
}
declSize, err := strconv.ParseInt(contentLength, 10, 64)
if err != nil {
err = fmt.Errorf("Wrong Content-Length value: %v", err)
return res, err
}
respBuffer := bytes.NewBuffer(nil)
size, err := io.Copy(respBuffer, resp.Body)
if err != nil {
return res, err
}
respBytes := respBuffer.Bytes()
if size != declSize {
err := fmt.Errorf("Mismatch Content-Length and recorded filesize")
return res, err
}
fmt.Printf("list: %s\n",string(respBytes))
err = json.Unmarshal(respBytes, &res)
if err != nil {
return res, err
}
return res, err
}
+13 -1
View File
@@ -24,7 +24,7 @@ import (
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
) )
func xxxTestFileLife(t *testing.T) { func TestFileLife(t *testing.T) {
var srvport int64 = 10250 var srvport int64 = 10250
srvdir := t.TempDir() srvdir := t.TempDir()
srvaddr := fmt.Sprintf("127.0.0.1:%d", srvport) srvaddr := fmt.Sprintf("127.0.0.1:%d", srvport)
@@ -119,6 +119,18 @@ func xxxTestFileLife(t *testing.T) {
require.NoError(t, err) require.NoError(t, err)
require.Equal(t, recsize, int64(filesize)) require.Equal(t, recsize, int64(filesize))
} }
{
// ListFiles
fmt.Printf("=== ListFiles ===\n")
cli := NewClient()
ctx := context.Background()
ctx, _ = context.WithTimeout(ctx, 1*time.Second)
files, err := cli.ListFiles(ctx, srvaddr+"/")
require.NoError(t, err)
require.NotZero(t, len(files))
}
{ {
// DeleteFile // DeleteFile
fmt.Printf("=== DeleteFile ===\n") fmt.Printf("=== DeleteFile ===\n")
+1 -1
View File
@@ -21,7 +21,7 @@ import (
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
) )
func TestImageLife(t *testing.T) { func xxxTestImageLife(t *testing.T) {
var srvport int64 = 10250 var srvport int64 = 10250
srvdir := t.TempDir() srvdir := t.TempDir()
srvaddr := fmt.Sprintf("127.0.0.1:%d", srvport) srvaddr := fmt.Sprintf("127.0.0.1:%d", srvport)