func main() { var err error flag.Parse() Conf, err = common.InitConfig(common.ConfFile) if err != nil { fmt.Printf("initConfig(\"%s\") failed (%s)\n", common.ConfFile, err.Error()) return } errLogger, _ := common.NewErrorLogger(Conf.LogPath, "error") frames.RunServer(Conf.TcpAddr, Conf.MonitorAddr, errLogger) }
func main() { path, err := filepath.Abs(os.Args[0]) if nil != err { fmt.Println(err) return } common.Home, _ = filepath.Split(path) as_server := flag.Bool("server", false, "Run as remote proxy server") conf := flag.String("file", common.Home+common.Product+".conf", "Specify config file for gsnova") event.Init() flag.Parse() if *as_server { remote.LaunchC4HttpServer() return } common.CfgFile = *conf common.InitLogger() common.InitConfig() proxy.InitHosts() proxy.InitSpac() proxy.InitGoogle() runtime.GOMAXPROCS(runtime.NumCPU()) var gae proxy.GAE var c4 proxy.C4 err = c4.Init() if nil != err { log.Printf("[WARN]Failed to init C4:%s\n", err.Error()) } err = proxy.InitSSH() if nil != err { log.Printf("[WARN]Failed to init SSH:%s\n", err.Error()) } err = gae.Init() if nil != err { log.Printf("[WARN]Failed to init GAE:%s\n", err.Error()) } proxy.InitSelfWebServer() proxy.PostInitSpac() log.Printf("=============Start %s %s==============\n", common.Product, common.Version) if proxy.C4Enable { if addr, exist := common.Cfg.GetProperty("C4", "Listen"); exist { go startLocalProxyServer(addr, proxy.C4_PROXY_SERVER) } } if proxy.SSHEnable { if addr, exist := common.Cfg.GetProperty("SSH", "Listen"); exist { go startLocalProxyServer(addr, proxy.SSH_PROXY_SERVER) } } if proxy.GAEEnable { //init fake cert if GAE inited success common.LoadRootCA() if addr, exist := common.Cfg.GetProperty("GAE", "Listen"); exist { go startLocalProxyServer(addr, proxy.GAE_PROXY_SERVER) } } addr, exist := common.Cfg.GetProperty("LocalServer", "Listen") if !exist { log.Fatalln("No config [LocalServer]->Listen found") } testEntry() startLocalProxyServer(addr, proxy.GLOBAL_PROXY_SERVER) //launchSystemTray() }