|
- package vm
-
- import (
- "context"
- "github.com/jinzhu/copier"
- "github.com/pkg/errors"
- "gitlink.org.cn/jcce-pcm/pcm-participant-openstack/openstack"
- "gitlink.org.cn/jcce-pcm/utils/result"
- "gitlink.org.cn/jcce-pcm/utils/tool"
- "gitlink.org.cn/jcce-pcm/utils/xerr"
- "k8s.io/apimachinery/pkg/util/json"
-
- "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/svc"
- "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/types"
-
- "github.com/zeromicro/go-zero/core/logx"
- )
-
- type ListNodesLogic struct {
- logx.Logger
- ctx context.Context
- svcCtx *svc.ServiceContext
- }
-
- func NewListNodesLogic(ctx context.Context, svcCtx *svc.ServiceContext) *ListNodesLogic {
- return &ListNodesLogic{
- Logger: logx.WithContext(ctx),
- ctx: ctx,
- svcCtx: svcCtx,
- }
- }
-
- func (l *ListNodesLogic) ListNodes(req *types.ListNodesReq) (resp *types.ListNodesResp, err error) {
- // todo: add your logic here and delete this line
- ListNodesReq := &openstack.ListNodesReq{}
- err = copier.CopyWithOption(ListNodesReq, req, copier.Option{Converters: tool.Converters})
- ListNodesResp, err := l.svcCtx.OpenstackRpc.ListNodes(l.ctx, ListNodesReq)
- if err != nil {
- return nil, errors.Wrapf(xerr.NewErrMsg("Failed to get Servers list"), "Failed to get db Servers list err : %v ,req:%+v", err, req)
- }
- marshal, err := json.Marshal(&ListNodesResp)
- if err != nil {
- return nil, result.NewDefaultError(err.Error())
- }
- json.Unmarshal(marshal, &resp)
- err = copier.CopyWithOption(&resp, &ListNodesResp, copier.Option{Converters: tool.Converters})
- return resp, err
- }
|