1
0
Fork 0
mirror of https://github.com/Luzifer/tex-api.git synced 2025-01-07 20:41:49 +00:00

Several fixes

Signed-off-by: Knut Ahlers <knut@ahlers.me>
This commit is contained in:
Knut Ahlers 2017-03-05 23:19:43 +01:00
parent f867de4912
commit 1554acab6d
Signed by: luzifer
GPG key ID: DC2729FDD34BE99E
3 changed files with 31 additions and 11 deletions

View file

@ -2,6 +2,12 @@ FROM golang
MAINTAINER Knut Ahlers <knut@ahlers.me> MAINTAINER Knut Ahlers <knut@ahlers.me>
RUN set -ex \
&& apt-get update \
&& apt-get install -y texlive-full \
&& apt-get clean \
&& rm -rf /var/lib/apt/lists/*
ADD . /go/src/github.com/Luzifer/tex-api ADD . /go/src/github.com/Luzifer/tex-api
WORKDIR /go/src/github.com/Luzifer/tex-api WORKDIR /go/src/github.com/Luzifer/tex-api
@ -9,13 +15,12 @@ RUN set -ex \
&& apt-get update \ && apt-get update \
&& apt-get install -y git ca-certificates \ && apt-get install -y git ca-certificates \
&& go install -ldflags "-X main.version=$(git describe --tags || git rev-parse --short HEAD || echo dev)" \ && go install -ldflags "-X main.version=$(git describe --tags || git rev-parse --short HEAD || echo dev)" \
&& apt-get install -y texlive-full \
&& apt-get clean \ && apt-get clean \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
EXPOSE 3000 EXPOSE 3000
VOLUME ["/store"] VOLUME ["/storage"]
ENTRYPOINT ["/go/bin/tex-api"] ENTRYPOINT ["/go/bin/tex-api"]
CMD ["--"] CMD ["--"]

26
main.go
View file

@ -8,6 +8,7 @@ import (
"io" "io"
"math" "math"
"net/http" "net/http"
"net/url"
"os" "os"
"os/exec" "os/exec"
"path" "path"
@ -24,7 +25,7 @@ import (
var ( var (
cfg = struct { cfg = struct {
ExecutionScript string `flag:"script" default:"tex-build.sh" description:"Script to execute (needs to generate output directory)"` ExecutionScript string `flag:"script" default:"/go/src/github.com/Luzifer/tex-api/tex-build.sh" description:"Script to execute (needs to generate output directory)"`
Listen string `flag:"listen" default:":3000" description:"IP/Port to listen on"` Listen string `flag:"listen" default:":3000" description:"IP/Port to listen on"`
StorageDir string `flag:"storage-dir" default:"/storage" description:"Where to store uploaded ZIPs and resulting files"` StorageDir string `flag:"storage-dir" default:"/storage" description:"Where to store uploaded ZIPs and resulting files"`
VersionAndExit bool `flag:"version" default:"false" description:"Prints current version and exits"` VersionAndExit bool `flag:"version" default:"false" description:"Prints current version and exits"`
@ -89,6 +90,13 @@ func (s statusOutput) Save() error {
return json.NewEncoder(f).Encode(s) return json.NewEncoder(f).Encode(s)
} }
func urlMust(u *url.URL, err error) *url.URL {
if err != nil {
log.Fatalf("Unable to retrieve URL from router: %s", err)
}
return u
}
func init() { func init() {
if err := rconfig.Parse(&cfg); err != nil { if err := rconfig.Parse(&cfg); err != nil {
log.Fatalf("Unable to parse commandline options: %s", err) log.Fatalf("Unable to parse commandline options: %s", err)
@ -128,8 +136,13 @@ func startNewJob(res http.ResponseWriter, r *http.Request) {
} }
if f, err := os.Create(inputFile); err == nil { if f, err := os.Create(inputFile); err == nil {
io.Copy(f, r.Body) defer f.Close()
f.Close() if _, err := io.Copy(f, r.Body); err != nil {
log.Errorf("Unable to copy input file %q: %s", inputFile, err)
http.Error(res, "An error ocurred. See details in log.", http.StatusInternalServerError)
return
}
f.Sync()
} else { } else {
log.Errorf("Unable to write input file %q: %s", inputFile, err) log.Errorf("Unable to write input file %q: %s", inputFile, err)
http.Error(res, "An error ocurred. See details in log.", http.StatusInternalServerError) http.Error(res, "An error ocurred. See details in log.", http.StatusInternalServerError)
@ -150,7 +163,7 @@ func startNewJob(res http.ResponseWriter, r *http.Request) {
go jobProcessor(jobUUID) go jobProcessor(jobUUID)
u, _ := router.Get("getJobStatus").URL(jobUUID.String()) u := urlMust(router.Get("waitForJob").URL("uid", jobUUID.String()))
http.Redirect(res, r, u.String(), http.StatusFound) http.Redirect(res, r, u.String(), http.StatusFound)
} }
@ -216,7 +229,7 @@ func waitForJob(res http.ResponseWriter, r *http.Request) {
} }
if status.Status != statusFinished { if status.Status != statusFinished {
u, _ := router.Get("waitForJob").URL(uid.String()) u := urlMust(router.Get("waitForJob").URL("uid", uid.String()))
u.Query().Set("loop", strconv.Itoa(loop)) u.Query().Set("loop", strconv.Itoa(loop))
<-time.After(time.Duration(math.Pow(sleepBase, float64(loop))) * time.Second) <-time.After(time.Duration(math.Pow(sleepBase, float64(loop))) * time.Second)
@ -224,7 +237,7 @@ func waitForJob(res http.ResponseWriter, r *http.Request) {
http.Redirect(res, r, u.String(), http.StatusFound) http.Redirect(res, r, u.String(), http.StatusFound)
} }
u, _ := router.Get("downloadAssets").URL(uid.String()) u := urlMust(router.Get("downloadAssets").URL("uid", uid.String()))
http.Redirect(res, r, u.String(), http.StatusFound) http.Redirect(res, r, u.String(), http.StatusFound)
} }
@ -307,6 +320,7 @@ func jobProcessor(uid uuid.UUID) {
cmd := exec.Command("/bin/bash", cfg.ExecutionScript) cmd := exec.Command("/bin/bash", cfg.ExecutionScript)
cmd.Dir = processingDir cmd.Dir = processingDir
cmd.Stderr = log.StandardLogger().WriterLevel(log.ErrorLevel)
status.UpdateStatus(statusStarted) status.UpdateStatus(statusStarted)
if err := status.Save(); err != nil { if err := status.Save(); err != nil {

View file

@ -3,8 +3,9 @@
set -ex set -ex
set -o pipefail set -o pipefail
BUILD_DIR=$1 unzip input.zip
cd $BUILD_DIR mkdir -p output
# TODO(kahlers): Add logic xelatex -halt-on-error -output-directory=output *.tex
xelatex -halt-on-error -output-directory=output *.tex