mirror of
https://github.com/jc21/nginx-proxy-manager.git
synced 2024-08-30 18:22:48 +00:00
44 lines
837 B
Go
44 lines
837 B
Go
package nginx
|
|
|
|
import (
|
|
"os/exec"
|
|
|
|
"npm/internal/logger"
|
|
|
|
"github.com/rotisserie/eris"
|
|
)
|
|
|
|
func reloadNginx() (string, error) {
|
|
return shExec([]string{"-s", "reload"})
|
|
}
|
|
|
|
func getNginxFilePath() (string, error) {
|
|
path, err := exec.LookPath("nginx")
|
|
if err != nil {
|
|
return path, eris.Wrapf(err, "Cannot find nginx execuatable script in PATH")
|
|
}
|
|
return path, nil
|
|
}
|
|
|
|
// shExec executes nginx with arguments
|
|
func shExec(args []string) (string, error) {
|
|
ng, err := getNginxFilePath()
|
|
if err != nil {
|
|
logger.Error("NginxError", err)
|
|
return "", err
|
|
}
|
|
|
|
logger.Debug("CMD: %s %v", ng, args)
|
|
// nolint: gosec
|
|
c := exec.Command(ng, args...)
|
|
|
|
b, e := c.CombinedOutput()
|
|
|
|
if e != nil {
|
|
logger.Error("NginxError", eris.Wrapf(err, "Command error: %s -- %v\n%+v", ng, args, e))
|
|
logger.Warn(string(b))
|
|
}
|
|
|
|
return string(b), e
|
|
}
|