Files
office_translator/docker/frontend/server.js
Sepehr Ramezani 2f7347b4db
Some checks failed
Build and Deploy / Backend Tests (push) Has been cancelled
Build and Deploy / Frontend Build Check (push) Has been cancelled
Build and Deploy / Build Docker Images (push) Has been cancelled
Build and Deploy / Deploy to Server (push) Has been cancelled
feat: fix registration 500, add forgot-password flow, frontend validation
- Fix MissingGreenlet: sync_engine now uses psycopg2 instead of asyncpg
- Fix bcrypt/passlib compat: pin bcrypt<4.1 in requirements
- Fix legacy password_hash NOT NULL: alter column to nullable in migration
- Add frontend password validation (uppercase + lowercase + digit)
- Add forgot-password and reset-password backend endpoints
- Add forgot-password and reset-password frontend pages
- Add email_service.py (SMTP via admin settings)
- Add reset_token/reset_token_expires columns to User model
- Migrate legacy JSON-only users to DB on password reset request
- Mount data/ volume in docker-compose.local.yml for persistence
- Add production deployment config (Dockerfile, nginx, deploy.sh)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-05-01 16:23:51 +02:00

67 lines
2.0 KiB
JavaScript

/**
* Custom Next.js standalone server.
* Proxies /api/* requests to BACKEND_URL (resolved at RUNTIME, not build time).
* This is needed because next.config.ts rewrites are baked in at build time.
*/
const { createServer } = require("http");
const { parse } = require("url");
const next = require("next");
const port = parseInt(process.env.PORT || "3000", 10);
const hostname = process.env.HOSTNAME || "0.0.0.0";
const dev = process.env.NODE_ENV !== "production";
const backendUrl = (process.env.BACKEND_URL || "http://127.0.0.1:8000").replace(/\/$/, "");
const app = next({ dev, hostname, port });
const handle = app.getRequestHandler();
app.prepare().then(() => {
createServer(async (req, res) => {
try {
const parsedUrl = parse(req.url, true);
const { pathname } = parsedUrl;
// Proxy /api/* to backend
if (pathname.startsWith("/api/")) {
const http = require("http");
const targetUrl = new URL(req.url, backendUrl);
const proxyReq = http.request(
targetUrl,
{
method: req.method,
headers: {
...req.headers,
host: targetUrl.host,
},
},
(proxyRes) => {
res.writeHead(proxyRes.statusCode, proxyRes.headers);
proxyRes.pipe(res, { end: true });
}
);
proxyReq.on("error", (err) => {
console.error(`Proxy error for ${req.url}:`, err.message);
res.writeHead(502);
res.end("Bad Gateway");
});
req.pipe(proxyReq, { end: true });
return;
}
// All other requests -> Next.js
await handle(req, res, parsedUrl);
} catch (err) {
console.error("Error occurred handling", req.url, err);
res.writeHead(500);
res.end("internal server error");
}
}).listen(port, hostname, () => {
console.log(`> Ready on http://${hostname}:${port}`);
console.log(`> API proxy: ${backendUrl}`);
});
});