feat: 用户信息采用sqlite进行存储,为后续webui添加更多支持
This commit is contained in:
parent
94e4678216
commit
ca63317029
27
go.mod
27
go.mod
|
@ -6,15 +6,18 @@ replace github.com/willf/bitset v1.2.1 => github.com/bits-and-blooms/bitset v1.2
|
|||
|
||||
require (
|
||||
github.com/Baozisoftware/qrcode-terminal-go v0.0.0-20170407111555-c0650d8dff0f
|
||||
github.com/fumiama/sqlite3 v1.14.6
|
||||
github.com/go-telegram-bot-api/telegram-bot-api/v5 v5.4.0-beta.0
|
||||
github.com/google/uuid v1.1.1
|
||||
github.com/google/uuid v1.3.0
|
||||
github.com/guonaihong/gout v0.2.9
|
||||
github.com/imroc/req/v3 v3.8.2
|
||||
github.com/lestrrat-go/file-rotatelogs v2.4.0+incompatible
|
||||
github.com/makiuchi-d/gozxing v0.1.1
|
||||
github.com/mxschmitt/playwright-go v0.1400.0
|
||||
github.com/nfnt/resize v0.0.0-20180221191011-83c6a9932646
|
||||
github.com/robfig/cron/v3 v3.0.0
|
||||
github.com/sirupsen/logrus v1.8.1
|
||||
github.com/skip2/go-qrcode v0.0.0-20200617195104-da1b6568686e
|
||||
github.com/t-tomalak/logrus-easy-formatter v0.0.0-20190827215021-c074f06c5816
|
||||
github.com/tidwall/gjson v1.11.0
|
||||
golang.org/x/image v0.0.0-20211028202545-6944b10bf410
|
||||
|
@ -22,28 +25,44 @@ require (
|
|||
)
|
||||
|
||||
require (
|
||||
fyne.io/fyne v1.4.3 // indirect
|
||||
github.com/danwakefield/fnmatch v0.0.0-20160403171240-cbb64ac3d964 // indirect
|
||||
github.com/davecgh/go-spew v1.1.1 // indirect
|
||||
github.com/flopp/go-findfont v0.1.0 // indirect
|
||||
github.com/fsnotify/fsnotify v1.4.9 // indirect
|
||||
github.com/fyne-io/mobile v0.1.2 // indirect
|
||||
github.com/go-gl/gl v0.0.0-20190320180904-bf2b1f2f34d7 // indirect
|
||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200625191551-73d3c3675aa3 // indirect
|
||||
github.com/go-playground/locales v0.13.0 // indirect
|
||||
github.com/go-playground/universal-translator v0.17.0 // indirect
|
||||
github.com/go-playground/validator/v10 v10.4.1 // indirect
|
||||
github.com/godbus/dbus/v5 v5.0.3 // indirect
|
||||
github.com/goki/freetype v0.0.0-20181231101311-fa8a33aabaff // indirect
|
||||
github.com/gorilla/websocket v1.4.2 // indirect
|
||||
github.com/hashicorp/errwrap v1.0.0 // indirect
|
||||
github.com/hashicorp/go-multierror v1.1.1 // indirect
|
||||
github.com/imroc/req/v3 v3.8.2 // indirect
|
||||
github.com/jonboulle/clockwork v0.2.2 // indirect
|
||||
github.com/leodido/go-urn v1.2.0 // indirect
|
||||
github.com/lestrrat-go/strftime v1.0.5 // indirect
|
||||
github.com/mattn/go-colorable v0.1.11 // indirect
|
||||
github.com/mattn/go-isatty v0.0.14 // indirect
|
||||
github.com/pkg/errors v0.9.1 // indirect
|
||||
github.com/skip2/go-qrcode v0.0.0-20200617195104-da1b6568686e // indirect
|
||||
github.com/pmezard/go-difflib v1.0.0 // indirect
|
||||
github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0 // indirect
|
||||
github.com/srwiley/oksvg v0.0.0-20200311192757-870daf9aa564 // indirect
|
||||
github.com/srwiley/rasterx v0.0.0-20200120212402-85cb7272f5e9 // indirect
|
||||
github.com/stretchr/testify v1.7.0 // indirect
|
||||
github.com/tidwall/match v1.1.1 // indirect
|
||||
github.com/tidwall/pretty v1.2.0 // indirect
|
||||
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9 // indirect
|
||||
golang.org/x/net v0.0.0-20220111093109-d55c255bac03 // indirect
|
||||
golang.org/x/sys v0.0.0-20210927094055-39ccf1dd6fa6 // indirect
|
||||
golang.org/x/sys v0.0.0-20220209214540-3681064d5158 // indirect
|
||||
golang.org/x/text v0.3.7 // indirect
|
||||
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 // indirect
|
||||
google.golang.org/protobuf v1.26.0 // indirect
|
||||
gopkg.in/square/go-jose.v2 v2.6.0 // indirect
|
||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c // indirect
|
||||
modernc.org/libc v1.14.5 // indirect
|
||||
modernc.org/mathutil v1.4.1 // indirect
|
||||
modernc.org/memory v1.0.5 // indirect
|
||||
)
|
||||
|
|
189
go.sum
189
go.sum
|
@ -1,14 +1,31 @@
|
|||
fyne.io/fyne v1.4.3 h1:356CnXCiYrrfaLGsB7qLK3c6ktzyh8WR05v/2RBu51I=
|
||||
fyne.io/fyne v1.4.3/go.mod h1:8kiPBNSDmuplxs9WnKCkaWYqbcXFy0DeAzwa6PBO9Z8=
|
||||
github.com/Baozisoftware/qrcode-terminal-go v0.0.0-20170407111555-c0650d8dff0f h1:2dk3eOnYllh+wUOuDhOoC2vUVoJF/5z478ryJ+wzEII=
|
||||
github.com/Baozisoftware/qrcode-terminal-go v0.0.0-20170407111555-c0650d8dff0f/go.mod h1:4a58ifQTEe2uwwsaqbh3i2un5/CBPg+At/qHpt18Tmk=
|
||||
github.com/Kodeworks/golang-image-ico v0.0.0-20141118225523-73f0f4cfade9/go.mod h1:7uhhqiBaR4CpN0k9rMjOtjpcfGd6DG2m04zQxKnWQ0I=
|
||||
github.com/akavel/rsrc v0.8.0/go.mod h1:uLoCtb9J+EyAqh+26kdrTgmzRBFPGOolLWKpdxkKq+c=
|
||||
github.com/danwakefield/fnmatch v0.0.0-20160403171240-cbb64ac3d964 h1:y5HC9v93H5EPKqaS1UYVg1uYah5Xf51mBfIoWehClUQ=
|
||||
github.com/danwakefield/fnmatch v0.0.0-20160403171240-cbb64ac3d964/go.mod h1:Xd9hchkHSWYkEqJwUGisez3G1QY8Ryz0sdWrLPMGjLk=
|
||||
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||
github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk=
|
||||
github.com/flopp/go-findfont v0.1.0 h1:lPn0BymDUtJo+ZkV01VS3661HL6F4qFlkhcJN55u6mU=
|
||||
github.com/flopp/go-findfont v0.1.0/go.mod h1:wKKxRDjD024Rh7VMwoU90i6ikQRCr+JTHB5n4Ejkqvw=
|
||||
github.com/fsnotify/fsnotify v1.4.9 h1:hsms1Qyu0jgnwNXIxa+/V/PDsU6CfLf6CNO8H7IWoS4=
|
||||
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
|
||||
github.com/fumiama/sqlite3 v1.14.6 h1:+e+iygyiDXQJVi7xeXIviBvR7hAc5y20WA9hRwfKn10=
|
||||
github.com/fumiama/sqlite3 v1.14.6/go.mod h1:Xx9a2/OtHuy9pBjow0N+bE/RhNeZ7zZz5xh25vqbA5A=
|
||||
github.com/fyne-io/mobile v0.1.2 h1:0HaXDtOOwyOTn3Umi0uKVCOgJtfX73c6unC4U8i5VZU=
|
||||
github.com/fyne-io/mobile v0.1.2/go.mod h1:/kOrWrZB6sasLbEy2JIvr4arEzQTXBTZGb3Y96yWbHY=
|
||||
github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE=
|
||||
github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI=
|
||||
github.com/gin-gonic/gin v1.7.0 h1:jGB9xAJQ12AIGNB4HguylppmDK1Am9ppF7XnGXXJuoU=
|
||||
github.com/gin-gonic/gin v1.7.0/go.mod h1:jD2toBW3GZUr5UMcdrwQA10I7RuaFOl/SGeDjXkfUtY=
|
||||
github.com/go-gl/gl v0.0.0-20190320180904-bf2b1f2f34d7 h1:SCYMcCJ89LjRGwEa0tRluNRiMjZHalQZrVrvTbPh+qw=
|
||||
github.com/go-gl/gl v0.0.0-20190320180904-bf2b1f2f34d7/go.mod h1:482civXOzJJCPzJ4ZOX/pwvXBWSnzD4OKMdH4ClKGbk=
|
||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200625191551-73d3c3675aa3 h1:q521PfSp5/z6/sD9FZZOWj4d1MLmfQW8PkRnI9M6PCE=
|
||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200625191551-73d3c3675aa3/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||
github.com/go-playground/assert/v2 v2.0.1 h1:MsBgLAaY856+nPRTKrp3/OZK38U/wa0CcBYNjji3q3A=
|
||||
github.com/go-playground/assert/v2 v2.0.1/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4=
|
||||
github.com/go-playground/locales v0.13.0 h1:HyWk6mgj5qFqCT5fjGBuRArbVDfE4hi8+e8ceBS/t7Q=
|
||||
|
@ -19,14 +36,20 @@ github.com/go-playground/validator/v10 v10.4.1 h1:pH2c5ADXtd66mxoE0Zm9SUhxE20r7a
|
|||
github.com/go-playground/validator/v10 v10.4.1/go.mod h1:nlOn6nFhuKACm19sB/8EGNn9GlaMV7XkbRSipzJ0Ii4=
|
||||
github.com/go-telegram-bot-api/telegram-bot-api/v5 v5.4.0-beta.0 h1:mbEDV1g6RBzKd4sFjOWuyZdxItw4CWu5Kq4KaBAJbHM=
|
||||
github.com/go-telegram-bot-api/telegram-bot-api/v5 v5.4.0-beta.0/go.mod h1:5+h9c5l1Z/+Pi+5boa1Fmr4Q+FImsXYnifor92ljaVs=
|
||||
github.com/godbus/dbus/v5 v5.0.3 h1:ZqHaoEF7TBzh4jzPmqVhE/5A1z9of6orkAe5uHoAeME=
|
||||
github.com/godbus/dbus/v5 v5.0.3/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
|
||||
github.com/goki/freetype v0.0.0-20181231101311-fa8a33aabaff h1:W71vTCKoxtdXgnm1ECDFkfQnpdqAO00zzGXLA5yaEX8=
|
||||
github.com/goki/freetype v0.0.0-20181231101311-fa8a33aabaff/go.mod h1:wfqRWLHRBsRgkp5dmbG56SA0DmVtwrF5N3oPdI8t+Aw=
|
||||
github.com/golang/protobuf v1.3.3/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw=
|
||||
github.com/golang/protobuf v1.5.0 h1:LUVKkCeviFUMKqHa4tXIIij/lbhnMbP7Fn5wKdKkRh4=
|
||||
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
|
||||
github.com/google/go-cmp v0.5.3/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
||||
github.com/google/go-cmp v0.5.5 h1:Khx7svrCpmxxtHBq5j2mp/xVjsi8hQMfNLvJFAlrGgU=
|
||||
github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
||||
github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
|
||||
github.com/google/uuid v1.1.1 h1:Gkbcsh/GbpXz7lPftLA3P6TYMwjCLYm83jiFQZF/3gY=
|
||||
github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
||||
github.com/google/uuid v1.3.0 h1:t6JiXgmwXMjEs8VusXIJk2BXHsn+wx8BZdTaoZ5fu7I=
|
||||
github.com/google/uuid v1.3.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
||||
github.com/gorilla/websocket v1.4.2 h1:+/TMaTYc4QFitKJxsQ7Yye35DkWvkdLcvGKqM+x0Ufc=
|
||||
github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE=
|
||||
github.com/guonaihong/gout v0.2.9 h1:8nU5hrtwP1qDwiadFvU+D+z3ud9WEk8iPSfxQDiebng=
|
||||
|
@ -38,11 +61,16 @@ github.com/hashicorp/go-multierror v1.1.1 h1:H5DkEtf6CXdFp0N0Em5UCwQpXMWke8IA0+l
|
|||
github.com/hashicorp/go-multierror v1.1.1/go.mod h1:iw975J/qwKPdAO1clOe2L8331t/9/fmwbPZ6JB6eMoM=
|
||||
github.com/imroc/req/v3 v3.8.2 h1:wFZ7B0dclCQyjClP5GwXRboUGIek5l0mCpodrGgT01c=
|
||||
github.com/imroc/req/v3 v3.8.2/go.mod h1:3JIicOKEDHfCSYYNLb/ObZNpx64EV5y40VlHMwhUCzU=
|
||||
github.com/jackmordaunt/icns v0.0.0-20181231085925-4f16af745526/go.mod h1:UQkeMHVoNcyXYq9otUupF7/h/2tmHlhrS2zw7ZVvUqc=
|
||||
github.com/jonboulle/clockwork v0.2.2 h1:UOGuzwb1PwsrDAObMuhUnj0p5ULPj8V/xJ7Kx9qUBdQ=
|
||||
github.com/jonboulle/clockwork v0.2.2/go.mod h1:Pkfl5aHPm1nk2H9h0bjmnJD/BcgbGXUBGnn1kMkgxc8=
|
||||
github.com/josephspurrier/goversioninfo v0.0.0-20200309025242-14b0ab84c6ca/go.mod h1:eJTEwMjXb7kZ633hO3Ln9mBUCOjX2+FlTljvpl9SYdE=
|
||||
github.com/json-iterator/go v1.1.9 h1:9yzud/Ht36ygwatGx56VwCZtlI/2AD15T1X2sjSuGns=
|
||||
github.com/json-iterator/go v1.1.9/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
|
||||
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51/go.mod h1:CzGEWj7cYgsdH8dAjBGEr58BoE7ScuLd+fwFZ44+/x8=
|
||||
github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
|
||||
github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
|
||||
github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
|
||||
github.com/leodido/go-urn v1.2.0 h1:hpXL4XnriNwQ/ABnpepYM/1vCLWNDfUNts8dX3xTG6Y=
|
||||
github.com/leodido/go-urn v1.2.0/go.mod h1:+8+nEpDfqqsY+g338gtMEUOtuK+4dEMhiQEgxpxOKII=
|
||||
github.com/lestrrat-go/envload v0.0.0-20180220234015-a3eb8ddeffcc h1:RKf14vYWi2ttpEmkA4aQ3j4u9dStX2t4M8UM6qqNsG8=
|
||||
|
@ -51,6 +79,7 @@ github.com/lestrrat-go/file-rotatelogs v2.4.0+incompatible h1:Y6sqxHMyB1D2YSzWkL
|
|||
github.com/lestrrat-go/file-rotatelogs v2.4.0+incompatible/go.mod h1:ZQnN8lSECaebrkQytbHj4xNgtg8CR7RYXnPok8e0EHA=
|
||||
github.com/lestrrat-go/strftime v1.0.5 h1:A7H3tT8DhTz8u65w+JRpiBxM4dINQhUXAZnhBa2xeOE=
|
||||
github.com/lestrrat-go/strftime v1.0.5/go.mod h1:E1nN3pCbtMSu1yjSVeyuRFVm/U0xoR76fd03sz+Qz4g=
|
||||
github.com/lucor/goinfo v0.0.0-20200401173949-526b5363a13a/go.mod h1:ORP3/rB5IsulLEBwQZCJyyV6niqmI7P4EWSmkug+1Ng=
|
||||
github.com/makiuchi-d/gozxing v0.1.1 h1:xxqijhoedi+/lZlhINteGbywIrewVdVv2wl9r5O9S1I=
|
||||
github.com/makiuchi-d/gozxing v0.1.1/go.mod h1:eRIHbOjX7QWxLIDJoQuMLhuXg9LAuw6znsUtRkNw9DU=
|
||||
github.com/mattn/go-colorable v0.1.11 h1:nQ+aFkoE2TMGc0b68U2OKSexC+eq46+XwZzWXHRmPYs=
|
||||
|
@ -66,11 +95,15 @@ github.com/mxschmitt/playwright-go v0.1400.0 h1:HL8dbxcVEobE+pNjASeYGJJRmd4+9gyu
|
|||
github.com/mxschmitt/playwright-go v0.1400.0/go.mod h1:kUvZFgMneRGknVLtC2DKQ42lhZiCmWzxgBdGwjC0vkw=
|
||||
github.com/nfnt/resize v0.0.0-20180221191011-83c6a9932646 h1:zYyBkD/k9seD2A7fsi6Oo2LfFZAehjjQMERAvZLEDnQ=
|
||||
github.com/nfnt/resize v0.0.0-20180221191011-83c6a9932646/go.mod h1:jpp1/29i3P1S/RLdc7JQKbRpFeM1dOBd8T9ki5s+AY8=
|
||||
github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno=
|
||||
github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||
github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||
github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
|
||||
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||
github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0 h1:OdAsTTz6OkFY5QxjkYwrChwuRruF69c169dPK26NUlk=
|
||||
github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0/go.mod h1:qqbHyh8v60DhA7CoWK5oRCqLrMHRGoxYCSS9EjAz6Eo=
|
||||
github.com/robfig/cron/v3 v3.0.0 h1:kQ6Cb7aHOHTSzNVNEhmp8EcWKLb4CbiMW9h9VyIhO4E=
|
||||
github.com/robfig/cron/v3 v3.0.0/go.mod h1:eQICP3HwyT7UooqI/z+Ov+PtYAWygg1TEWWzGIFLtro=
|
||||
github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE=
|
||||
|
@ -78,11 +111,18 @@ github.com/sirupsen/logrus v1.8.1 h1:dJKuHgqk1NNQlqoA6BTlM1Wf9DOH3NBjQyu0h9+AZZE
|
|||
github.com/sirupsen/logrus v1.8.1/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic61uBYv0=
|
||||
github.com/skip2/go-qrcode v0.0.0-20200617195104-da1b6568686e h1:MRM5ITcdelLK2j1vwZ3Je0FKVCfqOLp5zO6trqMLYs0=
|
||||
github.com/skip2/go-qrcode v0.0.0-20200617195104-da1b6568686e/go.mod h1:XV66xRDqSt+GTGFMVlhk3ULuV0y9ZmzeVGR4mloJI3M=
|
||||
github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B0CQ=
|
||||
github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
|
||||
github.com/srwiley/oksvg v0.0.0-20200311192757-870daf9aa564 h1:HunZiaEKNGVdhTRQOVpMmj5MQnGnv+e8uZNu3xFLgyM=
|
||||
github.com/srwiley/oksvg v0.0.0-20200311192757-870daf9aa564/go.mod h1:afMbS0qvv1m5tfENCwnOdZGOF8RGR/FsZ7bvBxQGZG4=
|
||||
github.com/srwiley/rasterx v0.0.0-20200120212402-85cb7272f5e9 h1:m59mIOBO4kfcNCEzJNy71UkeF4XIx2EVmL9KLwDQdmM=
|
||||
github.com/srwiley/rasterx v0.0.0-20200120212402-85cb7272f5e9/go.mod h1:mvWM0+15UqyrFKqdRjY6LuAVJR0HOVhJlEgZ5JWtSWU=
|
||||
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||
github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
|
||||
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
||||
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
||||
github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA=
|
||||
github.com/stretchr/testify v1.7.0 h1:nwc3DEeHmmLAfoZucVR881uASk0Mfjw8xYJ99tb5CcY=
|
||||
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||
github.com/t-tomalak/logrus-easy-formatter v0.0.0-20190827215021-c074f06c5816 h1:J6v8awz+me+xeb/cUTotKgceAYouhIB3pjzgRd6IlGk=
|
||||
|
@ -97,33 +137,61 @@ github.com/ugorji/go v1.1.7 h1:/68gy2h+1mWMrwZFeD1kQialdSzAb432dtpeJ42ovdo=
|
|||
github.com/ugorji/go v1.1.7/go.mod h1:kZn38zHttfInRq0xu/PH0az30d+z6vm202qpg1oXVMw=
|
||||
github.com/ugorji/go/codec v1.1.7 h1:2SvQaVZ1ouYrrKKwoSk2pzd4A9evlKJb9oTL+OaLUSs=
|
||||
github.com/ugorji/go/codec v1.1.7/go.mod h1:Ax+UKWsSmolVDwsd+7N3ZtXu+yMGCf907BLYF3GoBXY=
|
||||
github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||
github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
|
||||
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
|
||||
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9 h1:psW17arqaxU48Z5kZ0CQnkZWQJsqcURM6tKiBApRjXI=
|
||||
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
||||
golang.org/x/image v0.0.0-20190802002840-cff245a6509b/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0=
|
||||
golang.org/x/image v0.0.0-20200430140353-33d19683fad8/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0=
|
||||
golang.org/x/image v0.0.0-20211028202545-6944b10bf410 h1:hTftEOvwiOq2+O8k2D5/Q7COC7k5Qcrgc2TFURJYnvQ=
|
||||
golang.org/x/image v0.0.0-20211028202545-6944b10bf410/go.mod h1:023OzeP/+EPmXeapQh35lcL3II3LrY8Ic+EFFKVhULM=
|
||||
golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
|
||||
golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
|
||||
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
|
||||
golang.org/x/net v0.0.0-20200114155413-6afb5195e5aa h1:F+8P+gmewFQYRk6JoLQLwjBCTu3mcIURZfNkVweuRKA=
|
||||
golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||
golang.org/x/net v0.0.0-20200114155413-6afb5195e5aa/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||
golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||
golang.org/x/net v0.0.0-20200324143707-d3edc9973b7e/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A=
|
||||
golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
|
||||
golang.org/x/net v0.0.0-20220111093109-d55c255bac03 h1:0FB83qp0AzVJm+0wcIlauAjJ+tNdh7jLuacRYCIVv7s=
|
||||
golang.org/x/net v0.0.0-20220111093109-d55c255bac03/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
|
||||
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||
golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||
golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||
golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20191005200804-aed5e4c7ecf9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20200720211630-cb9d2d5c5666/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20201126233918-771906719818/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||
golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||
golang.org/x/sys v0.0.0-20210927094055-39ccf1dd6fa6 h1:foEbQz/B0Oz6YIqu/69kfXPYeFQAuuMYFkjaqXzl5Wo=
|
||||
golang.org/x/sys v0.0.0-20210902050250-f475640dd07b/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||
golang.org/x/sys v0.0.0-20210927094055-39ccf1dd6fa6/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||
golang.org/x/sys v0.0.0-20211007075335-d3039528d8ac/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||
golang.org/x/sys v0.0.0-20220209214540-3681064d5158 h1:rm+CHSpPEEW2IsXUib1ThaHIjuBVZjxNgSKmBLFfD4c=
|
||||
golang.org/x/sys v0.0.0-20220209214540-3681064d5158/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
|
||||
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||
golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
|
||||
golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
|
||||
golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
|
||||
golang.org/x/text v0.3.7 h1:olpwvP2KacW1ZWvsR7uQhoyTYvKAupfQrRGBFM352Gk=
|
||||
golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ=
|
||||
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
|
||||
golang.org/x/tools v0.0.0-20190808195139-e713427fea3f/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
|
||||
golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
|
||||
golang.org/x/tools v0.0.0-20200328031815-3db5fc6bac03/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8=
|
||||
golang.org/x/tools v0.0.0-20201124115921-2c860bdd6e78/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
||||
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||
golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE=
|
||||
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||
|
@ -132,6 +200,7 @@ google.golang.org/protobuf v1.26.0 h1:bxAC2xTBsZGibn2RTntX0oH50xLsqy1OxA9tTL3p/l
|
|||
google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
|
||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM=
|
||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||
gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||
gopkg.in/square/go-jose.v2 v2.6.0 h1:NGk74WTnPKBNUhNzQX7PYcTLUjoq7mzKk2OKbvwk2iI=
|
||||
gopkg.in/square/go-jose.v2 v2.6.0/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI=
|
||||
gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
||||
|
@ -139,3 +208,117 @@ gopkg.in/yaml.v2 v2.2.8 h1:obN1ZagJSUGI0Ek/LBmuj4SNLPfIny3KsKFopxRdj10=
|
|||
gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c h1:dUUwHk2QECo/6vqA44rthZ8ie2QXMNeKRTHCNY2nXvo=
|
||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||
lukechampine.com/uint128 v1.1.1/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk=
|
||||
modernc.org/cc/v3 v3.33.6/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.33.9/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.33.11/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.34.0/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.0/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.4/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.5/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.7/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.8/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.10/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.15/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.16/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.17/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.18/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.20/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/cc/v3 v3.35.22/go.mod h1:iPJg1pkwXqAV16SNgFBVYmggfMg6xhs+2oiO0vclK3g=
|
||||
modernc.org/ccgo/v3 v3.9.5/go.mod h1:umuo2EP2oDSBnD3ckjaVUXMrmeAw8C8OSICVa0iFf60=
|
||||
modernc.org/ccgo/v3 v3.10.0/go.mod h1:c0yBmkRFi7uW4J7fwx/JiijwOjeAeR2NoSaRVFPmjMw=
|
||||
modernc.org/ccgo/v3 v3.11.0/go.mod h1:dGNposbDp9TOZ/1KBxghxtUp/bzErD0/0QW4hhSaBMI=
|
||||
modernc.org/ccgo/v3 v3.11.1/go.mod h1:lWHxfsn13L3f7hgGsGlU28D9eUOf6y3ZYHKoPaKU0ag=
|
||||
modernc.org/ccgo/v3 v3.11.3/go.mod h1:0oHunRBMBiXOKdaglfMlRPBALQqsfrCKXgw9okQ3GEw=
|
||||
modernc.org/ccgo/v3 v3.12.4/go.mod h1:Bk+m6m2tsooJchP/Yk5ji56cClmN6R1cqc9o/YtbgBQ=
|
||||
modernc.org/ccgo/v3 v3.12.6/go.mod h1:0Ji3ruvpFPpz+yu+1m0wk68pdr/LENABhTrDkMDWH6c=
|
||||
modernc.org/ccgo/v3 v3.12.8/go.mod h1:Hq9keM4ZfjCDuDXxaHptpv9N24JhgBZmUG5q60iLgUo=
|
||||
modernc.org/ccgo/v3 v3.12.11/go.mod h1:0jVcmyDwDKDGWbcrzQ+xwJjbhZruHtouiBEvDfoIsdg=
|
||||
modernc.org/ccgo/v3 v3.12.14/go.mod h1:GhTu1k0YCpJSuWwtRAEHAol5W7g1/RRfS4/9hc9vF5I=
|
||||
modernc.org/ccgo/v3 v3.12.18/go.mod h1:jvg/xVdWWmZACSgOiAhpWpwHWylbJaSzayCqNOJKIhs=
|
||||
modernc.org/ccgo/v3 v3.12.20/go.mod h1:aKEdssiu7gVgSy/jjMastnv/q6wWGRbszbheXgWRHc8=
|
||||
modernc.org/ccgo/v3 v3.12.21/go.mod h1:ydgg2tEprnyMn159ZO/N4pLBqpL7NOkJ88GT5zNU2dE=
|
||||
modernc.org/ccgo/v3 v3.12.22/go.mod h1:nyDVFMmMWhMsgQw+5JH6B6o4MnZ+UQNw1pp52XYFPRk=
|
||||
modernc.org/ccgo/v3 v3.12.25/go.mod h1:UaLyWI26TwyIT4+ZFNjkyTbsPsY3plAEB6E7L/vZV3w=
|
||||
modernc.org/ccgo/v3 v3.12.29/go.mod h1:FXVjG7YLf9FetsS2OOYcwNhcdOLGt8S9bQ48+OP75cE=
|
||||
modernc.org/ccgo/v3 v3.12.36/go.mod h1:uP3/Fiezp/Ga8onfvMLpREq+KUjUmYMxXPO8tETHtA8=
|
||||
modernc.org/ccgo/v3 v3.12.38/go.mod h1:93O0G7baRST1vNj4wnZ49b1kLxt0xCW5Hsa2qRaZPqc=
|
||||
modernc.org/ccgo/v3 v3.12.43/go.mod h1:k+DqGXd3o7W+inNujK15S5ZYuPoWYLpF5PYougCmthU=
|
||||
modernc.org/ccgo/v3 v3.12.46/go.mod h1:UZe6EvMSqOxaJ4sznY7b23/k13R8XNlyWsO5bAmSgOE=
|
||||
modernc.org/ccgo/v3 v3.12.47/go.mod h1:m8d6p0zNps187fhBwzY/ii6gxfjob1VxWb919Nk1HUk=
|
||||
modernc.org/ccgo/v3 v3.12.50/go.mod h1:bu9YIwtg+HXQxBhsRDE+cJjQRuINuT9PUK4orOco/JI=
|
||||
modernc.org/ccgo/v3 v3.12.51/go.mod h1:gaIIlx4YpmGO2bLye04/yeblmvWEmE4BBBls4aJXFiE=
|
||||
modernc.org/ccgo/v3 v3.12.53/go.mod h1:8xWGGTFkdFEWBEsUmi+DBjwu/WLy3SSOrqEmKUjMeEg=
|
||||
modernc.org/ccgo/v3 v3.12.54/go.mod h1:yANKFTm9llTFVX1FqNKHE0aMcQb1fuPJx6p8AcUx+74=
|
||||
modernc.org/ccgo/v3 v3.12.55/go.mod h1:rsXiIyJi9psOwiBkplOaHye5L4MOOaCjHg1Fxkj7IeU=
|
||||
modernc.org/ccgo/v3 v3.12.56/go.mod h1:ljeFks3faDseCkr60JMpeDb2GSO3TKAmrzm7q9YOcMU=
|
||||
modernc.org/ccgo/v3 v3.12.57/go.mod h1:hNSF4DNVgBl8wYHpMvPqQWDQx8luqxDnNGCMM4NFNMc=
|
||||
modernc.org/ccgo/v3 v3.12.60/go.mod h1:k/Nn0zdO1xHVWjPYVshDeWKqbRWIfif5dtsIOCUVMqM=
|
||||
modernc.org/ccgo/v3 v3.12.66/go.mod h1:jUuxlCFZTUZLMV08s7B1ekHX5+LIAurKTTaugUr/EhQ=
|
||||
modernc.org/ccgo/v3 v3.12.67/go.mod h1:Bll3KwKvGROizP2Xj17GEGOTrlvB1XcVaBrC90ORO84=
|
||||
modernc.org/ccgo/v3 v3.12.73/go.mod h1:hngkB+nUUqzOf3iqsM48Gf1FZhY599qzVg1iX+BT3cQ=
|
||||
modernc.org/ccgo/v3 v3.12.81/go.mod h1:p2A1duHoBBg1mFtYvnhAnQyI6vL0uw5PGYLSIgF6rYY=
|
||||
modernc.org/ccgo/v3 v3.12.84/go.mod h1:ApbflUfa5BKadjHynCficldU1ghjen84tuM5jRynB7w=
|
||||
modernc.org/ccgo/v3 v3.12.86/go.mod h1:dN7S26DLTgVSni1PVA3KxxHTcykyDurf3OgUzNqTSrU=
|
||||
modernc.org/ccgo/v3 v3.12.90/go.mod h1:obhSc3CdivCRpYZmrvO88TXlW0NvoSVvdh/ccRjJYko=
|
||||
modernc.org/ccgo/v3 v3.12.92/go.mod h1:5yDdN7ti9KWPi5bRVWPl8UNhpEAtCjuEE7ayQnzzqHA=
|
||||
modernc.org/ccgo/v3 v3.13.1/go.mod h1:aBYVOUfIlcSnrsRVU8VRS35y2DIfpgkmVkYZ0tpIXi4=
|
||||
modernc.org/ccgo/v3 v3.15.9/go.mod h1:md59wBwDT2LznX/OTCPoVS6KIsdRgY8xqQwBV+hkTH0=
|
||||
modernc.org/ccgo/v3 v3.15.10/go.mod h1:wQKxoFn0ynxMuCLfFD09c8XPUCc8obfchoVR9Cn0fI8=
|
||||
modernc.org/ccgo/v3 v3.15.12/go.mod h1:VFePOWoCd8uDGRJpq/zfJ29D0EVzMSyID8LCMWYbX6I=
|
||||
modernc.org/ccorpus v1.11.1/go.mod h1:2gEUTrWqdpH2pXsmTM1ZkjeSrUWDpjMu2T6m29L/ErQ=
|
||||
modernc.org/httpfs v1.0.6/go.mod h1:7dosgurJGp0sPaRanU53W4xZYKh14wfzX420oZADeHM=
|
||||
modernc.org/libc v1.9.8/go.mod h1:U1eq8YWr/Kc1RWCMFUWEdkTg8OTcfLw2kY8EDwl039w=
|
||||
modernc.org/libc v1.9.11/go.mod h1:NyF3tsA5ArIjJ83XB0JlqhjTabTCHm9aX4XMPHyQn0Q=
|
||||
modernc.org/libc v1.11.0/go.mod h1:2lOfPmj7cz+g1MrPNmX65QCzVxgNq2C5o0jdLY2gAYg=
|
||||
modernc.org/libc v1.11.2/go.mod h1:ioIyrl3ETkugDO3SGZ+6EOKvlP3zSOycUETe4XM4n8M=
|
||||
modernc.org/libc v1.11.5/go.mod h1:k3HDCP95A6U111Q5TmG3nAyUcp3kR5YFZTeDS9v8vSU=
|
||||
modernc.org/libc v1.11.6/go.mod h1:ddqmzR6p5i4jIGK1d/EiSw97LBcE3dK24QEwCFvgNgE=
|
||||
modernc.org/libc v1.11.11/go.mod h1:lXEp9QOOk4qAYOtL3BmMve99S5Owz7Qyowzvg6LiZso=
|
||||
modernc.org/libc v1.11.13/go.mod h1:ZYawJWlXIzXy2Pzghaf7YfM8OKacP3eZQI81PDLFdY8=
|
||||
modernc.org/libc v1.11.16/go.mod h1:+DJquzYi+DMRUtWI1YNxrlQO6TcA5+dRRiq8HWBWRC8=
|
||||
modernc.org/libc v1.11.19/go.mod h1:e0dgEame6mkydy19KKaVPBeEnyJB4LGNb0bBH1EtQ3I=
|
||||
modernc.org/libc v1.11.24/go.mod h1:FOSzE0UwookyT1TtCJrRkvsOrX2k38HoInhw+cSCUGk=
|
||||
modernc.org/libc v1.11.26/go.mod h1:SFjnYi9OSd2W7f4ct622o/PAYqk7KHv6GS8NZULIjKY=
|
||||
modernc.org/libc v1.11.27/go.mod h1:zmWm6kcFXt/jpzeCgfvUNswM0qke8qVwxqZrnddlDiE=
|
||||
modernc.org/libc v1.11.28/go.mod h1:Ii4V0fTFcbq3qrv3CNn+OGHAvzqMBvC7dBNyC4vHZlg=
|
||||
modernc.org/libc v1.11.31/go.mod h1:FpBncUkEAtopRNJj8aRo29qUiyx5AvAlAxzlx9GNaVM=
|
||||
modernc.org/libc v1.11.34/go.mod h1:+Tzc4hnb1iaX/SKAutJmfzES6awxfU1BPvrrJO0pYLg=
|
||||
modernc.org/libc v1.11.37/go.mod h1:dCQebOwoO1046yTrfUE5nX1f3YpGZQKNcITUYWlrAWo=
|
||||
modernc.org/libc v1.11.39/go.mod h1:mV8lJMo2S5A31uD0k1cMu7vrJbSA3J3waQJxpV4iqx8=
|
||||
modernc.org/libc v1.11.42/go.mod h1:yzrLDU+sSjLE+D4bIhS7q1L5UwXDOw99PLSX0BlZvSQ=
|
||||
modernc.org/libc v1.11.44/go.mod h1:KFq33jsma7F5WXiYelU8quMJasCCTnHK0mkri4yPHgA=
|
||||
modernc.org/libc v1.11.45/go.mod h1:Y192orvfVQQYFzCNsn+Xt0Hxt4DiO4USpLNXBlXg/tM=
|
||||
modernc.org/libc v1.11.47/go.mod h1:tPkE4PzCTW27E6AIKIR5IwHAQKCAtudEIeAV1/SiyBg=
|
||||
modernc.org/libc v1.11.49/go.mod h1:9JrJuK5WTtoTWIFQ7QjX2Mb/bagYdZdscI3xrvHbXjE=
|
||||
modernc.org/libc v1.11.51/go.mod h1:R9I8u9TS+meaWLdbfQhq2kFknTW0O3aw3kEMqDDxMaM=
|
||||
modernc.org/libc v1.11.53/go.mod h1:5ip5vWYPAoMulkQ5XlSJTy12Sz5U6blOQiYasilVPsU=
|
||||
modernc.org/libc v1.11.54/go.mod h1:S/FVnskbzVUrjfBqlGFIPA5m7UwB3n9fojHhCNfSsnw=
|
||||
modernc.org/libc v1.11.55/go.mod h1:j2A5YBRm6HjNkoSs/fzZrSxCuwWqcMYTDPLNx0URn3M=
|
||||
modernc.org/libc v1.11.56/go.mod h1:pakHkg5JdMLt2OgRadpPOTnyRXm/uzu+Yyg/LSLdi18=
|
||||
modernc.org/libc v1.11.58/go.mod h1:ns94Rxv0OWyoQrDqMFfWwka2BcaF6/61CqJRK9LP7S8=
|
||||
modernc.org/libc v1.11.71/go.mod h1:DUOmMYe+IvKi9n6Mycyx3DbjfzSKrdr/0Vgt3j7P5gw=
|
||||
modernc.org/libc v1.11.75/go.mod h1:dGRVugT6edz361wmD9gk6ax1AbDSe0x5vji0dGJiPT0=
|
||||
modernc.org/libc v1.11.82/go.mod h1:NF+Ek1BOl2jeC7lw3a7Jj5PWyHPwWD4aq3wVKxqV1fI=
|
||||
modernc.org/libc v1.11.86/go.mod h1:ePuYgoQLmvxdNT06RpGnaDKJmDNEkV7ZPKI2jnsvZoE=
|
||||
modernc.org/libc v1.11.87/go.mod h1:Qvd5iXTeLhI5PS0XSyqMY99282y+3euapQFxM7jYnpY=
|
||||
modernc.org/libc v1.11.88/go.mod h1:h3oIVe8dxmTcchcFuCcJ4nAWaoiwzKCdv82MM0oiIdQ=
|
||||
modernc.org/libc v1.11.98/go.mod h1:ynK5sbjsU77AP+nn61+k+wxUGRx9rOFcIqWYYMaDZ4c=
|
||||
modernc.org/libc v1.11.101/go.mod h1:wLLYgEiY2D17NbBOEp+mIJJJBGSiy7fLL4ZrGGZ+8jI=
|
||||
modernc.org/libc v1.12.0/go.mod h1:2MH3DaF/gCU8i/UBiVE1VFRos4o523M7zipmwH8SIgQ=
|
||||
modernc.org/libc v1.14.1/go.mod h1:npFeGWjmZTjFeWALQLrvklVmAxv4m80jnG3+xI8FdJk=
|
||||
modernc.org/libc v1.14.2/go.mod h1:MX1GBLnRLNdvmK9azU9LCxZ5lMyhrbEMK8rG3X/Fe34=
|
||||
modernc.org/libc v1.14.3/go.mod h1:GPIvQVOVPizzlqyRX3l756/3ppsAgg1QgPxjr5Q4agQ=
|
||||
modernc.org/libc v1.14.5 h1:DAHvwGoVRDZs5iJXnX9RJrgXSsorupCWmJ2ac964Owk=
|
||||
modernc.org/libc v1.14.5/go.mod h1:2PJHINagVxO4QW/5OQdRrvMYo+bm5ClpUFfyXCYl9ak=
|
||||
modernc.org/mathutil v1.1.1/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E=
|
||||
modernc.org/mathutil v1.2.2/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E=
|
||||
modernc.org/mathutil v1.4.0/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E=
|
||||
modernc.org/mathutil v1.4.1 h1:ij3fYGe8zBF4Vu+g0oT7mB06r8sqGWKuJu1yXeR4by8=
|
||||
modernc.org/mathutil v1.4.1/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E=
|
||||
modernc.org/memory v1.0.4/go.mod h1:nV2OApxradM3/OVbs2/0OsP6nPfakXpi50C7dcoHXlc=
|
||||
modernc.org/memory v1.0.5 h1:XRch8trV7GgvTec2i7jc33YlUI0RKVDBvZ5eZ5m8y14=
|
||||
modernc.org/memory v1.0.5/go.mod h1:B7OYswTRnfGg+4tDH1t1OeUNnsy2viGTdME4tzd+IjM=
|
||||
modernc.org/opt v0.1.1/go.mod h1:WdSiB5evDcignE70guQKxYUl14mgWtbClRi5wmkkTX0=
|
||||
modernc.org/strutil v1.1.1/go.mod h1:DE+MQQ/hjKBZS2zNInV5hhcipt5rLPWkmpbGeW5mmdw=
|
||||
modernc.org/token v1.0.0/go.mod h1:UGzOrNV1mAFSEB63lOFHIpNRUVMvYTc6yu1SMY/XTDM=
|
||||
|
|
301
lib/core.go
301
lib/core.go
|
@ -1,8 +1,6 @@
|
|||
package lib
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"encoding/base64"
|
||||
"errors"
|
||||
"fmt"
|
||||
"image"
|
||||
|
@ -26,6 +24,8 @@ import (
|
|||
log "github.com/sirupsen/logrus"
|
||||
goqrcode "github.com/skip2/go-qrcode"
|
||||
"golang.org/x/image/bmp"
|
||||
|
||||
"github.com/huoxue1/study_xxqg/model"
|
||||
)
|
||||
|
||||
// Core
|
||||
|
@ -89,7 +89,7 @@ func (c *Core) Init() {
|
|||
}
|
||||
}
|
||||
|
||||
func (c *Core) L() ([]Cookie, error) {
|
||||
func (c *Core) L() (*model.User, error) {
|
||||
client := req.C()
|
||||
client.OnAfterResponse(func(client *req.Client, response *req.Response) error {
|
||||
return nil
|
||||
|
@ -149,53 +149,32 @@ func (c *Core) L() ([]Cookie, error) {
|
|||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
var (
|
||||
cos []Cookie
|
||||
)
|
||||
|
||||
for _, c := range response.Cookies() {
|
||||
co := Cookie{}
|
||||
co.Name = c.Name
|
||||
co.Path = c.Path
|
||||
co.Value = c.Value
|
||||
co.Domain = c.Domain
|
||||
co.Expires = int(c.Expires.Unix())
|
||||
co.SameSite = "Strict"
|
||||
co.HTTPOnly = c.HttpOnly
|
||||
co.Secure = c.Secure
|
||||
cos = append(cos, co)
|
||||
}
|
||||
resp, err := client.R().Get("https://pc.xuexi.cn/points/my-points.html")
|
||||
uid, nick, err := GetUserInfo(response.Cookies())
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
for _, c := range resp.Cookies() {
|
||||
co := Cookie{}
|
||||
co.Name = c.Name
|
||||
co.Path = c.Path
|
||||
co.Value = c.Value
|
||||
co.Domain = c.Domain
|
||||
co.Expires = int(c.Expires.Unix())
|
||||
co.SameSite = "Strict"
|
||||
co.HTTPOnly = c.HttpOnly
|
||||
co.Secure = c.Secure
|
||||
cos = append(cos, co)
|
||||
user := &model.User{
|
||||
Nick: nick,
|
||||
UID: uid,
|
||||
Token: response.Cookies()[0].Value,
|
||||
LoginTime: time.Now().UnixNano(),
|
||||
}
|
||||
info, nick, err := GetUserInfo(cos)
|
||||
err = model.AddUser(user)
|
||||
if err != nil {
|
||||
return cos, err
|
||||
return nil, err
|
||||
}
|
||||
c.Push("text", "登录成功,用户名:"+nick)
|
||||
err = SaveUser(User{
|
||||
Cookies: cos,
|
||||
Nick: nick,
|
||||
Uid: info,
|
||||
Time: time.Now().Add(time.Hour * 24).Unix(),
|
||||
})
|
||||
if err != nil {
|
||||
return cos, err
|
||||
}
|
||||
return cos, err
|
||||
//model.AddUser(&model.User{
|
||||
// Nick: nick,
|
||||
// UID: info,
|
||||
// Token: resp.Cookies()[],
|
||||
// LoginTime: 0,
|
||||
//})
|
||||
//if err != nil {
|
||||
// return cos, err
|
||||
//}
|
||||
return user, err
|
||||
}
|
||||
}
|
||||
return nil, errors.New("time out")
|
||||
|
@ -349,124 +328,124 @@ func (c *Core) IsQuit() bool {
|
|||
return !c.browser.IsConnected()
|
||||
}
|
||||
|
||||
func (c *Core) Login() ([]Cookie, error) {
|
||||
defer func() {
|
||||
i := recover()
|
||||
if i != nil {
|
||||
log.Errorln("登录模块出现无法挽救的错误")
|
||||
log.Errorln(i)
|
||||
}
|
||||
}()
|
||||
c.Push("text", "开始添加用户")
|
||||
page, err := (*c.context).NewPage()
|
||||
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
_, err = page.Goto("https://pc.xuexi.cn/points/login.html", playwright.PageGotoOptions{
|
||||
Referer: nil,
|
||||
Timeout: playwright.Float(30000),
|
||||
WaitUntil: playwright.WaitUntilStateDomcontentloaded,
|
||||
})
|
||||
if err != nil {
|
||||
log.Errorln("[core] ", "打开登录页面失败")
|
||||
log.Errorln("[core] ", err.Error())
|
||||
|
||||
return nil, err
|
||||
}
|
||||
log.Infoln("[core] ", "正在等待二维码加载")
|
||||
c.Push("text", "正在加载二维码")
|
||||
if runtime.GOOS == "windows" {
|
||||
time.Sleep(3 * time.Second)
|
||||
} else {
|
||||
_, _ = page.WaitForSelector(`#app > div > div.login_content > div > div.login_qrcode `, playwright.PageWaitForSelectorOptions{
|
||||
State: playwright.WaitForSelectorStateVisible,
|
||||
})
|
||||
}
|
||||
|
||||
_, err = page.Evaluate(`let h = document.body.scrollWidth/2;document.documentElement.scrollTop=h;`)
|
||||
|
||||
if err != nil {
|
||||
fmt.Println(err.Error())
|
||||
|
||||
return nil, err
|
||||
}
|
||||
|
||||
log.Infoln("[core] ", "加载验证码中,请耐心等待")
|
||||
|
||||
//frame := page.Frame(playwright.PageFrameOptions{
|
||||
// Name: playwright.String(`ddlogin-iframe`),
|
||||
// URL: nil,
|
||||
//})
|
||||
//if frame == nil {
|
||||
// log.Errorln("获取frame失败")
|
||||
//func (c *Core) Login() ([]Cookie, error) {
|
||||
// defer func() {
|
||||
// i := recover()
|
||||
// if i != nil {
|
||||
// log.Errorln("登录模块出现无法挽救的错误")
|
||||
// log.Errorln(i)
|
||||
// }
|
||||
// }()
|
||||
// c.Push("text", "开始添加用户")
|
||||
// page, err := (*c.context).NewPage()
|
||||
//
|
||||
// if err != nil {
|
||||
// return nil, err
|
||||
// }
|
||||
// _, err = page.Goto("https://pc.xuexi.cn/points/login.html", playwright.PageGotoOptions{
|
||||
// Referer: nil,
|
||||
// Timeout: playwright.Float(30000),
|
||||
// WaitUntil: playwright.WaitUntilStateDomcontentloaded,
|
||||
// })
|
||||
// if err != nil {
|
||||
// log.Errorln("[core] ", "打开登录页面失败")
|
||||
// log.Errorln("[core] ", err.Error())
|
||||
//
|
||||
// return nil, err
|
||||
// }
|
||||
// log.Infoln("[core] ", "正在等待二维码加载")
|
||||
// c.Push("text", "正在加载二维码")
|
||||
// if runtime.GOOS == "windows" {
|
||||
// time.Sleep(3 * time.Second)
|
||||
// } else {
|
||||
// _, _ = page.WaitForSelector(`#app > div > div.login_content > div > div.login_qrcode `, playwright.PageWaitForSelectorOptions{
|
||||
// State: playwright.WaitForSelectorStateVisible,
|
||||
// })
|
||||
// }
|
||||
//
|
||||
// _, err = page.Evaluate(`let h = document.body.scrollWidth/2;document.documentElement.scrollTop=h;`)
|
||||
//
|
||||
// if err != nil {
|
||||
// fmt.Println(err.Error())
|
||||
//
|
||||
// return nil, err
|
||||
// }
|
||||
//
|
||||
// log.Infoln("[core] ", "加载验证码中,请耐心等待")
|
||||
//
|
||||
// //frame := page.Frame(playwright.PageFrameOptions{
|
||||
// // Name: playwright.String(`ddlogin-iframe`),
|
||||
// // URL: nil,
|
||||
// //})
|
||||
// //if frame == nil {
|
||||
// // log.Errorln("获取frame失败")
|
||||
// //}
|
||||
//
|
||||
// removeNode(page)
|
||||
//
|
||||
// screen, _ := page.Screenshot()
|
||||
//
|
||||
// var result []byte
|
||||
// buffer := bytes.NewBuffer(result)
|
||||
// _ = Clip(bytes.NewReader(screen), buffer, 0, 0, 529, 70, 748, 284, 0)
|
||||
//
|
||||
// c.Push("markdown", fmt.Sprintf(" \n>点开查看登录二维码\n>请在五分钟内完成扫码", "data:image/png;base64,"+base64.StdEncoding.EncodeToString(buffer.Bytes())))
|
||||
// c.Push("image", base64.StdEncoding.EncodeToString(buffer.Bytes()))
|
||||
// matrix := GetPaymentStr(bytes.NewReader(buffer.Bytes()))
|
||||
// log.Debugln("已获取到二维码内容:" + matrix.GetText())
|
||||
//
|
||||
// c.Push("text", GetConfig().Scheme+url.QueryEscape(matrix.GetText()))
|
||||
//
|
||||
// qrcodeTerminal.New2(qrcodeTerminal.ConsoleColors.BrightBlack, qrcodeTerminal.ConsoleColors.BrightWhite, qrcodeTerminal.QRCodeRecoveryLevels.Low).Get(matrix.GetText()).Print()
|
||||
// _, err = page.WaitForNavigation(playwright.PageWaitForNavigationOptions{
|
||||
// Timeout: playwright.Float(30 * 1000 * 5),
|
||||
// URL: nil,
|
||||
// WaitUntil: nil,
|
||||
// })
|
||||
// if err != nil {
|
||||
// log.Errorln(err.Error())
|
||||
//
|
||||
// return nil, err
|
||||
// }
|
||||
// cookies, err := (*c.context).Cookies() //nolint:wsl
|
||||
// if err != nil {
|
||||
// log.Errorln("[core] ", "获取cookie失败")
|
||||
// return nil, err
|
||||
// }
|
||||
//
|
||||
// var (
|
||||
// cos []Cookie
|
||||
// )
|
||||
//
|
||||
// for _, c := range cookies {
|
||||
// co := Cookie{}
|
||||
// co.Name = c.Name
|
||||
// co.Path = c.Path
|
||||
// co.Value = c.Value
|
||||
// co.Domain = c.Domain
|
||||
// co.Expires = c.Expires
|
||||
// co.HTTPOnly = c.HttpOnly
|
||||
// co.SameSite = c.SameSite
|
||||
// co.Secure = c.Secure
|
||||
// cos = append(cos, co)
|
||||
// }
|
||||
// info, nick, err := GetUserInfo(cos)
|
||||
// if err != nil {
|
||||
// return nil, err
|
||||
// }
|
||||
// c.Push("text", "登录成功,用户名:"+nick)
|
||||
// err = SaveUser(User{
|
||||
// Cookies: cos,
|
||||
// Nick: nick,
|
||||
// Uid: info,
|
||||
// Time: time.Now().Add(time.Hour * 24).Unix(),
|
||||
// })
|
||||
// if err != nil {
|
||||
// return nil, err
|
||||
// }
|
||||
//
|
||||
// return cos, err
|
||||
//}
|
||||
|
||||
removeNode(page)
|
||||
|
||||
screen, _ := page.Screenshot()
|
||||
|
||||
var result []byte
|
||||
buffer := bytes.NewBuffer(result)
|
||||
_ = Clip(bytes.NewReader(screen), buffer, 0, 0, 529, 70, 748, 284, 0)
|
||||
|
||||
c.Push("markdown", fmt.Sprintf(" \n>点开查看登录二维码\n>请在五分钟内完成扫码", "data:image/png;base64,"+base64.StdEncoding.EncodeToString(buffer.Bytes())))
|
||||
c.Push("image", base64.StdEncoding.EncodeToString(buffer.Bytes()))
|
||||
matrix := GetPaymentStr(bytes.NewReader(buffer.Bytes()))
|
||||
log.Debugln("已获取到二维码内容:" + matrix.GetText())
|
||||
|
||||
c.Push("text", GetConfig().Scheme+url.QueryEscape(matrix.GetText()))
|
||||
|
||||
qrcodeTerminal.New2(qrcodeTerminal.ConsoleColors.BrightBlack, qrcodeTerminal.ConsoleColors.BrightWhite, qrcodeTerminal.QRCodeRecoveryLevels.Low).Get(matrix.GetText()).Print()
|
||||
_, err = page.WaitForNavigation(playwright.PageWaitForNavigationOptions{
|
||||
Timeout: playwright.Float(30 * 1000 * 5),
|
||||
URL: nil,
|
||||
WaitUntil: nil,
|
||||
})
|
||||
if err != nil {
|
||||
log.Errorln(err.Error())
|
||||
|
||||
return nil, err
|
||||
}
|
||||
cookies, err := (*c.context).Cookies() //nolint:wsl
|
||||
if err != nil {
|
||||
log.Errorln("[core] ", "获取cookie失败")
|
||||
return nil, err
|
||||
}
|
||||
|
||||
var (
|
||||
cos []Cookie
|
||||
)
|
||||
|
||||
for _, c := range cookies {
|
||||
co := Cookie{}
|
||||
co.Name = c.Name
|
||||
co.Path = c.Path
|
||||
co.Value = c.Value
|
||||
co.Domain = c.Domain
|
||||
co.Expires = c.Expires
|
||||
co.HTTPOnly = c.HttpOnly
|
||||
co.SameSite = c.SameSite
|
||||
co.Secure = c.Secure
|
||||
cos = append(cos, co)
|
||||
}
|
||||
info, nick, err := GetUserInfo(cos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
c.Push("text", "登录成功,用户名:"+nick)
|
||||
err = SaveUser(User{
|
||||
Cookies: cos,
|
||||
Nick: nick,
|
||||
Uid: info,
|
||||
Time: time.Now().Add(time.Hour * 24).Unix(),
|
||||
})
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return cos, err
|
||||
}
|
||||
|
||||
func removeNode(page playwright.Page) {
|
||||
page.Evaluate(`document.getElementsByClassName("layout-header")[0].remove()`) //nolint:errcheck
|
||||
|
@ -540,10 +519,10 @@ func Clip(in io.Reader, out io.Writer, wi, hi, x0, y0, x1, y1, quality int) (err
|
|||
return nil
|
||||
}
|
||||
|
||||
func WaitStudy(user *User, id string) {
|
||||
func WaitStudy(user *model.User, id string) {
|
||||
i := 0
|
||||
for i <= 180 {
|
||||
score, err := GetUserScore(user.Cookies)
|
||||
score, err := GetUserScore(user.ToCookies())
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
|
|
|
@ -8,6 +8,8 @@ import (
|
|||
|
||||
"github.com/mxschmitt/playwright-go"
|
||||
log "github.com/sirupsen/logrus"
|
||||
|
||||
"github.com/huoxue1/study_xxqg/model"
|
||||
)
|
||||
|
||||
const (
|
||||
|
@ -21,7 +23,7 @@ div > div.my-points-section > div.my-points-content > div:nth-child(6) > div.my-
|
|||
div > div.my-points-section > div.my-points-content > div:nth-child(7) > div.my-points-card-footer > div.buttonbox > div`
|
||||
)
|
||||
|
||||
func (c *Core) RespondDaily(cookies []Cookie, model string) {
|
||||
func (c *Core) RespondDaily(user *model.User, model string) {
|
||||
defer func() {
|
||||
err := recover()
|
||||
if err != nil {
|
||||
|
@ -35,7 +37,7 @@ func (c *Core) RespondDaily(cookies []Cookie, model string) {
|
|||
return
|
||||
}
|
||||
// 获取用户成绩
|
||||
score, err := GetUserScore(cookies)
|
||||
score, err := GetUserScore(user.ToCookies())
|
||||
if err != nil {
|
||||
log.Errorln("获取分数失败,停止每日答题", err.Error())
|
||||
|
||||
|
@ -51,14 +53,15 @@ func (c *Core) RespondDaily(cookies []Cookie, model string) {
|
|||
defer func() {
|
||||
page.Close()
|
||||
}()
|
||||
page.Goto("https://pc.xuexi.cn/points/my-points.html")
|
||||
err = (*c.context).AddCookies(cookieToParam(cookies)...)
|
||||
log.Infoln(user.ToBrowserCookies())
|
||||
err = (*c.context).AddCookies(user.ToBrowserCookies()...)
|
||||
if err != nil {
|
||||
log.Errorln(err.Error())
|
||||
log.Errorln("添加cookie信息失败,已退出答题")
|
||||
|
||||
return
|
||||
}
|
||||
page.Goto("https://pc.xuexi.cn/points/my-points.html")
|
||||
|
||||
log.Infoln("已加载答题模块")
|
||||
|
||||
_, err = page.Goto(MyPointsUri, playwright.PageGotoOptions{
|
||||
|
@ -172,6 +175,14 @@ func (c *Core) RespondDaily(cookies []Cookie, model string) {
|
|||
time.Sleep(10 * time.Second)
|
||||
log.Infoln("可能存在滑块")
|
||||
c.Push("text", "答题过程出现滑块,正在尝试滑动")
|
||||
en, err = handle.IsVisible()
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
if en {
|
||||
page.Evaluate("__nc.reset()")
|
||||
goto label
|
||||
}
|
||||
}
|
||||
}
|
||||
switch model {
|
||||
|
@ -339,7 +350,7 @@ func (c *Core) RespondDaily(cookies []Cookie, model string) {
|
|||
return
|
||||
}
|
||||
}
|
||||
score, _ = GetUserScore(cookies)
|
||||
score, _ = GetUserScore(user.ToCookies())
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -3,6 +3,7 @@ package lib
|
|||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
"net/http"
|
||||
"time"
|
||||
|
||||
"github.com/guonaihong/gout"
|
||||
|
@ -21,11 +22,11 @@ type Data struct {
|
|||
MaxScore int `json:"max_score"`
|
||||
}
|
||||
|
||||
func GetUserScore(cookies []Cookie) (Score, error) {
|
||||
func GetUserScore(cookies []*http.Cookie) (Score, error) {
|
||||
var score Score
|
||||
var resp []byte
|
||||
// 获取用户总分
|
||||
err := gout.GET(user_totalScore_url).SetCookies(cookieToJar(cookies)...).SetHeader(gout.H{
|
||||
err := gout.GET(user_totalScore_url).SetCookies(cookies...).SetHeader(gout.H{
|
||||
"Cache-Control": "no-cache",
|
||||
}).BindBody(&resp).Do()
|
||||
if err != nil {
|
||||
|
@ -42,7 +43,7 @@ func GetUserScore(cookies []Cookie) (Score, error) {
|
|||
score.TotalScore = int(gjson.GetBytes(resp, "data.score").Int())
|
||||
|
||||
// 获取用户今日得分
|
||||
err = gout.GET(user_todayTotalScore_url).SetCookies(cookieToJar(cookies)...).SetHeader(gout.H{
|
||||
err = gout.GET(user_todayTotalScore_url).SetCookies(cookies...).SetHeader(gout.H{
|
||||
"Cache-Control": "no-cache",
|
||||
}).BindBody(&resp).Do()
|
||||
if err != nil {
|
||||
|
@ -53,7 +54,7 @@ func GetUserScore(cookies []Cookie) (Score, error) {
|
|||
log.Debugln(gjson.GetBytes(resp, "@this|@pretty"))
|
||||
score.TodayScore = int(gjson.GetBytes(resp, "data.score").Int())
|
||||
|
||||
err = gout.GET(user_rateScore_url).SetCookies(cookieToJar(cookies)...).SetHeader(gout.H{
|
||||
err = gout.GET(user_rateScore_url).SetCookies(cookies...).SetHeader(gout.H{
|
||||
"Cache-Control": "no-cache",
|
||||
}).BindBody(&resp).Do()
|
||||
if err != nil {
|
||||
|
|
20
lib/study.go
20
lib/study.go
|
@ -11,6 +11,8 @@ import (
|
|||
"github.com/guonaihong/gout"
|
||||
"github.com/mxschmitt/playwright-go"
|
||||
log "github.com/sirupsen/logrus"
|
||||
|
||||
"github.com/huoxue1/study_xxqg/model"
|
||||
)
|
||||
|
||||
var (
|
||||
|
@ -92,7 +94,7 @@ func getLinks(model string) ([]Link, error) {
|
|||
* @receiver c
|
||||
* @param cookies
|
||||
*/
|
||||
func (c *Core) LearnArticle(cookies []Cookie) {
|
||||
func (c *Core) LearnArticle(user *model.User) {
|
||||
defer func() {
|
||||
err := recover()
|
||||
if err != nil {
|
||||
|
@ -104,7 +106,7 @@ func (c *Core) LearnArticle(cookies []Cookie) {
|
|||
return
|
||||
}
|
||||
|
||||
score, err := GetUserScore(cookies)
|
||||
score, err := GetUserScore(user.ToCookies())
|
||||
if err != nil {
|
||||
log.Errorln(err.Error())
|
||||
return
|
||||
|
@ -120,7 +122,7 @@ func (c *Core) LearnArticle(cookies []Cookie) {
|
|||
page.Close()
|
||||
}()
|
||||
|
||||
err = (*c.context).AddCookies(cookieToParam(cookies)...)
|
||||
err = (*c.context).AddCookies(user.ToBrowserCookies()...)
|
||||
if err != nil {
|
||||
log.Errorln("添加cookie失败" + err.Error())
|
||||
return
|
||||
|
@ -162,7 +164,7 @@ func (c *Core) LearnArticle(cookies []Cookie) {
|
|||
time.Sleep(1 * time.Second)
|
||||
}
|
||||
fmt.Println()
|
||||
score, _ = GetUserScore(cookies)
|
||||
score, _ = GetUserScore(user.ToCookies())
|
||||
if score.Content["article"].CurrentScore >= score.Content["article"].MaxScore {
|
||||
log.Infoln("检测到本次阅读学习分数已满,退出学习")
|
||||
break
|
||||
|
@ -185,7 +187,7 @@ func (c *Core) LearnArticle(cookies []Cookie) {
|
|||
* @receiver c
|
||||
* @param cookies
|
||||
*/
|
||||
func (c *Core) LearnVideo(cookies []Cookie) {
|
||||
func (c *Core) LearnVideo(user *model.User) {
|
||||
defer func() {
|
||||
err := recover()
|
||||
if err != nil {
|
||||
|
@ -196,7 +198,7 @@ func (c *Core) LearnVideo(cookies []Cookie) {
|
|||
if c.IsQuit() {
|
||||
return
|
||||
}
|
||||
score, err := GetUserScore(cookies)
|
||||
score, err := GetUserScore(user.ToCookies())
|
||||
if err != nil {
|
||||
log.Errorln(err.Error())
|
||||
return
|
||||
|
@ -226,13 +228,13 @@ func (c *Core) LearnVideo(cookies []Cookie) {
|
|||
if err != nil {
|
||||
return
|
||||
}
|
||||
err = (*c.context).AddCookies(cookieToParam(cookies)...)
|
||||
|
||||
err = (*c.context).AddCookies(user.ToBrowserCookies()...)
|
||||
if err != nil {
|
||||
log.Errorln("添加cookie失败" + err.Error())
|
||||
return
|
||||
}
|
||||
tryCount := 0
|
||||
|
||||
for {
|
||||
if tryCount < 20 {
|
||||
PrintScore(score)
|
||||
|
@ -267,7 +269,7 @@ func (c *Core) LearnVideo(cookies []Cookie) {
|
|||
time.Sleep(1 * time.Second)
|
||||
}
|
||||
fmt.Println()
|
||||
score, _ = GetUserScore(cookies)
|
||||
score, _ = GetUserScore(user.ToCookies())
|
||||
if score.Content["video"].CurrentScore >= score.Content["video"].MaxScore && score.Content["video_time"].CurrentScore >= score.Content["video_time"].MaxScore {
|
||||
log.Infoln("检测到本次视频学习分数已满,退出学习")
|
||||
break
|
||||
|
|
44
lib/tg.go
44
lib/tg.go
|
@ -13,6 +13,8 @@ import (
|
|||
tgbotapi "github.com/go-telegram-bot-api/telegram-bot-api/v5"
|
||||
"github.com/google/uuid"
|
||||
log "github.com/sirupsen/logrus"
|
||||
|
||||
"github.com/huoxue1/study_xxqg/model"
|
||||
)
|
||||
|
||||
var (
|
||||
|
@ -80,7 +82,7 @@ func (t *Telegram) Init() {
|
|||
}
|
||||
|
||||
channel := t.bot.GetUpdatesChan(tgbotapi.NewUpdate(1))
|
||||
|
||||
t.SendMsg("你的学习强国小助手上线了!")
|
||||
go func() {
|
||||
for {
|
||||
update := <-channel
|
||||
|
@ -184,7 +186,7 @@ func login(bot *Telegram, args []string) {
|
|||
}
|
||||
|
||||
func getAllUser(bot *Telegram, args []string) {
|
||||
users, err := GetUsers()
|
||||
users, err := model.Query()
|
||||
if err != nil {
|
||||
bot.SendMsg("获取用户失败" + err.Error())
|
||||
return
|
||||
|
@ -199,7 +201,7 @@ func getAllUser(bot *Telegram, args []string) {
|
|||
|
||||
func studyAll(bot *Telegram, args []string) {
|
||||
config := GetConfig()
|
||||
users, err := GetUsers()
|
||||
users, err := model.Query()
|
||||
if err != nil {
|
||||
bot.SendMsg(err.Error())
|
||||
return
|
||||
|
@ -241,11 +243,11 @@ func studyAll(bot *Telegram, args []string) {
|
|||
defer datas.Delete(u)
|
||||
core.Init()
|
||||
defer core.Quit()
|
||||
core.LearnArticle(user.Cookies)
|
||||
core.LearnVideo(user.Cookies)
|
||||
core.RespondDaily(user.Cookies, "daily")
|
||||
core.RespondDaily(user.Cookies, "weekly")
|
||||
core.RespondDaily(user.Cookies, "special")
|
||||
core.LearnArticle(user)
|
||||
core.LearnVideo(user)
|
||||
core.RespondDaily(user, "daily")
|
||||
core.RespondDaily(user, "weekly")
|
||||
core.RespondDaily(user, "special")
|
||||
c <- 1
|
||||
}()
|
||||
|
||||
|
@ -260,7 +262,7 @@ func studyAll(bot *Telegram, args []string) {
|
|||
{
|
||||
}
|
||||
}
|
||||
score, _ := GetUserScore(user.Cookies)
|
||||
score, _ := GetUserScore(user.ToCookies())
|
||||
bot.SendMsg(fmt.Sprintf("当前学习总积分:%v,今日得分:%v", score.TotalScore, score.TodayScore))
|
||||
}
|
||||
s()
|
||||
|
@ -269,16 +271,16 @@ func studyAll(bot *Telegram, args []string) {
|
|||
|
||||
func study(bot *Telegram, args []string) {
|
||||
config := GetConfig()
|
||||
users, err := GetUsers()
|
||||
users, err := model.Query()
|
||||
if err != nil {
|
||||
bot.SendMsg(err.Error())
|
||||
return
|
||||
}
|
||||
var cookies []Cookie
|
||||
var user *model.User
|
||||
switch {
|
||||
case len(users) == 1:
|
||||
bot.SendMsg("仅存在一名用户信息,自动进行学习")
|
||||
cookies = users[0].Cookies
|
||||
user = users[0]
|
||||
case len(users) == 0:
|
||||
bot.SendMsg("未发现用户信息,请输入/login进行用户登录")
|
||||
return
|
||||
|
@ -289,7 +291,7 @@ func study(bot *Telegram, args []string) {
|
|||
bot.SendMsg(err.Error())
|
||||
return
|
||||
}
|
||||
cookies = users[i].Cookies
|
||||
user = users[i]
|
||||
} else {
|
||||
msgID := bot.SendMsg("存在多名用户,未输入用户序号")
|
||||
markup := tgbotapi.InlineKeyboardMarkup{}
|
||||
|
@ -334,11 +336,11 @@ func study(bot *Telegram, args []string) {
|
|||
defer datas.Delete(u)
|
||||
core.Init()
|
||||
defer core.Quit()
|
||||
core.LearnArticle(cookies)
|
||||
core.LearnVideo(cookies)
|
||||
core.RespondDaily(cookies, "daily")
|
||||
core.RespondDaily(cookies, "weekly")
|
||||
core.RespondDaily(cookies, "special")
|
||||
core.LearnArticle(user)
|
||||
core.LearnVideo(user)
|
||||
core.RespondDaily(user, "daily")
|
||||
core.RespondDaily(user, "weekly")
|
||||
core.RespondDaily(user, "special")
|
||||
c <- 1
|
||||
}()
|
||||
|
||||
|
@ -354,12 +356,12 @@ func study(bot *Telegram, args []string) {
|
|||
|
||||
}
|
||||
}
|
||||
score, _ := GetUserScore(cookies)
|
||||
score, _ := GetUserScore(user.ToCookies())
|
||||
bot.SendMsg(fmt.Sprintf("当前学习总积分:%v,今日得分:%v", score.TotalScore, score.TodayScore))
|
||||
}
|
||||
|
||||
func getScores(bot *Telegram, args []string) {
|
||||
users, err := GetUsers()
|
||||
users, err := model.Query()
|
||||
if err != nil {
|
||||
log.Errorln(err.Error())
|
||||
bot.SendMsg("获取用户信息失败" + err.Error())
|
||||
|
@ -368,7 +370,7 @@ func getScores(bot *Telegram, args []string) {
|
|||
message := fmt.Sprintf("共获取到%v个有效用户信息\n", len(users))
|
||||
for _, user := range users {
|
||||
message += user.Nick + "\n"
|
||||
score, err := GetUserScore(user.Cookies)
|
||||
score, err := GetUserScore(user.ToCookies())
|
||||
if err != nil {
|
||||
message += err.Error() + "\n"
|
||||
}
|
||||
|
|
99
lib/user.go
99
lib/user.go
|
@ -1,100 +1,15 @@
|
|||
package lib
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"os"
|
||||
"net/http"
|
||||
|
||||
"github.com/guonaihong/gout"
|
||||
log "github.com/sirupsen/logrus"
|
||||
"github.com/tidwall/gjson"
|
||||
|
||||
"github.com/huoxue1/study_xxqg/model"
|
||||
)
|
||||
|
||||
func init() {
|
||||
_, err := os.Stat(`./config/user.json`)
|
||||
if err != nil {
|
||||
err := os.WriteFile(user_path, []byte("[]"), 0666)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
const (
|
||||
user_path = "./config/user.json"
|
||||
)
|
||||
|
||||
type User struct {
|
||||
Cookies []Cookie `json:"cookies"`
|
||||
Nick string `json:"nick"`
|
||||
Uid string `json:"uid"`
|
||||
Time int64 `json:"time"`
|
||||
}
|
||||
|
||||
// GetUsers
|
||||
/**
|
||||
* @Description: 获取所有cookie有效的用户
|
||||
* @return []User
|
||||
* @return error
|
||||
*/
|
||||
func GetUsers() ([]User, error) {
|
||||
file, err := os.ReadFile(user_path)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
var users []User
|
||||
err = json.Unmarshal(file, &users)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
var newUsers []User
|
||||
for i := 0; i < len(users); i++ {
|
||||
if CheckUserCookie(users[i]) {
|
||||
newUsers = append(newUsers, users[i])
|
||||
continue
|
||||
}
|
||||
log.Infoln("用户" + users[i].Nick + "cookie已失效")
|
||||
}
|
||||
return newUsers, err
|
||||
}
|
||||
|
||||
// SaveUser
|
||||
/**
|
||||
* @Description: 保存用户信息到user.json
|
||||
* @param user
|
||||
* @return error
|
||||
*/
|
||||
func SaveUser(user User) error {
|
||||
users, err := GetUsers()
|
||||
if err != nil {
|
||||
log.Errorln("获取用户信息错误")
|
||||
return err
|
||||
}
|
||||
a := false
|
||||
for _, u := range users {
|
||||
if u.Uid == user.Uid {
|
||||
u.Cookies = user.Cookies
|
||||
a = true
|
||||
}
|
||||
}
|
||||
if !a {
|
||||
users = append(users, user)
|
||||
}
|
||||
|
||||
data, err := json.Marshal(&users)
|
||||
if err != nil {
|
||||
log.Errorln("序列化用户失败")
|
||||
return err
|
||||
}
|
||||
err = os.WriteFile(user_path, data, 0666)
|
||||
if err != nil {
|
||||
log.Errorln("写入用户信息到文件错误")
|
||||
|
||||
return err
|
||||
}
|
||||
return err
|
||||
}
|
||||
|
||||
// GetUserInfo
|
||||
/**
|
||||
* @Description: 获取用户信息
|
||||
|
@ -103,10 +18,10 @@ func SaveUser(user User) error {
|
|||
* @return string
|
||||
* @return error
|
||||
*/
|
||||
func GetUserInfo(cookies []Cookie) (string, string, error) {
|
||||
func GetUserInfo(cookies []*http.Cookie) (string, string, error) {
|
||||
var resp []byte
|
||||
err := gout.GET(user_Info_url).
|
||||
SetCookies(cookieToJar(cookies)...).
|
||||
SetCookies(cookies...).
|
||||
SetHeader(gout.H{
|
||||
"Cache-Control": "no-cache",
|
||||
}).BindBody(&resp).Do()
|
||||
|
@ -128,8 +43,8 @@ func GetUserInfo(cookies []Cookie) (string, string, error) {
|
|||
* @param user
|
||||
* @return bool
|
||||
*/
|
||||
func CheckUserCookie(user User) bool {
|
||||
_, err := GetUserScore(user.Cookies)
|
||||
func CheckUserCookie(user *model.User) bool {
|
||||
_, err := GetUserScore(user.ToCookies())
|
||||
if err != nil && err.Error() == "token check failed" {
|
||||
return false
|
||||
}
|
||||
|
|
27
main.go
27
main.go
|
@ -14,6 +14,7 @@ import (
|
|||
easy "github.com/t-tomalak/logrus-easy-formatter"
|
||||
|
||||
"github.com/huoxue1/study_xxqg/lib"
|
||||
"github.com/huoxue1/study_xxqg/model"
|
||||
"github.com/huoxue1/study_xxqg/push"
|
||||
)
|
||||
|
||||
|
@ -106,15 +107,15 @@ func do() {
|
|||
core := lib.Core{ShowBrowser: config.ShowBrowser, Push: getPush}
|
||||
defer core.Quit()
|
||||
core.Init()
|
||||
var cookies []lib.Cookie
|
||||
users, _ := lib.GetUsers()
|
||||
var user *model.User
|
||||
users, _ := model.Query()
|
||||
switch {
|
||||
case len(users) < 1:
|
||||
log.Infoln("未检测到有效用户信息,将采用登录模式")
|
||||
cookies, _ = core.L()
|
||||
user, _ = core.L()
|
||||
case len(users) == 1:
|
||||
log.Infoln("检测到1位有效用户信息,采用默认用户")
|
||||
cookies = users[0].Cookies
|
||||
user = users[0]
|
||||
log.Infoln("已选择用户: ", users[0].Nick)
|
||||
default:
|
||||
for i, user := range users {
|
||||
|
@ -123,22 +124,22 @@ func do() {
|
|||
log.Infoln("请输入对应序号选择对应账户")
|
||||
var i int
|
||||
_, _ = fmt.Scanln(&i)
|
||||
cookies = users[i-1].Cookies
|
||||
user = users[i-1]
|
||||
log.Infoln("已选择用户: ", users[i-1].Nick)
|
||||
}
|
||||
|
||||
go core.LearnArticle(cookies)
|
||||
go core.LearnVideo(cookies)
|
||||
lib.WaitStudy(&lib.User{Cookies: cookies}, "")
|
||||
go core.LearnArticle(user)
|
||||
go core.LearnVideo(user)
|
||||
lib.WaitStudy(user, "")
|
||||
if config.Model == 2 {
|
||||
core.RespondDaily(cookies, "daily")
|
||||
core.RespondDaily(user, "daily")
|
||||
} else if config.Model == 3 {
|
||||
core.RespondDaily(cookies, "daily")
|
||||
core.RespondDaily(cookies, "weekly")
|
||||
core.RespondDaily(cookies, "special")
|
||||
core.RespondDaily(user, "daily")
|
||||
core.RespondDaily(user, "weekly")
|
||||
core.RespondDaily(user, "special")
|
||||
}
|
||||
|
||||
score, err := lib.GetUserScore(cookies)
|
||||
score, err := lib.GetUserScore(user.ToCookies())
|
||||
if err != nil {
|
||||
log.Errorln("获取成绩失败")
|
||||
log.Debugln(err.Error())
|
||||
|
|
|
@ -0,0 +1,39 @@
|
|||
package model
|
||||
|
||||
import (
|
||||
"database/sql"
|
||||
|
||||
_ "github.com/fumiama/sqlite3"
|
||||
|
||||
log "github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
var (
|
||||
db *sql.DB
|
||||
)
|
||||
|
||||
func init() {
|
||||
var err error
|
||||
db, err = sql.Open("sqlite3", "./config/user.db")
|
||||
if err != nil {
|
||||
log.Errorln("用户数据库打开失败,请检查config目录权限")
|
||||
log.Panicln(err.Error())
|
||||
}
|
||||
_, _ = db.Exec(`create table user
|
||||
(
|
||||
nick TEXT,
|
||||
uid TEXT not null
|
||||
constraint user_pk
|
||||
primary key,
|
||||
token TEXT not null,
|
||||
login_time integer not null
|
||||
);
|
||||
`)
|
||||
}
|
||||
|
||||
func ping() {
|
||||
err := db.Ping()
|
||||
if err != nil {
|
||||
log.Errorln("数据库断开了连接")
|
||||
}
|
||||
}
|
|
@ -0,0 +1,197 @@
|
|||
// Package model
|
||||
// @Description:
|
||||
package model
|
||||
|
||||
import (
|
||||
"database/sql"
|
||||
"net/http"
|
||||
"time"
|
||||
|
||||
"github.com/guonaihong/gout"
|
||||
"github.com/mxschmitt/playwright-go"
|
||||
log "github.com/sirupsen/logrus"
|
||||
"github.com/tidwall/gjson"
|
||||
)
|
||||
|
||||
// User
|
||||
/**
|
||||
* @Description:
|
||||
*/
|
||||
type User struct {
|
||||
Nick string `json:"nick"`
|
||||
UID string `json:"uid"`
|
||||
Token string `json:"token"`
|
||||
LoginTime int64 `json:"login_time"`
|
||||
}
|
||||
|
||||
// Query
|
||||
/**
|
||||
* @Description:
|
||||
* @return []*User
|
||||
* @return error
|
||||
*/
|
||||
func Query() ([]*User, error) {
|
||||
var users []*User
|
||||
ping()
|
||||
results, err := db.Query("select * from user")
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
defer func(results *sql.Rows) {
|
||||
err := results.Close()
|
||||
if err != nil {
|
||||
log.Errorln("关闭results失败" + err.Error())
|
||||
}
|
||||
}(results)
|
||||
for results.Next() {
|
||||
u := new(User)
|
||||
err := results.Scan(&u.Nick, &u.UID, &u.Token, &u.LoginTime)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if CheckUserCookie(u) {
|
||||
users = append(users, u)
|
||||
} else {
|
||||
log.Infoln("用户" + u.Nick + "cookie已失效")
|
||||
}
|
||||
}
|
||||
return users, err
|
||||
}
|
||||
|
||||
// Find
|
||||
/**
|
||||
* @Description:
|
||||
* @param uid
|
||||
* @return *User
|
||||
*/
|
||||
func Find(uid string) *User {
|
||||
u := new(User)
|
||||
err := db.QueryRow("select * from user where uid=?;", uid).Scan(&u.Nick, &u.UID, &u.Token, &u.LoginTime)
|
||||
if err != nil {
|
||||
return nil
|
||||
}
|
||||
return u
|
||||
}
|
||||
|
||||
// AddUser
|
||||
/**
|
||||
* @Description:
|
||||
* @param user
|
||||
* @return error
|
||||
*/
|
||||
func AddUser(user *User) error {
|
||||
ping()
|
||||
count := UserCount(user.UID)
|
||||
if count < 1 {
|
||||
_, err := db.Exec("insert into user (nick, uid, token, login_time) values (?,?,?,?)", user.Nick, user.UID, user.Token, user.LoginTime)
|
||||
if err != nil {
|
||||
log.Errorln("数据库插入失败")
|
||||
log.Errorln(err.Error())
|
||||
return err
|
||||
}
|
||||
return err
|
||||
}
|
||||
err := UpdateUser(user)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
// UpdateUser
|
||||
/**
|
||||
* @Description:
|
||||
* @param user
|
||||
* @return error
|
||||
*/
|
||||
func UpdateUser(user *User) error {
|
||||
ping()
|
||||
_, err := db.Exec("update user set token=? where uid = ?", user.Token, user.UID)
|
||||
if err != nil {
|
||||
log.Errorln("更新数据失败")
|
||||
log.Errorln(err.Error())
|
||||
return err
|
||||
}
|
||||
return err
|
||||
}
|
||||
|
||||
// UserCount
|
||||
/**
|
||||
* @Description:
|
||||
* @param uid
|
||||
* @return int
|
||||
*/
|
||||
func UserCount(uid string) int {
|
||||
ping()
|
||||
var count int
|
||||
err := db.QueryRow("select count(*) from user where uid = ?", uid).Scan(&count)
|
||||
if err != nil {
|
||||
return 0
|
||||
}
|
||||
return count
|
||||
}
|
||||
|
||||
func DeleteUser(uid string) error {
|
||||
ping()
|
||||
_, err := db.Exec("delete from user where uid = ?;", uid)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return err
|
||||
}
|
||||
|
||||
// ToCookies
|
||||
/**
|
||||
* @Description: 获取user的cookie
|
||||
* @receiver u
|
||||
* @return []*http.Cookie
|
||||
*/
|
||||
func (u *User) ToCookies() []*http.Cookie {
|
||||
cookie := &http.Cookie{
|
||||
Name: "token",
|
||||
Value: u.Token,
|
||||
Path: "/",
|
||||
Domain: "xuexi.cn",
|
||||
Expires: time.Now().Add(time.Hour * 12),
|
||||
Secure: false,
|
||||
HttpOnly: false,
|
||||
SameSite: http.SameSiteStrictMode,
|
||||
}
|
||||
return []*http.Cookie{cookie}
|
||||
}
|
||||
|
||||
func (u *User) ToBrowserCookies() []playwright.SetNetworkCookieParam {
|
||||
cookie := playwright.SetNetworkCookieParam{
|
||||
Name: "token",
|
||||
Value: u.Token,
|
||||
Path: playwright.String("/"),
|
||||
Domain: playwright.String(".xuexi.cn"),
|
||||
Expires: playwright.Int(int(time.Now().Add(time.Hour * 12).UnixNano())),
|
||||
Secure: playwright.Bool(false),
|
||||
HttpOnly: playwright.Bool(false),
|
||||
SameSite: playwright.String("Strict"),
|
||||
}
|
||||
return []playwright.SetNetworkCookieParam{cookie}
|
||||
}
|
||||
|
||||
// CheckUserCookie
|
||||
/**
|
||||
* @Description: 获取用户成绩
|
||||
* @param user
|
||||
* @return bool
|
||||
*/
|
||||
func CheckUserCookie(user *User) bool {
|
||||
var resp []byte
|
||||
err := gout.GET("https://pc-api.xuexi.cn/open/api/score/get").SetCookies(user.ToCookies()...).SetHeader(gout.H{
|
||||
"Cache-Control": "no-cache",
|
||||
}).BindBody(&resp).Do()
|
||||
if err != nil {
|
||||
log.Errorln("获取用户总分错误" + err.Error())
|
||||
|
||||
return false
|
||||
}
|
||||
if !gjson.GetBytes(resp, "ok").Bool() {
|
||||
return false
|
||||
}
|
||||
return true
|
||||
}
|
|
@ -0,0 +1,33 @@
|
|||
package model
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
log "github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
func TestInsert(t *testing.T) {
|
||||
err := AddUser(&User{
|
||||
Nick: "123",
|
||||
UID: "123",
|
||||
Token: "123444444444444444444444444",
|
||||
LoginTime: 1031312,
|
||||
})
|
||||
if err != nil {
|
||||
log.Errorln(err.Error())
|
||||
}
|
||||
}
|
||||
|
||||
func TestQuery(t *testing.T) {
|
||||
users, err := Query()
|
||||
if err != nil {
|
||||
log.Errorln(err.Error())
|
||||
return
|
||||
}
|
||||
log.Infoln(users[0].UID)
|
||||
}
|
||||
|
||||
func TestFind(t *testing.T) {
|
||||
user := Find("123")
|
||||
log.Infoln(user.Nick)
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package utils
|
||||
|
||||
func KillOnWin(pid int) {
|
||||
|
||||
}
|
Loading…
Reference in New Issue