mirror of
https://github.com/schollz/croc.git
synced 2025-10-11 13:21:00 +02:00
allow remembering --internal-dns flag
This commit is contained in:
parent
df78f3333d
commit
1d3c822ef3
3 changed files with 54 additions and 24 deletions
|
@ -135,28 +135,6 @@ func Run() (err error) {
|
||||||
return app.Run(os.Args)
|
return app.Run(os.Args)
|
||||||
}
|
}
|
||||||
|
|
||||||
func getConfigDir() (homedir string, err error) {
|
|
||||||
homedir, err = os.UserHomeDir()
|
|
||||||
if err != nil {
|
|
||||||
log.Error(err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if envHomedir, isSet := os.LookupEnv("CROC_CONFIG_DIR"); isSet {
|
|
||||||
homedir = envHomedir
|
|
||||||
} else if xdgConfigHome, isSet := os.LookupEnv("XDG_CONFIG_HOME"); isSet {
|
|
||||||
homedir = path.Join(xdgConfigHome, "croc")
|
|
||||||
} else {
|
|
||||||
homedir = path.Join(homedir, ".config", "croc")
|
|
||||||
}
|
|
||||||
|
|
||||||
if _, err = os.Stat(homedir); os.IsNotExist(err) {
|
|
||||||
log.Debugf("creating home directory %s", homedir)
|
|
||||||
err = os.MkdirAll(homedir, 0700)
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func setDebugLevel(c *cli.Context) {
|
func setDebugLevel(c *cli.Context) {
|
||||||
if c.Bool("debug") {
|
if c.Bool("debug") {
|
||||||
log.SetLevel("debug")
|
log.SetLevel("debug")
|
||||||
|
@ -167,7 +145,7 @@ func setDebugLevel(c *cli.Context) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func getConfigFile() string {
|
func getConfigFile() string {
|
||||||
configFile, err := getConfigDir()
|
configFile, err := utils.GetConfigDir()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error(err)
|
log.Error(err)
|
||||||
return ""
|
return ""
|
||||||
|
@ -446,7 +424,7 @@ func receive(c *cli.Context) (err error) {
|
||||||
|
|
||||||
// load options here
|
// load options here
|
||||||
setDebugLevel(c)
|
setDebugLevel(c)
|
||||||
configFile, err := getConfigDir()
|
configFile, err := utils.GetConfigDir()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error(err)
|
log.Error(err)
|
||||||
return
|
return
|
||||||
|
|
|
@ -5,6 +5,9 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
"os"
|
"os"
|
||||||
|
"path"
|
||||||
|
|
||||||
|
"github.com/schollz/croc/v9/src/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
// TCP_BUFFER_SIZE is the maximum packet size
|
// TCP_BUFFER_SIZE is the maximum packet size
|
||||||
|
@ -41,12 +44,39 @@ var publicDns = []string{
|
||||||
"[2620:119:53::53]", // Cisco OpenDNS
|
"[2620:119:53::53]", // Cisco OpenDNS
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getConfigFile() (fname string, err error) {
|
||||||
|
configFile, err := utils.GetConfigDir()
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fname = path.Join(configFile, "internal-dns")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
|
doRemember := false
|
||||||
for _, flag := range os.Args {
|
for _, flag := range os.Args {
|
||||||
if flag == "--internal-dns" {
|
if flag == "--internal-dns" {
|
||||||
INTERNAL_DNS = true
|
INTERNAL_DNS = true
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
if flag == "--remember" {
|
||||||
|
doRemember = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if doRemember {
|
||||||
|
// save in config file
|
||||||
|
fname, err := getConfigFile()
|
||||||
|
if err == nil {
|
||||||
|
f, _ := os.Create(fname)
|
||||||
|
f.Close()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if !INTERNAL_DNS {
|
||||||
|
fname, err := getConfigFile()
|
||||||
|
if err == nil {
|
||||||
|
INTERNAL_DNS = utils.Exists(fname)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
var err error
|
var err error
|
||||||
DEFAULT_RELAY, err = lookup(DEFAULT_RELAY)
|
DEFAULT_RELAY, err = lookup(DEFAULT_RELAY)
|
||||||
|
|
|
@ -15,6 +15,7 @@ import (
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
|
"path"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -23,6 +24,27 @@ import (
|
||||||
"github.com/schollz/mnemonicode"
|
"github.com/schollz/mnemonicode"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// Get or create home directory
|
||||||
|
func GetConfigDir() (homedir string, err error) {
|
||||||
|
homedir, err = os.UserHomeDir()
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if envHomedir, isSet := os.LookupEnv("CROC_CONFIG_DIR"); isSet {
|
||||||
|
homedir = envHomedir
|
||||||
|
} else if xdgConfigHome, isSet := os.LookupEnv("XDG_CONFIG_HOME"); isSet {
|
||||||
|
homedir = path.Join(xdgConfigHome, "croc")
|
||||||
|
} else {
|
||||||
|
homedir = path.Join(homedir, ".config", "croc")
|
||||||
|
}
|
||||||
|
|
||||||
|
if _, err = os.Stat(homedir); os.IsNotExist(err) {
|
||||||
|
err = os.MkdirAll(homedir, 0700)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
// Exists reports whether the named file or directory exists.
|
// Exists reports whether the named file or directory exists.
|
||||||
func Exists(name string) bool {
|
func Exists(name string) bool {
|
||||||
if _, err := os.Stat(name); err != nil {
|
if _, err := os.Stat(name); err != nil {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue