feat: wireguard / vproxy configuration
This commit is contained in:
@@ -45,6 +45,39 @@ func PushFileToContainer(container, filePath, destinationPath string) bool {
|
||||
return err == nil
|
||||
}
|
||||
|
||||
func RunWireguardDockerContainer(envFilePath string, cv ConfigValues) error {
|
||||
containerName := "vproxy"
|
||||
|
||||
removeExistingContainer(containerName)
|
||||
|
||||
absPath, err := filepath.Abs(envFilePath)
|
||||
if err != nil {
|
||||
return fmt.Errorf("erro ao resolver caminho absoluto: %w", err)
|
||||
}
|
||||
|
||||
cmd := exec.Command(
|
||||
"docker", "run", "-it", "-d",
|
||||
"--name", containerName,
|
||||
"--network", "app-dono_app",
|
||||
"--restart", "unless-stopped",
|
||||
"--cap-add=NET_ADMIN",
|
||||
"--device", "/dev/net/tun:/dev/net/tun",
|
||||
"--log-opt", "max-size=5m",
|
||||
"--log-opt", "max-file=1",
|
||||
"--env-file", absPath,
|
||||
wireguardImageName,
|
||||
)
|
||||
|
||||
out, err := cmd.CombinedOutput()
|
||||
if err != nil {
|
||||
return fmt.Errorf("docker run falhou: %w\noutput: %s", err, string(out))
|
||||
}
|
||||
|
||||
time.Sleep(2 * time.Second)
|
||||
containerID := strings.TrimSpace(string(out))
|
||||
return verifyContainerRunning(containerID)
|
||||
}
|
||||
|
||||
func RunAppClienteContainer(image, containerName, configPath, configDestinationPath string, cv ConfigValues) error {
|
||||
removeExistingContainer(containerName)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user