代码拉取完成,页面将自动刷新
package clusteregistrationtokens
import (
"fmt"
"net/http"
"net/url"
"github.com/rancher/norman/condition"
"github.com/rancher/norman/httperror"
"github.com/rancher/norman/types"
"github.com/rancher/rancher/pkg/clustermanager"
corev1 "k8s.io/api/core/v1"
"k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/client-go/transport"
)
type ShellLinkHandler struct {
Proxy http.Handler
ClusterManager *clustermanager.Manager
}
func (s *ShellLinkHandler) LinkHandler(apiContext *types.APIContext, next types.RequestHandler) error {
context, err := s.ClusterManager.UserContext(apiContext.ID)
if err != nil {
return err
}
userManager := context.Management.UserManager
userID := userManager.GetUser(apiContext)
token, err := userManager.EnsureToken("kubectl-shell-"+userID, "Access to kubectl shell in the browser", userID)
if err != nil {
return err
}
pods, err := context.K8sClient.CoreV1().Pods("cattle-system").List(v1.ListOptions{
LabelSelector: "app=cattle-agent",
})
if err != nil {
return err
}
for _, pod := range pods.Items {
if condition.Cond(corev1.PodReady).IsTrue(&pod) {
vars := url.Values{}
vars.Add("container", "agent")
vars.Add("stdout", "1")
vars.Add("stdin", "1")
vars.Add("stderr", "1")
vars.Add("tty", "1")
vars.Add("command", "kubectl-shell.sh")
vars.Add("command", token)
vars.Add("command", context.ClusterName)
path := fmt.Sprintf("/k8s/clusters/%s/api/v1/namespaces/%s/pods/%s/exec", context.ClusterName, "cattle-system", pod.Name)
req := apiContext.Request
req.URL.Path = path
req.URL.RawQuery = vars.Encode()
// we want to run this as a the system user
req.Header.Del(transport.ImpersonateUserHeader)
req.Header.Del(transport.ImpersonateGroupHeader)
req.Header.Del(transport.ImpersonateUserExtraHeaderPrefix)
s.Proxy.ServeHTTP(apiContext.Response, req)
return nil
}
}
return httperror.NewAPIError(httperror.NotFound, "failed to find kubectl pod")
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。