Banging my head against the wall with Mailer on production

I've had a mailer working fine in my NodeJS app on both production and developement servers. Now it suddenly gives me this error on production, but still works fine on the developement server. They both use the same mailer with the same settings yet the error says the settings are incorrect on production. It's hosted on Orangehost and again, it was working fine before.

    "status": "500",
    "code": "EAUTH",
    "message": "Invalid login: 535 Incorrect authentication data",
    "stack": "Error: Invalid login: 535 Incorrect authentication data\n    at SMTPConnection._formatError (/home/r4xdes/nodevenv/r4xdesignsnodejs/18/lib/node_modules/nodemailer/lib/smtp-connection/index.js:807:19)\n    at SMTPConnection._actionAUTHComplete (/home/r4xdes/nodevenv/r4xdesignsnodejs/18/lib/node_modules/nodemailer/lib/smtp-connection/index.js:1586:34)\n    at SMTPConnection.<anonymous> (/home/r4xdes/nodevenv/r4xdesignsnodejs/18/lib/node_modules/nodemailer/lib/smtp-connection/index.js:554:26)\n    at SMTPConnection._processResponse (/home/r4xdes/nodevenv/r4xdesignsnodejs/18/lib/node_modules/nodemailer/lib/smtp-connection/index.js:991:20)\n    at SMTPConnection._onData (/home/r4xdes/nodevenv/r4xdesignsnodejs/18/lib/node_modules/nodemailer/lib/smtp-connection/index.js:772:14)\n    at SMTPConnection._onSocketData (/home/r4xdes/nodevenv/r4xdesignsnodejs/18/lib/node_modules/nodemailer/lib/smtp-connection/index.js:195:44)\n    at TLSSocket.emit (node:events:517:28)\n    at addChunk (node:internal/streams/readable:368:12)\n    at readableAddChunk (node:internal/streams/readable:341:9)\n    at Readable.push (node:internal/streams/readable:278:10)"

Just did a complete redo of the site by creating a new node js app and uploading everything fresh, ran npm install, still giving that error...... :tired_face:

chatGPT response:

The error message indicates that the SMTP server rejected the authentication credentials, which is likely due to incorrect username or password, or due to specific security settings of the email provider. Here are some steps to troubleshoot this issue:

  1. Verify Credentials: Double-check the email and password you’re using in the SMTP configuration. If using environment variables, ensure they’re correctly set.

  2. Enable Less Secure App Access: If you’re using Gmail or similar email providers, check if the “Allow less secure app access” setting is enabled in your email account’s security settings. This setting is often required for third-party applications to connect.

  3. Enable Two-Factor Authentication: If two-factor authentication (2FA) is enabled on the email account, you might need to create an "app-specific password" instead of using the usual account password.

  4. Use the Correct Port and Encryption: Verify that the SMTP settings (such as port, secure flag, and host) match the email provider's recommendations. Common ports are 587 (for TLS) and 465 (for SSL).

  5. Check IP or Firewall Restrictions: Some providers block certain IP addresses or may have restrictions if too many failed login attempts were made. Consider reaching out to your provider’s support if these steps don’t resolve the issue.

If you’re still having trouble, sharing the relevant part of your SMTP configuration code (excluding sensitive information) could help diagnose the problem further.

1 Like

I don't know if it's a node issue or not as I don't use Node (yet). But I find I always have better luck with the mailer if I have it set to 'Server Default' rather than 'SMTP'.

Yes, but the same exact credentials work fine on my development server, email goes out no problem, but when I upload everything to the production server, I get that error. That's what's so frustrating.

Who is your SMTP provider?

Right now I'm using gmail smtp, been working fine on both servers until this morning. I've tried several others as well.

Strange. Could you try creating a second mailer with a different name (e.g. mail2) and replace any references in your workflows to the second mailer?

Yea I may try something like that. Right now, I'm trying to rewrite the app to allow guest checkout cause it's my wife's craft website and she has a market tomorrow where she will be showcasing the site. Isn't that always the case, major bug right when you don't need it.....sigh

Thanks for all the replies so far guys. Much appreciated. Stressing over here.

This is the way!

Interesting .... you may have come across something. I also host with Orangehost and my PHP site mails no problem. However I set up a test on my Node project and get 500 errors using the same settings.

It's weird that it just started though. I have access to another node compatible server with a client of mine. I may upload it there and test when I get a chance. Right now, too much of a time crunch.

What version of Node did you use on orange host? I'm using 18.20.4

When you say development server, you mean http://localhost?

Yes localhost using docker. Unfortunately, I'd had no luck with Orangehost support when it comes to node. They say they just support wordpress.

Create a new Gmail App Password and change the mailer settings in the Production target and deploy again

If it doesn't work, try again with Wappler 6 (non-beta)

Sorry if I'm wrong
I think there's another password you can generate in order to send mails under smtp:

In spanish, but kind of easy to follow:

Again, sorry if this is not the case..

Same

I have a new app password and that works on local/development server. But no luck with it on production orangehost. I was using binding for the host, port, username and password so I just hardcoded them on production and still same error. Urgh. really apprecate the helps guys, thanks so much.

Sorry @baub didn't see that, but practically the same.

Maybe you need to configure something on the google cloud console? :thinking:

It's a regular gmail account or a suite one?
Maybe I can do some test on digital ocean and check what is happening..