Meteor 帐户在 Email.send 有效时使用 gmail 失败,为什么?

Meteor accounts failing with gmail while Email.send works, why?

我们有一个准备部署的 Meteor 应用程序,我们终于要将它连接到 gmail 帐户以发送电子邮件。电子邮件配置设置为

Meteor.startup(function () {
  smtp = {
  username: 'noreply@cloaklabs.com',
  password: 'abcdabcdabcdabcd', // masked - a gmail application-specific 16 character password to use for two-factor auth
  server:   'smtp.gmail.com',
  port: 587 // also tried 465 to no avail
  };
  process.env.MAIL_URL = 'smtp://' + encodeURIComponent(smtp.username) + ':' + encodeURIComponent(smtp.password) + '@' + encodeURIComponent(smtp.server) + ':' + smtp.port;
});

当应用程序直接调用 Email.send(...) 时,电子邮件发送成功。

但是当我们这样做时:

Accounts.createUser({email: email, password: password, profile: profile},function(err){...})

我们在服务器日志中得到以下回溯:

Exception while invoking method 'createUser' SenderError: Mail from command failed - 555 5.5.2 Syntax error. ba12sm12306756pac.23 - gsmtp
at Object.Future.wait (/Users/Michel/.meteor/packages/meteor-tool/.1.0.40.1wbeh3b++os.osx.x86_64+web.browser+web.cordova/meteor-tool-os.osx.x86_64/dev_bundle/server-lib/node_modules/fibers/future.js:326:15)
at smtpSend (packages/email/email.js:91:1)
at Object.Email.send (packages/email/email.js:168:1)
at Object.Accounts.sendVerificationEmail (packages/accounts-password/password_server.js:602:1)
at Meteor.methods.createUser (packages/accounts-password/password_server.js:723:1)
at tryLoginMethod (packages/accounts-base/accounts_server.js:186:1)
at Object.Accounts._loginMethod (packages/accounts-base/accounts_server.js:302:1)
at [object Object].Meteor.methods.createUser (packages/accounts-password/password_server.js:699:1)
... traceback truncated

这感觉像是一个错误。关于 SO 的相关问题与我最接近的是 555 5.5.2 Syntax error. gmail's smtp 那里的建议是使用

"name <emailAddress>"

而不是仅 "emailAddress" 作为收件人的地址,但是没有办法通过 Accounts.createUser() 推送此语法,并且在任何情况下 Email.send() 都可以正常工作。

嗯,这很愚蠢:结果只是 Accounts.emailTemplates.from 上的一个散乱的 > 字符。必须使用节点检查器调试 Meteor 的 email.js 才能最终找到它,但它现在可以正常工作了。