Initial working version
This commit is contained in:
commit
cc8b4adaf2
1 changed files with 51 additions and 0 deletions
51
main.go
Normal file
51
main.go
Normal file
|
@ -0,0 +1,51 @@
|
|||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"os"
|
||||
"os/signal"
|
||||
"strings"
|
||||
"net/http"
|
||||
"bytes"
|
||||
)
|
||||
|
||||
|
||||
func main() {
|
||||
|
||||
args := os.Args[1:]
|
||||
tunnelSpecParts := strings.Split(args[0], ":")
|
||||
tunnelId := args[0]
|
||||
host := tunnelSpecParts[0]
|
||||
port := tunnelSpecParts[1]
|
||||
|
||||
client := &http.Client{}
|
||||
|
||||
caddyAddRouteStr := fmt.Sprintf("{\"@id\":\"%s\",\"match\":[{\"host\":[\"%s\"]}],\"handle\":[{\"handler\":\"reverse_proxy\",\"upstreams\":[{\"dial\":\":%s\"}]}]}", tunnelId, host, port);
|
||||
|
||||
resp, err := http.Post("http://127.0.0.1:2019/config/apps/http/servers/sirtunnel/routes", "application/json", bytes.NewBuffer([]byte(caddyAddRouteStr)))
|
||||
|
||||
if err != nil {
|
||||
fmt.Println("Tunnel creation failed")
|
||||
panic(err)
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
fmt.Println("Tunnel created successfully")
|
||||
|
||||
// wait for CTRL-C
|
||||
c := make(chan os.Signal, 1)
|
||||
signal.Notify(c, os.Interrupt)
|
||||
<-c
|
||||
|
||||
fmt.Println("Cleaning up tunnel")
|
||||
|
||||
req, err := http.NewRequest("DELETE", fmt.Sprintf("http://127.0.0.1:2019/id/%s", tunnelId), nil)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
req.Header.Add("Content-Type", "application/json")
|
||||
_, err = client.Do(req)
|
||||
|
||||
fmt.Println("Exiting")
|
||||
}
|
Loading…
Reference in a new issue