2023-05-17 17:34:29 +02:00
|
|
|
//go:build cgo
|
|
|
|
|
2022-09-05 09:06:08 +02:00
|
|
|
/*
|
|
|
|
Copyright (c) Edgeless Systems GmbH
|
|
|
|
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
2022-06-30 11:14:26 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
2024-02-08 14:20:01 +00:00
|
|
|
"log/slog"
|
|
|
|
"os"
|
2022-06-30 11:14:26 +02:00
|
|
|
|
2024-05-24 15:14:16 +02:00
|
|
|
"github.com/edgelesssys/constellation/v2/hack/qemu-metadata-api/dhcp/dnsmasq"
|
|
|
|
"github.com/edgelesssys/constellation/v2/hack/qemu-metadata-api/dhcp/virtwrapper"
|
2022-09-21 13:47:57 +02:00
|
|
|
"github.com/edgelesssys/constellation/v2/hack/qemu-metadata-api/server"
|
|
|
|
"github.com/edgelesssys/constellation/v2/internal/logger"
|
2022-06-30 11:14:26 +02:00
|
|
|
"libvirt.org/go/libvirt"
|
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
bindPort := flag.String("port", "8080", "Port to bind to")
|
2024-05-24 15:14:16 +02:00
|
|
|
targetNetwork := flag.String("network", "constellation-network", "Name of the network in libvirt")
|
2022-10-05 09:11:30 +02:00
|
|
|
libvirtURI := flag.String("libvirt-uri", "qemu:///system", "URI of the libvirt connection")
|
2024-05-24 15:14:16 +02:00
|
|
|
leasesFileName := flag.String("dnsmasq-leases", "", "Path to the dnsmasq leases file")
|
2022-11-26 19:44:34 +01:00
|
|
|
initSecretHash := flag.String("initsecrethash", "", "brcypt hash of the init secret")
|
2022-06-30 11:14:26 +02:00
|
|
|
flag.Parse()
|
|
|
|
|
2024-02-08 14:20:01 +00:00
|
|
|
log := logger.NewJSONLogger(slog.LevelInfo)
|
2022-06-30 11:14:26 +02:00
|
|
|
|
2024-05-24 15:14:16 +02:00
|
|
|
var leaseGetter server.LeaseGetter
|
|
|
|
if *leasesFileName == "" {
|
|
|
|
conn, err := libvirt.NewConnect(*libvirtURI)
|
|
|
|
if err != nil {
|
|
|
|
log.With(slog.Any("error", err)).Error("Failed to connect to libvirt")
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
defer conn.Close()
|
|
|
|
leaseGetter = virtwrapper.New(conn, *targetNetwork)
|
|
|
|
} else {
|
|
|
|
log.Info("Using dnsmasq leases file")
|
|
|
|
leaseGetter = dnsmasq.New(*leasesFileName)
|
2022-06-30 11:14:26 +02:00
|
|
|
}
|
|
|
|
|
2024-05-24 15:14:16 +02:00
|
|
|
serv := server.New(log, *targetNetwork, *initSecretHash, leaseGetter)
|
2022-06-30 11:14:26 +02:00
|
|
|
if err := serv.ListenAndServe(*bindPort); err != nil {
|
2024-02-08 14:20:01 +00:00
|
|
|
log.With(slog.Any("error", err)).Error("Failed to serve")
|
|
|
|
os.Exit(1)
|
2022-06-30 11:14:26 +02:00
|
|
|
}
|
|
|
|
}
|