mirror of
https://github.com/rancher/os.git
synced 2025-09-06 09:14:31 +00:00
81 lines
1.9 KiB
Go
81 lines
1.9 KiB
Go
package server
|
|
|
|
import (
|
|
"crypto/hmac"
|
|
"crypto/sha512"
|
|
"encoding/base64"
|
|
"fmt"
|
|
"net/http"
|
|
"strings"
|
|
)
|
|
|
|
var (
|
|
tokenHash = "tokenByHash"
|
|
)
|
|
|
|
func (i *InventoryServer) cacerts(rw http.ResponseWriter, req *http.Request) {
|
|
ca := i.cacert()
|
|
|
|
rw.Header().Set("Content-Type", "text/plain")
|
|
var bytes []byte
|
|
if strings.TrimSpace(ca) != "" {
|
|
if !strings.HasSuffix(ca, "\n") {
|
|
ca += "\n"
|
|
}
|
|
bytes = []byte(ca)
|
|
}
|
|
|
|
nonce := req.Header.Get("X-Cattle-Nonce")
|
|
authorization := strings.TrimPrefix(req.Header.Get("Authorization"), "Bearer ")
|
|
|
|
if authorization != "" && nonce != "" {
|
|
crt, err := i.secretCache.GetByIndex(tokenHash, authorization)
|
|
if err == nil && len(crt) > 0 {
|
|
digest := hmac.New(sha512.New, crt[0].Data[tokenKey])
|
|
digest.Write([]byte(nonce))
|
|
digest.Write([]byte{0})
|
|
digest.Write(bytes)
|
|
digest.Write([]byte{0})
|
|
hash := digest.Sum(nil)
|
|
rw.Header().Set("X-Cattle-Hash", base64.StdEncoding.EncodeToString(hash))
|
|
} else if machines, err := i.machineCache.GetByIndex(tokenHash, authorization); len(machines) == 1 && err == nil {
|
|
digest := hmac.New(sha512.New, []byte(machines[0].Spec.TPMHash))
|
|
digest.Write([]byte(nonce))
|
|
digest.Write([]byte{0})
|
|
digest.Write(bytes)
|
|
digest.Write([]byte{0})
|
|
hash := digest.Sum(nil)
|
|
rw.Header().Set("X-Cattle-Hash", base64.StdEncoding.EncodeToString(hash))
|
|
}
|
|
}
|
|
|
|
if len(bytes) > 0 {
|
|
_, _ = rw.Write([]byte(ca))
|
|
}
|
|
}
|
|
|
|
func (i *InventoryServer) cacert() string {
|
|
setting, err := i.settingCache.Get("cacerts")
|
|
if err != nil {
|
|
return ""
|
|
}
|
|
if setting.Value == "" {
|
|
setting, err = i.settingCache.Get("internal-cacerts")
|
|
if err != nil {
|
|
return ""
|
|
}
|
|
}
|
|
return setting.Value
|
|
}
|
|
|
|
func (i *InventoryServer) serverURL() (string, error) {
|
|
setting, err := i.settingCache.Get("server-url")
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
if setting.Value == "" {
|
|
return "", fmt.Errorf("server-url is not set")
|
|
}
|
|
return setting.Value, nil
|
|
}
|