I have a Linux web app deployed as code
data:image/s3,"s3://crabby-images/f6fb9/f6fb910d2d05c3b4d3e89c40f3a6084c1a2c7738" alt="User's image"
I used to define connection string with the name of the database. The one in use is with dash: myjax-integration
. That connection string consistently returned as empty from configuration manager.
So after figuring the root cause (several hours of pain) I found that the problem is about dash in the name. At the same time, I have another Windows-based web app, where dash works just fine.
And it works on the local computer (Windows). The problem only happens on the cloud.
I created 2 connection strings for testing:
data:image/s3,"s3://crabby-images/4b3c0/4b3c00aed3bcd72c36d6c1a8132e7cbae7f74cb5" alt="User's image"
And log them on startup.
var builder = WebApplication.CreateBuilder(args);
builder.Configuration.AddEnvironmentVariables();
.....
var app = builder.Build();
var logger = app.Services.GetRequiredService<ILogger<object>>();
logger.LogInformation($"connection string myjax-integration:[{builder.Configuration.GetConnectionString("myjax-integration")}]");
logger.LogInformation($"connection string myjax_integration:[{builder.Configuration.GetConnectionString("myjax_integration")}]");
And the one with the dash is consistently empty. data:image/s3,"s3://crabby-images/58e62/58e62809a906477b3abd501ecf5c5123d3a1e983" alt="User's image"
I've tried changing the connection name to something else, but as long as there is a dash in it, that name doesn't return the connection string.
As far as I could find, this is nowhere documented. Is it a feature or a bug? If the latter, where is a good place to lodge a bug report?