2024-10-11 17:22:31 -05:00
|
|
|
// Copyright 2016 The go-qemu Authors.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2024-10-11 23:01:55 -05:00
|
|
|
"embed"
|
2024-10-11 17:22:31 -05:00
|
|
|
"net"
|
2024-10-26 10:34:04 -05:00
|
|
|
"os"
|
|
|
|
"path/filepath"
|
2024-10-11 17:22:31 -05:00
|
|
|
"time"
|
|
|
|
|
2024-10-17 17:15:49 -05:00
|
|
|
"github.com/digitalocean/go-qemu/hypervisor"
|
2024-10-26 10:34:04 -05:00
|
|
|
"go.wit.com/dev/alexflint/arg"
|
|
|
|
pb "go.wit.com/lib/protobuf/virtbuf"
|
|
|
|
"go.wit.com/log"
|
2024-10-11 17:22:31 -05:00
|
|
|
)
|
|
|
|
|
2024-10-11 22:39:19 -05:00
|
|
|
var Version string
|
2024-10-11 17:22:31 -05:00
|
|
|
|
2024-10-11 23:01:55 -05:00
|
|
|
//go:embed resources/*
|
|
|
|
var resources embed.FS
|
|
|
|
|
2024-10-11 23:06:47 -05:00
|
|
|
var hv *hypervisor.Hypervisor
|
|
|
|
|
2024-10-11 17:22:31 -05:00
|
|
|
func main() {
|
2024-10-26 10:34:04 -05:00
|
|
|
if os.Getenv("VIRTIGO_HOME") == "" {
|
|
|
|
homeDir, _ := os.UserHomeDir()
|
|
|
|
fullpath := filepath.Join(homeDir, ".config/virtigo")
|
|
|
|
os.Setenv("VIRTIGO_HOME", fullpath)
|
|
|
|
}
|
|
|
|
var pp *arg.Parser
|
|
|
|
pp = arg.MustParse(&argv)
|
|
|
|
|
|
|
|
if pp == nil {
|
|
|
|
pp.WriteHelp(os.Stdout)
|
|
|
|
os.Exit(0)
|
|
|
|
}
|
|
|
|
|
|
|
|
me.cluster = new(pb.Cluster)
|
|
|
|
if err := me.cluster.ConfigLoad(); err != nil {
|
|
|
|
log.Info("config file error:", err)
|
|
|
|
os.Exit(0)
|
|
|
|
}
|
|
|
|
|
|
|
|
for i, e := range me.cluster.Events {
|
|
|
|
log.Info("Event", i, e)
|
|
|
|
}
|
|
|
|
|
|
|
|
if argv.Start != "" {
|
|
|
|
newStart(argv.Start)
|
|
|
|
os.Exit(0)
|
|
|
|
}
|
|
|
|
|
|
|
|
log.DaemonMode(true)
|
2024-10-11 17:22:31 -05:00
|
|
|
|
|
|
|
// fmt.Printf("\nConnecting to %s://%s\n", *network, *address)
|
|
|
|
newConn := func() (net.Conn, error) {
|
|
|
|
// return net.DialTimeout(*network, *address, *timeout)
|
2024-10-11 22:39:19 -05:00
|
|
|
return net.DialTimeout("unix", "/var/run/libvirt/libvirt-sock", 2*time.Second)
|
2024-10-11 17:22:31 -05:00
|
|
|
// return net.DialTimeout("tcp", "farm02:16514", *timeout)
|
|
|
|
}
|
|
|
|
|
|
|
|
driver := hypervisor.NewRPCDriver(newConn)
|
2024-10-11 23:06:47 -05:00
|
|
|
hv = hypervisor.New(driver)
|
2024-10-11 17:22:31 -05:00
|
|
|
|
2024-10-11 23:06:47 -05:00
|
|
|
poolHypervisor(hv)
|
2024-10-11 23:01:55 -05:00
|
|
|
|
|
|
|
startHTTP()
|
2024-10-11 17:22:31 -05:00
|
|
|
}
|