mirror of
https://github.com/AvengeMedia/DankMaterialShell.git
synced 2025-12-05 21:15:38 -05:00
- Dedicated view in settings - VPN profile management - Ethernet disconnection - Turn prompts into floating windows
677 lines
20 KiB
Go
677 lines
20 KiB
Go
package network
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"net"
|
|
|
|
"github.com/AvengeMedia/DankMaterialShell/core/internal/log"
|
|
"github.com/AvengeMedia/DankMaterialShell/core/internal/server/models"
|
|
)
|
|
|
|
type Request struct {
|
|
ID int `json:"id,omitempty"`
|
|
Method string `json:"method"`
|
|
Params map[string]interface{} `json:"params,omitempty"`
|
|
}
|
|
|
|
type SuccessResult struct {
|
|
Success bool `json:"success"`
|
|
Message string `json:"message"`
|
|
}
|
|
|
|
func HandleRequest(conn net.Conn, req Request, manager *Manager) {
|
|
switch req.Method {
|
|
case "network.getState":
|
|
handleGetState(conn, req, manager)
|
|
case "network.wifi.scan":
|
|
handleScanWiFi(conn, req, manager)
|
|
case "network.wifi.networks":
|
|
handleGetWiFiNetworks(conn, req, manager)
|
|
case "network.wifi.connect":
|
|
handleConnectWiFi(conn, req, manager)
|
|
case "network.wifi.disconnect":
|
|
handleDisconnectWiFi(conn, req, manager)
|
|
case "network.wifi.forget":
|
|
handleForgetWiFi(conn, req, manager)
|
|
case "network.wifi.toggle":
|
|
handleToggleWiFi(conn, req, manager)
|
|
case "network.wifi.enable":
|
|
handleEnableWiFi(conn, req, manager)
|
|
case "network.wifi.disable":
|
|
handleDisableWiFi(conn, req, manager)
|
|
case "network.ethernet.connect.config":
|
|
handleConnectEthernetSpecificConfig(conn, req, manager)
|
|
case "network.ethernet.connect":
|
|
handleConnectEthernet(conn, req, manager)
|
|
case "network.ethernet.disconnect":
|
|
handleDisconnectEthernet(conn, req, manager)
|
|
case "network.preference.set":
|
|
handleSetPreference(conn, req, manager)
|
|
case "network.info":
|
|
handleGetNetworkInfo(conn, req, manager)
|
|
case "network.ethernet.info":
|
|
handleGetWiredNetworkInfo(conn, req, manager)
|
|
case "network.subscribe":
|
|
handleSubscribe(conn, req, manager)
|
|
case "network.credentials.submit":
|
|
handleCredentialsSubmit(conn, req, manager)
|
|
case "network.credentials.cancel":
|
|
handleCredentialsCancel(conn, req, manager)
|
|
case "network.vpn.profiles":
|
|
handleListVPNProfiles(conn, req, manager)
|
|
case "network.vpn.active":
|
|
handleListActiveVPN(conn, req, manager)
|
|
case "network.vpn.connect":
|
|
handleConnectVPN(conn, req, manager)
|
|
case "network.vpn.disconnect":
|
|
handleDisconnectVPN(conn, req, manager)
|
|
case "network.vpn.disconnectAll":
|
|
handleDisconnectAllVPN(conn, req, manager)
|
|
case "network.vpn.clearCredentials":
|
|
handleClearVPNCredentials(conn, req, manager)
|
|
case "network.vpn.plugins":
|
|
handleListVPNPlugins(conn, req, manager)
|
|
case "network.vpn.import":
|
|
handleImportVPN(conn, req, manager)
|
|
case "network.vpn.getConfig":
|
|
handleGetVPNConfig(conn, req, manager)
|
|
case "network.vpn.updateConfig":
|
|
handleUpdateVPNConfig(conn, req, manager)
|
|
case "network.vpn.delete":
|
|
handleDeleteVPN(conn, req, manager)
|
|
case "network.vpn.setCredentials":
|
|
handleSetVPNCredentials(conn, req, manager)
|
|
case "network.wifi.setAutoconnect":
|
|
handleSetWiFiAutoconnect(conn, req, manager)
|
|
default:
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("unknown method: %s", req.Method))
|
|
}
|
|
}
|
|
|
|
func handleCredentialsSubmit(conn net.Conn, req Request, manager *Manager) {
|
|
token, ok := req.Params["token"].(string)
|
|
if !ok {
|
|
log.Warnf("handleCredentialsSubmit: missing or invalid token parameter")
|
|
models.RespondError(conn, req.ID, "missing or invalid 'token' parameter")
|
|
return
|
|
}
|
|
|
|
secretsRaw, ok := req.Params["secrets"].(map[string]interface{})
|
|
if !ok {
|
|
log.Warnf("handleCredentialsSubmit: missing or invalid secrets parameter")
|
|
models.RespondError(conn, req.ID, "missing or invalid 'secrets' parameter")
|
|
return
|
|
}
|
|
|
|
secrets := make(map[string]string)
|
|
for k, v := range secretsRaw {
|
|
if str, ok := v.(string); ok {
|
|
secrets[k] = str
|
|
}
|
|
}
|
|
|
|
save := true
|
|
if saveParam, ok := req.Params["save"].(bool); ok {
|
|
save = saveParam
|
|
}
|
|
|
|
if err := manager.SubmitCredentials(token, secrets, save); err != nil {
|
|
log.Warnf("handleCredentialsSubmit: failed to submit credentials: %v", err)
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
|
|
log.Infof("handleCredentialsSubmit: credentials submitted successfully")
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "credentials submitted"})
|
|
}
|
|
|
|
func handleCredentialsCancel(conn net.Conn, req Request, manager *Manager) {
|
|
token, ok := req.Params["token"].(string)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing or invalid 'token' parameter")
|
|
return
|
|
}
|
|
|
|
if err := manager.CancelCredentials(token); err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "credentials cancelled"})
|
|
}
|
|
|
|
func handleGetState(conn net.Conn, req Request, manager *Manager) {
|
|
state := manager.GetState()
|
|
models.Respond(conn, req.ID, state)
|
|
}
|
|
|
|
func handleScanWiFi(conn net.Conn, req Request, manager *Manager) {
|
|
device, _ := req.Params["device"].(string)
|
|
var err error
|
|
if device != "" {
|
|
err = manager.ScanWiFiDevice(device)
|
|
} else {
|
|
err = manager.ScanWiFi()
|
|
}
|
|
if err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "scanning"})
|
|
}
|
|
|
|
func handleGetWiFiNetworks(conn net.Conn, req Request, manager *Manager) {
|
|
networks := manager.GetWiFiNetworks()
|
|
models.Respond(conn, req.ID, networks)
|
|
}
|
|
|
|
func handleConnectWiFi(conn net.Conn, req Request, manager *Manager) {
|
|
ssid, ok := req.Params["ssid"].(string)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing or invalid 'ssid' parameter")
|
|
return
|
|
}
|
|
|
|
var connReq ConnectionRequest
|
|
connReq.SSID = ssid
|
|
|
|
if password, ok := req.Params["password"].(string); ok {
|
|
connReq.Password = password
|
|
}
|
|
if username, ok := req.Params["username"].(string); ok {
|
|
connReq.Username = username
|
|
}
|
|
if device, ok := req.Params["device"].(string); ok {
|
|
connReq.Device = device
|
|
}
|
|
|
|
if interactive, ok := req.Params["interactive"].(bool); ok {
|
|
connReq.Interactive = interactive
|
|
} else {
|
|
state := manager.GetState()
|
|
alreadyConnected := state.WiFiConnected && state.WiFiSSID == ssid
|
|
|
|
if alreadyConnected && connReq.Device == "" {
|
|
connReq.Interactive = false
|
|
} else {
|
|
networkInfo, err := manager.GetNetworkInfo(ssid)
|
|
isSaved := err == nil && networkInfo.Saved
|
|
|
|
if isSaved {
|
|
connReq.Interactive = false
|
|
} else if err == nil && networkInfo.Secured && connReq.Password == "" && connReq.Username == "" {
|
|
connReq.Interactive = true
|
|
}
|
|
}
|
|
}
|
|
|
|
if anonymousIdentity, ok := req.Params["anonymousIdentity"].(string); ok {
|
|
connReq.AnonymousIdentity = anonymousIdentity
|
|
}
|
|
if domainSuffixMatch, ok := req.Params["domainSuffixMatch"].(string); ok {
|
|
connReq.DomainSuffixMatch = domainSuffixMatch
|
|
}
|
|
if eapMethod, ok := req.Params["eapMethod"].(string); ok {
|
|
connReq.EAPMethod = eapMethod
|
|
}
|
|
if phase2Auth, ok := req.Params["phase2Auth"].(string); ok {
|
|
connReq.Phase2Auth = phase2Auth
|
|
}
|
|
if caCertPath, ok := req.Params["caCertPath"].(string); ok {
|
|
connReq.CACertPath = caCertPath
|
|
}
|
|
if clientCertPath, ok := req.Params["clientCertPath"].(string); ok {
|
|
connReq.ClientCertPath = clientCertPath
|
|
}
|
|
if privateKeyPath, ok := req.Params["privateKeyPath"].(string); ok {
|
|
connReq.PrivateKeyPath = privateKeyPath
|
|
}
|
|
if useSystemCACerts, ok := req.Params["useSystemCACerts"].(bool); ok {
|
|
connReq.UseSystemCACerts = &useSystemCACerts
|
|
}
|
|
|
|
if err := manager.ConnectWiFi(connReq); err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "connecting"})
|
|
}
|
|
|
|
func handleDisconnectWiFi(conn net.Conn, req Request, manager *Manager) {
|
|
device, _ := req.Params["device"].(string)
|
|
var err error
|
|
if device != "" {
|
|
err = manager.DisconnectWiFiDevice(device)
|
|
} else {
|
|
err = manager.DisconnectWiFi()
|
|
}
|
|
if err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "disconnected"})
|
|
}
|
|
|
|
func handleForgetWiFi(conn net.Conn, req Request, manager *Manager) {
|
|
ssid, ok := req.Params["ssid"].(string)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing or invalid 'ssid' parameter")
|
|
return
|
|
}
|
|
|
|
if err := manager.ForgetWiFiNetwork(ssid); err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "forgotten"})
|
|
}
|
|
|
|
func handleToggleWiFi(conn net.Conn, req Request, manager *Manager) {
|
|
if err := manager.ToggleWiFi(); err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
|
|
state := manager.GetState()
|
|
models.Respond(conn, req.ID, map[string]bool{"enabled": state.WiFiEnabled})
|
|
}
|
|
|
|
func handleEnableWiFi(conn net.Conn, req Request, manager *Manager) {
|
|
if err := manager.EnableWiFi(); err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
models.Respond(conn, req.ID, map[string]bool{"enabled": true})
|
|
}
|
|
|
|
func handleDisableWiFi(conn net.Conn, req Request, manager *Manager) {
|
|
if err := manager.DisableWiFi(); err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
models.Respond(conn, req.ID, map[string]bool{"enabled": false})
|
|
}
|
|
|
|
func handleConnectEthernetSpecificConfig(conn net.Conn, req Request, manager *Manager) {
|
|
uuid, ok := req.Params["uuid"].(string)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing or invalid 'uuid' parameter")
|
|
return
|
|
}
|
|
if err := manager.activateConnection(uuid); err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "connecting"})
|
|
}
|
|
|
|
func handleConnectEthernet(conn net.Conn, req Request, manager *Manager) {
|
|
if err := manager.ConnectEthernet(); err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "connecting"})
|
|
}
|
|
|
|
func handleDisconnectEthernet(conn net.Conn, req Request, manager *Manager) {
|
|
device, _ := req.Params["device"].(string)
|
|
var err error
|
|
if device != "" {
|
|
err = manager.DisconnectEthernetDevice(device)
|
|
} else {
|
|
err = manager.DisconnectEthernet()
|
|
}
|
|
if err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "disconnected"})
|
|
}
|
|
|
|
func handleSetPreference(conn net.Conn, req Request, manager *Manager) {
|
|
preference, ok := req.Params["preference"].(string)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing or invalid 'preference' parameter")
|
|
return
|
|
}
|
|
|
|
if err := manager.SetConnectionPreference(ConnectionPreference(preference)); err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, map[string]string{"preference": preference})
|
|
}
|
|
|
|
func handleGetNetworkInfo(conn net.Conn, req Request, manager *Manager) {
|
|
ssid, ok := req.Params["ssid"].(string)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing or invalid 'ssid' parameter")
|
|
return
|
|
}
|
|
|
|
network, err := manager.GetNetworkInfoDetailed(ssid)
|
|
if err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, network)
|
|
}
|
|
|
|
func handleGetWiredNetworkInfo(conn net.Conn, req Request, manager *Manager) {
|
|
uuid, ok := req.Params["uuid"].(string)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing or invalid 'uuid' parameter")
|
|
return
|
|
}
|
|
|
|
network, err := manager.GetWiredNetworkInfoDetailed(uuid)
|
|
if err != nil {
|
|
models.RespondError(conn, req.ID, err.Error())
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, network)
|
|
}
|
|
|
|
func handleSubscribe(conn net.Conn, req Request, manager *Manager) {
|
|
clientID := fmt.Sprintf("client-%p", conn)
|
|
stateChan := manager.Subscribe(clientID)
|
|
defer manager.Unsubscribe(clientID)
|
|
|
|
initialState := manager.GetState()
|
|
event := NetworkEvent{
|
|
Type: EventStateChanged,
|
|
Data: initialState,
|
|
}
|
|
if err := json.NewEncoder(conn).Encode(models.Response[NetworkEvent]{
|
|
ID: req.ID,
|
|
Result: &event,
|
|
}); err != nil {
|
|
return
|
|
}
|
|
|
|
for state := range stateChan {
|
|
event := NetworkEvent{
|
|
Type: EventStateChanged,
|
|
Data: state,
|
|
}
|
|
if err := json.NewEncoder(conn).Encode(models.Response[NetworkEvent]{
|
|
Result: &event,
|
|
}); err != nil {
|
|
return
|
|
}
|
|
}
|
|
}
|
|
|
|
func handleListVPNProfiles(conn net.Conn, req Request, manager *Manager) {
|
|
profiles, err := manager.ListVPNProfiles()
|
|
if err != nil {
|
|
log.Warnf("handleListVPNProfiles: failed to list profiles: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to list VPN profiles: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, profiles)
|
|
}
|
|
|
|
func handleListActiveVPN(conn net.Conn, req Request, manager *Manager) {
|
|
active, err := manager.ListActiveVPN()
|
|
if err != nil {
|
|
log.Warnf("handleListActiveVPN: failed to list active VPNs: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to list active VPNs: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, active)
|
|
}
|
|
|
|
func handleConnectVPN(conn net.Conn, req Request, manager *Manager) {
|
|
uuidOrName, ok := req.Params["uuidOrName"].(string)
|
|
if !ok {
|
|
name, nameOk := req.Params["name"].(string)
|
|
uuid, uuidOk := req.Params["uuid"].(string)
|
|
if nameOk {
|
|
uuidOrName = name
|
|
} else if uuidOk {
|
|
uuidOrName = uuid
|
|
} else {
|
|
log.Warnf("handleConnectVPN: missing uuidOrName/name/uuid parameter")
|
|
models.RespondError(conn, req.ID, "missing 'uuidOrName', 'name', or 'uuid' parameter")
|
|
return
|
|
}
|
|
}
|
|
|
|
// Default to true - only allow one VPN connection at a time
|
|
singleActive := true
|
|
if sa, ok := req.Params["singleActive"].(bool); ok {
|
|
singleActive = sa
|
|
}
|
|
|
|
if err := manager.ConnectVPN(uuidOrName, singleActive); err != nil {
|
|
log.Warnf("handleConnectVPN: failed to connect: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to connect VPN: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "VPN connection initiated"})
|
|
}
|
|
|
|
func handleDisconnectVPN(conn net.Conn, req Request, manager *Manager) {
|
|
uuidOrName, ok := req.Params["uuidOrName"].(string)
|
|
if !ok {
|
|
name, nameOk := req.Params["name"].(string)
|
|
uuid, uuidOk := req.Params["uuid"].(string)
|
|
if nameOk {
|
|
uuidOrName = name
|
|
} else if uuidOk {
|
|
uuidOrName = uuid
|
|
} else {
|
|
log.Warnf("handleDisconnectVPN: missing uuidOrName/name/uuid parameter")
|
|
models.RespondError(conn, req.ID, "missing 'uuidOrName', 'name', or 'uuid' parameter")
|
|
return
|
|
}
|
|
}
|
|
|
|
if err := manager.DisconnectVPN(uuidOrName); err != nil {
|
|
log.Warnf("handleDisconnectVPN: failed to disconnect: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to disconnect VPN: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "VPN disconnected"})
|
|
}
|
|
|
|
func handleDisconnectAllVPN(conn net.Conn, req Request, manager *Manager) {
|
|
if err := manager.DisconnectAllVPN(); err != nil {
|
|
log.Warnf("handleDisconnectAllVPN: failed: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to disconnect all VPNs: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "All VPNs disconnected"})
|
|
}
|
|
|
|
func handleClearVPNCredentials(conn net.Conn, req Request, manager *Manager) {
|
|
uuidOrName, ok := req.Params["uuid"].(string)
|
|
if !ok {
|
|
uuidOrName, ok = req.Params["name"].(string)
|
|
}
|
|
if !ok {
|
|
uuidOrName, ok = req.Params["uuidOrName"].(string)
|
|
}
|
|
if !ok {
|
|
log.Warnf("handleClearVPNCredentials: missing uuidOrName/name/uuid parameter")
|
|
models.RespondError(conn, req.ID, "missing uuidOrName/name/uuid parameter")
|
|
return
|
|
}
|
|
|
|
if err := manager.ClearVPNCredentials(uuidOrName); err != nil {
|
|
log.Warnf("handleClearVPNCredentials: failed: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to clear VPN credentials: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "VPN credentials cleared"})
|
|
}
|
|
|
|
func handleSetWiFiAutoconnect(conn net.Conn, req Request, manager *Manager) {
|
|
ssid, ok := req.Params["ssid"].(string)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing or invalid 'ssid' parameter")
|
|
return
|
|
}
|
|
|
|
autoconnect, ok := req.Params["autoconnect"].(bool)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing or invalid 'autoconnect' parameter")
|
|
return
|
|
}
|
|
|
|
if err := manager.SetWiFiAutoconnect(ssid, autoconnect); err != nil {
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to set autoconnect: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "autoconnect updated"})
|
|
}
|
|
|
|
func handleListVPNPlugins(conn net.Conn, req Request, manager *Manager) {
|
|
plugins, err := manager.ListVPNPlugins()
|
|
if err != nil {
|
|
log.Warnf("handleListVPNPlugins: failed to list plugins: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to list VPN plugins: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, plugins)
|
|
}
|
|
|
|
func handleImportVPN(conn net.Conn, req Request, manager *Manager) {
|
|
filePath, ok := req.Params["file"].(string)
|
|
if !ok {
|
|
filePath, ok = req.Params["path"].(string)
|
|
}
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing 'file' or 'path' parameter")
|
|
return
|
|
}
|
|
|
|
name, _ := req.Params["name"].(string)
|
|
|
|
result, err := manager.ImportVPN(filePath, name)
|
|
if err != nil {
|
|
log.Warnf("handleImportVPN: failed to import: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to import VPN: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, result)
|
|
}
|
|
|
|
func handleGetVPNConfig(conn net.Conn, req Request, manager *Manager) {
|
|
uuidOrName, ok := req.Params["uuid"].(string)
|
|
if !ok {
|
|
uuidOrName, ok = req.Params["name"].(string)
|
|
}
|
|
if !ok {
|
|
uuidOrName, ok = req.Params["uuidOrName"].(string)
|
|
}
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing 'uuid', 'name', or 'uuidOrName' parameter")
|
|
return
|
|
}
|
|
|
|
config, err := manager.GetVPNConfig(uuidOrName)
|
|
if err != nil {
|
|
log.Warnf("handleGetVPNConfig: failed to get config: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to get VPN config: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, config)
|
|
}
|
|
|
|
func handleUpdateVPNConfig(conn net.Conn, req Request, manager *Manager) {
|
|
connUUID, ok := req.Params["uuid"].(string)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing 'uuid' parameter")
|
|
return
|
|
}
|
|
|
|
updates := make(map[string]interface{})
|
|
|
|
if name, ok := req.Params["name"].(string); ok {
|
|
updates["name"] = name
|
|
}
|
|
if autoconnect, ok := req.Params["autoconnect"].(bool); ok {
|
|
updates["autoconnect"] = autoconnect
|
|
}
|
|
if data, ok := req.Params["data"].(map[string]interface{}); ok {
|
|
updates["data"] = data
|
|
}
|
|
|
|
if len(updates) == 0 {
|
|
models.RespondError(conn, req.ID, "no updates provided")
|
|
return
|
|
}
|
|
|
|
if err := manager.UpdateVPNConfig(connUUID, updates); err != nil {
|
|
log.Warnf("handleUpdateVPNConfig: failed to update: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to update VPN config: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "VPN config updated"})
|
|
}
|
|
|
|
func handleDeleteVPN(conn net.Conn, req Request, manager *Manager) {
|
|
uuidOrName, ok := req.Params["uuid"].(string)
|
|
if !ok {
|
|
uuidOrName, ok = req.Params["name"].(string)
|
|
}
|
|
if !ok {
|
|
uuidOrName, ok = req.Params["uuidOrName"].(string)
|
|
}
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing 'uuid', 'name', or 'uuidOrName' parameter")
|
|
return
|
|
}
|
|
|
|
if err := manager.DeleteVPN(uuidOrName); err != nil {
|
|
log.Warnf("handleDeleteVPN: failed to delete: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to delete VPN: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "VPN deleted"})
|
|
}
|
|
|
|
func handleSetVPNCredentials(conn net.Conn, req Request, manager *Manager) {
|
|
connUUID, ok := req.Params["uuid"].(string)
|
|
if !ok {
|
|
models.RespondError(conn, req.ID, "missing 'uuid' parameter")
|
|
return
|
|
}
|
|
|
|
username, _ := req.Params["username"].(string)
|
|
password, _ := req.Params["password"].(string)
|
|
|
|
save := true
|
|
if saveParam, ok := req.Params["save"].(bool); ok {
|
|
save = saveParam
|
|
}
|
|
|
|
if err := manager.SetVPNCredentials(connUUID, username, password, save); err != nil {
|
|
log.Warnf("handleSetVPNCredentials: failed to set credentials: %v", err)
|
|
models.RespondError(conn, req.ID, fmt.Sprintf("failed to set VPN credentials: %v", err))
|
|
return
|
|
}
|
|
|
|
models.Respond(conn, req.ID, SuccessResult{Success: true, Message: "VPN credentials set"})
|
|
}
|