From a3cc1364dfa433331bcc6f180336af7f746731f8 Mon Sep 17 00:00:00 2001 From: Neil Hanlon Date: Wed, 28 Feb 2024 18:11:43 -0500 Subject: [PATCH 1/4] feat: add command to dump project info as JSON --- peridot/cmd/v1/peridot/BUILD.bazel | 1 + peridot/cmd/v1/peridot/main.go | 1 + peridot/cmd/v1/peridot/project_info.go | 63 ++++++++++++++++++++++++++ 3 files changed, 65 insertions(+) create mode 100644 peridot/cmd/v1/peridot/project_info.go diff --git a/peridot/cmd/v1/peridot/BUILD.bazel b/peridot/cmd/v1/peridot/BUILD.bazel index a53319cc..3855a6f0 100644 --- a/peridot/cmd/v1/peridot/BUILD.bazel +++ b/peridot/cmd/v1/peridot/BUILD.bazel @@ -11,6 +11,7 @@ go_library( "lookaside_upload.go", "main.go", "project.go", + "project_info.go", "project_catalog_sync.go", "project_create_hashed_repos.go", "utils.go", diff --git a/peridot/cmd/v1/peridot/main.go b/peridot/cmd/v1/peridot/main.go index 63df1b8b..085a53ae 100644 --- a/peridot/cmd/v1/peridot/main.go +++ b/peridot/cmd/v1/peridot/main.go @@ -59,6 +59,7 @@ func init() { build.AddCommand(buildPackage) root.AddCommand(project) + project.AddCommand(projectInfo) project.AddCommand(projectCreateHashedRepos) project.AddCommand(projectCatalogSync) diff --git a/peridot/cmd/v1/peridot/project_info.go b/peridot/cmd/v1/peridot/project_info.go new file mode 100644 index 00000000..20465ef7 --- /dev/null +++ b/peridot/cmd/v1/peridot/project_info.go @@ -0,0 +1,63 @@ +// Copyright (c) All respective contributors to the Peridot Project. All rights reserved. +// Copyright (c) 2021-2022 Rocky Enterprise Software Foundation, Inc. All rights reserved. +// Copyright (c) 2021-2022 Ctrl IQ, Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright notice, +// this list of conditions and the following disclaimer in the documentation +// and/or other materials provided with the distribution. +// +// 3. Neither the name of the copyright holder nor the names of its contributors +// may be used to endorse or promote products derived from this software without +// specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +// POSSIBILITY OF SUCH DAMAGE. + +package main + +import ( + "fmt" + "log" + + "github.com/spf13/cobra" + "openapi.peridot.resf.org/peridotopenapi" +) + +var projectInfo = &cobra.Command{ + Use: "info", + Run: projectInfoMn, +} + +func projectInfoMn(_ *cobra.Command, _ []string) { + projectID := mustGetProjectID() + + cl := getClient(serviceProject).(peridotopenapi.ProjectServiceApi) + + log.Printf("getting info for project %s", projectID) + res, _, err := cl.GetProject(getContext(), projectID).Execute() + + if err != nil { + errFatal(err) + } + + data, err := res.Project.MarshalJSON() + if err != nil { + errFatal(err) + } + fmt.Println(string(data)) +} From e39b29d30af2ec04e165a1adfd20fd9efcdfc38d Mon Sep 17 00:00:00 2001 From: Neil Hanlon Date: Wed, 28 Feb 2024 18:20:33 -0500 Subject: [PATCH 2/4] add project list command --- peridot/cmd/v1/peridot/BUILD.bazel | 1 + peridot/cmd/v1/peridot/main.go | 1 + peridot/cmd/v1/peridot/project_list.go | 61 ++++++++++++++++++++++++++ 3 files changed, 63 insertions(+) create mode 100644 peridot/cmd/v1/peridot/project_list.go diff --git a/peridot/cmd/v1/peridot/BUILD.bazel b/peridot/cmd/v1/peridot/BUILD.bazel index 3855a6f0..3b720a47 100644 --- a/peridot/cmd/v1/peridot/BUILD.bazel +++ b/peridot/cmd/v1/peridot/BUILD.bazel @@ -12,6 +12,7 @@ go_library( "main.go", "project.go", "project_info.go", + "project_list.go", "project_catalog_sync.go", "project_create_hashed_repos.go", "utils.go", diff --git a/peridot/cmd/v1/peridot/main.go b/peridot/cmd/v1/peridot/main.go index 085a53ae..2e2ce6ba 100644 --- a/peridot/cmd/v1/peridot/main.go +++ b/peridot/cmd/v1/peridot/main.go @@ -60,6 +60,7 @@ func init() { root.AddCommand(project) project.AddCommand(projectInfo) + project.AddCommand(projectList) project.AddCommand(projectCreateHashedRepos) project.AddCommand(projectCatalogSync) diff --git a/peridot/cmd/v1/peridot/project_list.go b/peridot/cmd/v1/peridot/project_list.go new file mode 100644 index 00000000..152fbb66 --- /dev/null +++ b/peridot/cmd/v1/peridot/project_list.go @@ -0,0 +1,61 @@ +// Copyright (c) All respective contributors to the Peridot Project. All rights reserved. +// Copyright (c) 2021-2022 Rocky Enterprise Software Foundation, Inc. All rights reserved. +// Copyright (c) 2021-2022 Ctrl IQ, Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright notice, +// this list of conditions and the following disclaimer in the documentation +// and/or other materials provided with the distribution. +// +// 3. Neither the name of the copyright holder nor the names of its contributors +// may be used to endorse or promote products derived from this software without +// specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +// POSSIBILITY OF SUCH DAMAGE. + +package main + +import ( + "fmt" + "log" + + "github.com/spf13/cobra" + "openapi.peridot.resf.org/peridotopenapi" +) + +var projectList = &cobra.Command{ + Use: "list", + Run: projectListMn, +} + +func projectListMn(_ *cobra.Command, _ []string) { + cl := getClient(serviceProject).(peridotopenapi.ProjectServiceApi) + + log.Println("looking for all projects") + res, _, err := cl.ListProjects(getContext()).Execute() + + if err != nil { + errFatal(err) + } + + data, err := res.MarshalJSON() + if err != nil { + errFatal(err) + } + fmt.Println(string(data)) +} From 034fe12c0a59b4d4c9d2169f89d07a62d73c18c8 Mon Sep 17 00:00:00 2001 From: Neil Hanlon Date: Wed, 28 Feb 2024 19:04:23 -0500 Subject: [PATCH 3/4] WIP: external/internal repository commands --- peridot/cmd/v1/peridot/BUILD.bazel | 5 ++ peridot/cmd/v1/peridot/main.go | 13 +++- .../cmd/v1/peridot/project_external_repo.go | 37 +++++++++ .../v1/peridot/project_external_repo_list.go | 62 +++++++++++++++ peridot/cmd/v1/peridot/project_repo.go | 37 +++++++++ peridot/cmd/v1/peridot/project_repo_get.go | 75 +++++++++++++++++++ peridot/cmd/v1/peridot/project_repo_list.go | 62 +++++++++++++++ 7 files changed, 289 insertions(+), 2 deletions(-) create mode 100644 peridot/cmd/v1/peridot/project_external_repo.go create mode 100644 peridot/cmd/v1/peridot/project_external_repo_list.go create mode 100644 peridot/cmd/v1/peridot/project_repo.go create mode 100644 peridot/cmd/v1/peridot/project_repo_get.go create mode 100644 peridot/cmd/v1/peridot/project_repo_list.go diff --git a/peridot/cmd/v1/peridot/BUILD.bazel b/peridot/cmd/v1/peridot/BUILD.bazel index 3b720a47..70f2002a 100644 --- a/peridot/cmd/v1/peridot/BUILD.bazel +++ b/peridot/cmd/v1/peridot/BUILD.bazel @@ -13,8 +13,13 @@ go_library( "project.go", "project_info.go", "project_list.go", + "project_repo.go", + "project_repo_get.go", + "project_repo_list.go", "project_catalog_sync.go", "project_create_hashed_repos.go", + "project_external_repo.go", + "project_external_repo_list.go", "utils.go", ], data = [ diff --git a/peridot/cmd/v1/peridot/main.go b/peridot/cmd/v1/peridot/main.go index 2e2ce6ba..03b853bc 100644 --- a/peridot/cmd/v1/peridot/main.go +++ b/peridot/cmd/v1/peridot/main.go @@ -31,11 +31,12 @@ package main import ( + "log" + "strings" + "github.com/sirupsen/logrus" "github.com/spf13/cobra" "github.com/spf13/viper" - "log" - "strings" ) var root = &cobra.Command{ @@ -64,6 +65,14 @@ func init() { project.AddCommand(projectCreateHashedRepos) project.AddCommand(projectCatalogSync) + project.AddCommand(repo) + repo.AddCommand(projectRepoList) + repo.AddCommand(projectRepoGet) + + project.AddCommand(externalRepo) + externalRepo.AddCommand(externalRepoList) + //externalRepo.AddCommand(externalRepoGet) + root.AddCommand(impCmd) viper.SetEnvPrefix("PERIDOT") diff --git a/peridot/cmd/v1/peridot/project_external_repo.go b/peridot/cmd/v1/peridot/project_external_repo.go new file mode 100644 index 00000000..a9ace30e --- /dev/null +++ b/peridot/cmd/v1/peridot/project_external_repo.go @@ -0,0 +1,37 @@ +// Copyright (c) All respective contributors to the Peridot Project. All rights reserved. +// Copyright (c) 2021-2022 Rocky Enterprise Software Foundation, Inc. All rights reserved. +// Copyright (c) 2021-2022 Ctrl IQ, Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright notice, +// this list of conditions and the following disclaimer in the documentation +// and/or other materials provided with the distribution. +// +// 3. Neither the name of the copyright holder nor the names of its contributors +// may be used to endorse or promote products derived from this software without +// specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +// POSSIBILITY OF SUCH DAMAGE. + +package main + +import "github.com/spf13/cobra" + +var externalRepo = &cobra.Command{ + Use: "external-repo", +} diff --git a/peridot/cmd/v1/peridot/project_external_repo_list.go b/peridot/cmd/v1/peridot/project_external_repo_list.go new file mode 100644 index 00000000..f9061ed6 --- /dev/null +++ b/peridot/cmd/v1/peridot/project_external_repo_list.go @@ -0,0 +1,62 @@ +// Copyright (c) All respective contributors to the Peridot Project. All rights reserved. +// Copyright (c) 2021-2022 Rocky Enterprise Software Foundation, Inc. All rights reserved. +// Copyright (c) 2021-2022 Ctrl IQ, Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright notice, +// this list of conditions and the following disclaimer in the documentation +// and/or other materials provided with the distribution. +// +// 3. Neither the name of the copyright holder nor the names of its contributors +// may be used to endorse or promote products derived from this software without +// specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +// POSSIBILITY OF SUCH DAMAGE. + +package main + +import ( + "encoding/json" + "fmt" + + "github.com/spf13/cobra" + "openapi.peridot.resf.org/peridotopenapi" +) + +var externalRepoList = &cobra.Command{ + Use: "list", + Run: projectExternalRepoListMn, +} + +func projectExternalRepoListMn(_ *cobra.Command, _ []string) { + projectID := mustGetProjectID() + + cl := getClient(serviceProject).(peridotopenapi.ProjectServiceApi) + + res, _, err := cl.ListExternalRepositories(getContext(), projectID).Execute() + if err != nil { + errFatal(err) + } + + data, err := json.Marshal(res.Repositories) + if err != nil { + errFatal(err) + } + + fmt.Println(string(data)) +} diff --git a/peridot/cmd/v1/peridot/project_repo.go b/peridot/cmd/v1/peridot/project_repo.go new file mode 100644 index 00000000..d1faf834 --- /dev/null +++ b/peridot/cmd/v1/peridot/project_repo.go @@ -0,0 +1,37 @@ +// Copyright (c) All respective contributors to the Peridot Project. All rights reserved. +// Copyright (c) 2021-2022 Rocky Enterprise Software Foundation, Inc. All rights reserved. +// Copyright (c) 2021-2022 Ctrl IQ, Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright notice, +// this list of conditions and the following disclaimer in the documentation +// and/or other materials provided with the distribution. +// +// 3. Neither the name of the copyright holder nor the names of its contributors +// may be used to endorse or promote products derived from this software without +// specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +// POSSIBILITY OF SUCH DAMAGE. + +package main + +import "github.com/spf13/cobra" + +var repo = &cobra.Command{ + Use: "repo", +} diff --git a/peridot/cmd/v1/peridot/project_repo_get.go b/peridot/cmd/v1/peridot/project_repo_get.go new file mode 100644 index 00000000..ac6a47b6 --- /dev/null +++ b/peridot/cmd/v1/peridot/project_repo_get.go @@ -0,0 +1,75 @@ +// Copyright (c) All respective contributors to the Peridot Project. All rights reserved. +// Copyright (c) 2021-2022 Rocky Enterprise Software Foundation, Inc. All rights reserved. +// Copyright (c) 2021-2022 Ctrl IQ, Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright notice, +// this list of conditions and the following disclaimer in the documentation +// and/or other materials provided with the distribution. +// +// 3. Neither the name of the copyright holder nor the names of its contributors +// may be used to endorse or promote products derived from this software without +// specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +// POSSIBILITY OF SUCH DAMAGE. + +package main + +import ( + "encoding/json" + "fmt" + + "github.com/spf13/cobra" + "openapi.peridot.resf.org/peridotopenapi" +) + +var projectRepoGet = &cobra.Command{ + Use: "get", + Args: cobra.ExactArgs(1), + Run: projectRepoGetMn, +} + +func projectRepoGetMn(_ *cobra.Command, args []string) { + projectID := mustGetProjectID() + + cl := getClient(serviceProject).(peridotopenapi.ProjectServiceApi) + + repositories, _, err := cl.ListRepositories(getContext(), projectID).Execute() + if err != nil { + errFatal(err) + } + + var repoID string = "" + for _, repo := range *repositories.Repositories { + if *repo.Name == args[0] { + repoID = *repo.Id + } + } + + res, _, err := cl.GetRepository(getContext(), projectID, repoID).Execute() + if err != nil { + errFatal(err) + } + + data, err := json.Marshal(res.Repository) + if err != nil { + errFatal(err) + } + + fmt.Println(string(data)) +} diff --git a/peridot/cmd/v1/peridot/project_repo_list.go b/peridot/cmd/v1/peridot/project_repo_list.go new file mode 100644 index 00000000..32e38a5d --- /dev/null +++ b/peridot/cmd/v1/peridot/project_repo_list.go @@ -0,0 +1,62 @@ +// Copyright (c) All respective contributors to the Peridot Project. All rights reserved. +// Copyright (c) 2021-2022 Rocky Enterprise Software Foundation, Inc. All rights reserved. +// Copyright (c) 2021-2022 Ctrl IQ, Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright notice, +// this list of conditions and the following disclaimer in the documentation +// and/or other materials provided with the distribution. +// +// 3. Neither the name of the copyright holder nor the names of its contributors +// may be used to endorse or promote products derived from this software without +// specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +// POSSIBILITY OF SUCH DAMAGE. + +package main + +import ( + "encoding/json" + "fmt" + + "github.com/spf13/cobra" + "openapi.peridot.resf.org/peridotopenapi" +) + +var projectRepoList = &cobra.Command{ + Use: "list", + Run: projectRepoListMn, +} + +func projectRepoListMn(_ *cobra.Command, _ []string) { + projectID := mustGetProjectID() + + cl := getClient(serviceProject).(peridotopenapi.ProjectServiceApi) + + res, _, err := cl.ListRepositories(getContext(), projectID).Execute() + if err != nil { + errFatal(err) + } + + data, err := json.Marshal(res.Repositories) + if err != nil { + errFatal(err) + } + + fmt.Println(string(data)) +} From 84423b25ab3b71b167d122e5d9ddbe7464dee3a4 Mon Sep 17 00:00:00 2001 From: Neil Hanlon Date: Wed, 28 Feb 2024 19:23:47 -0500 Subject: [PATCH 4/4] plumb API for External Repositories --- peridot/db/db.go | 1 + peridot/db/psql/repository.go | 10 +++++++++ peridot/impl/v1/project.go | 41 +++++++++++++++++++++++++++++++++++ 3 files changed, 52 insertions(+) diff --git a/peridot/db/db.go b/peridot/db/db.go index 51d04a06..71fd868c 100644 --- a/peridot/db/db.go +++ b/peridot/db/db.go @@ -125,6 +125,7 @@ type Access interface { GetPluginsForProject(projectId string) (models.Plugins, error) GetExternalRepositoriesForProject(projectId string) (models.ExternalRepositories, error) + GetExternalRepository(projectId string, id string) (models.ExternalRepository, error) DeleteExternalRepositoryForProject(projectId string, externalRepositoryId string) error CreateExternalRepositoryForProject(projectId string, repoURL string, priority *int32, moduleHotfixes bool) (*models.ExternalRepository, error) FindRepositoriesForPackage(projectId string, pkg string, internalOnly bool) (models.Repositories, error) diff --git a/peridot/db/psql/repository.go b/peridot/db/psql/repository.go index a3104a54..0774bcd4 100644 --- a/peridot/db/psql/repository.go +++ b/peridot/db/psql/repository.go @@ -45,6 +45,16 @@ func (a *Access) GetExternalRepositoriesForProject(projectId string) (ret models return ret, nil } +func (a *Access) GetExternalRepository(projectId string, repoId string) (*models.ExternalRepository, error) { + var r models.ExternalRepository + err := a.query.Select(&r, "select id, created_at, project_id, url, priority, module_hotfixes from external_repositories where project_id = $1 and id = $2 order by created_at desc", projectId, repoId) + if err != nil { + return nil, err + } + + return &r, nil +} + func (a *Access) DeleteExternalRepositoryForProject(projectId string, id string) error { _, err := a.query.Exec("delete from external_repositories where project_id = $1 and id = $2", projectId, id) return err diff --git a/peridot/impl/v1/project.go b/peridot/impl/v1/project.go index 0c9aee9d..e6165b25 100644 --- a/peridot/impl/v1/project.go +++ b/peridot/impl/v1/project.go @@ -236,6 +236,47 @@ func (s *Server) GetRepository(ctx context.Context, req *peridotpb.GetRepository }, nil } +func (s *Server) ListExternalRepositories(ctx context.Context, req *peridotpb.ListExternalRepositoriesRequest) (*peridotpb.ListExternalRepositoriesResponse, error) { + if err := req.ValidateAll(); err != nil { + return nil, err + } + if err := s.checkPermission(ctx, ObjectProject, req.ProjectId.Value, PermissionView); err != nil { + return nil, err + } + + repos, err := s.db.GetExternalRepositoriesForProject(req.ProjectId.Value) + if err != nil { + s.log.Errorf("could not list repositories: %v", err) + return nil, utils.CouldNotRetrieveObjects + } + + return &peridotpb.ListExternalRepositoriesResponse { + Repositories: repos.ToProto(), + }, nil +} + +func (s *Server) GetExternalRepository(ctx context.Context, req *peridotpb.GetExternalRepositoryRequest) (*peridotpb.GetExternalRepositoryResponse, error) { + if err := req.ValidateAll(); err != nil { + return nil, err + } + if err := s.checkPermission(ctx, ObjectProject, req.ProjectId.Value, PermissionView); err != nil { + return nil, err + } + + repos, err := s.db.GetExternalRepositoryForProject(req.ProjectId.Value, &req.Id.Value, false) + if err != nil { + s.log.Errorf("could not list repositories: %v", err) + return nil, utils.CouldNotRetrieveObjects + } + if len(repos) == 0 { + return nil, utils.CouldNotFindObject + } + + return &peridotpb.GetRepositoryResponse{ + Repository: repos[0].ToProto(), + }, nil +} + func (s *Server) GetProjectCredentials(ctx context.Context, req *peridotpb.GetProjectCredentialsRequest) (*peridotpb.GetProjectCredentialsResponse, error) { if err := req.ValidateAll(); err != nil { return nil, err