minecraftimage/src/main.go

143 lines
2.7 KiB
Go
Raw Permalink Normal View History

2020-10-13 08:21:37 +00:00
package main
import (
"bufio"
"fmt"
"io"
"net"
"os"
"os/exec"
"os/signal"
"strings"
"syscall"
2021-09-17 10:14:03 +00:00
"log"
2021-10-12 10:32:30 +00:00
"regexp"
2021-11-26 22:44:38 +00:00
"bytes"
2020-10-13 08:21:37 +00:00
"github.com/creack/pty"
)
func main() {
2021-09-20 23:32:37 +00:00
log.Println("\033[32mStarting Server\033[0m")
2020-10-13 08:21:37 +00:00
sigs := make(chan os.Signal, 1)
signal.Notify(sigs, syscall.SIGTERM)
2021-11-03 05:59:52 +00:00
//get environmental variables
2021-10-12 10:32:30 +00:00
var minram, maxram, args, stop, jar, regex string
2020-10-13 08:21:37 +00:00
for _, e := range os.Environ() {
pair := strings.SplitN(e, "=", 2)
switch pair[0] {
case "MIN_MEM":
minram = "-Xms" + pair[1]
case "MAX_MEM":
maxram = "-Xmx" + pair[1]
case "ARGS":
args = pair[1]
case "STOP":
stop = pair[1]
2021-09-17 10:14:03 +00:00
case "JAR":
jar = pair[1]
2021-10-12 10:32:30 +00:00
case "REGEX":
regex = pair[1]
2020-10-13 08:21:37 +00:00
}
}
2021-10-12 10:32:30 +00:00
2021-11-26 22:44:38 +00:00
//create command
var cmdversion *exec.Cmd
cmdversion = exec.Command("java", "--version")
var out bytes.Buffer
cmdversion.Stdout = &out
cmdversion.Run()
log.Println(out.String())
2021-09-20 09:40:29 +00:00
log.Printf("Ram: Min: %s Max: %s Stop: %s Jar: %s\n\r", minram, maxram, stop, jar)
2021-11-03 05:59:52 +00:00
//check if there is a server jar
2021-09-20 09:40:29 +00:00
if _, err := os.Stat("/server/"+jar); os.IsNotExist(err) {
2021-09-20 23:32:37 +00:00
log.Println("\033[31mJar \"" + jar + "\" not found\033[0m")
2021-09-20 09:40:29 +00:00
os.Exit(1)
}
2021-09-17 10:14:03 +00:00
2020-10-13 08:21:37 +00:00
var cmd *exec.Cmd
2021-11-26 22:44:38 +00:00
2020-10-13 08:21:37 +00:00
if args == "" {
2021-09-17 10:14:03 +00:00
cmd = exec.Command("java", minram, maxram, "-jar", jar)
2020-10-13 08:21:37 +00:00
} else {
2021-09-17 10:14:03 +00:00
cmd = exec.Command("java", minram, maxram, args, "-jar", jar)
2021-09-20 09:40:29 +00:00
log.Printf("Args: %s \n\r", args)
2020-10-13 08:21:37 +00:00
}
2021-11-03 05:59:52 +00:00
//start server
2020-10-13 08:21:37 +00:00
cmd.Dir = "/server"
tty, err := pty.Start(cmd)
2021-11-03 05:59:52 +00:00
2020-10-13 08:21:37 +00:00
if err != nil {
panic(err)
2021-09-20 09:40:29 +00:00
2020-10-13 08:21:37 +00:00
}
2021-11-11 11:55:15 +00:00
ln, _ := net.Listen("tcp", ":8081")
2021-11-03 05:59:52 +00:00
//cleanup
2020-10-13 08:21:37 +00:00
defer func() {
cmd.Process.Kill()
cmd.Process.Wait()
tty.Close()
ln.Close()
}()
2021-10-12 10:32:30 +00:00
// capture sigterm
2020-10-13 08:21:37 +00:00
go func() {
sig := <-sigs
if sig == syscall.SIGTERM {
2021-09-20 23:32:37 +00:00
fmt.Println("\033[31mStopping server\033[0m")
2020-10-13 08:21:37 +00:00
tty.WriteString(stop + "\n\r")
}
}()
2021-11-03 05:59:52 +00:00
//accepts command from cmd.go and sends them to the server
2021-11-11 11:55:15 +00:00
2020-10-13 08:21:37 +00:00
go func() {
//accept connections from clients
for {
conn, err := ln.Accept()
if err != nil {
continue
}
go handleClient(conn, tty)
}
}()
2021-11-03 05:59:52 +00:00
//copy to standard out. If the the is a regex pattern, do output anything that matches
2021-10-12 10:32:30 +00:00
go func() {
filter := regexp.MustCompile(regex)
if(regex != "") {
scanner := bufio.NewScanner(tty)
for scanner.Scan() {
text := scanner.Text()
if(!filter.MatchString(text)) {
fmt.Println(text)
}
}
2021-11-03 05:59:52 +00:00
} else { //don't filter
2021-10-12 10:32:30 +00:00
io.Copy(os.Stdout, tty)
}
}()
2021-11-03 05:59:52 +00:00
//copy stdin
2020-10-13 08:21:37 +00:00
go func() {
io.Copy(tty, os.Stdin)
}()
2021-11-03 05:59:52 +00:00
cmd.Wait() //wait for server to stop
2021-09-20 23:32:37 +00:00
tty.Write([]byte("\033[31mServer Stopped\033[0m"))
2020-10-13 08:21:37 +00:00
os.Exit(0)
}
2021-11-03 05:59:52 +00:00
//take commands from cmd.go and send it to sdtin of the server
2020-10-13 08:21:37 +00:00
func handleClient(conn net.Conn, tty *os.File) {
defer conn.Close()
cmd, _ := bufio.NewReader(conn).ReadString('\n')
tty.Write([]byte(cmd))
}