From dbd8d2438b4597c1fd122c99e757045b5baade6e Mon Sep 17 00:00:00 2001 From: Luk Lu Date: Sun, 27 Mar 2022 16:37:36 +0800 Subject: [PATCH] =?UTF-8?q?=E5=AE=9E=E7=8E=B0=EF=BC=9A=E8=85=BE=E8=AE=AF?= =?UTF-8?q?=E4=BA=91=E7=9A=84=E7=9F=AD=E4=BF=A1=E5=8F=91=E9=80=81=E3=80=82?= =?UTF-8?q?=E5=B0=9A=E6=9C=AA=E6=B5=8B=E8=AF=95=E3=80=82?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ConfigTemplate.js => ConfigSecret.Template.js | 7 ++- messenger.js | 50 +++++++++++++++---- package.json | 3 +- 3 files changed, 48 insertions(+), 12 deletions(-) rename ConfigTemplate.js => ConfigSecret.Template.js (89%) diff --git a/ConfigTemplate.js b/ConfigSecret.Template.js similarity index 89% rename from ConfigTemplate.js rename to ConfigSecret.Template.js index 7448bb3..3583bed 100644 --- a/ConfigTemplate.js +++ b/ConfigSecret.Template.js @@ -10,6 +10,7 @@ module.exports = { tls: { rejectUnauthorized: false } }, SMS: { + vendor: '', // DXTON, UNICLOUD, ALIYUN, TENCENT DXTON: { urlChina:'http://sms.106jiekou.com/utf8/sms.aspx?account=????&password=????', urlWorld:'http://sms.106jiekou.com/utf8/worldapi.aspx?account=????&password=????', @@ -21,7 +22,8 @@ module.exports = { TEMPLATE_PASSCODE_REGISTER_NEWUSER: ' ?????? ', TEMPLATE_PASSCODE_RESET_PASSWORD: ' ?????? ', TEMPLATE_PASSCODE_CHANGE_PHONE: ' ?????? ', - TEMPLATE_PASSCODE_GENERAL: ' ?????? ', + TEMPLATE_PASSCODE_GENERAL_PURPOSE: ' ?????? ', + TEMPLATE_PASSCODE_SIMPLEST: ' ?????? ', }, ALIYUN: { accessKeyId:'????', @@ -30,7 +32,8 @@ module.exports = { TEMPLATE_PASSCODE_REGISTER_NEWUSER: ' ?????? ', TEMPLATE_PASSCODE_RESET_PASSWORD: ' ?????? ', TEMPLATE_PASSCODE_CHANGE_PHONE: ' ?????? ', - TEMPLATE_PASSCODE_GENERAL: ' ?????? ', + TEMPLATE_PASSCODE_GENERAL_PURPOSE: ' ?????? ', + TEMPLATE_PASSCODE_SIMPLEST: ' ?????? ', }, TENCENT: { // https://cloud.tencent.com/document/product/382/43197 credential: { diff --git a/messenger.js b/messenger.js index a3401ef..bd30d88 100644 --- a/messenger.js +++ b/messenger.js @@ -8,7 +8,8 @@ module.exports = { init (envi) { my.envi = envi my.smtpTransporter = NodeMailer.createTransport(envi.SMTP) - my.smsClient = new (require('@alicloud/sms-sdk'))(envi.SMS.aliyun) // https://www.npmjs.com/package/@alicloud/sms-sdk + my.smsClientAliyun = new (require('@alicloud/sms-sdk'))(envi.SMS.ALIYUN) // https://www.npmjs.com/package/@alicloud/sms-sdk + my.smsClientTencent = new (require('tencentcloud-sdk-nodejs').sms.v20210111.Client)(envi.SMS.TENCENT) // https://cloud.tencent.com/document/product/382/43197 }, // 或者如果smtp参数已经确定,就可以直接定义 sendMail: Bluebird.promisify(Smtp.sendMail).bind(Smtp) @@ -20,8 +21,8 @@ module.exports = { async sendSms ({ phone, vendor, msg, // for vendor==='DXTON' msgParam, msgTemplate, // for ['ALIYUN','UNICLOUD'].includes(vendor) - signName, // for vendor==='ALIYUN', - appid, // for vendor==='UNICLOUD', + signName, // for vendor==='ALIYUN', 'TENCENT' + appid, // for vendor==='UNICLOUD', 'TENCENT' } = {}) { // 通过option对象,对外提供统一的调用参数格式 if (/^\+\d+-\d+$/.test(phone)) { @@ -31,9 +32,14 @@ module.exports = { return await this.sendSmsAliyun(phone, msgParam, msgTemplate, signName) } else if (vendor === 'UNICLOUD' && msgParam && msgTemplate) { return await this.sendSmsUnicloud({phone, msgParam, msgTemplate, appid}) + } else if (vendor === 'TENCENT' && msgParam && msgTemplate) { + return await this.sendSmsTencent({phone, msgParam, msgTemplate, appid, signName}) + } else { + return { _state: 'SMS_UNKNOWN_VENDOR', error: {} } } + } else { + return { _state: 'SMS_INVALID_PHONE', error: {} } } - return null // 手机号格式错误,或者 vendor 错误。 }, /* 使用 dxton.com 的短信接口 http://www.dxton.com/help_detail/38.html @@ -73,13 +79,13 @@ module.exports = { }, async sendSmsAliyun (phone, msgParam, msgTemplate, signName) { - my.smsClient = my.smsClient || new (require('@alicloud/sms-sdk'))(wo.envi.SMS.aliyun) + my.smsClientAliyun = my.smsClientAliyun || new (require('@alicloud/sms-sdk'))(wo.envi.SMS.ALIYUN) const [countryCode, callNumber] = phone.match(/\d+/g) const smsNumber = countryCode === '86' ? callNumber : `00${countryCode}${callNumber}` const envi = my.envi || wo.envi - return await my.smsClient + return await my.smsClientAliyun .sendSMS({ PhoneNumbers: smsNumber, //必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式;发送国际/港澳台消息时,接收号码格式为00+国际区号+号码,如“0085200000000” SignName: signName || envi.SMS.ALIYUN.signName, //必填:短信签名-可在短信控制台中找到 @@ -101,13 +107,13 @@ module.exports = { ) }, - async sendSmsUnicloud({ phone, msgTemplate, msgParam, appid, smsKey, smsSecret }) { + async sendSmsUnicloud({ phone, msgTemplate, msgParam, appid }) { try { const envi = my.envi || wo.envi // 不能在下面调用 my.envi.*** 因为 my.envi 可能并未初始化,而 unicloud 又不支持 ?. 操作符. const result = await uniCloud.sendSms({ appid: appid || envi.SMS.UNICLOUD.appid, - smsKey: smsKey || envi.SMS.UNICLOUD.smsKey, - smsSecret: smsSecret || envi.SMS.UNICLOUD.smsSecret, + smsKey: envi.SMS.UNICLOUD.smsKey, + smsSecret: envi.SMS.UNICLOUD.smsSecret, phone: phone.match(/\d+/g)[1], templateId: msgTemplate || 'uni_sms_test', data: msgParam // 模版中的变量的值,例如 { passcode: '234345', purpose: '注册' } @@ -122,6 +128,32 @@ module.exports = { error // { errCode, errMsg } } } + }, + + async sendSmsTencent ({ phone, msgTemplate, msgParam, signName, appid }) { + my.smsClientTencent = my.smsClientTencent || new (require('tencentcloud-sdk-nodejs').sms.v20210111.Client)(envi.SMS.TENCENT) + + const envi = my.envi || wo.envi + + return await my.smsClientTencent.SendSms({ // API: https://cloud.tencent.com/document/product/382/55981 + PhoneNumber: phone.replace('-', ''), + SmsSdkAppid: appid || envi.SMS.TENCENT.appid, + SignName: signName || envi.SMS.TENCENT.signName, + TemplateID: msgTemplate, + TemplateParam: msgParam, + }).then( + function ({SendStatusSet, RequestId} = {}) { + let { SerialNo, PhoneNumber, Fee, Code, Message, IsoCode } = SendStatusSet[0] + if (Code === 'Ok') { + return { _state: 'SMS_SENT_SUCCESS' } + } else { + return { _state: 'SMS_SEND_FAIL', error: {SendStatusSet, RequestId} } + } + }, + function (error) { + return { _state: 'SMS_SEND_ERROR', error } + } + ) } } diff --git a/package.json b/package.json index 0600f30..85411f2 100644 --- a/package.json +++ b/package.json @@ -5,7 +5,8 @@ "private": true, "dependencies": { "@alicloud/sms-sdk": "^1.1.3", - "nodemailer": "^4.4.1" + "nodemailer": "^4.4.1", + "tencentcloud-sdk-nodejs": "^4.0.315" }, "scripts": { "setup": "npm install"