1
0
mirror of https://github.com/nikoksr/notify.git synced 2025-01-07 23:01:59 +02:00
notify/service/wechat
ImgBotApp 7c290c3d61
[ImgBot] Optimize images
*Total -- 182.91kb -> 169.87kb (7.13%)

/service/wechat/img/wechat_usage.png -- 14.57kb -> 7.69kb (47.21%)
/service/wechat/img/wechat_sandbox_2.png -- 68.20kb -> 62.27kb (8.7%)
/assets/gopher-letter.svg -- 100.15kb -> 99.91kb (0.23%)

Signed-off-by: ImgBotApp <ImgBotHelp@gmail.com>
2021-04-27 05:47:17 +00:00
..
img [ImgBot] Optimize images 2021-04-27 05:47:17 +00:00
mock_wechatMessageManager.go feat: added support for WeChat 2021-03-21 18:54:10 +02:00
README.md build-passing commit 2021-04-15 12:12:28 +03:00
wechat_test.go feat: added support for WeChat 2021-03-21 18:54:10 +02:00
wechat.go build-passing commit 2021-04-23 21:09:02 +03:00

WeChat

Prerequisites

To use the service you need to apply for a WeChat Official Account. Application approval is a manual process and might take a while. In the meantime, you can test your code using the sandbox.

You need the following configuration information to sent out text messages with an Official Account:

  1. AppID
  2. AppSecret
  3. Token
  4. EncodingAESKey
  5. Verification URL

The AppID and AppSecret are provided to you by WeChat. The Token, EncodingAESKey and the Verifications URL, you set yourself and are needed by the authentication method. More on this here.

Getting Started

Until your application is approved, sign in to the sandbox to get an AppID, an AppSecret and set the Token and the Verification URL. Typically, you need a service like ngrok for the latter. You don't need to/cannot set the EncodingAESKey, because it's not required in the sandbox environment:

wechat_sandbox_1.png

You also need a user subscribed to your Official Account. You can use your own:

wechat_sandbox_2.png

Usage

package main

import (
  "github.com/silenceper/wechat/v2/cache"
  "log"
  "context"
  "fmt"
  "net/http"
  "github.com/nikoksr/notify"
  "github.com/nikoksr/notify/service/wechat"
)

func main() {

  wechatSvc := wechat.New(&wechat.Config{
    AppID:          "abcdefghi",
    AppSecret:      "jklmnopqr",
    Token:          "mytoken",
    EncodingAESKey: "IGNORED-IN-SANDBOX",
    Cache:          cache.NewMemory(),
  })

  // do this only once, or when settings are updated
  devMode := true
  wechatSvc.WaitForOneOffVerification(":7999", devMode, func(r *http.Request, verified bool) {
    if !verified {
      fmt.Println("unknown or failed verification call")
    } else {
      fmt.Println("verification call done")
    }
  })

  wechatSvc.AddReceivers("some-user-openid")

  notifier := notify.New()
  notifier.UseServices(wechatSvc)

  err := notifier.Send(context.Background(), "subject", "message")
  if err != nil {
    log.Fatalf("notifier.Send() failed: %s", err.Error())
  }

  log.Println("notification sent")
}

wechat_usage.png