This repository has been archived on 2024-03-03. You can view files and clone it, but cannot push or open issues or pull requests.
adlin/pkg/login-validator/cmd/pxetpl.go

48 lines
1.6 KiB
Go
Raw Normal View History

2018-02-12 10:39:44 +00:00
package main
import (
2019-02-26 11:34:31 +00:00
"crypto/hmac"
"crypto/sha512"
2018-02-12 10:39:44 +00:00
"fmt"
"io/ioutil"
"net"
"os"
"path"
"text/template"
)
const pxeUserTplPath = "pxelinux.cfg/tpl"
2019-02-26 11:34:31 +00:00
const ipxeUserTplPath = "pxelinux.cfg/tpl.ipxe"
2018-02-12 10:39:44 +00:00
const pxeUserPath = "pxelinux.cfg"
2019-02-26 11:34:31 +00:00
func RegisterUserMAC(ent ARPEntry, username string) error {
if err := registerUser(ipxeUserTplPath, fmt.Sprintf("%02x:%02x:%02x:%02x:%02x:%02x.ipxe", ent.HWAddress[0], ent.HWAddress[1], ent.HWAddress[2], ent.HWAddress[3], ent.HWAddress[4], ent.HWAddress[5]), username); err != nil {
2018-02-12 10:39:44 +00:00
return err
} else {
2019-02-26 11:34:31 +00:00
return registerUser(pxeUserTplPath, fmt.Sprintf("%02x-%02x-%02x-%02x-%02x-%02x-%02x", ent.HWType, ent.HWAddress[0], ent.HWAddress[1], ent.HWAddress[2], ent.HWAddress[3], ent.HWAddress[4], ent.HWAddress[5]), username)
2018-02-12 10:39:44 +00:00
}
}
func RegisterUserIP(ip net.IP, username string) error {
2019-02-26 11:34:31 +00:00
return registerUser(pxeUserTplPath, fmt.Sprintf("%02X%02X%02X%02X", ip.To4()[0], ip.To4()[1], ip.To4()[2], ip.To4()[3]), username)
2018-02-12 10:39:44 +00:00
}
2019-02-26 11:34:31 +00:00
func registerUser(tplPath string, filename string, username string) error {
if pxeTplCnt, err := ioutil.ReadFile(path.Join(tftpDir, tplPath)); err != nil {
2018-02-12 10:39:44 +00:00
return err
} else if userfd, err := os.OpenFile(path.Join(tftpDir, pxeUserPath, filename), os.O_RDWR|os.O_CREATE, 0644); err != nil {
return err
} else {
defer userfd.Close()
2019-02-26 11:34:31 +00:00
pkey := hmac.New(sha512.New512_224, []byte(loginSalt))
2018-02-12 10:39:44 +00:00
if pxeTmpl, err := template.New("pxeUser").Parse(string(pxeTplCnt)); err != nil {
return err
2019-02-26 11:34:31 +00:00
} else if err := pxeTmpl.Execute(userfd, map[string]string{"username": username, "pkey": fmt.Sprintf("%x", pkey.Sum([]byte(username)))}); err != nil {
2018-02-12 10:39:44 +00:00
return err
}
}
return nil
}