'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); const path = require('node:path'); const node_fs = require('node:fs'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e["default"] : e; } const path__default = /*#__PURE__*/_interopDefaultLegacy(path); const defaultCacheDir = "node_modules/.vite"; function viteBasicSslPlugin(options) { return { name: "vite:basic-ssl", async configResolved(config) { const certificate = await getCertificate(options?.certDir ?? (config.cacheDir ?? defaultCacheDir) + "/basic-ssl", options?.name, options?.domains); const https = () => ({ cert: certificate, key: certificate }); if (config.server.https === void 0 || !!config.server.https) { config.server.https = Object.assign({}, config.server.https, https()); } if (config.preview.https === void 0 || !!config.preview.https) { config.preview.https = Object.assign({}, config.preview.https, https()); } } }; } async function getCertificate(cacheDir, name, domains) { const cachePath = path__default.join(cacheDir, "_cert.pem"); try { const [stat, content] = await Promise.all([ node_fs.promises.stat(cachePath), node_fs.promises.readFile(cachePath, "utf8") ]); if (Date.now() - stat.ctime.valueOf() > 30 * 24 * 60 * 60 * 1e3) { throw new Error("cache is outdated."); } return content; } catch { const content = (await import('./chunks/certificate.cjs')).createCertificate(name, domains); node_fs.promises.mkdir(cacheDir, { recursive: true }).then(() => node_fs.promises.writeFile(cachePath, content)).catch(() => { }); return content; } } module.exports = viteBasicSslPlugin; module.exports["default"] = viteBasicSslPlugin; module.exports.getCertificate = getCertificate;