-
-
Notifications
You must be signed in to change notification settings - Fork 446
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
bug: empty strings are removed from connector configuration (prevents use of SMTP relay without user/password) #6754
Comments
Hi @bpow, would you like to let us know which email service are you using? I think the problem you're encountering might be a special case requiring specific handling. If you could tell us which email service it is, we might be able to find a better solution. |
Thanks for looking into this, @darcyYe. The SMTP server involved is institutional email relay-- I'm not sure what specific software it is running, but I'm pretty sure it's RFC-standard SMTP. Just with access controlled by source (e.g., on a VLAN) rather than by credentials. I can say that I am able to send test emails directly using nodemailer with something like the following: let nodemailer = require('nodemailer');
console.log('getting started');
let transporter = nodemailer.createTransport({
host: "relay.test.com",
port: 25,
auth: {
user: "",
pass: "",
},
});
transporter.verify(function (error, success) {
if (error) {
console.log(error);
} else {
console.log("Server is ready for us!");
}
});
const message = {
from: "[email protected]",
to: "[email protected]",
subject: "nodemailer test",
text: "Let's see if this message makes its way through!",
};
transporter.sendMail(message, function(err, info) {
if (err) {
console.log(`err: ${err}`);
}
}); (with the So it works to be able to send messages if However, it also works if I change the If you want to see the unexpected behavior when empty strings are provided for # This compose file is for demonstration only, do not use in prod.
version: "3.9"
services:
app:
depends_on:
postgres:
condition: service_healthy
image: ghcr.io/logto-io/logto:1.21.0
entrypoint: ["sh", "-c", "npm run cli db seed -- --swe && npm start"]
ports:
- 3001:3001
- 3002:3002
environment:
- TRUST_PROXY_HEADER=1
- DB_URL=postgres://postgres:changeme@postgres:5432/logto
# Mandatory for GitPod to map host env to the container, thus GitPod can dynamically configure the public URL of Logto;
# Or, you can leverage it for local testing.
- ENDPOINT
- ADMIN_ENDPOINT
postgres:
image: postgres:14-alpine
user: postgres
environment:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: changeme
healthcheck:
test: ["CMD-SHELL", "pg_isready"]
interval: 10s
timeout: 5s
retries: 5
mailpit:
image: 'axllent/mailpit:latest'
expose:
- '${FORWARD_MAILPIT_PORT:-1025}:1025'
ports:
- '${FORWARD_MAILPIT_DASHBOARD_PORT:-8025}:8025' It's not a perfect example since mailpit in this configuration will accept any user/pass combination, but it will accept empty strings. To show the behavior using this setup:
I hope this outlines things clearly enough. I can make a short screen recording if you think that would help. But TL;DR, could we maybe just make the |
Describe the bug
Trying to set up a SMTP relay with the SMTP connector that doesn't require user/password does not work because the api endpoint removes JSON key/value pairs from the
auth
parameter.Expected behavior
It should be possible to provide
auth
parameter like the following:And to have this configuration passed along to nodemailer.
How to reproduce?
Auth
text input for the SMTP connector.Auth
box will change to just have"type": "login"
.It looks like this happens because of the call to
cleanDeep
inpackages/core/src/routes/connector/index.ts
, which includes theconfig
object.This also leads to weird behavior where if you have a relay that doesn't require user/pass, then when you first put the full info in the
Auth
input block, you can successfully "send" to test the email connector, but after it is saved and the user/pass items are removed, the connector won't work and send/test won't work anymore.Context
Screenshots
The text was updated successfully, but these errors were encountered: