aboutsummaryrefslogtreecommitdiffstats
path: root/wireguard-go-bridge/src/api-ios.go
diff options
context:
space:
mode:
Diffstat (limited to 'wireguard-go-bridge/src/api-ios.go')
-rw-r--r--wireguard-go-bridge/src/api-ios.go26
1 files changed, 20 insertions, 6 deletions
diff --git a/wireguard-go-bridge/src/api-ios.go b/wireguard-go-bridge/src/api-ios.go
index ace83d9..de730eb 100644
--- a/wireguard-go-bridge/src/api-ios.go
+++ b/wireguard-go-bridge/src/api-ios.go
@@ -15,10 +15,10 @@ import "C"
import (
"bufio"
+ "bytes"
"errors"
"git.zx2c4.com/wireguard-go/tun"
"golang.org/x/sys/unix"
- "io/ioutil"
"log"
"math"
"os"
@@ -94,8 +94,7 @@ func wgTurnOn(settings string, tunFd int32) int32 {
logger.Info.Println("Attaching to interface")
device := NewDevice(tun, logger)
- bufferedSettings := bufio.NewReadWriter(bufio.NewReader(strings.NewReader(settings)), bufio.NewWriter(ioutil.Discard))
- setError := ipcSetOperation(device, bufferedSettings)
+ setError := ipcSetOperation(device, bufio.NewReader(strings.NewReader(settings)))
if setError != nil {
logger.Error.Println(setError)
return -1
@@ -133,15 +132,30 @@ func wgSetConfig(tunnelHandle int32, settings string) int64 {
if !ok {
return 0
}
- bufferedSettings := bufio.NewReadWriter(bufio.NewReader(strings.NewReader(settings)), bufio.NewWriter(ioutil.Discard))
- err := ipcSetOperation(device, bufferedSettings)
+ err := ipcSetOperation(device, bufio.NewReader(strings.NewReader(settings)))
if err != nil {
device.log.Error.Println(err)
- return err.Code
+ return err.int64
}
return 0
}
+//export wgGetConfig
+func wgGetConfig(tunnelHandle int32) *C.char {
+ device, ok := tunnelHandles[tunnelHandle]
+ if !ok {
+ return nil
+ }
+ settings := new(bytes.Buffer)
+ writer := bufio.NewWriter(settings)
+ err := ipcGetOperation(device, writer)
+ if err != nil {
+ return nil
+ }
+ writer.Flush()
+ return C.CString(settings.String())
+}
+
//export wgBindInterfaceScope
func wgBindInterfaceScope(tunnelHandle int32, ifscope int32) {
var operr error