Initial commit
This commit is contained in:
41
Dockerfile
Normal file
41
Dockerfile
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
FROM golang:1.12-alpine AS gobuild
|
||||||
|
|
||||||
|
WORKDIR /go/src/kubedoom
|
||||||
|
ADD kubedoom.go .
|
||||||
|
RUN CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -o kubedoom .
|
||||||
|
|
||||||
|
FROM ubuntu:19.10 AS ubuntu
|
||||||
|
# make sure the package repository is up to date
|
||||||
|
RUN apt-get update
|
||||||
|
|
||||||
|
FROM ubuntu AS ubuntu-deps
|
||||||
|
# Install dependencies
|
||||||
|
RUN apt-get install -y -o APT::Install-Suggests=0 --no-install-recommends git wget ca-certificates
|
||||||
|
RUN git clone https://github.com/GideonRed/dockerdoom.git
|
||||||
|
RUN wget http://distro.ibiblio.org/pub/linux/distributions/slitaz/sources/packages/d/doom1.wad
|
||||||
|
RUN wget -O /usr/bin/kubectl https://storage.googleapis.com/kubernetes-release/release/v1.15.3/bin/linux/amd64/kubectl && chmod +x /usr/bin/kubectl
|
||||||
|
|
||||||
|
FROM ubuntu AS ubuntu-build
|
||||||
|
|
||||||
|
ENV DEBIAN_FRONTEND=noninteractive
|
||||||
|
RUN apt-get install -y -o APT::Install-Suggests=0 --no-install-recommends build-essential libsdl-mixer1.2-dev libsdl-net1.2-dev gcc
|
||||||
|
|
||||||
|
# Setup doom
|
||||||
|
COPY --from=ubuntu-deps /dockerdoom /dockerdoom
|
||||||
|
RUN cd /dockerdoom/trunk && ./configure --enable-static && make && make install
|
||||||
|
|
||||||
|
FROM ubuntu
|
||||||
|
RUN apt-get install -y -o APT::Install-Suggests=0 --no-install-recommends libsdl-mixer1.2 libsdl-net1.2 x11vnc xvfb netcat-openbsd
|
||||||
|
|
||||||
|
|
||||||
|
WORKDIR /root/
|
||||||
|
|
||||||
|
# Setup a password
|
||||||
|
RUN mkdir ~/.vnc && x11vnc -storepasswd 1234 ~/.vnc/passwd
|
||||||
|
|
||||||
|
COPY --from=ubuntu-deps /doom1.wad .
|
||||||
|
COPY --from=ubuntu-deps /usr/bin/kubectl /usr/bin/
|
||||||
|
COPY --from=ubuntu-build /usr/local/games/psdoom /usr/local/games/
|
||||||
|
COPY --from=gobuild /go/src/kubedoom/kubedoom .
|
||||||
|
|
||||||
|
ENTRYPOINT ["/root/kubedoom"]
|
9
kind-config.yaml
Normal file
9
kind-config.yaml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
kind: Cluster
|
||||||
|
apiVersion: kind.sigs.k8s.io/v1alpha3
|
||||||
|
nodes:
|
||||||
|
- role: control-plane
|
||||||
|
- role: worker
|
||||||
|
extraPortMappings:
|
||||||
|
- containerPort: 5900
|
||||||
|
hostPort: 5900
|
||||||
|
listenAddress: "127.0.0.1" # Optional, defaults to "0.0.0.0"
|
139
kubedoom.go
Normal file
139
kubedoom.go
Normal file
@ -0,0 +1,139 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
//TODO: Make your container die if you die
|
||||||
|
|
||||||
|
import (
|
||||||
|
"flag"
|
||||||
|
//"fmt"
|
||||||
|
"log"
|
||||||
|
"net"
|
||||||
|
"os"
|
||||||
|
"os/exec"
|
||||||
|
"strings"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
func runCmd(cmdstring string) {
|
||||||
|
parts := strings.Split(cmdstring, " ")
|
||||||
|
cmd := exec.Command(parts[0], parts[1:len(parts)]...)
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
cmd.Stderr = os.Stderr
|
||||||
|
err := cmd.Run()
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("The following command failed: \"%v\"\n", cmdstring)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func outputCmd(argv []string) string {
|
||||||
|
cmd := exec.Command(argv[0], argv[1:len(argv)]...)
|
||||||
|
cmd.Stderr = os.Stderr
|
||||||
|
output, err := cmd.Output()
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("The following command failed: \"%v\"\n", argv)
|
||||||
|
}
|
||||||
|
return string(output)
|
||||||
|
}
|
||||||
|
|
||||||
|
func startCmd(cmdstring string) {
|
||||||
|
parts := strings.Split(cmdstring, " ")
|
||||||
|
cmd := exec.Command(parts[0], parts[1:len(parts)]...)
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
cmd.Stdin = os.Stdin
|
||||||
|
err := cmd.Start()
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("The following command failed: \"%v\"\n", cmdstring)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func startCmdSilent(cmdstring string) {
|
||||||
|
parts := strings.Split(cmdstring, " ")
|
||||||
|
cmd := exec.Command(parts[0], parts[1:len(parts)]...)
|
||||||
|
cmd.Stdin = os.Stdin
|
||||||
|
err := cmd.Start()
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("The following command failed: \"%v\"\n", cmdstring)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func socketLoop(listener net.Listener) {
|
||||||
|
log.Print("Socket loop")
|
||||||
|
for true {
|
||||||
|
log.Print("accept?")
|
||||||
|
conn, err := listener.Accept()
|
||||||
|
log.Print("accept!")
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
stop := false
|
||||||
|
for !stop {
|
||||||
|
bytes := make([]byte, 40960)
|
||||||
|
log.Print("Reading")
|
||||||
|
n, err := conn.Read(bytes)
|
||||||
|
if err != nil {
|
||||||
|
stop = true
|
||||||
|
}
|
||||||
|
log.Print("got suff")
|
||||||
|
bytes = bytes[0:n]
|
||||||
|
strbytes := strings.TrimSpace(string(bytes))
|
||||||
|
log.Printf("Received: '%s'", strbytes)
|
||||||
|
if strbytes == "list" {
|
||||||
|
// output := outputCmd(fmt.Sprintf("%v ps -q", dockerBinary))
|
||||||
|
args := []string{"kubectl", "get", "pods", "-A", "-o", "go-template", "--template={{range .items}}{{.metadata.namespace}}/{{.metadata.name}} {{end}}"}
|
||||||
|
output := outputCmd(args)
|
||||||
|
log.Printf("output: '%s'", output)
|
||||||
|
_, err = conn.Write([]byte(output))
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal("Could not write to socker file")
|
||||||
|
}
|
||||||
|
//cmd := exec.Command("/usr/bin/docker", "inspect", "-f", "{{.Name}}", "`docker", "ps", "-q`")
|
||||||
|
// outputstr := strings.TrimSpace(output)
|
||||||
|
// pods := strings.Split(outputstr, "\n")
|
||||||
|
// for _, pod := range pods {
|
||||||
|
// log.Print(pod)
|
||||||
|
// _, err = conn.Write([]byte(pod + " "))
|
||||||
|
// if err != nil {
|
||||||
|
// log.Fatal("Could not write to socker file")
|
||||||
|
// }
|
||||||
|
// time.Sleep(time.Duration(200) * time.Millisecond)
|
||||||
|
// }
|
||||||
|
conn.Close()
|
||||||
|
stop = true
|
||||||
|
} else if strings.HasPrefix(strbytes, "kill ") {
|
||||||
|
log.Printf("killcommand: '%s'", strbytes)
|
||||||
|
// parts := strings.Split(strbytes, " ")
|
||||||
|
// pod := strings.TrimSpace(parts[1])
|
||||||
|
// podparts := strings.Split(pod, "/")
|
||||||
|
// namespace := podparts[0]
|
||||||
|
|
||||||
|
// podname := podparts[1]
|
||||||
|
// log.Printf("Pod to kill: %s // %s", namespace, podname)
|
||||||
|
// cmd := exec.Command(dockerBinary, "rm", "-f", docker_id)
|
||||||
|
// go cmd.Run()
|
||||||
|
conn.Close()
|
||||||
|
stop = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var asciiDisplay bool
|
||||||
|
flag.BoolVar(&asciiDisplay, "asciiDisplay", false, "Don't use fancy vnc, throw DOOM straightup on my terminal screen")
|
||||||
|
flag.Parse()
|
||||||
|
|
||||||
|
listener, err := net.Listen("unix", "/dockerdoom.socket")
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("Could not create socket file")
|
||||||
|
}
|
||||||
|
|
||||||
|
if !asciiDisplay {
|
||||||
|
log.Print("Create virtual display")
|
||||||
|
startCmd("/usr/bin/Xvfb :99 -ac -screen 0 640x480x24")
|
||||||
|
time.Sleep(time.Duration(2) * time.Second)
|
||||||
|
startCmd("x11vnc -geometry 640x480 -forever -usepw -display :99")
|
||||||
|
log.Print("You can now connect to it with a VNC viewer at port 5900")
|
||||||
|
}
|
||||||
|
log.Print("Trying to start DOOM ...")
|
||||||
|
startCmdSilent("/usr/bin/env DISPLAY=:99 /usr/local/games/psdoom -warp -E1M1")
|
||||||
|
socketLoop(listener)
|
||||||
|
}
|
4
manifest/00namespace.yaml
Normal file
4
manifest/00namespace.yaml
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Namespace
|
||||||
|
metadata:
|
||||||
|
name: kubedoom
|
25
manifest/deployment.yaml
Normal file
25
manifest/deployment.yaml
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
apiVersion: apps/v1beta2
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: kubedoom
|
||||||
|
name: kubedoom
|
||||||
|
namespace: kubedoom
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: kubedoom
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: kubedoom
|
||||||
|
spec:
|
||||||
|
hostNetwork: true
|
||||||
|
serviceAccountName: kubedoom
|
||||||
|
containers:
|
||||||
|
- image: kubedoom:0.1.2
|
||||||
|
name: kubedoom
|
||||||
|
ports:
|
||||||
|
- containerPort: 5900
|
||||||
|
name: vnc
|
18
manifest/rbac.yaml
Normal file
18
manifest/rbac.yaml
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: kubedoom
|
||||||
|
namespace: kubedoom
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: kubedoom
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: cluster-admin
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: kubedoom
|
||||||
|
namespace: kubedoom
|
15
manifest/service.yaml
Normal file
15
manifest/service.yaml
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
# apiVersion: v1
|
||||||
|
# kind: Service
|
||||||
|
# metadata:
|
||||||
|
# labels:
|
||||||
|
# app: kubedoom
|
||||||
|
# name: kubedoom
|
||||||
|
# namespace: kubedoom
|
||||||
|
# spec:
|
||||||
|
# type: NodePort
|
||||||
|
# ports:
|
||||||
|
# - name: vnc
|
||||||
|
# port: 5900
|
||||||
|
# targetPort: vnc
|
||||||
|
# selector:
|
||||||
|
# app: kubedoom
|
Reference in New Issue
Block a user