- Refactor file embedding to use Go 1.16 embed functionality.
- Remove references to previous bindata packages from build scripts and docs
This commit is contained in:
parent
03c42eb1e8
commit
256a80646f
@ -21,17 +21,15 @@ workflows:
|
|||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
docker:
|
docker:
|
||||||
- image: circleci/golang:1.15
|
- image: circleci/golang:1.16
|
||||||
working_directory: /go/src/github.com/xddxdd/bird-lg-go
|
working_directory: /go/src/github.com/xddxdd/bird-lg-go
|
||||||
steps:
|
steps:
|
||||||
- checkout
|
- checkout
|
||||||
- run: go get -v -t -d ./...
|
- run: GO111MODULE=auto go get -v -t -d ./...
|
||||||
- run: go get -u github.com/kevinburke/go-bindata/...
|
- run: GO111MODULE=auto go test -v ./...
|
||||||
- run: cd frontend && go generate
|
|
||||||
- run: go test -v ./...
|
|
||||||
deploy:
|
deploy:
|
||||||
docker:
|
docker:
|
||||||
- image: circleci/golang:1.15
|
- image: circleci/golang:1.16
|
||||||
working_directory: /go/src/github.com/xddxdd/bird-lg-go
|
working_directory: /go/src/github.com/xddxdd/bird-lg-go
|
||||||
parameters:
|
parameters:
|
||||||
image_arch:
|
image_arch:
|
||||||
|
@ -33,8 +33,6 @@ Or, you can manually do the building steps:
|
|||||||
```bash
|
```bash
|
||||||
# Build frontend binary
|
# Build frontend binary
|
||||||
cd frontend
|
cd frontend
|
||||||
go get -u github.com/kevinburke/go-bindata/...
|
|
||||||
go generate
|
|
||||||
go build -ldflags "-w -s" -o frontend
|
go build -ldflags "-w -s" -o frontend
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
@ -44,8 +42,6 @@ go build -ldflags "-w -s" -o proxy
|
|||||||
cd ..
|
cd ..
|
||||||
```
|
```
|
||||||
|
|
||||||
- If you get `undefined: MustAssetString`, you need to uninstall an older version of go-bindata from your machine: see [#11](https://github.com/xddxdd/bird-lg-go/issues/11)
|
|
||||||
|
|
||||||
## Build Docker Images
|
## Build Docker Images
|
||||||
|
|
||||||
Run `make dockerfile` and you'll get a bunch of Dockerfiles for different architectures:
|
Run `make dockerfile` and you'll get a bunch of Dockerfiles for different architectures:
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
.PHONY: all
|
.PHONY: all
|
||||||
all:
|
all:
|
||||||
go get -u github.com/kevinburke/go-bindata/...
|
|
||||||
go generate
|
|
||||||
go build -ldflags "-w -s" -o frontend
|
go build -ldflags "-w -s" -o frontend
|
||||||
|
@ -1,9 +1,5 @@
|
|||||||
module github.com/xddxdd/bird-lg-go/frontend
|
module github.com/xddxdd/bird-lg-go/frontend
|
||||||
|
|
||||||
go 1.15
|
go 1.16
|
||||||
|
|
||||||
require (
|
require github.com/gorilla/handlers v1.5.1
|
||||||
github.com/elazarl/go-bindata-assetfs v1.0.1
|
|
||||||
github.com/gorilla/handlers v1.5.1
|
|
||||||
github.com/kevinburke/go-bindata v3.22.0+incompatible // indirect
|
|
||||||
)
|
|
||||||
|
@ -1,8 +1,4 @@
|
|||||||
github.com/elazarl/go-bindata-assetfs v1.0.1 h1:m0kkaHRKEu7tUIUFVwhGGGYClXvyl4RE03qmvRTNfbw=
|
|
||||||
github.com/elazarl/go-bindata-assetfs v1.0.1/go.mod h1:v+YaWX3bdea5J/mo8dSETolEo7R71Vk1u8bnjau5yw4=
|
|
||||||
github.com/felixge/httpsnoop v1.0.1 h1:lvB5Jl89CsZtGIWuTcDM1E/vkVs49/Ml7JJe07l8SPQ=
|
github.com/felixge/httpsnoop v1.0.1 h1:lvB5Jl89CsZtGIWuTcDM1E/vkVs49/Ml7JJe07l8SPQ=
|
||||||
github.com/felixge/httpsnoop v1.0.1/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U=
|
github.com/felixge/httpsnoop v1.0.1/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U=
|
||||||
github.com/gorilla/handlers v1.5.1 h1:9lRY6j8DEeeBT10CvO9hGW0gmky0BprnvDI5vfhUHH4=
|
github.com/gorilla/handlers v1.5.1 h1:9lRY6j8DEeeBT10CvO9hGW0gmky0BprnvDI5vfhUHH4=
|
||||||
github.com/gorilla/handlers v1.5.1/go.mod h1:t8XrUpc4KVXb7HGyJ4/cEnwQiaxrX/hz1Zv/4g96P1Q=
|
github.com/gorilla/handlers v1.5.1/go.mod h1:t8XrUpc4KVXb7HGyJ4/cEnwQiaxrX/hz1Zv/4g96P1Q=
|
||||||
github.com/kevinburke/go-bindata v3.22.0+incompatible h1:/JmqEhIWQ7GRScV0WjX/0tqBrC5D21ALg0H0U/KZ/ts=
|
|
||||||
github.com/kevinburke/go-bindata v3.22.0+incompatible/go.mod h1:/pEEZ72flUW2p0yi30bslSp9YqD9pysLxunQDdb2CPM=
|
|
||||||
|
@ -7,9 +7,6 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
// binary data
|
|
||||||
//go:generate go-bindata -prefix bindata -o bindata.go bindata/...
|
|
||||||
|
|
||||||
type settingType struct {
|
type settingType struct {
|
||||||
servers []string
|
servers []string
|
||||||
serversDisplay []string
|
serversDisplay []string
|
||||||
|
@ -19,9 +19,6 @@ ENV GOOS=linux GOARCH=s390x
|
|||||||
ENV CGO_ENABLED=0 GO111MODULE=on
|
ENV CGO_ENABLED=0 GO111MODULE=on
|
||||||
WORKDIR /root
|
WORKDIR /root
|
||||||
COPY . .
|
COPY . .
|
||||||
# go-bindata is run on the build host as part of the go generate step
|
|
||||||
RUN GOARCH=amd64 go get -u github.com/kevinburke/go-bindata/...
|
|
||||||
RUN go generate
|
|
||||||
RUN go build -ldflags "-w -s" -o /frontend
|
RUN go build -ldflags "-w -s" -o /frontend
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
|
@ -1,17 +1,24 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"embed"
|
||||||
"strings"
|
"strings"
|
||||||
"text/template"
|
"text/template"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// import templates and other assets
|
||||||
|
//go:embed assets
|
||||||
|
var assets embed.FS
|
||||||
|
|
||||||
|
const TEMPLATE_PATH = "assets/templates/"
|
||||||
|
|
||||||
// template argument structures
|
// template argument structures
|
||||||
|
|
||||||
// page
|
// page
|
||||||
type TemplatePage struct {
|
type TemplatePage struct {
|
||||||
// Global options
|
// Global options
|
||||||
Options map[string]string
|
Options map[string]string
|
||||||
Servers []string
|
Servers []string
|
||||||
ServersEscaped []string
|
ServersEscaped []string
|
||||||
ServersDisplay []string
|
ServersDisplay []string
|
||||||
|
|
||||||
@ -95,7 +102,7 @@ var requiredTemplates = [...]string{
|
|||||||
"bird",
|
"bird",
|
||||||
}
|
}
|
||||||
|
|
||||||
// import templates from bindata
|
// import templates from embedded assets
|
||||||
|
|
||||||
func ImportTemplates() {
|
func ImportTemplates() {
|
||||||
|
|
||||||
@ -105,13 +112,16 @@ func ImportTemplates() {
|
|||||||
// for each template that is needed
|
// for each template that is needed
|
||||||
for _, tmpl := range requiredTemplates {
|
for _, tmpl := range requiredTemplates {
|
||||||
|
|
||||||
// extract the template definition from the bindata
|
// extract the template definition from the embedded assets
|
||||||
def := MustAssetString("templates/" + tmpl + ".tpl")
|
def, err := assets.ReadFile(TEMPLATE_PATH + tmpl + ".tpl")
|
||||||
|
if err != nil {
|
||||||
|
panic("Unable to read template (" + TEMPLATE_PATH + tmpl + ": " + err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
// and add it to the template library
|
// and add it to the template library
|
||||||
template, err := template.New(tmpl).Parse(def)
|
template, err := template.New(tmpl).Parse(string(def))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic("Unable to parse template (templates/" + tmpl + ": " + err.Error())
|
panic("Unable to parse template (" + TEMPLATE_PATH + tmpl + ": " + err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
// store in the library
|
// store in the library
|
||||||
|
@ -4,12 +4,12 @@ import (
|
|||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"html"
|
"html"
|
||||||
|
"io/fs"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
assetfs "github.com/elazarl/go-bindata-assetfs"
|
|
||||||
"github.com/gorilla/handlers"
|
"github.com/gorilla/handlers"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -183,13 +183,12 @@ func webServerStart() {
|
|||||||
http.Redirect(w, r, "/summary/"+url.PathEscape(strings.Join(setting.servers, "+")), 302)
|
http.Redirect(w, r, "/summary/"+url.PathEscape(strings.Join(setting.servers, "+")), 302)
|
||||||
})
|
})
|
||||||
|
|
||||||
// serve static pages using the AssetFS and bindata
|
// serve static pages using embedded assets from template.go
|
||||||
fs := http.FileServer(&assetfs.AssetFS{
|
subfs, err := fs.Sub(assets, "assets")
|
||||||
Asset: Asset,
|
if err != nil {
|
||||||
AssetDir: AssetDir,
|
panic("Webserver fs.sub failed: " + err.Error())
|
||||||
AssetInfo: AssetInfo,
|
}
|
||||||
Prefix: "",
|
fs := http.FileServer(http.FS(subfs))
|
||||||
})
|
|
||||||
|
|
||||||
http.Handle("/static/", fs)
|
http.Handle("/static/", fs)
|
||||||
http.Handle("/robots.txt", fs)
|
http.Handle("/robots.txt", fs)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user