From 908f9772f5a32df12826c45d33d0d4bc5f4823bf Mon Sep 17 00:00:00 2001 From: mahao Date: Fri, 8 Sep 2023 16:03:54 +0800 Subject: [PATCH] support raw api (#715) Signed-off-by: Allen --- README.md | 1 + .../server/multitenant/handlers.go | 51 +++++++++++++++---- pkg/chartmuseum/server/multitenant/routes.go | 2 +- 3 files changed, 42 insertions(+), 12 deletions(-) diff --git a/README.md b/README.md index 0b5c55ec..77b7c7a8 100644 --- a/README.md +++ b/README.md @@ -38,6 +38,7 @@ Powered by some great Go technology: - `GET /api/charts//` - describe a chart version - `GET /api/charts///templates` - get chart template - `GET /api/charts///values` - get chart values +- `GET /api/charts///raw` - get all the files of chart - `HEAD /api/charts/` - check if chart exists (any versions) - `HEAD /api/charts//` - check if chart version exists diff --git a/pkg/chartmuseum/server/multitenant/handlers.go b/pkg/chartmuseum/server/multitenant/handlers.go index 6743b82b..89387054 100644 --- a/pkg/chartmuseum/server/multitenant/handlers.go +++ b/pkg/chartmuseum/server/multitenant/handlers.go @@ -27,17 +27,13 @@ import ( "time" cm_storage "github.com/chartmuseum/storage" - + "github.com/gin-gonic/gin" + "go.uber.org/zap" cm_logger "helm.sh/chartmuseum/pkg/chartmuseum/logger" cm_repo "helm.sh/chartmuseum/pkg/repo" - "helm.sh/helm/v3/pkg/chart" "helm.sh/helm/v3/pkg/chart/loader" helm_repo "helm.sh/helm/v3/pkg/repo" - - "github.com/gin-gonic/gin" - - "go.uber.org/zap" ) var ( @@ -157,6 +153,7 @@ func (server *MultiTenantServer) getStorageObjectRequestHandler(c *gin.Context) } c.Data(200, storageObject.ContentType, storageObject.Content) } + func (server *MultiTenantServer) getStorageObjectTemplateRequestHandler(c *gin.Context) { repo := c.Param("repo") name := c.Param("name") @@ -186,6 +183,34 @@ func (server *MultiTenantServer) getStorageObjectTemplateRequestHandler(c *gin.C }) } +func (server *MultiTenantServer) getStorageObjectRawRequestHandler(c *gin.Context) { + repo := c.Param("repo") + name := c.Param("name") + version := c.Param("version") + + log := server.Logger.ContextLoggingFn(c) + + fileName, err := server.getChartFileName(log, repo, name, version) + if err != nil { + c.JSON(http.StatusNotFound, gin.H{"error": err.Message}) + return + } + + storageObject, err := server.getStorageObject(log, repo, fileName) + if err != nil { + c.JSON(err.Status, gin.H{"error": err.Message}) + return + } + chrt, err1 := loader.LoadArchive(bytes.NewReader(storageObject.Content)) + if err1 != nil { + c.JSON(http.StatusInternalServerError, gin.H{"error": err1}) + return + } + c.JSON(200, map[string]interface{}{ + "raw": chrt.Raw, + }) +} + func (server *MultiTenantServer) getStorageObjectValuesRequestHandler(c *gin.Context) { repo := c.Param("repo") name := c.Param("name") @@ -222,6 +247,7 @@ func (server *MultiTenantServer) getStorageObjectValuesRequestHandler(c *gin.Con } c.Data(200, "application/yaml", data) } + func (server *MultiTenantServer) getAllChartsRequestHandler(c *gin.Context) { repo := c.Param("repo") offset := 0 @@ -368,7 +394,8 @@ func (server *MultiTenantServer) postPackageRequestHandler(c *gin.Context) { chart, chartErr := cm_repo.ChartVersionFromStorageObject(cm_storage.Object{ Path: pathutil.Join(repo, filename), Content: content, - LastModified: time.Now()}) + LastModified: time.Now(), + }) if chartErr != nil { log(cm_logger.ErrorLevel, "cannot get chart from content", zap.Error(chartErr), zap.Binary("content", content)) } @@ -430,9 +457,10 @@ func (server *MultiTenantServer) postPackageAndProvenanceRequestHandler(c *gin.C if len(c.Errors) > 0 { return // this is a "request too large" } - c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf( - "no package or provenance file found in form fields %s and %s", - server.ChartPostFormFieldName, server.ProvPostFormFieldName), + c.JSON(http.StatusBadRequest, gin.H{ + "error": fmt.Sprintf( + "no package or provenance file found in form fields %s and %s", + server.ChartPostFormFieldName, server.ProvPostFormFieldName), }) return } @@ -466,7 +494,8 @@ func (server *MultiTenantServer) postPackageAndProvenanceRequestHandler(c *gin.C chart, chartErr := cm_repo.ChartVersionFromStorageObject(cm_storage.Object{ Path: path, Content: chartContent, - LastModified: time.Now()}) + LastModified: time.Now(), + }) if chartErr != nil { log(cm_logger.ErrorLevel, "cannot get chart from content", zap.Error(err), zap.Binary("content", chartContent)) } diff --git a/pkg/chartmuseum/server/multitenant/routes.go b/pkg/chartmuseum/server/multitenant/routes.go index 77a673a4..cefdde68 100644 --- a/pkg/chartmuseum/server/multitenant/routes.go +++ b/pkg/chartmuseum/server/multitenant/routes.go @@ -18,7 +18,6 @@ package multitenant import ( cm_auth "github.com/chartmuseum/auth" - cm_router "helm.sh/chartmuseum/pkg/chartmuseum/router" ) @@ -49,6 +48,7 @@ func (s *MultiTenantServer) Routes() []*cm_router.Route { {Method: "GET", Path: "/api/:repo/charts/:name/:version", Handler: s.getChartVersionRequestHandler, Action: cm_auth.PullAction}, {Method: "GET", Path: "/api/:repo/charts/:name/:version/templates", Handler: s.getStorageObjectTemplateRequestHandler, Action: cm_auth.PullAction}, {Method: "GET", Path: "/api/:repo/charts/:name/:version/values", Handler: s.getStorageObjectValuesRequestHandler, Action: cm_auth.PullAction}, + {Method: "GET", Path: "/api/:repo/charts/:name/:version/raw", Handler: s.getStorageObjectRawRequestHandler, Action: cm_auth.PullAction}, {Method: "POST", Path: "/api/:repo/charts", Handler: s.postRequestHandler, Action: cm_auth.PushAction}, {Method: "POST", Path: "/api/:repo/prov", Handler: s.postProvenanceFileRequestHandler, Action: cm_auth.PushAction}, }