forked from p85947160/gitea
parent
93bac4e10d
commit
99ffd826e5
2
go.mod
2
go.mod
|
@ -45,7 +45,7 @@ require (
|
||||||
github.com/glycerine/goconvey v0.0.0-20190315024820-982ee783a72e // indirect
|
github.com/glycerine/goconvey v0.0.0-20190315024820-982ee783a72e // indirect
|
||||||
github.com/go-macaron/binding v0.0.0-20160711225916-9440f336b443
|
github.com/go-macaron/binding v0.0.0-20160711225916-9440f336b443
|
||||||
github.com/go-macaron/cache v0.0.0-20151013081102-561735312776
|
github.com/go-macaron/cache v0.0.0-20151013081102-561735312776
|
||||||
github.com/go-macaron/captcha v0.0.0-20151123225153-8aa5919789ab
|
github.com/go-macaron/captcha v0.0.0-20190710000913-8dc5911259df
|
||||||
github.com/go-macaron/cors v0.0.0-20190309005821-6fd6a9bfe14e9
|
github.com/go-macaron/cors v0.0.0-20190309005821-6fd6a9bfe14e9
|
||||||
github.com/go-macaron/csrf v0.0.0-20180426211211-503617c6b372
|
github.com/go-macaron/csrf v0.0.0-20180426211211-503617c6b372
|
||||||
github.com/go-macaron/i18n v0.0.0-20160612092837-ef57533c3b0f
|
github.com/go-macaron/i18n v0.0.0-20160612092837-ef57533c3b0f
|
||||||
|
|
4
go.sum
4
go.sum
|
@ -113,8 +113,8 @@ github.com/go-macaron/binding v0.0.0-20160711225916-9440f336b443 h1:i801KPR7j76u
|
||||||
github.com/go-macaron/binding v0.0.0-20160711225916-9440f336b443/go.mod h1:u+H6rwW+HQwUL+w5uaEJSpIlVZDye1o9MB4Su0JfRfM=
|
github.com/go-macaron/binding v0.0.0-20160711225916-9440f336b443/go.mod h1:u+H6rwW+HQwUL+w5uaEJSpIlVZDye1o9MB4Su0JfRfM=
|
||||||
github.com/go-macaron/cache v0.0.0-20151013081102-561735312776 h1:UYIHS1r0WotqB5cIa0PAiV0m6GzD9rDBcn4alp5JgCw=
|
github.com/go-macaron/cache v0.0.0-20151013081102-561735312776 h1:UYIHS1r0WotqB5cIa0PAiV0m6GzD9rDBcn4alp5JgCw=
|
||||||
github.com/go-macaron/cache v0.0.0-20151013081102-561735312776/go.mod h1:hHAsZm/oBZVcY+S7qdQL6Vbg5VrXF6RuKGuqsszt3Ok=
|
github.com/go-macaron/cache v0.0.0-20151013081102-561735312776/go.mod h1:hHAsZm/oBZVcY+S7qdQL6Vbg5VrXF6RuKGuqsszt3Ok=
|
||||||
github.com/go-macaron/captcha v0.0.0-20151123225153-8aa5919789ab h1:4VFhsA3GE5Wwq1Ymr8KWCmrOWi1wRLEgdj48LPfQjxI=
|
github.com/go-macaron/captcha v0.0.0-20190710000913-8dc5911259df h1:MdgvtI3Y1u/DHNj7xUGOqAv+KGoTikjy8xQtCm12L78=
|
||||||
github.com/go-macaron/captcha v0.0.0-20151123225153-8aa5919789ab/go.mod h1:j9TJ+0nwUOWBvNnm0bheHIPFf3cC62EQo7n7O6PbjZA=
|
github.com/go-macaron/captcha v0.0.0-20190710000913-8dc5911259df/go.mod h1:j9TJ+0nwUOWBvNnm0bheHIPFf3cC62EQo7n7O6PbjZA=
|
||||||
github.com/go-macaron/cors v0.0.0-20190309005821-6fd6a9bfe14e9 h1:A0QGzY6UHHEil0I2e7C21JenNNG0mmrj5d9SFWTlgr8=
|
github.com/go-macaron/cors v0.0.0-20190309005821-6fd6a9bfe14e9 h1:A0QGzY6UHHEil0I2e7C21JenNNG0mmrj5d9SFWTlgr8=
|
||||||
github.com/go-macaron/cors v0.0.0-20190309005821-6fd6a9bfe14e9/go.mod h1:utmMRnVIrXPSfA9MFcpIYKEpKawjKxf62vv62k4707E=
|
github.com/go-macaron/cors v0.0.0-20190309005821-6fd6a9bfe14e9/go.mod h1:utmMRnVIrXPSfA9MFcpIYKEpKawjKxf62vv62k4707E=
|
||||||
github.com/go-macaron/csrf v0.0.0-20180426211211-503617c6b372 h1:acrx8CnDmlKl+BPoOOLEK9Ko+SrWFB5pxRuGkKj4iqo=
|
github.com/go-macaron/csrf v0.0.0-20180426211211-503617c6b372 h1:acrx8CnDmlKl+BPoOOLEK9Ko+SrWFB5pxRuGkKj4iqo=
|
||||||
|
|
|
@ -1,14 +1,10 @@
|
||||||
sudo: false
|
sudo: false
|
||||||
language: go
|
language: go
|
||||||
|
|
||||||
go:
|
go:
|
||||||
- 1.3
|
- 1.6.x
|
||||||
- 1.4
|
- 1.7.x
|
||||||
- 1.5
|
- 1.8.x
|
||||||
- tip
|
- 1.9.x
|
||||||
|
- 1.10.x
|
||||||
|
|
||||||
script: go test -v -cover -race
|
script: go test -v -cover -race
|
||||||
|
|
||||||
notifications:
|
|
||||||
email:
|
|
||||||
- u@gogs.io
|
|
||||||
|
|
|
@ -19,6 +19,7 @@ package captcha
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"html/template"
|
"html/template"
|
||||||
|
"image/color"
|
||||||
"path"
|
"path"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
@ -49,6 +50,7 @@ type Captcha struct {
|
||||||
ChallengeNums int
|
ChallengeNums int
|
||||||
Expiration int64
|
Expiration int64
|
||||||
CachePrefix string
|
CachePrefix string
|
||||||
|
ColorPalette color.Palette
|
||||||
}
|
}
|
||||||
|
|
||||||
// generate key string
|
// generate key string
|
||||||
|
@ -61,16 +63,21 @@ func (c *Captcha) genRandChars() string {
|
||||||
return string(com.RandomCreateBytes(c.ChallengeNums, defaultChars...))
|
return string(com.RandomCreateBytes(c.ChallengeNums, defaultChars...))
|
||||||
}
|
}
|
||||||
|
|
||||||
// tempalte func for output html
|
// CreateHTML outputs HTML for display and fetch new captcha images.
|
||||||
func (c *Captcha) CreateHtml() template.HTML {
|
func (c *Captcha) CreateHTML() template.HTML {
|
||||||
value, err := c.CreateCaptcha()
|
value, err := c.CreateCaptcha()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(fmt.Errorf("fail to create captcha: %v", err))
|
panic(fmt.Errorf("fail to create captcha: %v", err))
|
||||||
}
|
}
|
||||||
return template.HTML(fmt.Sprintf(`<input type="hidden" name="%s" value="%s">
|
return template.HTML(fmt.Sprintf(`<input type="hidden" name="%[1]s" value="%[2]s">
|
||||||
<a class="captcha" href="javascript:">
|
<a class="captcha" href="javascript:" tabindex="-1">
|
||||||
<img onclick="this.src=('%s%s%s.png?reload='+(new Date()).getTime())" class="captcha-img" src="%s%s%s.png">
|
<img onclick="this.src=('%[3]s%[4]s%[2]s.png?reload='+(new Date()).getTime())" class="captcha-img" src="%[3]s%[4]s%[2]s.png">
|
||||||
</a>`, c.FieldIdName, value, c.SubURL, c.URLPrefix, value, c.SubURL, c.URLPrefix, value))
|
</a>`, c.FieldIdName, value, c.SubURL, c.URLPrefix))
|
||||||
|
}
|
||||||
|
|
||||||
|
// DEPRECATED
|
||||||
|
func (c *Captcha) CreateHtml() template.HTML {
|
||||||
|
return c.CreateHTML()
|
||||||
}
|
}
|
||||||
|
|
||||||
// create a new captcha id
|
// create a new captcha id
|
||||||
|
@ -139,6 +146,9 @@ type Options struct {
|
||||||
Expiration int64
|
Expiration int64
|
||||||
// Cache key prefix captcha characters. Default is "captcha_".
|
// Cache key prefix captcha characters. Default is "captcha_".
|
||||||
CachePrefix string
|
CachePrefix string
|
||||||
|
// ColorPalette holds a collection of primary colors used for
|
||||||
|
// the captcha's text. If not defined, a random color will be generated.
|
||||||
|
ColorPalette color.Palette
|
||||||
}
|
}
|
||||||
|
|
||||||
func prepareOptions(options []Options) Options {
|
func prepareOptions(options []Options) Options {
|
||||||
|
@ -192,6 +202,7 @@ func NewCaptcha(opt Options) *Captcha {
|
||||||
ChallengeNums: opt.ChallengeNums,
|
ChallengeNums: opt.ChallengeNums,
|
||||||
Expiration: opt.Expiration,
|
Expiration: opt.Expiration,
|
||||||
CachePrefix: opt.CachePrefix,
|
CachePrefix: opt.CachePrefix,
|
||||||
|
ColorPalette: opt.ColorPalette,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -229,9 +240,10 @@ func Captchaer(options ...Options) macaron.Handler {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if _, err := NewImage([]byte(chars), cpt.StdWidth, cpt.StdHeight).WriteTo(ctx.Resp); err != nil {
|
if _, err := NewImage([]byte(chars), cpt.StdWidth, cpt.StdHeight, cpt.ColorPalette).WriteTo(ctx.Resp); err != nil {
|
||||||
panic(fmt.Errorf("write captcha: %v", err))
|
panic(fmt.Errorf("write captcha: %v", err))
|
||||||
}
|
}
|
||||||
|
ctx.Status(200)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -265,16 +265,22 @@ func randFloat(from, to float64) float64 {
|
||||||
return (to-from)*prng.Float64() + from
|
return (to-from)*prng.Float64() + from
|
||||||
}
|
}
|
||||||
|
|
||||||
func randomPalette() color.Palette {
|
func randomPalette(primary color.Palette) color.Palette {
|
||||||
p := make([]color.Color, circleCount+1)
|
p := make([]color.Color, circleCount+1)
|
||||||
// Transparent color.
|
// Transparent color.
|
||||||
p[0] = color.RGBA{0xFF, 0xFF, 0xFF, 0x00}
|
p[0] = color.RGBA{0xFF, 0xFF, 0xFF, 0x00}
|
||||||
// Primary color.
|
// Primary color.
|
||||||
prim := color.RGBA{
|
var prim color.RGBA
|
||||||
uint8(randIntn(129)),
|
if len(primary) == 0 {
|
||||||
uint8(randIntn(129)),
|
prim = color.RGBA{
|
||||||
uint8(randIntn(129)),
|
uint8(randIntn(129)),
|
||||||
0xFF,
|
uint8(randIntn(129)),
|
||||||
|
uint8(randIntn(129)),
|
||||||
|
0xFF,
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
r, g, b, a := primary[randIntn(len(primary)-1)].RGBA()
|
||||||
|
prim = color.RGBA{uint8(r), uint8(g), uint8(b), uint8(a)}
|
||||||
}
|
}
|
||||||
p[1] = prim
|
p[1] = prim
|
||||||
// Circle colors.
|
// Circle colors.
|
||||||
|
@ -285,10 +291,11 @@ func randomPalette() color.Palette {
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewImage returns a new captcha image of the given width and height with the
|
// NewImage returns a new captcha image of the given width and height with the
|
||||||
// given digits, where each digit must be in range 0-9.
|
// given digits, where each digit must be in range 0-9. The digit's color is
|
||||||
func NewImage(digits []byte, width, height int) *Image {
|
// chosen by random from the colorPalette.
|
||||||
|
func NewImage(digits []byte, width, height int, colorPalette color.Palette) *Image {
|
||||||
m := new(Image)
|
m := new(Image)
|
||||||
m.Paletted = image.NewPaletted(image.Rect(0, 0, width, height), randomPalette())
|
m.Paletted = image.NewPaletted(image.Rect(0, 0, width, height), randomPalette(colorPalette))
|
||||||
m.calculateSizes(width, height, len(digits))
|
m.calculateSizes(width, height, len(digits))
|
||||||
// Randomly position captcha inside the image.
|
// Randomly position captcha inside the image.
|
||||||
maxx := width - (m.numWidth+m.dotSize)*len(digits) - m.dotSize
|
maxx := width - (m.numWidth+m.dotSize)*len(digits) - m.dotSize
|
||||||
|
|
|
@ -120,7 +120,7 @@ github.com/go-macaron/binding
|
||||||
github.com/go-macaron/cache
|
github.com/go-macaron/cache
|
||||||
github.com/go-macaron/cache/memcache
|
github.com/go-macaron/cache/memcache
|
||||||
github.com/go-macaron/cache/redis
|
github.com/go-macaron/cache/redis
|
||||||
# github.com/go-macaron/captcha v0.0.0-20151123225153-8aa5919789ab
|
# github.com/go-macaron/captcha v0.0.0-20190710000913-8dc5911259df
|
||||||
github.com/go-macaron/captcha
|
github.com/go-macaron/captcha
|
||||||
# github.com/go-macaron/cors v0.0.0-20190309005821-6fd6a9bfe14e9
|
# github.com/go-macaron/cors v0.0.0-20190309005821-6fd6a9bfe14e9
|
||||||
github.com/go-macaron/cors
|
github.com/go-macaron/cors
|
||||||
|
|
Loading…
Reference in New Issue