aboutsummaryrefslogtreecommitdiff
path: root/plugin.go
blob: 1c453c25f3ed96fbdf3f95caf9cbb9cafa3d68ec (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
package proxy

import (
	"log"
	"os"
	"os/exec"
	"plugin"
	"sync"
)

var pluginsOnce sync.Once

func loadPlugins() {
	pluginsOnce.Do(openPlugins)
}

func openPlugins() {
	version, ok := Version()
	if !ok {
		log.Fatal("unable to retrieve proxy version")
	}

	pathVer := "github.com/HimbeerserverDE/mt-multiserver-proxy@" + version

	path := Path("plugins")
	os.Mkdir(path, 0777)

	dir, err := os.ReadDir(path)
	if err != nil {
		log.Fatal(err)
	}

	for _, pl := range dir {
		if pl.IsDir() {
			plPath := path + "/" + pl.Name()

			wd, err := os.Getwd()
			if err != nil {
				log.Fatal(err)
			}

			if err := os.Chdir(plPath); err != nil {
				log.Fatal(err)
			}

			if err := goCmd("get", "-u", pathVer); err != nil {
				log.Fatal(err)
			}

			if err := goCmd("mod", "tidy"); err != nil {
				log.Fatal(err)
			}

			if err := goCmd("build", "-buildmode=plugin"); err != nil {
				log.Fatal(err)
			}

			if err := os.Chdir(wd); err != nil {
				log.Fatal(err)
			}

			_, err = plugin.Open(path + "/" + pl.Name() + ".so")
			if err != nil {
				log.Print(err)
				continue
			}
		} else {
			_, err := plugin.Open(path + "/" + pl.Name())
			if err != nil {
				log.Print(err)
				continue
			}
		}
	}

	log.Print("load plugins")
}

func goCmd(args ...string) error {
	cmd := exec.Command("go", args...)

	cmd.Stdin = os.Stdin
	cmd.Stdout = os.Stdout
	cmd.Stderr = os.Stderr

	return cmd.Run()
}