@editframe/vite-plugin 0.45.3 → 0.45.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +16 -0
- package/dist/index.js +11 -0
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.d.ts
CHANGED
|
@@ -7,6 +7,22 @@ interface VitePluginEditframeOptions {
|
|
|
7
7
|
}
|
|
8
8
|
declare const vitePluginEditframe: (options: VitePluginEditframeOptions) => {
|
|
9
9
|
name: string;
|
|
10
|
+
config(this: vite0.ConfigPluginContext, _config: unknown, {
|
|
11
|
+
command
|
|
12
|
+
}: {
|
|
13
|
+
command: string;
|
|
14
|
+
}): {
|
|
15
|
+
define: {
|
|
16
|
+
__EF_DEFAULT_API_HOST__: string;
|
|
17
|
+
__EF_TELEMETRY_ENABLED__: string;
|
|
18
|
+
};
|
|
19
|
+
} | undefined;
|
|
20
|
+
configResolved(this: vite0.MinimalPluginContextWithoutEnvironment, resolvedConfig: {
|
|
21
|
+
define?: Record<string, string>;
|
|
22
|
+
server?: {
|
|
23
|
+
port?: number;
|
|
24
|
+
};
|
|
25
|
+
}): void;
|
|
10
26
|
configureServer(this: vite0.MinimalPluginContextWithoutEnvironment, server: vite0.ViteDevServer): void;
|
|
11
27
|
};
|
|
12
28
|
//#endregion
|
package/dist/index.js
CHANGED
|
@@ -15,6 +15,17 @@ const getEditframeClient = () => {
|
|
|
15
15
|
const vitePluginEditframe = (options) => {
|
|
16
16
|
return {
|
|
17
17
|
name: "vite-plugin-editframe",
|
|
18
|
+
config(_config, { command }) {
|
|
19
|
+
if (command === "serve") return { define: {
|
|
20
|
+
__EF_DEFAULT_API_HOST__: JSON.stringify("http://localhost:5173"),
|
|
21
|
+
__EF_TELEMETRY_ENABLED__: JSON.stringify(!process.env.EF_NO_TELEMETRY)
|
|
22
|
+
} };
|
|
23
|
+
},
|
|
24
|
+
configResolved(resolvedConfig) {
|
|
25
|
+
const port = resolvedConfig.server?.port ?? 5173;
|
|
26
|
+
resolvedConfig.define ??= {};
|
|
27
|
+
resolvedConfig.define["__EF_DEFAULT_API_HOST__"] = JSON.stringify(`http://localhost:${port}`);
|
|
28
|
+
},
|
|
18
29
|
configureServer(server) {
|
|
19
30
|
server.middlewares.use(createJitTranscodeMiddleware({
|
|
20
31
|
...options,
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["import { Client, createURLToken } from \"@editframe/api\";\nimport {\n cacheImage,\n findOrCreateCaptions,\n generateTrack,\n generateScrubTrack,\n generateTrackFragmentIndex,\n md5FilePath,\n} from \"@editframe/assets\";\nimport debug from \"debug\";\nimport type { Plugin } from \"vite\";\n\nimport { createJitTranscodeMiddleware } from \"./jitTranscodeMiddleware.js\";\nimport {\n createAssetsApiMiddleware,\n createLocalFilesApiMiddleware,\n handleClearCache,\n} from \"./middleware.js\";\nimport { forbidRelativePaths } from \"./forbidRelativePaths.js\";\n\ninterface VitePluginEditframeOptions {\n root: string;\n cacheRoot: string;\n}\n\nconst getEditframeClient = () => {\n const token = process.env.EF_TOKEN;\n const efHost = process.env.EF_HOST;\n if (!token) {\n throw new Error(\"EF_TOKEN environment variable must be set\");\n }\n return new Client(token, efHost);\n};\n\nexport const vitePluginEditframe = (options: VitePluginEditframeOptions) => {\n return {\n name: \"vite-plugin-editframe\",\n\n configureServer(server) {\n server.middlewares.use(\n createJitTranscodeMiddleware(\n { ...options, handleRemoteUrls: true },\n { generateTrack, generateScrubTrack, generateTrackFragmentIndex },\n ),\n );\n\n server.middlewares.use(\n createAssetsApiMiddleware(options, {\n cacheImage,\n findOrCreateCaptions,\n }),\n );\n\n server.middlewares.use(\n createLocalFilesApiMiddleware(options, {\n generateTrack,\n generateScrubTrack,\n generateTrackFragmentIndex,\n md5FilePath,\n }),\n );\n\n server.middlewares.use(async (req, res, next) => {\n const log = debug(\"ef:vite-plugin\");\n if (req.url?.startsWith(\"/@ef\")) {\n forbidRelativePaths(req);\n } else {\n return next();\n }\n\n log(`Handling ${req.url} at ${new Date().toISOString()}`);\n\n const cacheRoot = options.cacheRoot.replace(\"dist/\", \"src/\");\n const efPrefix = req.url.split(\"/\")[1];\n\n switch (efPrefix) {\n case \"@ef-clear-cache\": {\n await handleClearCache(req, res, cacheRoot);\n break;\n }\n case \"@ef-sign-url\": {\n if (req.method !== \"POST\") {\n res.writeHead(405, { Allow: \"POST\" });\n res.end();\n break;\n }\n\n log(\"Signing URL token\");\n\n let body = \"\";\n req.on(\"data\", (chunk) => {\n body += chunk.toString();\n });\n\n req.on(\"end\", async () => {\n try {\n const payload = JSON.parse(body);\n log(\"Token signing request payload:\", payload);\n\n const { url, params } = payload;\n if (!url) {\n res.writeHead(400, { \"Content-Type\": \"application/json\" });\n res.end(JSON.stringify({ error: \"URL is required\" }));\n return;\n }\n\n const client = getEditframeClient();\n\n let fullUrl = url;\n if (params) {\n const urlObj = new URL(url);\n Object.entries(params).forEach(([key, value]) => {\n urlObj.searchParams.set(key, String(value));\n });\n fullUrl = urlObj.toString();\n }\n\n log(\"Creating token for full URL:\", fullUrl);\n const token = await createURLToken(client, fullUrl);\n\n res.writeHead(200, { \"Content-Type\": \"application/json\" });\n res.end(JSON.stringify({ token }));\n } catch (error) {\n log(`Error signing URL token: ${error}`);\n res.writeHead(500, { \"Content-Type\": \"application/json\" });\n res.end(JSON.stringify({ error: \"Failed to sign URL token\" }));\n }\n });\n\n break;\n }\n default:\n log(`Unknown asset type ${efPrefix}`);\n break;\n }\n });\n },\n } satisfies Plugin;\n};\n"],"mappings":";;;;;;;;AAyBA,MAAM,2BAA2B;CAC/B,MAAM,QAAQ,QAAQ,IAAI;CAC1B,MAAM,SAAS,QAAQ,IAAI;AAC3B,KAAI,CAAC,MACH,OAAM,IAAI,MAAM,4CAA4C;AAE9D,QAAO,IAAI,OAAO,OAAO,OAAO;;AAGlC,MAAa,uBAAuB,YAAwC;AAC1E,QAAO;EACL,MAAM;EAEN,gBAAgB,QAAQ;AACtB,UAAO,YAAY,IACjB,6BACE;IAAE,GAAG;IAAS,kBAAkB;IAAM,EACtC;IAAE;IAAe;IAAoB;IAA4B,CAClE,CACF;AAED,UAAO,YAAY,IACjB,0BAA0B,SAAS;IACjC;IACA;IACD,CAAC,CACH;AAED,UAAO,YAAY,IACjB,8BAA8B,SAAS;IACrC;IACA;IACA;IACA;IACD,CAAC,CACH;AAED,UAAO,YAAY,IAAI,OAAO,KAAK,KAAK,SAAS;IAC/C,MAAM,MAAM,MAAM,iBAAiB;AACnC,QAAI,IAAI,KAAK,WAAW,OAAO,CAC7B,qBAAoB,IAAI;QAExB,QAAO,MAAM;AAGf,QAAI,YAAY,IAAI,IAAI,uBAAM,IAAI,MAAM,EAAC,aAAa,GAAG;IAEzD,MAAM,YAAY,QAAQ,UAAU,QAAQ,SAAS,OAAO;IAC5D,MAAM,WAAW,IAAI,IAAI,MAAM,IAAI,CAAC;AAEpC,YAAQ,UAAR;KACE,KAAK;AACH,YAAM,iBAAiB,KAAK,KAAK,UAAU;AAC3C;KAEF,KAAK,gBAAgB;AACnB,UAAI,IAAI,WAAW,QAAQ;AACzB,WAAI,UAAU,KAAK,EAAE,OAAO,QAAQ,CAAC;AACrC,WAAI,KAAK;AACT;;AAGF,UAAI,oBAAoB;MAExB,IAAI,OAAO;AACX,UAAI,GAAG,SAAS,UAAU;AACxB,eAAQ,MAAM,UAAU;QACxB;AAEF,UAAI,GAAG,OAAO,YAAY;AACxB,WAAI;QACF,MAAM,UAAU,KAAK,MAAM,KAAK;AAChC,YAAI,kCAAkC,QAAQ;QAE9C,MAAM,EAAE,KAAK,WAAW;AACxB,YAAI,CAAC,KAAK;AACR,aAAI,UAAU,KAAK,EAAE,gBAAgB,oBAAoB,CAAC;AAC1D,aAAI,IAAI,KAAK,UAAU,EAAE,OAAO,mBAAmB,CAAC,CAAC;AACrD;;QAGF,MAAM,SAAS,oBAAoB;QAEnC,IAAI,UAAU;AACd,YAAI,QAAQ;SACV,MAAM,SAAS,IAAI,IAAI,IAAI;AAC3B,gBAAO,QAAQ,OAAO,CAAC,SAAS,CAAC,KAAK,WAAW;AAC/C,iBAAO,aAAa,IAAI,KAAK,OAAO,MAAM,CAAC;WAC3C;AACF,mBAAU,OAAO,UAAU;;AAG7B,YAAI,gCAAgC,QAAQ;QAC5C,MAAM,QAAQ,MAAM,eAAe,QAAQ,QAAQ;AAEnD,YAAI,UAAU,KAAK,EAAE,gBAAgB,oBAAoB,CAAC;AAC1D,YAAI,IAAI,KAAK,UAAU,EAAE,OAAO,CAAC,CAAC;gBAC3B,OAAO;AACd,YAAI,4BAA4B,QAAQ;AACxC,YAAI,UAAU,KAAK,EAAE,gBAAgB,oBAAoB,CAAC;AAC1D,YAAI,IAAI,KAAK,UAAU,EAAE,OAAO,4BAA4B,CAAC,CAAC;;QAEhE;AAEF;;KAEF;AACE,UAAI,sBAAsB,WAAW;AACrC;;KAEJ;;EAEL"}
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["import { Client, createURLToken } from \"@editframe/api\";\nimport {\n cacheImage,\n findOrCreateCaptions,\n generateTrack,\n generateScrubTrack,\n generateTrackFragmentIndex,\n md5FilePath,\n} from \"@editframe/assets\";\nimport debug from \"debug\";\nimport type { Plugin } from \"vite\";\n\nimport { createJitTranscodeMiddleware } from \"./jitTranscodeMiddleware.js\";\nimport {\n createAssetsApiMiddleware,\n createLocalFilesApiMiddleware,\n handleClearCache,\n} from \"./middleware.js\";\nimport { forbidRelativePaths } from \"./forbidRelativePaths.js\";\n\ninterface VitePluginEditframeOptions {\n root: string;\n cacheRoot: string;\n}\n\nconst getEditframeClient = () => {\n const token = process.env.EF_TOKEN;\n const efHost = process.env.EF_HOST;\n if (!token) {\n throw new Error(\"EF_TOKEN environment variable must be set\");\n }\n return new Client(token, efHost);\n};\n\nexport const vitePluginEditframe = (options: VitePluginEditframeOptions) => {\n return {\n name: \"vite-plugin-editframe\",\n\n config(_config: unknown, { command }: { command: string }) {\n if (command === \"serve\") {\n return {\n define: {\n __EF_DEFAULT_API_HOST__: JSON.stringify(\"http://localhost:5173\"),\n __EF_TELEMETRY_ENABLED__: JSON.stringify(!process.env.EF_NO_TELEMETRY),\n },\n };\n }\n },\n\n configResolved(resolvedConfig: {\n define?: Record<string, string>;\n server?: { port?: number };\n }) {\n const port = resolvedConfig.server?.port ?? 5173;\n resolvedConfig.define ??= {};\n resolvedConfig.define[\"__EF_DEFAULT_API_HOST__\"] = JSON.stringify(`http://localhost:${port}`);\n },\n\n configureServer(server) {\n server.middlewares.use(\n createJitTranscodeMiddleware(\n { ...options, handleRemoteUrls: true },\n { generateTrack, generateScrubTrack, generateTrackFragmentIndex },\n ),\n );\n\n server.middlewares.use(\n createAssetsApiMiddleware(options, {\n cacheImage,\n findOrCreateCaptions,\n }),\n );\n\n server.middlewares.use(\n createLocalFilesApiMiddleware(options, {\n generateTrack,\n generateScrubTrack,\n generateTrackFragmentIndex,\n md5FilePath,\n }),\n );\n\n server.middlewares.use(async (req, res, next) => {\n const log = debug(\"ef:vite-plugin\");\n if (req.url?.startsWith(\"/@ef\")) {\n forbidRelativePaths(req);\n } else {\n return next();\n }\n\n log(`Handling ${req.url} at ${new Date().toISOString()}`);\n\n const cacheRoot = options.cacheRoot.replace(\"dist/\", \"src/\");\n const efPrefix = req.url.split(\"/\")[1];\n\n switch (efPrefix) {\n case \"@ef-clear-cache\": {\n await handleClearCache(req, res, cacheRoot);\n break;\n }\n case \"@ef-sign-url\": {\n if (req.method !== \"POST\") {\n res.writeHead(405, { Allow: \"POST\" });\n res.end();\n break;\n }\n\n log(\"Signing URL token\");\n\n let body = \"\";\n req.on(\"data\", (chunk) => {\n body += chunk.toString();\n });\n\n req.on(\"end\", async () => {\n try {\n const payload = JSON.parse(body);\n log(\"Token signing request payload:\", payload);\n\n const { url, params } = payload;\n if (!url) {\n res.writeHead(400, { \"Content-Type\": \"application/json\" });\n res.end(JSON.stringify({ error: \"URL is required\" }));\n return;\n }\n\n const client = getEditframeClient();\n\n let fullUrl = url;\n if (params) {\n const urlObj = new URL(url);\n Object.entries(params).forEach(([key, value]) => {\n urlObj.searchParams.set(key, String(value));\n });\n fullUrl = urlObj.toString();\n }\n\n log(\"Creating token for full URL:\", fullUrl);\n const token = await createURLToken(client, fullUrl);\n\n res.writeHead(200, { \"Content-Type\": \"application/json\" });\n res.end(JSON.stringify({ token }));\n } catch (error) {\n log(`Error signing URL token: ${error}`);\n res.writeHead(500, { \"Content-Type\": \"application/json\" });\n res.end(JSON.stringify({ error: \"Failed to sign URL token\" }));\n }\n });\n\n break;\n }\n default:\n log(`Unknown asset type ${efPrefix}`);\n break;\n }\n });\n },\n } satisfies Plugin;\n};\n"],"mappings":"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"}
|