ripple-api/app/v1/meta_linux.go

109 lines
2.4 KiB
Go
Raw Normal View History

// +build !windows
2016-11-21 16:04:27 +00:00
// TODO: Make all these methods POST
2016-04-07 17:32:48 +00:00
package v1
import (
"io"
"io/ioutil"
"log"
2016-04-07 17:32:48 +00:00
"os"
"os/exec"
2016-04-07 17:32:48 +00:00
"syscall"
2016-04-09 16:14:38 +00:00
"time"
2016-04-07 17:32:48 +00:00
2019-02-23 13:09:10 +00:00
"github.com/osuYozora/rippleapi/common"
2016-04-07 17:32:48 +00:00
)
// MetaRestartGET restarts the API with Zero Downtime™.
2016-04-16 16:05:24 +00:00
func MetaRestartGET(md common.MethodData) common.CodeMessager {
2016-04-07 17:32:48 +00:00
proc, err := os.FindProcess(syscall.Getpid())
if err != nil {
2016-04-16 16:05:24 +00:00
return common.SimpleResponse(500, "couldn't find process. what the fuck?")
2016-04-07 17:32:48 +00:00
}
2016-04-09 16:14:38 +00:00
go func() {
time.Sleep(time.Second)
proc.Signal(syscall.SIGUSR2)
}()
2016-04-16 16:05:24 +00:00
return common.SimpleResponse(200, "brb")
2016-04-07 17:32:48 +00:00
}
2016-04-09 16:14:38 +00:00
2016-04-10 09:51:34 +00:00
var upSince = time.Now()
2016-04-09 16:14:38 +00:00
2016-04-16 16:05:24 +00:00
type metaUpSinceResponse struct {
common.ResponseBase
Code int `json:"code"`
Since int64 `json:"since"`
}
2016-04-09 16:14:38 +00:00
// MetaUpSinceGET retrieves the moment the API application was started.
// Mainly used to get if the API was restarted.
2016-04-16 16:05:24 +00:00
func MetaUpSinceGET(md common.MethodData) common.CodeMessager {
return metaUpSinceResponse{
Code: 200,
Since: int64(upSince.UnixNano()),
2016-04-09 16:14:38 +00:00
}
}
// MetaUpdateGET updates the API to the latest version, and restarts it.
2016-04-16 16:05:24 +00:00
func MetaUpdateGET(md common.MethodData) common.CodeMessager {
if f, err := os.Stat(".git"); err == os.ErrNotExist || !f.IsDir() {
2016-04-16 16:05:24 +00:00
return common.SimpleResponse(500, "instance is not using git")
}
go func() {
2016-04-19 14:07:27 +00:00
if !execCommand("git", "pull", "origin", "master") {
return
}
// go get
2016-04-19 14:07:27 +00:00
// -u: update all dependencies
// -d: stop after downloading deps
2016-05-14 18:31:28 +00:00
if !execCommand("go", "get", "-v", "-u", "-d") {
return
}
2016-08-15 19:56:29 +00:00
if !execCommand("bash", "-c", "go build -v -ldflags \"-X main.Version=`git rev-parse HEAD`\"") {
return
}
proc, err := os.FindProcess(syscall.Getpid())
if err != nil {
log.Println(err)
return
}
proc.Signal(syscall.SIGUSR2)
}()
2016-04-16 16:05:24 +00:00
return common.SimpleResponse(200, "Started updating! "+surpriseMe())
}
func execCommand(command string, args ...string) bool {
cmd := exec.Command(command, args...)
cmd.Env = os.Environ()
stdout, err := cmd.StdoutPipe()
if err != nil {
log.Println(err)
return false
}
stderr, err := cmd.StderrPipe()
if err != nil {
log.Println(err)
return false
}
if err := cmd.Start(); err != nil {
log.Println(err)
return false
}
data, err := ioutil.ReadAll(stderr)
if err != nil {
log.Println(err)
return false
}
// Bob. We got a problem.
if len(data) != 0 {
log.Println(string(data))
}
io.Copy(os.Stdout, stdout)
cmd.Wait()
stdout.Close()
return true
}