fix(deploy): don't let docker compose build require runtime JWT_KEY
docker compose build interpolates the whole file, so the ${JWT_KEY:?} guard
failed the build step when ENV_FILE lacked JWT_KEY. Default it empty (${JWT_KEY:-})
so build/db steps succeed, and enforce the secret at runtime instead: the server
throws on boot in Production if Jwt:Key is missing/dev/<32 chars.
Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
@@ -15,9 +15,14 @@ using Microsoft.IdentityModel.Tokens;
|
||||
var builder = WebApplication.CreateBuilder(args);
|
||||
|
||||
// --- options ---
|
||||
const string DevJwtKey = "dev-only-insecure-key-change-me-please-32+bytes!!";
|
||||
var jwt = builder.Configuration.GetSection("Jwt").Get<JwtOptions>() ?? new JwtOptions();
|
||||
if (string.IsNullOrWhiteSpace(jwt.Key))
|
||||
jwt.Key = "dev-only-insecure-key-change-me-please-32+bytes!!";
|
||||
jwt.Key = DevJwtKey;
|
||||
// In Production a real secret is mandatory — refuse to boot with the dev key.
|
||||
if (builder.Environment.IsProduction() && (jwt.Key == DevJwtKey || jwt.Key.Length < 32))
|
||||
throw new InvalidOperationException(
|
||||
"Jwt:Key (env JWT_KEY) must be a 32+ char secret in Production. Set it in ENV_FILE: openssl rand -hex 32");
|
||||
builder.Services.AddSingleton(jwt);
|
||||
builder.Services.AddSingleton<TokenService>();
|
||||
builder.Services.AddSingleton<GameManager>();
|
||||
|
||||
Reference in New Issue
Block a user