securityos/node_modules/next/dist/telemetry/detached-flush.js

49 lines
1.6 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
const _path = /*#__PURE__*/ _interop_require_default(require("path"));
const _storage = require("./storage");
const _config = /*#__PURE__*/ _interop_require_default(require("../server/config"));
const _getprojectdir = require("../lib/get-project-dir");
const _constants = require("../shared/lib/constants");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
(async ()=>{
const args = [
...process.argv
];
let dir = args.pop();
const mode = args.pop();
if (!dir || mode !== "dev") {
throw new Error(`Invalid flags should be run as node detached-flush dev ./path-to/project`);
}
dir = (0, _getprojectdir.getProjectDir)(dir);
const config = await (0, _config.default)(_constants.PHASE_DEVELOPMENT_SERVER, dir);
const distDir = _path.default.join(dir, config.distDir || ".next");
const eventsPath = _path.default.join(distDir, "_events.json");
let events;
try {
events = JSON.parse(_fs.default.readFileSync(eventsPath, "utf8"));
} catch (err) {
if (err.code === "ENOENT") {
// no events to process we can exit now
process.exit(0);
}
throw err;
}
const telemetry = new _storage.Telemetry({
distDir
});
await telemetry.record(events);
await telemetry.flush();
// finished flushing events clean-up/exit
_fs.default.unlinkSync(eventsPath);
process.exit(0);
})();
//# sourceMappingURL=detached-flush.js.map