mirror of
https://github.com/luscis/openlan.git
synced 2025-12-24 11:10:54 +08:00
716 lines
17 KiB
Go
Executable File
716 lines
17 KiB
Go
Executable File
package api
|
|
|
|
import (
|
|
"net/http"
|
|
"strings"
|
|
|
|
"github.com/gorilla/mux"
|
|
"github.com/luscis/openlan/pkg/cache"
|
|
"github.com/luscis/openlan/pkg/libol"
|
|
"github.com/luscis/openlan/pkg/models"
|
|
"github.com/luscis/openlan/pkg/schema"
|
|
)
|
|
|
|
type Network struct {
|
|
cs SwitchApi
|
|
}
|
|
|
|
func (h Network) Router(router *mux.Router) {
|
|
router.HandleFunc("/api/network", h.List).Methods("GET")
|
|
router.HandleFunc("/api/network", h.Post).Methods("POST")
|
|
router.HandleFunc("/api/network", h.Save).Methods("PUT")
|
|
router.HandleFunc("/api/network/{id}", h.Get).Methods("GET")
|
|
router.HandleFunc("/api/network/{id}", h.Delete).Methods("DELETE")
|
|
router.HandleFunc("/api/network/{id}", h.Save).Methods("PUT")
|
|
router.HandleFunc("/get/network/{id}/ovpn", h.Profile).Methods("GET")
|
|
router.HandleFunc("/api/network/{id}/ovpn", h.Profile).Methods("GET")
|
|
router.HandleFunc("/api/network/{id}/openvpn/restart", h.StartVPN).Methods("POST")
|
|
}
|
|
|
|
func (h Network) List(w http.ResponseWriter, r *http.Request) {
|
|
nets := make([]schema.Network, 0, 1024)
|
|
for u := range cache.Network.List() {
|
|
if u == nil {
|
|
break
|
|
}
|
|
nets = append(nets, models.NewNetworkSchema(u))
|
|
}
|
|
ResponseJson(w, nets)
|
|
}
|
|
|
|
func (h Network) Get(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
net := cache.Network.Get(vars["id"])
|
|
if net != nil {
|
|
ResponseJson(w, models.NewNetworkSchema(net))
|
|
} else {
|
|
http.Error(w, vars["id"], http.StatusNotFound)
|
|
}
|
|
}
|
|
|
|
func (h Network) Post(w http.ResponseWriter, r *http.Request) {
|
|
network := &schema.Network{}
|
|
if err := GetData(r, network); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
data, err := libol.Marshal(&network.Config, true)
|
|
if err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
cs := h.cs.Config()
|
|
obj, err := cs.AddNetwork(data)
|
|
if err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
cs.CorrectNetwork(obj, "json")
|
|
if obj := cs.GetNetwork(obj.Name); obj != nil {
|
|
h.cs.AddNetwork(obj.Name)
|
|
} else {
|
|
http.Error(w, network.Name+" not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
ResponseJson(w, "success")
|
|
}
|
|
|
|
func (h Network) Delete(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
network := vars["id"]
|
|
worker := Call.GetWorker(network)
|
|
if worker == nil {
|
|
http.Error(w, "network not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
h.cs.DelNetwork(network)
|
|
ResponseJson(w, "success")
|
|
}
|
|
|
|
func (h Network) Save(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
network := &schema.Network{}
|
|
if name, ok := vars["id"]; ok {
|
|
network.Name = name
|
|
}
|
|
if network.Name == "" {
|
|
if err := GetData(r, network); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
}
|
|
h.cs.SaveNetwork(network.Name)
|
|
ResponseJson(w, "success")
|
|
}
|
|
|
|
func (h Network) Profile(w http.ResponseWriter, r *http.Request) {
|
|
server := strings.SplitN(r.Host, ":", 2)[0]
|
|
vars := mux.Vars(r)
|
|
data, err := cache.VPNClient.GetClientProfile(vars["id"], server)
|
|
if err == nil {
|
|
_, _ = w.Write([]byte(data))
|
|
} else {
|
|
http.Error(w, err.Error(), http.StatusNotFound)
|
|
}
|
|
}
|
|
|
|
func (h Network) StartVPN(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
id := vars["id"]
|
|
|
|
worker := Call.GetWorker(id)
|
|
if worker == nil {
|
|
http.Error(w, "Network not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
worker.StartVPN()
|
|
ResponseJson(w, true)
|
|
}
|
|
|
|
type SNAT struct {
|
|
cs SwitchApi
|
|
}
|
|
|
|
func (h SNAT) Router(router *mux.Router) {
|
|
router.HandleFunc("/api/network/{id}/snat", h.Post).Methods("POST")
|
|
router.HandleFunc("/api/network/{id}/snat", h.Delete).Methods("DELETE")
|
|
}
|
|
|
|
func (h SNAT) Post(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
name := vars["id"]
|
|
|
|
if obj := Call.GetWorker(name); obj != nil {
|
|
obj.EnableSnat()
|
|
} else {
|
|
http.Error(w, name+" not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
ResponseJson(w, "success")
|
|
}
|
|
|
|
func (h SNAT) Delete(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
name := vars["id"]
|
|
|
|
if obj := Call.GetWorker(name); obj != nil {
|
|
obj.DisableSnat()
|
|
} else {
|
|
http.Error(w, name+" not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
ResponseJson(w, "success")
|
|
}
|
|
|
|
type DNAT struct {
|
|
cs SwitchApi
|
|
}
|
|
|
|
func (h DNAT) Router(router *mux.Router) {
|
|
router.HandleFunc("/api/network/{id}/dnat", h.Get).Methods("GET")
|
|
router.HandleFunc("/api/network/{id}/dnat", h.Post).Methods("POST")
|
|
router.HandleFunc("/api/network/{id}/dnat", h.Delete).Methods("DELETE")
|
|
}
|
|
|
|
func (h DNAT) Get(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
name := vars["id"]
|
|
|
|
caller := Call.GetWorker(name)
|
|
if caller == nil {
|
|
http.Error(w, name+" not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
var items []schema.DNAT
|
|
caller.ListDnat(func(data schema.DNAT) {
|
|
items = append(items, data)
|
|
})
|
|
ResponseJson(w, items)
|
|
}
|
|
|
|
func (h DNAT) Post(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
name := vars["id"]
|
|
|
|
caller := Call.GetWorker(name)
|
|
if caller == nil {
|
|
http.Error(w, name+" not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
value := schema.DNAT{}
|
|
if err := GetData(r, &value); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
if err := caller.AddDnat(value); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
ResponseJson(w, "success")
|
|
}
|
|
|
|
func (h DNAT) Delete(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
name := vars["id"]
|
|
|
|
caller := Call.GetWorker(name)
|
|
if caller == nil {
|
|
http.Error(w, name+" not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
value := schema.DNAT{}
|
|
if err := GetData(r, &value); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
if err := caller.DelDnat(value); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
ResponseJson(w, "success")
|
|
}
|
|
|
|
type RouterTunnel struct {
|
|
cs SwitchApi
|
|
}
|
|
|
|
func (h RouterTunnel) Router(router *mux.Router) {
|
|
router.HandleFunc("/api/network/router/tunnel", h.Post).Methods("POST")
|
|
router.HandleFunc("/api/network/router/tunnel", h.Delete).Methods("DELETE")
|
|
}
|
|
|
|
func (h RouterTunnel) Post(w http.ResponseWriter, r *http.Request) {
|
|
caller := Call.routerApi
|
|
if caller == nil {
|
|
http.Error(w, "Router not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
value := schema.RouterTunnel{}
|
|
if err := GetData(r, &value); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
if err := caller.AddTunnel(value); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
ResponseJson(w, "success")
|
|
}
|
|
|
|
func (h RouterTunnel) Delete(w http.ResponseWriter, r *http.Request) {
|
|
caller := Call.routerApi
|
|
if caller == nil {
|
|
http.Error(w, "Router not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
value := schema.RouterTunnel{}
|
|
if err := GetData(r, &value); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
if err := caller.DelTunnel(value); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
ResponseJson(w, "success")
|
|
}
|
|
|
|
type Bgp struct {
|
|
cs SwitchApi
|
|
}
|
|
|
|
func (h Bgp) Router(router *mux.Router) {
|
|
router.HandleFunc("/api/network/bgp/global", h.Get).Methods("GET")
|
|
router.HandleFunc("/api/network/bgp/global", h.Post).Methods("POST")
|
|
router.HandleFunc("/api/network/bgp/global", h.Remove).Methods("DELETE")
|
|
router.HandleFunc("/api/network/bgp/neighbor", h.RemoveNeighbor).Methods("DELETE")
|
|
router.HandleFunc("/api/network/bgp/neighbor", h.AddNeighbor).Methods("POST")
|
|
router.HandleFunc("/api/network/bgp/advertis", h.RemoveAdvertis).Methods("DELETE")
|
|
router.HandleFunc("/api/network/bgp/advertis", h.AddAdvertis).Methods("POST")
|
|
router.HandleFunc("/api/network/bgp/receives", h.RemoveReceivess).Methods("DELETE")
|
|
router.HandleFunc("/api/network/bgp/receives", h.AddReceivess).Methods("POST")
|
|
}
|
|
|
|
func (h Bgp) Get(w http.ResponseWriter, r *http.Request) {
|
|
libol.Debug("Bgp.Get %s")
|
|
if Call.bgpApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
data := Call.bgpApi.Get()
|
|
ResponseJson(w, data)
|
|
}
|
|
|
|
func (h Bgp) Post(w http.ResponseWriter, r *http.Request) {
|
|
data := schema.Bgp{}
|
|
if err := GetData(r, &data); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.bgpApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.bgpApi.Enable(data)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
func (h Bgp) Remove(w http.ResponseWriter, r *http.Request) {
|
|
if Call.bgpApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.bgpApi.Disable()
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
func (h Bgp) RemoveNeighbor(w http.ResponseWriter, r *http.Request) {
|
|
nei := schema.BgpNeighbor{}
|
|
if err := GetData(r, &nei); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.bgpApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.bgpApi.DelNeighbor(nei)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
func (h Bgp) AddNeighbor(w http.ResponseWriter, r *http.Request) {
|
|
nei := schema.BgpNeighbor{}
|
|
if err := GetData(r, &nei); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.bgpApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.bgpApi.AddNeighbor(nei)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
func (h Bgp) RemoveAdvertis(w http.ResponseWriter, r *http.Request) {
|
|
data := schema.BgpPrefix{}
|
|
if err := GetData(r, &data); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.bgpApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.bgpApi.DelAdvertis(data)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
func (h Bgp) AddAdvertis(w http.ResponseWriter, r *http.Request) {
|
|
data := schema.BgpPrefix{}
|
|
if err := GetData(r, &data); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.bgpApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.bgpApi.AddAdvertis(data)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
func (h Bgp) RemoveReceivess(w http.ResponseWriter, r *http.Request) {
|
|
data := schema.BgpPrefix{}
|
|
if err := GetData(r, &data); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.bgpApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.bgpApi.DelReceives(data)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
func (h Bgp) AddReceivess(w http.ResponseWriter, r *http.Request) {
|
|
data := schema.BgpPrefix{}
|
|
if err := GetData(r, &data); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.bgpApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.bgpApi.AddReceives(data)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
type Ceci struct {
|
|
cs SwitchApi
|
|
}
|
|
|
|
func (h Ceci) Router(router *mux.Router) {
|
|
router.HandleFunc("/api/network/ceci/tcp", h.Get).Methods("GET")
|
|
router.HandleFunc("/api/network/ceci/tcp", h.Post).Methods("POST")
|
|
router.HandleFunc("/api/network/ceci/tcp", h.Remove).Methods("DELETE")
|
|
}
|
|
|
|
func (h Ceci) Get(w http.ResponseWriter, r *http.Request) {
|
|
libol.Debug("Ceci.Get %s")
|
|
ResponseJson(w, nil)
|
|
}
|
|
|
|
func (h Ceci) Post(w http.ResponseWriter, r *http.Request) {
|
|
data := schema.CeciTcp{}
|
|
if err := GetData(r, &data); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.ceciApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.ceciApi.AddTcp(data)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
func (h Ceci) Remove(w http.ResponseWriter, r *http.Request) {
|
|
data := schema.CeciTcp{}
|
|
if err := GetData(r, &data); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.ceciApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.ceciApi.DelTcp(data)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
type IPSec struct {
|
|
cs SwitchApi
|
|
}
|
|
|
|
func (h IPSec) Router(router *mux.Router) {
|
|
router.HandleFunc("/api/network/ipsec/tunnel", h.Get).Methods("GET")
|
|
router.HandleFunc("/api/network/ipsec/tunnel", h.Post).Methods("POST")
|
|
router.HandleFunc("/api/network/ipsec/tunnel", h.Delete).Methods("DELETE")
|
|
router.HandleFunc("/api/network/ipsec/tunnel/restart", h.Start).Methods("PUT")
|
|
}
|
|
|
|
func (h IPSec) Get(w http.ResponseWriter, r *http.Request) {
|
|
libol.Debug("IPSec.Get %s")
|
|
tunnels := make([]schema.IPSecTunnel, 0, 1024)
|
|
if Call.ipsecApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.ipsecApi.ListTunnels(func(obj schema.IPSecTunnel) {
|
|
tunnels = append(tunnels, obj)
|
|
})
|
|
ResponseJson(w, tunnels)
|
|
}
|
|
|
|
func (h IPSec) Post(w http.ResponseWriter, r *http.Request) {
|
|
tun := &schema.IPSecTunnel{}
|
|
if err := GetData(r, tun); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.ipsecApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.ipsecApi.AddTunnel(*tun)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
func (h IPSec) Delete(w http.ResponseWriter, r *http.Request) {
|
|
tun := &schema.IPSecTunnel{}
|
|
if err := GetData(r, tun); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.ipsecApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.ipsecApi.DelTunnel(*tun)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
func (h IPSec) Start(w http.ResponseWriter, r *http.Request) {
|
|
tun := &schema.IPSecTunnel{}
|
|
if err := GetData(r, tun); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
if Call.ipsecApi == nil {
|
|
http.Error(w, "network is nil", http.StatusBadRequest)
|
|
return
|
|
}
|
|
Call.ipsecApi.StartTunnel(*tun)
|
|
ResponseMsg(w, 0, "")
|
|
}
|
|
|
|
type PrefixRoute struct {
|
|
cs SwitchApi
|
|
}
|
|
|
|
func (rt PrefixRoute) Router(router *mux.Router) {
|
|
router.HandleFunc("/api/network/{id}/route", rt.List).Methods("GET")
|
|
router.HandleFunc("/api/network/{id}/route", rt.Add).Methods("POST")
|
|
router.HandleFunc("/api/network/{id}/route", rt.Del).Methods("DELETE")
|
|
router.HandleFunc("/api/network/{id}/route", rt.Save).Methods("PUT")
|
|
}
|
|
|
|
func (rt PrefixRoute) List(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
id := vars["id"]
|
|
|
|
routes := make([]schema.PrefixRoute, 0, 1024)
|
|
|
|
worker := Call.GetWorker(id)
|
|
if worker == nil {
|
|
http.Error(w, "Network not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
worker.ListRoute(func(obj schema.PrefixRoute) {
|
|
routes = append(routes, obj)
|
|
})
|
|
ResponseJson(w, routes)
|
|
}
|
|
|
|
func (rt PrefixRoute) Add(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
id := vars["id"]
|
|
|
|
worker := Call.GetWorker(id)
|
|
if worker == nil {
|
|
http.Error(w, "Network not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
pr := &schema.PrefixRoute{}
|
|
if err := GetData(r, pr); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
if err := worker.AddRoute(pr, rt.cs); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
ResponseJson(w, true)
|
|
}
|
|
|
|
func (rt PrefixRoute) Del(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
id := vars["id"]
|
|
|
|
worker := Call.GetWorker(id)
|
|
if worker == nil {
|
|
http.Error(w, "Network not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
pr := &schema.PrefixRoute{}
|
|
if err := GetData(r, pr); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
if err := worker.DelRoute(pr, rt.cs); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
ResponseJson(w, true)
|
|
}
|
|
|
|
func (rt PrefixRoute) Save(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
id := vars["id"]
|
|
|
|
worker := Call.GetWorker(id)
|
|
if worker == nil {
|
|
http.Error(w, "Network not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
worker.SaveRoute()
|
|
|
|
ResponseJson(w, true)
|
|
}
|
|
|
|
type ClientQoS struct {
|
|
}
|
|
|
|
func (h ClientQoS) Router(router *mux.Router) {
|
|
router.HandleFunc("/api/network/{id}/qos", h.List).Methods("GET")
|
|
router.HandleFunc("/api/network/{id}/qos", h.Add).Methods("POST")
|
|
router.HandleFunc("/api/network/{id}/qos", h.Del).Methods("DELETE")
|
|
router.HandleFunc("/api/network/{id}/qos", h.Save).Methods("PUT")
|
|
}
|
|
|
|
func (h ClientQoS) List(w http.ResponseWriter, r *http.Request) {
|
|
|
|
qosList := make([]schema.Qos, 0, 1024)
|
|
vars := mux.Vars(r)
|
|
id := vars["id"]
|
|
|
|
worker := Call.GetWorker(id)
|
|
if worker == nil {
|
|
http.Error(w, "Network not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
var qos = worker.Qoser()
|
|
qos.ListQos(func(obj schema.Qos) {
|
|
qosList = append(qosList, obj)
|
|
})
|
|
|
|
ResponseJson(w, qosList)
|
|
}
|
|
|
|
func (h ClientQoS) Add(w http.ResponseWriter, r *http.Request) {
|
|
qos := &schema.Qos{}
|
|
if err := GetData(r, qos); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
vars := mux.Vars(r)
|
|
id := vars["id"]
|
|
|
|
worker := Call.GetWorker(id)
|
|
if worker == nil {
|
|
http.Error(w, "Network not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
if err := worker.Qoser().AddQos(qos.Name, qos.InSpeed); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
ResponseJson(w, true)
|
|
}
|
|
|
|
func (h ClientQoS) Del(w http.ResponseWriter, r *http.Request) {
|
|
|
|
qos := &schema.Qos{}
|
|
if err := GetData(r, qos); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
vars := mux.Vars(r)
|
|
id := vars["id"]
|
|
|
|
worker := Call.GetWorker(id)
|
|
if worker == nil {
|
|
http.Error(w, "Network not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
if err := worker.Qoser().DelQos(qos.Name); err != nil {
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
ResponseJson(w, true)
|
|
}
|
|
|
|
func (h ClientQoS) Save(w http.ResponseWriter, r *http.Request) {
|
|
vars := mux.Vars(r)
|
|
id := vars["id"]
|
|
|
|
worker := Call.GetWorker(id)
|
|
if worker == nil {
|
|
http.Error(w, "Network not found", http.StatusBadRequest)
|
|
return
|
|
}
|
|
qos := worker.Qoser()
|
|
qos.SaveQos()
|
|
|
|
ResponseJson(w, "success")
|
|
}
|