Files
i2p.plugins.tor-updater/serve/serve.go

174 lines
4.3 KiB
Go

package tbserve
import (
"encoding/json"
"fmt"
"io/ioutil"
"log"
"net/http"
"path/filepath"
"strings"
tbget "i2pgit.org/idk/i2p.plugins.tor-manager/get"
TBSupervise "i2pgit.org/idk/i2p.plugins.tor-manager/supervise"
)
type Client struct {
hostname string
TBD *tbget.TBDownloader
TBS *TBSupervise.Supervisor
}
func NewClient(hostname string, lang string, os string, arch string) (*Client, error) {
m := &Client{
hostname: hostname,
TBD: tbget.NewTBDownloader(lang, os, arch),
}
tgz, sig, err := m.TBD.DownloadUpdaterForLang(lang)
if err != nil {
panic(err)
}
var home string
if home, err = m.TBD.CheckSignature(tgz, sig); err != nil {
log.Fatal(err)
} else {
log.Printf("Signature check passed: %s %s", tgz, sig)
}
m.TBS = TBSupervise.NewSupervisor(home, lang)
return m, nil
}
func (m *Client) ServeHTTP(rw http.ResponseWriter, rq *http.Request) {
path := rq.URL.Path
log.Printf("ServeHTTP: '%s'", path)
fileextension := filepath.Ext(path)
switch fileextension {
case ".json":
m.serveJSON(rw, rq)
return
case ".css":
m.serveCSS(rw, rq)
return
case ".js":
m.serveJS(rw, rq)
return
case ".png":
m.servePNG(rw, rq)
return
case ".ico":
m.serveICO(rw, rq)
return
case ".svg":
m.serveSVG(rw, rq)
return
default:
switch path {
case "/launch-tor-browser":
log.Println("Starting Tor Browser")
go m.TBS.RunTBWithLang()
http.Redirect(rw, rq, "/", http.StatusFound)
case "/launch-i2p-browser":
log.Println("Starting I2P Browser")
go m.TBS.RunI2PBWithLang()
http.Redirect(rw, rq, "/", http.StatusFound)
case "/start-tor":
log.Println("Starting Tor")
go m.TBS.RunTorWithLang()
http.Redirect(rw, rq, "/", http.StatusFound)
case "/stop-tor":
log.Println("Stopping Tor")
go m.TBS.StopTor()
http.Redirect(rw, rq, "/", http.StatusFound)
default:
b, _ := m.Page()
rw.Header().Set("Content-Type", "text/html")
rw.Write([]byte(b))
}
}
}
func (m *Client) Serve() error {
//http.Handle("/", m)
go m.TBS.RunTorWithLang()
return http.ListenAndServe("127.0.0.1:7695", m)
}
func (m *Client) generateMirrorJSON() (map[string]interface{}, error) {
if !strings.HasSuffix(m.hostname, "/") {
m.hostname += "/"
}
path := filepath.Join(tbget.DOWNLOAD_PATH, "downloads.json")
preBytes, err := ioutil.ReadFile(path)
if err != nil {
return nil, fmt.Errorf("GenerateMirrorJSON: %s", err)
}
binpath, _, err := m.TBD.GetUpdaterForLangFromJsonBytes(preBytes, "en-US")
if err != nil {
return nil, fmt.Errorf("GenerateMirrorJSON: %s", err)
}
urlparts := strings.Split(binpath, "/")
replaceString := GenerateReplaceString(urlparts[:len(urlparts)-1])
fmt.Printf("Replacing: %s with %s\n", replaceString, m.hostname)
jsonBytes := []byte(strings.Replace(string(preBytes), replaceString, m.hostname, -1))
var JSON map[string]interface{}
if err := json.Unmarshal(jsonBytes, &JSON); err != nil {
panic(err)
}
return JSON, nil
}
func (m *Client) GenerateMirrorJSON() (string, error) {
JSON, err := m.generateMirrorJSON()
if err != nil {
return "", err
}
path := filepath.Join(tbget.DOWNLOAD_PATH, "downloads.json")
preBytes, err := ioutil.ReadFile(path)
if err != nil {
return "", fmt.Errorf("GenerateMirrorJSONBytes: %s", err)
}
binpath, _, err := m.TBD.GetUpdaterForLangFromJsonBytes(preBytes, "en-US")
if err != nil {
return "", fmt.Errorf("GenerateMirrorJSONBytes: %s", err)
}
urlparts := strings.Split(binpath, "/")
replaceString := GenerateReplaceString(urlparts[:len(urlparts)-1])
if platform, ok := JSON["downloads"]; ok {
rtp := m.TBD.GetRuntimePair()
for k, v := range platform.(map[string]interface{}) {
if k != rtp {
delete(platform.(map[string]interface{}), k)
}
for k2 := range v.(map[string]interface{}) {
if k2 != m.TBD.Lang {
delete(v.(map[string]interface{}), k2)
}
}
}
bytes, err := json.MarshalIndent(JSON, "", " ")
if err != nil {
return "", err
}
return strings.Replace(string(bytes), replaceString, m.hostname, -1), nil
}
return "", fmt.Errorf("GenerateMirrorJSONBytes: %s", "No downloads found")
}
func GenerateReplaceString(urlparts []string) string {
replaceString := ""
for _, val := range urlparts {
if val == "https" {
replaceString += val + "//"
} else {
replaceString += val + "/"
}
}
if !strings.HasSuffix(replaceString, "/") {
replaceString += "/"
}
return replaceString
}