upgrade to use embed from Go 1.16
This commit is contained in:
parent
cccc7a97ea
commit
53e75b199a
|
@ -8,7 +8,7 @@ jobs:
|
||||||
- name: Set up Golang
|
- name: Set up Golang
|
||||||
uses: actions/setup-go@v2
|
uses: actions/setup-go@v2
|
||||||
with:
|
with:
|
||||||
go-version: '^1.13.1'
|
go-version: '^1.16.0'
|
||||||
- run: go version
|
- run: go version
|
||||||
|
|
||||||
- name: Check out code into the Go module directory
|
- name: Check out code into the Go module directory
|
||||||
|
|
|
@ -42,11 +42,7 @@ func handle(w http.ResponseWriter, r *http.Request) {
|
||||||
|
|
||||||
## Compatibility
|
## Compatibility
|
||||||
|
|
||||||
This package is in a module and I recommand using the following version of Go:
|
This package uses embed package from Go 1.16. If for some reason you have to use pre 1.16 version of Go, reference pre 1.4 version of this module in your go.mod.
|
||||||
|
|
||||||
* 1.9.7+ for Go 1.9
|
|
||||||
* 1.10.3+ for Go 1.10
|
|
||||||
* Go 1.11 or later
|
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
If your found a bug, please contribute!
|
If your found a bug, please contribute!
|
||||||
|
|
|
@ -3,6 +3,7 @@ package captcha
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
_ "embed"
|
||||||
"image"
|
"image"
|
||||||
"image/color"
|
"image/color"
|
||||||
"image/draw"
|
"image/draw"
|
||||||
|
@ -22,6 +23,8 @@ import (
|
||||||
|
|
||||||
const charPreset = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"
|
const charPreset = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"
|
||||||
|
|
||||||
|
//go:embed fonts/Comismsh.ttf
|
||||||
|
var ttf []byte
|
||||||
var ttfFont *truetype.Font
|
var ttfFont *truetype.Font
|
||||||
|
|
||||||
// Options manage captcha generation details.
|
// Options manage captcha generation details.
|
||||||
|
@ -134,7 +137,7 @@ func New(width int, height int, option ...SetOption) (*Data, error) {
|
||||||
|
|
||||||
text := randomText(options)
|
text := randomText(options)
|
||||||
img := image.NewNRGBA(image.Rect(0, 0, width, height))
|
img := image.NewNRGBA(image.Rect(0, 0, width, height))
|
||||||
draw.Draw(img, img.Bounds(), &image.Uniform{options.BackgroundColor}, image.ZP, draw.Src)
|
draw.Draw(img, img.Bounds(), &image.Uniform{options.BackgroundColor}, image.Point{}, draw.Src)
|
||||||
drawNoise(img, options)
|
drawNoise(img, options)
|
||||||
drawCurves(img, options)
|
drawCurves(img, options)
|
||||||
err := drawText(text, img, options)
|
err := drawText(text, img, options)
|
||||||
|
@ -155,7 +158,7 @@ func NewMathExpr(width int, height int, option ...SetOption) (*Data, error) {
|
||||||
|
|
||||||
text, equation := randomEquation()
|
text, equation := randomEquation()
|
||||||
img := image.NewNRGBA(image.Rect(0, 0, width, height))
|
img := image.NewNRGBA(image.Rect(0, 0, width, height))
|
||||||
draw.Draw(img, img.Bounds(), &image.Uniform{options.BackgroundColor}, image.ZP, draw.Src)
|
draw.Draw(img, img.Bounds(), &image.Uniform{options.BackgroundColor}, image.Point{}, draw.Src)
|
||||||
drawNoise(img, options)
|
drawNoise(img, options)
|
||||||
drawCurves(img, options)
|
drawCurves(img, options)
|
||||||
err := drawText(equation, img, options)
|
err := drawText(equation, img, options)
|
||||||
|
|
40
fonts/gen.go
40
fonts/gen.go
|
@ -1,40 +0,0 @@
|
||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"fmt"
|
|
||||||
"go/format"
|
|
||||||
"io/ioutil"
|
|
||||||
"log"
|
|
||||||
"path/filepath"
|
|
||||||
)
|
|
||||||
|
|
||||||
// This program generates a go file for Comismsh font
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
src, err := ioutil.ReadFile("Comismsh.ttf")
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
buf := new(bytes.Buffer)
|
|
||||||
fmt.Fprint(buf, "// DO NOT EDIT. This file is generated.\n\n")
|
|
||||||
fmt.Fprint(buf, "package captcha\n\n")
|
|
||||||
fmt.Fprint(buf, "// The following is Comismsh TrueType font data.\n")
|
|
||||||
fmt.Fprint(buf, "var ttf = []byte{")
|
|
||||||
for i, x := range src {
|
|
||||||
if i&15 == 0 {
|
|
||||||
buf.WriteByte('\n')
|
|
||||||
}
|
|
||||||
fmt.Fprintf(buf, "%#02x,", x)
|
|
||||||
}
|
|
||||||
fmt.Fprint(buf, "\n}\n")
|
|
||||||
|
|
||||||
dst, err := format.Source(buf.Bytes())
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
|
||||||
if err := ioutil.WriteFile(filepath.Join("../", "font.go"), dst, 0666); err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
4
go.mod
4
go.mod
|
@ -1,8 +1,8 @@
|
||||||
module github.com/steambap/captcha
|
module github.com/steambap/captcha
|
||||||
|
|
||||||
go 1.12
|
go 1.16
|
||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0
|
github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0
|
||||||
golang.org/x/image v0.0.0-20201208152932-35266b937fa6
|
golang.org/x/image v0.0.0-20210628002857-a66eb6448b8d
|
||||||
)
|
)
|
||||||
|
|
7
go.sum
7
go.sum
|
@ -1,5 +1,6 @@
|
||||||
github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0 h1:DACJavvAHhabrF08vX0COfcOBJRhZ8lUbR+ZWIs0Y5g=
|
github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0 h1:DACJavvAHhabrF08vX0COfcOBJRhZ8lUbR+ZWIs0Y5g=
|
||||||
github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k=
|
github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k=
|
||||||
golang.org/x/image v0.0.0-20201208152932-35266b937fa6 h1:nfeHNc1nAqecKCy2FCy4HY+soOOe5sDLJ/gZLbx6GYI=
|
golang.org/x/image v0.0.0-20210628002857-a66eb6448b8d h1:RNPAfi2nHY7C2srAV8A49jpsYr0ADedCk1wq6fTMTvs=
|
||||||
golang.org/x/image v0.0.0-20201208152932-35266b937fa6/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0=
|
golang.org/x/image v0.0.0-20210628002857-a66eb6448b8d/go.mod h1:023OzeP/+EPmXeapQh35lcL3II3LrY8Ic+EFFKVhULM=
|
||||||
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
|
||||||
|
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
|
||||||
|
|
Reference in New Issue