Compare commits

...

9 commits

4 changed files with 37 additions and 30 deletions

View file

@ -1,28 +0,0 @@
kind: pipeline
type: docker
name: default
steps:
- name: validate
image: golang
commands:
- go build
- go test
- name: deploy
image: golang
environment:
SSH_PRIVATE_KEY:
from_secret: ssh_private_key
commands:
- go build
- apt-get update; apt-get install -y rsync
- mkdir ~/.ssh
- echo "$SSH_PRIVATE_KEY" > ~/.ssh/id_rsa; chmod 600 ~/.ssh/id_rsa
- ssh-keyscan -t rsa factorio.blackolivepineapple.pizza >> ~/.ssh/known_hosts
- ssh service@factorio.blackolivepineapple.pizza sudo service factorio-site stop || true
- rsync --rsync-path="sudo rsync" --archive --verbose --compress . service@factorio.blackolivepineapple.pizza:/opt/factorio-site/
- ssh service@factorio.blackolivepineapple.pizza sudo mv /opt/factorio-site/factorio-site.service /etc/systemd/system/
- ssh service@factorio.blackolivepineapple.pizza sudo systemctl daemon-reload
- ssh service@factorio.blackolivepineapple.pizza sudo service factorio-site start
when:
branch: master

7
Makefile Normal file
View file

@ -0,0 +1,7 @@
minecraft-site: minecraft-site.go index.html go.mod go.sum
go build -tags netgo -ldflags '-extldflags "-static"'
.PHONY: deploy
deploy: minecraft-site
rsync --rsync-path="sudo -u minecraft rsync" minecraft-site zirconium:/home/minecraft/minecraft-site
ssh zirconium sudo systemctl restart minecraft-site.service

View file

@ -55,6 +55,9 @@
{{end}} {{end}}
</section> </section>
{{end}} {{end}}
<p class="light">This page maintained by chandlerswift's <a href="https://git.chandlerswift.com/chandlerswift/minecraft-site">minecraft server list</a>.</p> <p class="light">
This page maintained by chandlerswift's <a href="https://git.chandlerswift.com/chandlerswift/minecraft-site">minecraft server list</a>.
<a href="/data.json">API at /data.json</a>.
</p>
</body> </body>
</html> </html>

View file

@ -2,6 +2,7 @@ package main
import ( import (
"crypto/tls" "crypto/tls"
_ "embed"
"encoding/json" "encoding/json"
"fmt" "fmt"
"html/template" "html/template"
@ -35,6 +36,9 @@ type pageData struct {
Servers []server Servers []server
} }
//go:embed index.html
var indexhtml string
func main() { func main() {
// Parse config file // Parse config file
@ -63,12 +67,16 @@ func main() {
// Set up templates // Set up templates
fmt.Print("Parsing templates...\n") fmt.Print("Parsing templates...\n")
t, err := template.ParseFiles("templates/index.html") t, err := template.New("").Parse(indexhtml)
if err != nil { if err != nil {
log.Fatalf("Error parsing HTML template: %v\n", err) log.Fatalf("Error parsing HTML template: %v\n", err)
} }
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
if r.URL.Path != "/" {
http.NotFound(w, r)
return
}
// Update servers with current data // Update servers with current data
for i, s := range config.Servers { for i, s := range config.Servers {
@ -85,6 +93,23 @@ func main() {
} }
}) })
http.HandleFunc("/data.json", func(w http.ResponseWriter, r *http.Request) {
// Update servers with current data
for i, s := range config.Servers {
// TODO: Query instead (opportunistically?) to get mod lists, etc
config.Servers[i].Status, err = minequery.Ping17(s.Host, s.Port)
if err != nil {
log.Printf("Error querying server: %v", err)
}
}
msg, err := json.Marshal(config.Servers)
if err != nil {
http.Error(w, err.Error(), 500)
}
w.Header().Set("Content-Type", "application/json")
w.Write(msg)
})
// Serve backup directory // Serve backup directory
if serveBackups { // TODO: add HTML if serveBackups { // TODO: add HTML
http.Handle("/backups/", http.StripPrefix("/backups/", http.FileServer(http.Dir(config.BackupDir)))) http.Handle("/backups/", http.StripPrefix("/backups/", http.FileServer(http.Dir(config.BackupDir))))