page_auth_handler.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. package bridge
  2. import (
  3. "dashoo.cn/opms_libary/plugin/wechat/context"
  4. "dashoo.cn/opms_libary/plugin/wechat/mp/oauth"
  5. "dashoo.cn/opms_libary/plugin/wechat/mp/user"
  6. "fmt"
  7. "net/http"
  8. "net/url"
  9. )
  10. //PageOAuthHandler 微信网页授权
  11. type PageOAuthHandler struct {
  12. // *wxcontext.Context
  13. *oauth.Oauth
  14. myURLOfPageOAuthCallback string
  15. myURLNeedPageOAuth string
  16. openID string
  17. openIDExisting bool
  18. checkOpenIDExistingFunc func(openID string) (existing bool, stopNow bool)
  19. user.Info
  20. afterGetUserInfoFunc func(user user.Info) (stopNow bool)
  21. }
  22. //NewPageOAuthHandler PageOAuthHandler初始化
  23. func NewPageOAuthHandler(context *context.Context, myURLOfPageOAuthCallback string) *PageOAuthHandler {
  24. pa := new(PageOAuthHandler)
  25. pa.Oauth = oauth.NewOauth(context)
  26. pa.myURLOfPageOAuthCallback = myURLOfPageOAuthCallback
  27. return pa
  28. }
  29. func (c *PageOAuthHandler) getCallbackURL() (u string) {
  30. return fmt.Sprintf("%s?target=%s", c.myURLOfPageOAuthCallback, url.QueryEscape(c.myURLNeedPageOAuth))
  31. }
  32. /*SetFuncCheckOpenIDExisting 设置检查OpenID在您的系统中是否已经存在
  33. handler:
  34. func(openID string) (existing bool){
  35. //用获得的openID,检查是否在你的系统中已经存在此用户
  36. //如果存在,调用你的Login方法,设置cookie, session等,然后return true
  37. //如果你的系统中不存在此openID用户, return false, handler会自动去获取用户信息
  38. }
  39. */
  40. func (c *PageOAuthHandler) SetFuncCheckOpenIDExisting(handler func(string) (existing bool, stopNow bool)) {
  41. c.checkOpenIDExistingFunc = handler
  42. }
  43. /*SetFuncAfterGetUserInfo 设置获得用户信息后执行
  44. handler:
  45. func(user oauth.UserInfo) (needStop bool) {
  46. //handler已经获得了用户信息,你可以用此信息,自动为用户完成一些动作,比如注册,头像等
  47. //默认needStop为false, 表示handler会自动redirect到你最开始需要授权的网页,此时你的系统已经完成了自动登陆等动作
  48. //如果你需要redirect到你需要的url,直接调用http.redirect; return true。 表示需要停止后面的动作
  49. }
  50. */
  51. func (c *PageOAuthHandler) SetFuncAfterGetUserInfo(handler func(user.Info) bool) {
  52. c.afterGetUserInfoFunc = handler
  53. }
  54. //Handle handler
  55. func (c *PageOAuthHandler) Handle() (err error) {
  56. code := c.Query("code")
  57. c.myURLNeedPageOAuth = c.Query("target")
  58. if code != "" {
  59. var acsTkn oauth.ResAccessToken
  60. acsTkn, err = c.GetUserAccessToken(code)
  61. if err != nil {
  62. return
  63. }
  64. openID := acsTkn.OpenID
  65. existing, stopNow := c.checkOpenIDExistingFunc(openID)
  66. if stopNow {
  67. return
  68. }
  69. if existing {
  70. http.Redirect(c.Writer, c.Request, c.myURLNeedPageOAuth, 302)
  71. return
  72. }
  73. //用 user模块的,没用oauth模板,可以获得更多信息
  74. u, err := user.NewUser(c.Oauth.Context).GetUserInfo(openID)
  75. if err != nil {
  76. return err
  77. }
  78. stopNow = c.afterGetUserInfoFunc(*u)
  79. if stopNow {
  80. return nil
  81. }
  82. http.Redirect(c.Writer, c.Request, c.myURLNeedPageOAuth, 302)
  83. return nil
  84. } else {
  85. //code为空时
  86. c.Redirect(c.getCallbackURL(), "snsapi_base", "base")
  87. }
  88. return
  89. }