Make repos and snapshots API return JSON objects for packages when asked

This commit is contained in:
Sylvain Baubeau
2014-12-18 18:16:35 +01:00
parent d983e10d08
commit d847cba870
3 changed files with 43 additions and 24 deletions

View File

@@ -178,6 +178,15 @@ func apiReposPackagesShow(c *gin.Context) {
return
}
list, err := deb.NewPackageListFromRefList(repo.RefList(), context.CollectionFactory().PackageCollection(), nil)
if err != nil {
c.Fail(500, err)
return
}
list.PrepareIndex()
result := []*deb.Package{}
queryS := c.Request.URL.Query().Get("q")
if queryS != "" {
q, err := query.Parse(queryS)
@@ -186,14 +195,6 @@ func apiReposPackagesShow(c *gin.Context) {
return
}
list, err := deb.NewPackageListFromRefList(repo.RefList(), context.CollectionFactory().PackageCollection(), nil)
if err != nil {
c.Fail(500, err)
return
}
list.PrepareIndex()
withDeps := c.Request.URL.Query().Get("withDeps") == "1"
architecturesList := []string{}
@@ -212,16 +213,23 @@ func apiReposPackagesShow(c *gin.Context) {
}
}
result, err := list.Filter([]deb.PackageQuery{q}, withDeps,
list, err = list.Filter([]deb.PackageQuery{q}, withDeps,
nil, context.DependencyOptions(), architecturesList)
if err != nil {
c.Fail(500, err)
return
}
}
c.JSON(200, result.Strings())
if c.Request.URL.Query().Get("format") == "details" {
list.ForEach(func(p *deb.Package) error {
result = append(result, p)
return nil
})
c.JSON(200, result)
} else {
c.JSON(200, repo.RefList().Strings())
c.JSON(200, list.Strings())
}
}

View File

@@ -234,13 +234,19 @@ func apiSnapshotsShow(c *gin.Context) {
collection.RLock()
defer collection.RUnlock()
repo, err := collection.ByName(c.Params.ByName("name"))
snapshot, err := collection.ByName(c.Params.ByName("name"))
if err != nil {
c.Fail(404, err)
return
}
c.JSON(200, repo)
err = collection.LoadComplete(snapshot)
if err != nil {
c.Fail(500, err)
return
}
c.JSON(200, snapshot)
}
// DELETE /api/snapshots/:name
@@ -405,22 +411,21 @@ func apiSnapshotsSearchPackages(c *gin.Context) {
list.PrepareIndex()
packages, err := list.Filter([]deb.PackageQuery{q}, withDeps,
list, err = list.Filter([]deb.PackageQuery{q}, withDeps,
nil, context.DependencyOptions(), architecturesList)
if err != nil {
c.Fail(500, fmt.Errorf("unable to search: %s", err))
}
}
packages.ForEach(func(p *deb.Package) error {
result = append(result, p)
return nil
})
} else {
if c.Request.URL.Query().Get("format") == "details" {
list.ForEach(func(p *deb.Package) error {
result = append(result, p)
return nil
})
}
c.JSON(200, result)
c.JSON(200, result)
} else {
c.JSON(200, list.Strings())
}
}