change - add default configuration paths (#121)

This commit is contained in:
Amirhossein Shaerpour 2024-07-22 17:41:26 +03:30 committed by GitHub
parent ff99bfd4a6
commit 42a097d490
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 24 additions and 3 deletions

View file

@ -33,7 +33,7 @@ of wireproxy by [@juev](https://github.com/juev).
# Usage
```
./wireproxy -c [path to config]
./wireproxy [-c path to config]
```
```
@ -47,6 +47,7 @@ Arguments:
-h --help Print help information
-c --config Path of configuration file
Default paths: /etc/wireproxy/wireproxy.conf, $HOME/.config/wireproxy.conf
-s --silent Silent mode
-d --daemon Make wireproxy run in background
-i --info Specify the address and port for exposing health status

View file

@ -22,6 +22,12 @@ import (
// an argument to denote that this process was spawned by -d
const daemonProcess = "daemon-process"
// default paths for wireproxy config file
var default_config_paths = []string {
"/etc/wireproxy/wireproxy.conf",
os.Getenv("HOME")+"/.config/wireproxy.conf",
}
var version = "1.0.8-dev"
func panicIfError(err error) {
@ -51,6 +57,16 @@ func executablePath() string {
return programPath
}
// check if default config file paths exist
func configFilePath() (string, bool) {
for _, path := range default_config_paths {
if _, err := os.Stat(path); err == nil {
return path, true
}
}
return "", false
}
func lock(stage string) {
switch stage {
case "boot":
@ -177,9 +193,13 @@ func main() {
}
if *config == "" {
if path, config_exist := configFilePath(); config_exist {
*config = path
} else {
fmt.Println("configuration path is required")
return
}
}
if !*daemon {
lock("read-config")