mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2025-02-23 12:37:25 +00:00
* Changes to DE preview site to support managed identity. Changes to infrastructure to use new preview site. * Fix formatting. * Potential fix for code scanning alert no. 56: Server-side request forgery Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com> * Use different secrets for subscription/tenant/client id's. * Revert new id names. * Update Az CLI config. * Update to Node 18 and update security vulnerable dependencies. --------- Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com>
88 lines
2.6 KiB
JavaScript
88 lines
2.6 KiB
JavaScript
const express = require("express");
|
|
const { createProxyMiddleware } = require("http-proxy-middleware");
|
|
const port = process.env.PORT || 3000;
|
|
const fetch = require("node-fetch");
|
|
|
|
const backendEndpoint = "https://cdb-ms-mpac-pbe.cosmos.azure.com";
|
|
const previewSiteEndpoint = "https://dataexplorer-preview.azurewebsites.net";
|
|
const previewStorageWebsiteEndpoint = "https://dataexplorerpreview.z5.web.core.windows.net/";
|
|
const githubApiUrl = "https://api.github.com/repos/Azure/cosmos-explorer";
|
|
const githubPullRequestUrl = "https://github.com/Azure/cosmos-explorer/pull";
|
|
const azurePortalMpacEndpoint = "https://ms.portal.azure.com/";
|
|
|
|
const api = createProxyMiddleware({
|
|
target: backendEndpoint,
|
|
changeOrigin: true,
|
|
logLevel: "debug",
|
|
bypass: (req, res) => {
|
|
if (req.method === "OPTIONS") {
|
|
res.statusCode = 200;
|
|
res.send();
|
|
}
|
|
},
|
|
});
|
|
|
|
const proxy = createProxyMiddleware({
|
|
target: backendEndpoint,
|
|
changeOrigin: true,
|
|
secure: false,
|
|
logLevel: "debug",
|
|
pathRewrite: { "^/proxy": "" },
|
|
router: (req) => {
|
|
let newTarget = req.headers["x-ms-proxy-target"];
|
|
return newTarget;
|
|
},
|
|
});
|
|
|
|
const commit = createProxyMiddleware({
|
|
target: previewStorageWebsiteEndpoint,
|
|
changeOrigin: true,
|
|
secure: false,
|
|
logLevel: "debug",
|
|
pathRewrite: { "^/commit": "/" },
|
|
});
|
|
|
|
const app = express();
|
|
|
|
app.use("/api", api);
|
|
app.use("/proxy", proxy);
|
|
app.use("/commit", commit);
|
|
app.get("/pull/:pr(\\d+)", (req, res) => {
|
|
const pr = req.params.pr;
|
|
if (!/^\d+$/.test(pr)) {
|
|
return res.status(400).send("Invalid pull request number");
|
|
}
|
|
const [, query] = req.originalUrl.split("?");
|
|
const search = new URLSearchParams(query);
|
|
|
|
fetch(`${githubApiUrl}/pulls/${pr}`)
|
|
.then((response) => response.json())
|
|
.then(({ head: { ref, sha } }) => {
|
|
const prUrl = new URL(`${githubPullRequestUrl}/${pr}`);
|
|
prUrl.hash = ref;
|
|
search.set("feature.pr", prUrl.href);
|
|
|
|
const explorer = new URL(`${previewSiteEndpoint}/commit/${sha}/explorer.html`);
|
|
explorer.search = search.toString();
|
|
|
|
const portal = new URL(azurePortalMpacEndpoint);
|
|
portal.searchParams.set("dataExplorerSource", explorer.href);
|
|
|
|
return res.redirect(portal.href);
|
|
})
|
|
.catch(() => res.sendStatus(500));
|
|
});
|
|
app.get("/", (req, res) => {
|
|
fetch(`${githubApiUrl}/branches/master`)
|
|
.then((response) => response.json())
|
|
.then(({ commit: { sha } }) => {
|
|
const explorer = new URL(`${previewSiteEndpoint}/commit/${sha}/hostedExplorer.html`);
|
|
return res.redirect(explorer.href);
|
|
})
|
|
.catch(() => res.sendStatus(500));
|
|
});
|
|
|
|
app.listen(port, () => {
|
|
console.log(`Example app listening on port: ${port}`);
|
|
});
|