2
0
mirror of https://github.com/acepanel/panel.git synced 2026-02-04 10:17:17 +08:00

feat: compose接口

This commit is contained in:
耗子
2025-03-20 02:49:18 +08:00
parent c3498aa5c5
commit 7d39015d97
8 changed files with 243 additions and 1 deletions

View File

@@ -0,0 +1,111 @@
package service
import (
"net/http"
"github.com/go-rat/chix"
"github.com/tnb-labs/panel/internal/biz"
"github.com/tnb-labs/panel/internal/http/request"
)
type ContainerComposeService struct {
containerComposeRepo biz.ContainerComposeRepo
}
func NewContainerComposeService(containerCompose biz.ContainerComposeRepo) *ContainerComposeService {
return &ContainerComposeService{
containerComposeRepo: containerCompose,
}
}
func (s *ContainerComposeService) List(w http.ResponseWriter, r *http.Request) {
files, err := s.containerComposeRepo.List()
if err != nil {
Error(w, http.StatusInternalServerError, "%v", err)
return
}
paged, total := Paginate(r, files)
Success(w, chix.M{
"total": total,
"items": paged,
})
}
func (s *ContainerComposeService) Get(w http.ResponseWriter, r *http.Request) {
req, err := Bind[request.ContainerComposeGet](r)
if err != nil {
Error(w, http.StatusUnprocessableEntity, "%v", err)
return
}
content, err := s.containerComposeRepo.Get(req.Name)
if err != nil {
Error(w, http.StatusInternalServerError, "%v", err)
return
}
Success(w, content)
}
func (s *ContainerComposeService) Create(w http.ResponseWriter, r *http.Request) {
req, err := Bind[request.ContainerComposeCreate](r)
if err != nil {
Error(w, http.StatusUnprocessableEntity, "%v", err)
return
}
if err = s.containerComposeRepo.Create(req.Name, req.Compose); err != nil {
Error(w, http.StatusInternalServerError, "%v", err)
return
}
Success(w, nil)
}
func (s *ContainerComposeService) Up(w http.ResponseWriter, r *http.Request) {
req, err := Bind[request.ContainerComposeUp](r)
if err != nil {
Error(w, http.StatusUnprocessableEntity, "%v", err)
return
}
if err = s.containerComposeRepo.Up(req.Name, req.Force); err != nil {
Error(w, http.StatusInternalServerError, "%v", err)
return
}
Success(w, nil)
}
func (s *ContainerComposeService) Down(w http.ResponseWriter, r *http.Request) {
req, err := Bind[request.ContainerComposeDown](r)
if err != nil {
Error(w, http.StatusUnprocessableEntity, "%v", err)
return
}
if err = s.containerComposeRepo.Down(req.Name); err != nil {
Error(w, http.StatusInternalServerError, "%v", err)
return
}
Success(w, nil)
}
func (s *ContainerComposeService) Remove(w http.ResponseWriter, r *http.Request) {
req, err := Bind[request.ContainerComposeRemove](r)
if err != nil {
Error(w, http.StatusUnprocessableEntity, "%v", err)
return
}
if err = s.containerComposeRepo.Remove(req.Name); err != nil {
Error(w, http.StatusInternalServerError, "%v", err)
return
}
Success(w, nil)
}

View File

@@ -11,6 +11,7 @@ var ProviderSet = wire.NewSet(
NewCertDNSService,
NewCliService,
NewContainerService,
NewContainerComposeService,
NewContainerImageService,
NewContainerNetworkService,
NewContainerVolumeService,