一、注册zoom 账号、以便在zoom app maketplace创建app。
data:image/s3,"s3://crabby-images/038f8/038f82c8307adbab1d818e551212d95044dd5acf" alt=""
二、安装git、node.js、vscode开发环境(略)。
三、注册ngrok账号,获得一个免费的https静态域名。
data:image/s3,"s3://crabby-images/75f59/75f590fb0e23e51400d60a64f0eae90331e86d60" alt=""
四、配置zoom app(wxl),设置上一步获得的https静态域名,验证地址为/auth
data:image/s3,"s3://crabby-images/d6bbe/d6bbea1b9d3b70de59fa3a254e88cd440cd9b81c" alt=""
五、事件订阅(会议开始和会议结束,也可以订阅其它事件)
data:image/s3,"s3://crabby-images/090ec/090ec753f47470b23e70d18bd948bb1a9dd27061" alt=""
六、选择在哪些界面使用app(wxl)、设置主页和允许访问的域名。
data:image/s3,"s3://crabby-images/0f1cb/0f1cb70df68f86244235ad7857a1a2e129db6b22" alt=""
七、设置访问范围
data:image/s3,"s3://crabby-images/72b5f/72b5fc8439ff662ce7b97d703adcda9bacb0c8f1" alt=""
八、生成共享app(wxl)的链接
data:image/s3,"s3://crabby-images/e3ddc/e3ddc34ee19ca08bc2f68d85291a11882c2d0b7f" alt=""
九、开始开发过程(power shell)
1、git clone https://github.com/zoom/zoomapps-sample-js
2、cd zoomapps-sample-js
3、npm install
4、配置.env(参数来源创建app的过程,SESSION_SECRET为随机初始化值)
data:image/s3,"s3://crabby-images/18a84/18a841a7bd28a1a3ca7cb3cc4b3deedce911815c" alt=""
5、在app.js文件的95行-149行增加/webhook的处理(接收会议开始和结束事情的订阅信息)
app.post('/webhook', (req, res) => {
var response
console.log(req.headers)
console.log(req.body)
// construct the message string
const message = `v0:${req.headers['x-zm-request-timestamp']}:${JSON.stringify(req.body)}`
const hashForVerify = crypto.createHmac('sha256', secretToken).update(message).digest('hex')
// hash the message string with your Webhook Secret Token and prepend the version semantic
const signature = `v0=${hashForVerify}`
// you validating the request came from Zoom https://marketplace.zoom.us/docs/api-reference/webhook-reference#notification-structure
if (req.headers['x-zm-signature'] === signature) {
// Zoom validating you control the webhook endpoint https://marketplace.zoom.us/docs/api-reference/webhook-reference#validate-webhook-endpoint
if(req.body.event === 'endpoint.url_validation') {
const hashForValidate = crypto.createHmac('sha256', secretToken).update(req.body.payload.plainToken).digest('hex')
response = {
message: {
plainToken: req.body.payload.plainToken,
encryptedToken: hashForValidate
},
status: 200
}
console.log(response.message)
res.status(response.status)
res.json(response.message)
} else {
response = { message: 'Authorized request to Zoom Webhook sample.', status: 200 }
console.log(response.message)
res.status(response.status)
res.json(response)
// business logic here, example make API request to Zoom or 3rd party
}
} else {
response = { message: 'Unauthorized request to Zoom Webhook sample.', status: 401 }
console.log(response.message)
res.status(response.status)
res.json(response)
}
})
6、npm start dev
7、ngrok http --domain=shortly-adapted-akita.ngrok-free.app 3000
data:image/s3,"s3://crabby-images/67a4a/67a4ae7b7962c2eb2c6cd33528cf6abb20045476" alt=""
8、访问静态域名
data:image/s3,"s3://crabby-images/2bb2e/2bb2efa0b7ab7f1039bd040ff1c94cbc45f6a143" alt=""
9、点击click here 安装app到zoom中
data:image/s3,"s3://crabby-images/fe35c/fe35c2e42a0ac51a526410d5b1da73666ac91193" alt=""
10、允许后
data:image/s3,"s3://crabby-images/d0446/d0446b0e5cd55bcb60e85b080807cf9cd8191d4c" alt=""
11、打开zoom应用,app(wxl)显示就在zoom窗口中了。
data:image/s3,"s3://crabby-images/5c1f4/5c1f44ef3d6871d748b57d55936827365ebc487b" alt=""
12、点击开始视频会议,获得开始会议事件的订阅信息
data:image/s3,"s3://crabby-images/f55cf/f55cf924c9ec0f3a9db253ae55aec3d63b157cef" alt=""
13、点击结束会议,获得结束会议事件订阅信息
data:image/s3,"s3://crabby-images/cc892/cc892accc623d65254f1268081d16a808f4f9645" alt=""