0
0
mirror of https://github.com/vx3r/wg-gen-web.git synced 2025-01-07 03:24:37 +00:00

Merge pull request #34 from sphen13/client_allowed_ips

default client allowed ips in server config
This commit is contained in:
vx3r 2020-04-15 12:19:58 +09:00 committed by GitHub
commit 9e4b22d0ef
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 44 additions and 1 deletions

View File

@ -36,6 +36,10 @@ func ReadServer() (*model.Server, error) {
server.Dns = append(server.Dns, "fd9f::10:0:0:2") server.Dns = append(server.Dns, "fd9f::10:0:0:2")
server.Dns = append(server.Dns, "10.0.0.2") server.Dns = append(server.Dns, "10.0.0.2")


server.AllowedIPs = make([]string, 0)
server.AllowedIPs = append(server.AllowedIPs, "0.0.0.0/0")
server.AllowedIPs = append(server.AllowedIPs, "::/0")

server.PersistentKeepalive = 16 server.PersistentKeepalive = 16
server.Mtu = 0 server.Mtu = 0
server.PreUp = "echo WireGuard PreUp" server.PreUp = "echo WireGuard PreUp"

View File

@ -16,6 +16,7 @@ type Server struct {
Endpoint string `json:"endpoint"` Endpoint string `json:"endpoint"`
PersistentKeepalive int `json:"persistentKeepalive"` PersistentKeepalive int `json:"persistentKeepalive"`
Dns []string `json:"dns"` Dns []string `json:"dns"`
AllowedIPs []string `json:"allowedips"`
PreUp string `json:"preUp"` PreUp string `json:"preUp"`
PostUp string `json:"postUp"` PostUp string `json:"postUp"`
PreDown string `json:"preDown"` PreDown string `json:"preDown"`
@ -59,6 +60,12 @@ func (a Server) IsValid() []error {
errs = append(errs, fmt.Errorf("dns %s is invalid", dns)) errs = append(errs, fmt.Errorf("dns %s is invalid", dns))
} }
} }
// check if the allowedIPs are valid
for _, allowedIP := range a.AllowedIPs {
if !util.IsValidCidr(allowedIP) {
errs = append(errs, fmt.Errorf("allowedIP %s is invalid", allowedIP))
}
}


return errs return errs
} }

View File

@ -382,7 +382,7 @@
name: "", name: "",
email: "", email: "",
enable: true, enable: true,
allowedIPs: ["0.0.0.0/0", "::/0"], allowedIPs: this.server.allowedips,
address: this.server.address, address: this.server.address,
} }
}, },

View File

@ -85,6 +85,26 @@
</v-chip> </v-chip>
</template> </template>
</v-combobox> </v-combobox>
<v-combobox
v-model="server.allowedips"
chips
hint="Write IPv4 or IPv6 address and hit enter"
label="Default Allowed IPs for clients"
multiple
dark
>
<template v-slot:selection="{ attrs, item, select, selected }">
<v-chip
v-bind="attrs"
:input-value="selected"
close
@click="select"
@click:close="server.allowedips.splice(server.allowedips.indexOf(item), 1)"
>
<strong>{{ item }}</strong>&nbsp;
</v-chip>
</template>
</v-combobox>
<v-text-field <v-text-field
type="number" type="number"
v-model="server.mtu" v-model="server.mtu"
@ -218,6 +238,18 @@
} }
} }


// check client AllowedIPs
if (this.server.allowedips.length < 1) {
this.notify('error', 'Please provide at least one valid CIDR address for client allowed IPs');
return;
}
for (let i = 0; i < this.server.allowedips.length; i++){
if (this.$isCidr(this.server.allowedips[i]) === 0) {
this.notify('error', 'Invalid CIDR detected, please correct before submitting');
return
}
}

this.api.patch('/server', this.server).then((res) => { this.api.patch('/server', this.server).then((res) => {
this.notify('success', "Server successfully updated"); this.notify('success', "Server successfully updated");
this.server = res; this.server = res;