DKube v1.0
This commit is contained in:
100
service/secret.go
Normal file
100
service/secret.go
Normal file
@ -0,0 +1,100 @@
|
||||
package service
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"github.com/wonderivan/logger"
|
||||
corev1 "k8s.io/api/core/v1"
|
||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
)
|
||||
|
||||
var Secret secret
|
||||
|
||||
type secret struct{}
|
||||
|
||||
type SecretsResp struct {
|
||||
Items []corev1.Secret `json:"items"`
|
||||
Total int `json:"total"`
|
||||
}
|
||||
|
||||
func (s *secret) GetSecrets(filterName, namespace string, limit, page int) (secretsResp *SecretsResp, err error) {
|
||||
secretList, err := K8s.ClientSet.CoreV1().Secrets(namespace).List(context.TODO(), metav1.ListOptions{})
|
||||
if err != nil {
|
||||
logger.Error(errors.New("获取Secret列表失败, " + err.Error()))
|
||||
return nil, errors.New("获取Secret列表失败, " + err.Error())
|
||||
}
|
||||
selectableData := &dataSelector{
|
||||
GenericDataList: s.toCells(secretList.Items),
|
||||
DataSelect: &DataSelectQuery{
|
||||
Filter: &FilterQuery{Name: filterName},
|
||||
Paginate: &PaginateQuery{
|
||||
Limit: limit,
|
||||
Page: page,
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
filtered := selectableData.Filter()
|
||||
total := len(filtered.GenericDataList)
|
||||
data := filtered.Sort().Paginate()
|
||||
secrets := s.fromCells(data.GenericDataList)
|
||||
return &SecretsResp{
|
||||
Items: secrets,
|
||||
Total: total,
|
||||
}, nil
|
||||
}
|
||||
|
||||
func (s *secret) GetSecretDetail(secretName, namespace string) (secret *corev1.Secret, err error) {
|
||||
secret, err = K8s.ClientSet.CoreV1().Secrets(namespace).Get(context.TODO(), secretName, metav1.GetOptions{})
|
||||
if err != nil {
|
||||
logger.Error(errors.New("获取Secret详情失败, " + err.Error()))
|
||||
return nil, errors.New("获取Secret详情失败, " + err.Error())
|
||||
}
|
||||
|
||||
return secret, nil
|
||||
}
|
||||
|
||||
func (s *secret) DeleteSecret(secretName, namespace string) (err error) {
|
||||
err = K8s.ClientSet.CoreV1().Secrets(namespace).Delete(context.TODO(), secretName, metav1.DeleteOptions{})
|
||||
if err != nil {
|
||||
logger.Error(errors.New("删除Secret失败, " + err.Error()))
|
||||
return errors.New("删除Secret失败, " + err.Error())
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (s *secret) UpdateSecret(namespace, content string) (err error) {
|
||||
var secret = &corev1.Secret{}
|
||||
|
||||
err = json.Unmarshal([]byte(content), secret)
|
||||
if err != nil {
|
||||
logger.Error(errors.New("反序列化失败, " + err.Error()))
|
||||
return errors.New("反序列化失败, " + err.Error())
|
||||
}
|
||||
|
||||
_, err = K8s.ClientSet.CoreV1().Secrets(namespace).Update(context.TODO(), secret, metav1.UpdateOptions{})
|
||||
if err != nil {
|
||||
logger.Error(errors.New("更新Secret失败, " + err.Error()))
|
||||
return errors.New("更新Secret失败, " + err.Error())
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func (s *secret) toCells(std []corev1.Secret) []DataCell {
|
||||
cells := make([]DataCell, len(std))
|
||||
for i := range std {
|
||||
cells[i] = secretCell(std[i])
|
||||
}
|
||||
return cells
|
||||
}
|
||||
|
||||
func (s *secret) fromCells(cells []DataCell) []corev1.Secret {
|
||||
secrets := make([]corev1.Secret, len(cells))
|
||||
for i := range cells {
|
||||
secrets[i] = corev1.Secret(cells[i].(secretCell))
|
||||
}
|
||||
|
||||
return secrets
|
||||
}
|
Reference in New Issue
Block a user