添加 init(envi) 方法来初始化;把phone参数合并到第二个{...}参数里
This commit is contained in:
		
							parent
							
								
									03b896d0fa
								
							
						
					
					
						commit
						a7d45c3473
					
				@ -17,6 +17,37 @@ module.exports = {
 | 
				
			|||||||
    aliyun:{
 | 
					    aliyun:{
 | 
				
			||||||
      accessKeyId:'????',
 | 
					      accessKeyId:'????',
 | 
				
			||||||
      secretAccessKey:'????',
 | 
					      secretAccessKey:'????',
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    tencent:{ // https://cloud.tencent.com/document/product/382/43197
 | 
				
			||||||
 | 
					      credential: {
 | 
				
			||||||
 | 
					        /* 必填:腾讯云账户密钥对secretId,secretKey。
 | 
				
			||||||
 | 
					         * 这里采用的是从环境变量读取的方式,需要在环境变量中先设置这两个值。
 | 
				
			||||||
 | 
					         * 你也可以直接在代码中写死密钥对,但是小心不要将代码复制、上传或者分享给他人,
 | 
				
			||||||
 | 
					         * 以免泄露密钥对危及你的财产安全。
 | 
				
			||||||
 | 
					         * SecretId、SecretKey 查询: https://console.cloud.tencent.com/cam/capi */
 | 
				
			||||||
 | 
					        secretId: process.env.secretId,
 | 
				
			||||||
 | 
					        secretKey: process.env.secretKey,
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      /* 必填:地域信息,可以直接填写字符串ap-guangzhou,支持的地域列表参考 https://cloud.tencent.com/document/api/382/52071#.E5.9C.B0.E5.9F.9F.E5.88.97.E8.A1.A8 */
 | 
				
			||||||
 | 
					      region: "ap-guangzhou", // ap-beijing, ap-nanjing
 | 
				
			||||||
 | 
					      /* 非必填:
 | 
				
			||||||
 | 
					        * 客户端配置对象,可以指定超时时间等配置 */
 | 
				
			||||||
 | 
					      profile: {
 | 
				
			||||||
 | 
					        /* SDK默认用TC3-HMAC-SHA256进行签名,非必要请不要修改这个字段 */
 | 
				
			||||||
 | 
					        signMethod: "HmacSHA256",
 | 
				
			||||||
 | 
					        httpProfile: {
 | 
				
			||||||
 | 
					          /* SDK默认使用POST方法。
 | 
				
			||||||
 | 
					            * 如果你一定要使用GET方法,可以在这里设置。GET方法无法处理一些较大的请求 */
 | 
				
			||||||
 | 
					          reqMethod: "POST",
 | 
				
			||||||
 | 
					          /* SDK有默认的超时时间,非必要请不要进行调整
 | 
				
			||||||
 | 
					            * 如有需要请在代码中查阅以获取最新的默认值 */
 | 
				
			||||||
 | 
					          reqTimeout: 30,
 | 
				
			||||||
 | 
					          /**
 | 
				
			||||||
 | 
					           * 指定接入地域域名,默认就近地域接入域名为 sms.tencentcloudapi.com ,也支持指定地域域名访问,例如广州地域的域名为 sms.ap-guangzhou.tencentcloudapi.com
 | 
				
			||||||
 | 
					           */
 | 
				
			||||||
 | 
					          endpoint: "sms.tencentcloudapi.com"
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
							
								
								
									
										42
									
								
								messenger.js
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								messenger.js
									
									
									
									
									
								
							@ -1,27 +1,28 @@
 | 
				
			|||||||
const util = require('util')
 | 
					const util = require('util')
 | 
				
			||||||
//const RequestPromise = require('request-promise-native') // request-promise/-native。https://www.npmjs.com/package/request-promise. 还看到一个方法:Bluebird.promisifyAll(require("request"));
 | 
					 | 
				
			||||||
const http = require('http')
 | 
					const http = require('http')
 | 
				
			||||||
const NodeMailer = require('nodemailer') // 或者 const smtpTransporter=require('nodemailer').createTransport({host:'', port:25, auth:{user:'',pass:''}})
 | 
					const NodeMailer = require('nodemailer')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
let smtpTransporter = null
 | 
					const my = {}
 | 
				
			||||||
 | 
					 | 
				
			||||||
let smsClient = null // 在调用时,才创建 smsClient,防止 wo.envi 还没有建立好。
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
module.exports = {
 | 
					module.exports = {
 | 
				
			||||||
 | 
					  init (envi) {
 | 
				
			||||||
  async sendMail (option) {
 | 
					    my.envi = envi
 | 
				
			||||||
    // 或者如果smtp参数已经确定,就可以直接定义 sendMail: Bluebird.promisify(Smtp.sendMail).bind(Smtp)
 | 
					    my.smtpTransporter = NodeMailer.createTransport(envi.SMTP)
 | 
				
			||||||
    smtpTransporter = smtpTransporter || NodeMailer.createTransport(wo.envi.SMTP)
 | 
					    my.smsClient = new (require('@alicloud/sms-sdk'))(envi.SMS.aliyun) // https://www.npmjs.com/package/@alicloud/sms-sdk
 | 
				
			||||||
    return await util.promisify(smtpTransporter.sendMail).call(smtpTransporter, option)
 | 
					 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  async sendSms (phone, { vendor, msg, msgParam, templateCode, signName }={}) {
 | 
					  async sendMail (option) { // 或者如果smtp参数已经确定,就可以直接定义 sendMail: Bluebird.promisify(Smtp.sendMail).bind(Smtp)
 | 
				
			||||||
 | 
					    my.smtpTransporter = my.smtpTransporter || NodeMailer.createTransport(wo.envi.SMTP)
 | 
				
			||||||
 | 
					    return await util.promisify(my.smtpTransporter.sendMail).call(my.smtpTransporter, option)
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  
 | 
				
			||||||
 | 
					  async sendSms ({ phone, vendor, msg, msgParam, msgTemplate, signName }={}) {
 | 
				
			||||||
    // 通过option对象,对外提供统一的调用参数格式
 | 
					    // 通过option对象,对外提供统一的调用参数格式
 | 
				
			||||||
    if (/^\+\d+-\d+$/.test(phone)) {
 | 
					    if (/^\+\d+-\d+$/.test(phone)) {
 | 
				
			||||||
      if (vendor === 'dxton' && msg) {
 | 
					      if (vendor === 'dxton' && msg) {
 | 
				
			||||||
        return await this.sendSmsDxton(phone, msg)
 | 
					        return await this.sendSmsDxton(phone, msg)
 | 
				
			||||||
      } else if (vendor === 'aliyun' && msgParam && templateCode && signName) {
 | 
					      } else if (vendor === 'aliyun' && msgParam && msgTemplate && signName) {
 | 
				
			||||||
        return await this.sendSmsAliyun(phone, msgParam, templateCode, signName)
 | 
					        return await this.sendSmsAliyun(phone, msgParam, msgTemplate, signName)
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    return null // 手机号格式错误,或者 option.vendor 错误。
 | 
					    return null // 手机号格式错误,或者 option.vendor 错误。
 | 
				
			||||||
@ -63,15 +64,8 @@ module.exports = {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  async sendSmsAliyun (phone, msgParam, templateCode, signName) {
 | 
					  async sendSmsAliyun (phone, msgParam, msgTemplate, signName) {
 | 
				
			||||||
    // msgParam 是消息模板参数对象,例如 { code: "890353" }
 | 
					    my.smsClient = my.smsClient || new (require('@alicloud/sms-sdk'))(wo.envi.SMS.aliyun)
 | 
				
			||||||
    smsClient =
 | 
					 | 
				
			||||||
      smsClient ||
 | 
					 | 
				
			||||||
      new (require('@alicloud/sms-sdk'))({
 | 
					 | 
				
			||||||
        // 在调用时,才创建 smsClient,防止 wo.envi 还没有建立好。
 | 
					 | 
				
			||||||
        accessKeyId: wo.envi.SMS.aliyun.accessKeyId,
 | 
					 | 
				
			||||||
        secretAccessKey: wo.envi.SMS.aliyun.secretAccessKey,
 | 
					 | 
				
			||||||
      })
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    var matches = phone.match(/\d+/g)
 | 
					    var matches = phone.match(/\d+/g)
 | 
				
			||||||
    var smsNumber
 | 
					    var smsNumber
 | 
				
			||||||
@ -80,11 +74,11 @@ module.exports = {
 | 
				
			|||||||
    } else {
 | 
					    } else {
 | 
				
			||||||
      smsNumber = '00' + matches[0] + matches[1]
 | 
					      smsNumber = '00' + matches[0] + matches[1]
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    return await smsClient
 | 
					    return await my.smsClient
 | 
				
			||||||
      .sendSMS({
 | 
					      .sendSMS({
 | 
				
			||||||
        PhoneNumbers: smsNumber, //必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式;发送国际/港澳台消息时,接收号码格式为00+国际区号+号码,如“0085200000000”
 | 
					        PhoneNumbers: smsNumber, //必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式;发送国际/港澳台消息时,接收号码格式为00+国际区号+号码,如“0085200000000”
 | 
				
			||||||
        SignName: signName, //必填:短信签名-可在短信控制台中找到
 | 
					        SignName: signName, //必填:短信签名-可在短信控制台中找到
 | 
				
			||||||
        TemplateCode: templateCode, //必填:短信模板-可在短信控制台中找到,发送国际/港澳台消息时,请使用国际/港澳台短信模版
 | 
					        TemplateCode: msgTemplate, //必填:短信模板-可在短信控制台中找到,发送国际/港澳台消息时,请使用国际/港澳台短信模版
 | 
				
			||||||
        TemplateParam: JSON.stringify(msgParam), //可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时。
 | 
					        TemplateParam: JSON.stringify(msgParam), //可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时。
 | 
				
			||||||
      })
 | 
					      })
 | 
				
			||||||
      .then(
 | 
					      .then(
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user