@any-listen/extension-kit 0.1.0 → 0.1.1

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/README.md CHANGED
@@ -46,7 +46,7 @@ const config: ExtensionConfig = {
46
46
  author: 'Your Name',
47
47
  homepage: 'https://example.com',
48
48
  license: 'MIT',
49
- target_engine: 'any-listen',
49
+ target_engine: '1.0.0',
50
50
  categories: ['music'],
51
51
  tags: ['example'],
52
52
  grant: ['internet'],
package/dist/bin.js CHANGED
@@ -9,8 +9,8 @@ var { values } = parseArgs({
9
9
  publish: { type: "boolean" }
10
10
  }
11
11
  });
12
- if (values.build) import("./build-CUKFiHZ-.js");
13
- else if (values.publish) import("./publish-BUpufhVY.js");
12
+ if (values.build) import("./build-cwRtaFpY.js");
13
+ else if (values.publish) import("./publish-WfB8QiEk.js");
14
14
  else console.log("Please specify a command: build or publish");
15
15
  //#endregion
16
16
 
@@ -95,7 +95,6 @@ var pack = async (config) => {
95
95
  };
96
96
  //#endregion
97
97
  //#region src/vite.config.ts
98
- var isProd = process.env.NODE_ENV == "production";
99
98
  var createBuildConfig = (name, filePath) => {
100
99
  return defineConfig({
101
100
  base: "./",
@@ -106,7 +105,6 @@ var createBuildConfig = (name, filePath) => {
106
105
  target: "esnext",
107
106
  emptyOutDir: true,
108
107
  minify: false,
109
- watch: isProd ? null : { buildDelay: 500 },
110
108
  outDir: state.distDir,
111
109
  rolldownOptions: {
112
110
  external: ["any-listen"],
@@ -139,4 +137,4 @@ var run = async () => {
139
137
  run();
140
138
  //#endregion
141
139
 
142
- //# sourceMappingURL=build-CUKFiHZ-.js.map
140
+ //# sourceMappingURL=build-cwRtaFpY.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build-cwRtaFpY.js","names":[],"sources":["../src/cpResources.ts","../src/mainifest.ts","../src/pack.ts","../src/vite.config.ts","../src/build.ts"],"sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\n\nimport { state } from './state'\n\nexport const cpResources = async () => {\n const sourcePath = state.resourcesDir\n const targetPath = path.join(state.distDir, 'resources')\n const sourceI18nPath = state.i18nDir\n const targetI18nPath = path.join(state.distDir, 'i18n')\n\n await Promise.all([\n fs.promises.cp(sourcePath, targetPath, { recursive: true }),\n fs.promises.cp(sourceI18nPath, targetI18nPath, { recursive: true }),\n ])\n}\n","import fs from 'node:fs'\nimport path from 'node:path'\n\nimport { EXTENSION } from './constants'\nimport { state } from './state'\nimport type { ExtensionConfig } from './types/build'\n\nexport const createMainifest = async (config: ExtensionConfig) => {\n const mainifest = {\n id: config.id,\n name: config.name,\n description: config.description,\n icon: config.icon,\n version: config.version,\n target_engine: config.target_engine,\n author: config.author,\n homepage: config.homepage,\n license: config.license,\n categories: config.categories,\n tags: config.tags,\n grant: config.grant,\n contributes: config.contributes,\n main: EXTENSION.entryFileName,\n }\n\n await fs.promises.writeFile(path.join(state.distDir, EXTENSION.mainifestName), JSON.stringify(mainifest, null, 2), 'utf8')\n}\n","import crypto from 'node:crypto'\nimport fs from 'node:fs'\nimport path from 'node:path'\n\nimport { EXTENSION } from './constants'\nimport { state } from './state'\nimport type { ExtensionConfig } from './types/build'\nimport { buildPackageName } from './utils'\n\nconst buildPublicKey = (publicKey: string) => {\n if (!publicKey.includes('-----BEGIN PUBLIC KEY-----')) {\n return `-----BEGIN PUBLIC KEY-----\\n${publicKey}\\n-----END PUBLIC KEY-----`\n }\n return publicKey\n}\n\nconst signData = (data: Buffer, privateKey: string) => {\n const sign = crypto.createSign('SHA256')\n sign.update(data)\n sign.end()\n const signature = sign.sign(privateKey, 'hex')\n return signature\n}\nconst verifySignature = (data: Buffer, publicKey: string, signature: string) => {\n const verify = crypto.createVerify('SHA256')\n verify.update(data)\n verify.end()\n const isValid = verify.verify(publicKey, signature, 'hex')\n return isValid\n}\n\nconst packFile = async ({ gzip, cwd, files, dist }: { gzip: boolean; cwd: string; files: string[]; dist: string }) => {\n const { c } = await import('tar')\n return new Promise<void>((resolve, reject) => {\n c(\n {\n gzip,\n cwd,\n },\n files\n )\n .pipe(fs.createWriteStream(dist))\n .on('finish', () => {\n resolve()\n })\n .on('error', reject)\n })\n}\n\nexport const pack = async (config: ExtensionConfig) => {\n let privateKey = process.env.PRI_KEY?.trim()\n let publicKey = process.env.PUB_KEY?.trim()\n if (!privateKey || !publicKey) throw new Error('Missing private key or public key')\n if (!privateKey.includes('-----BEGIN PRIVATE KEY-----')) {\n privateKey = `-----BEGIN PRIVATE KEY-----\\n${privateKey}\\n-----END PRIVATE KEY-----`\n }\n\n const unpackedDir = path.join(state.outputDir, 'unpacked')\n await fs.promises.rm(unpackedDir, { recursive: true }).catch(() => {})\n await fs.promises.mkdir(unpackedDir, { recursive: true }).catch(() => {})\n const extBundleFilePath = path.join(unpackedDir, EXTENSION.extBundleFileName)\n await packFile({\n gzip: true,\n cwd: state.distDir,\n files: [EXTENSION.entryFileName, EXTENSION.mainifestName, 'resources', 'i18n'],\n dist: extBundleFilePath,\n })\n const buf = await fs.promises.readFile(extBundleFilePath)\n const signature = signData(buf, privateKey)\n if (!verifySignature(buf, buildPublicKey(publicKey), signature)) {\n throw new Error('Signature is valid, please check your public key')\n }\n await fs.promises.writeFile(path.join(unpackedDir, EXTENSION.signFileName), `${signature}\\n${publicKey}`)\n await packFile({\n gzip: true,\n cwd: unpackedDir,\n files: [EXTENSION.extBundleFileName, EXTENSION.signFileName],\n dist: path.join(state.outputDir, buildPackageName(config)),\n })\n}\n","import { defineConfig } from 'vite'\n\nimport { EXTENSION } from './constants'\nimport { state } from './state'\n\nconst createBuildConfig = (name: string, filePath: string) => {\n return defineConfig({\n base: './',\n mode: process.env.NODE_ENV,\n publicDir: false,\n resolve: {\n alias: {\n '@': state.srcDir,\n },\n },\n build: {\n target: 'esnext',\n emptyOutDir: true,\n minify: false,\n outDir: state.distDir,\n rolldownOptions: {\n external: ['any-listen'],\n input: {\n [name]: filePath,\n },\n output: {\n entryFileNames: '[name]',\n format: 'iife',\n },\n },\n },\n })\n}\n\nexport default (isIsolateMode?: boolean) => {\n const inputs = isIsolateMode\n ? {\n [EXTENSION.entryFileName]: state.mainEntry,\n 'resources/isolate-preload.js': state.isolatePreloadEntry,\n }\n : {\n [EXTENSION.entryFileName]: state.mainEntry,\n }\n return Object.entries(inputs).map(([name, filePath]) => createBuildConfig(name, filePath))\n}\n","import { cpResources } from './cpResources'\nimport { createMainifest } from './mainifest'\nimport { pack } from './pack'\nimport { state } from './state'\nimport { build, getConfig, loadEnvFile } from './utils'\nimport createConfigs from './vite.config'\n\nconst run = async () => {\n await loadEnvFile()\n const config = await getConfig()\n const appConfigs = createConfigs(state.isIsolateMode)\n await Promise.all(appConfigs.map(async (appConfig) => build(appConfig)))\n await Promise.all([cpResources(), createMainifest(config)])\n await pack(config)\n}\n\nvoid run()\n"],"mappings":"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"}
@@ -22,7 +22,8 @@ var run = async () => {
22
22
  version: "",
23
23
  download_url: "",
24
24
  log: "",
25
- date: (/* @__PURE__ */ new Date()).toISOString()
25
+ date: (/* @__PURE__ */ new Date()).toISOString(),
26
+ history: []
26
27
  };
27
28
  versionInfo.version = config.version;
28
29
  if (config.download_url_template) versionInfo.download_url = `${config.download_url_template.replaceAll("{version}", config.version)}/${buildPackageName(config)}`;
@@ -37,4 +38,4 @@ var run = async () => {
37
38
  run();
38
39
  //#endregion
39
40
 
40
- //# sourceMappingURL=publish-BUpufhVY.js.map
41
+ //# sourceMappingURL=publish-WfB8QiEk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"publish-WfB8QiEk.js","names":[],"sources":["../src/publish.ts"],"sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\n\nimport type { VersionInfo } from './types/build'\nimport { buildPackageName, getConfig, ROOT_DIR } from './utils'\n\nexport const run = async () => {\n const config = await getConfig()\n const filePath = path.join(ROOT_DIR, 'publish/version.json')\n let versionInfo = await fs.promises\n .readFile(filePath, 'utf-8')\n .then((d) => JSON.parse(d) as VersionInfo)\n .catch(() => null)\n if (versionInfo) {\n if (versionInfo.version === config.version) {\n console.warn(`Version (v${config.version}) already published`)\n process.exit(1)\n }\n versionInfo.history ||= []\n versionInfo.history.push({\n version: versionInfo.version,\n download_url: versionInfo.download_url,\n log: versionInfo.log,\n date: versionInfo.date,\n })\n } else {\n versionInfo = { version: '', download_url: '', log: '', date: new Date().toISOString(), history: [] }\n }\n versionInfo.version = config.version\n if (config.download_url_template) {\n versionInfo.download_url = `${config.download_url_template.replaceAll('{version}', config.version)}/${buildPackageName(config)}`\n }\n versionInfo.log = await fs.promises\n .readFile(path.join(ROOT_DIR, 'publish/changeLog.md'), 'utf-8')\n .then((d) => d.toString().trim())\n .catch(() => '')\n versionInfo.date = new Date().toISOString()\n\n await fs.promises.rm(filePath, { recursive: true, force: true })\n await fs.promises.writeFile(filePath, JSON.stringify(versionInfo))\n}\n\nvoid run()\n"],"mappings":";;;;AAMA,IAAa,MAAM,YAAY;CAC7B,MAAM,SAAS,MAAM,WAAW;CAChC,MAAM,WAAW,KAAK,KAAK,UAAU,uBAAuB;CAC5D,IAAI,cAAc,MAAM,GAAG,SACxB,SAAS,UAAU,QAAQ,CAC3B,MAAM,MAAM,KAAK,MAAM,EAAE,CAAgB,CACzC,YAAY,KAAK;AACpB,KAAI,aAAa;AACf,MAAI,YAAY,YAAY,OAAO,SAAS;AAC1C,WAAQ,KAAK,aAAa,OAAO,QAAQ,qBAAqB;AAC9D,WAAQ,KAAK,EAAE;;AAEjB,cAAY,YAAY,EAAE;AAC1B,cAAY,QAAQ,KAAK;GACvB,SAAS,YAAY;GACrB,cAAc,YAAY;GAC1B,KAAK,YAAY;GACjB,MAAM,YAAY;GACnB,CAAC;OAEF,eAAc;EAAE,SAAS;EAAI,cAAc;EAAI,KAAK;EAAI,uBAAM,IAAI,MAAM,EAAC,aAAa;EAAE,SAAS,EAAE;EAAE;AAEvG,aAAY,UAAU,OAAO;AAC7B,KAAI,OAAO,sBACT,aAAY,eAAe,GAAG,OAAO,sBAAsB,WAAW,aAAa,OAAO,QAAQ,CAAC,GAAG,iBAAiB,OAAO;AAEhI,aAAY,MAAM,MAAM,GAAG,SACxB,SAAS,KAAK,KAAK,UAAU,uBAAuB,EAAE,QAAQ,CAC9D,MAAM,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,CAChC,YAAY,GAAG;AAClB,aAAY,wBAAO,IAAI,MAAM,EAAC,aAAa;AAE3C,OAAM,GAAG,SAAS,GAAG,UAAU;EAAE,WAAW;EAAM,OAAO;EAAM,CAAC;AAChE,OAAM,GAAG,SAAS,UAAU,UAAU,KAAK,UAAU,YAAY,CAAC;;AAG/D,KAAK"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@any-listen/extension-kit",
3
- "version": "0.1.0",
3
+ "version": "0.1.1",
4
4
  "keywords": [
5
5
  "any-listen",
6
6
  "any-listen-extension"
package/src/publish.ts CHANGED
@@ -24,7 +24,7 @@ export const run = async () => {
24
24
  date: versionInfo.date,
25
25
  })
26
26
  } else {
27
- versionInfo = { version: '', download_url: '', log: '', date: new Date().toISOString() }
27
+ versionInfo = { version: '', download_url: '', log: '', date: new Date().toISOString(), history: [] }
28
28
  }
29
29
  versionInfo.version = config.version
30
30
  if (config.download_url_template) {
@@ -3,8 +3,6 @@ import { defineConfig } from 'vite'
3
3
  import { EXTENSION } from './constants'
4
4
  import { state } from './state'
5
5
 
6
- const isProd = process.env.NODE_ENV == 'production'
7
-
8
6
  const createBuildConfig = (name: string, filePath: string) => {
9
7
  return defineConfig({
10
8
  base: './',
@@ -19,11 +17,6 @@ const createBuildConfig = (name: string, filePath: string) => {
19
17
  target: 'esnext',
20
18
  emptyOutDir: true,
21
19
  minify: false,
22
- watch: isProd
23
- ? null
24
- : {
25
- buildDelay: 500,
26
- },
27
20
  outDir: state.distDir,
28
21
  rolldownOptions: {
29
22
  external: ['any-listen'],
@@ -892,6 +892,10 @@ declare global {
892
892
 
893
893
  readonly onLocaleChanged: (callback: (locale: Locale) => void) => () => void
894
894
  }
895
+ interface Constants {
896
+ readonly storageDir: string
897
+ readonly extensionDir: string
898
+ }
895
899
  /** 应用相关 */
896
900
  interface App {
897
901
  showMessage: (message: string, options?: MessageDialogOptions) => Promise<number>
@@ -1120,6 +1124,7 @@ declare global {
1120
1124
  }
1121
1125
  }
1122
1126
  command: Command
1127
+ constants: Constants
1123
1128
  }
1124
1129
  }
1125
1130
  }
@@ -1 +0,0 @@
1
- {"version":3,"file":"build-CUKFiHZ-.js","names":[],"sources":["../src/cpResources.ts","../src/mainifest.ts","../src/pack.ts","../src/vite.config.ts","../src/build.ts"],"sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\n\nimport { state } from './state'\n\nexport const cpResources = async () => {\n const sourcePath = state.resourcesDir\n const targetPath = path.join(state.distDir, 'resources')\n const sourceI18nPath = state.i18nDir\n const targetI18nPath = path.join(state.distDir, 'i18n')\n\n await Promise.all([\n fs.promises.cp(sourcePath, targetPath, { recursive: true }),\n fs.promises.cp(sourceI18nPath, targetI18nPath, { recursive: true }),\n ])\n}\n","import fs from 'node:fs'\nimport path from 'node:path'\n\nimport { EXTENSION } from './constants'\nimport { state } from './state'\nimport type { ExtensionConfig } from './types/build'\n\nexport const createMainifest = async (config: ExtensionConfig) => {\n const mainifest = {\n id: config.id,\n name: config.name,\n description: config.description,\n icon: config.icon,\n version: config.version,\n target_engine: config.target_engine,\n author: config.author,\n homepage: config.homepage,\n license: config.license,\n categories: config.categories,\n tags: config.tags,\n grant: config.grant,\n contributes: config.contributes,\n main: EXTENSION.entryFileName,\n }\n\n await fs.promises.writeFile(path.join(state.distDir, EXTENSION.mainifestName), JSON.stringify(mainifest, null, 2), 'utf8')\n}\n","import crypto from 'node:crypto'\nimport fs from 'node:fs'\nimport path from 'node:path'\n\nimport { EXTENSION } from './constants'\nimport { state } from './state'\nimport type { ExtensionConfig } from './types/build'\nimport { buildPackageName } from './utils'\n\nconst buildPublicKey = (publicKey: string) => {\n if (!publicKey.includes('-----BEGIN PUBLIC KEY-----')) {\n return `-----BEGIN PUBLIC KEY-----\\n${publicKey}\\n-----END PUBLIC KEY-----`\n }\n return publicKey\n}\n\nconst signData = (data: Buffer, privateKey: string) => {\n const sign = crypto.createSign('SHA256')\n sign.update(data)\n sign.end()\n const signature = sign.sign(privateKey, 'hex')\n return signature\n}\nconst verifySignature = (data: Buffer, publicKey: string, signature: string) => {\n const verify = crypto.createVerify('SHA256')\n verify.update(data)\n verify.end()\n const isValid = verify.verify(publicKey, signature, 'hex')\n return isValid\n}\n\nconst packFile = async ({ gzip, cwd, files, dist }: { gzip: boolean; cwd: string; files: string[]; dist: string }) => {\n const { c } = await import('tar')\n return new Promise<void>((resolve, reject) => {\n c(\n {\n gzip,\n cwd,\n },\n files\n )\n .pipe(fs.createWriteStream(dist))\n .on('finish', () => {\n resolve()\n })\n .on('error', reject)\n })\n}\n\nexport const pack = async (config: ExtensionConfig) => {\n let privateKey = process.env.PRI_KEY?.trim()\n let publicKey = process.env.PUB_KEY?.trim()\n if (!privateKey || !publicKey) throw new Error('Missing private key or public key')\n if (!privateKey.includes('-----BEGIN PRIVATE KEY-----')) {\n privateKey = `-----BEGIN PRIVATE KEY-----\\n${privateKey}\\n-----END PRIVATE KEY-----`\n }\n\n const unpackedDir = path.join(state.outputDir, 'unpacked')\n await fs.promises.rm(unpackedDir, { recursive: true }).catch(() => {})\n await fs.promises.mkdir(unpackedDir, { recursive: true }).catch(() => {})\n const extBundleFilePath = path.join(unpackedDir, EXTENSION.extBundleFileName)\n await packFile({\n gzip: true,\n cwd: state.distDir,\n files: [EXTENSION.entryFileName, EXTENSION.mainifestName, 'resources', 'i18n'],\n dist: extBundleFilePath,\n })\n const buf = await fs.promises.readFile(extBundleFilePath)\n const signature = signData(buf, privateKey)\n if (!verifySignature(buf, buildPublicKey(publicKey), signature)) {\n throw new Error('Signature is valid, please check your public key')\n }\n await fs.promises.writeFile(path.join(unpackedDir, EXTENSION.signFileName), `${signature}\\n${publicKey}`)\n await packFile({\n gzip: true,\n cwd: unpackedDir,\n files: [EXTENSION.extBundleFileName, EXTENSION.signFileName],\n dist: path.join(state.outputDir, buildPackageName(config)),\n })\n}\n","import { defineConfig } from 'vite'\n\nimport { EXTENSION } from './constants'\nimport { state } from './state'\n\nconst isProd = process.env.NODE_ENV == 'production'\n\nconst createBuildConfig = (name: string, filePath: string) => {\n return defineConfig({\n base: './',\n mode: process.env.NODE_ENV,\n publicDir: false,\n resolve: {\n alias: {\n '@': state.srcDir,\n },\n },\n build: {\n target: 'esnext',\n emptyOutDir: true,\n minify: false,\n watch: isProd\n ? null\n : {\n buildDelay: 500,\n },\n outDir: state.distDir,\n rolldownOptions: {\n external: ['any-listen'],\n input: {\n [name]: filePath,\n },\n output: {\n entryFileNames: '[name]',\n format: 'iife',\n },\n },\n },\n })\n}\n\nexport default (isIsolateMode?: boolean) => {\n const inputs = isIsolateMode\n ? {\n [EXTENSION.entryFileName]: state.mainEntry,\n 'resources/isolate-preload.js': state.isolatePreloadEntry,\n }\n : {\n [EXTENSION.entryFileName]: state.mainEntry,\n }\n return Object.entries(inputs).map(([name, filePath]) => createBuildConfig(name, filePath))\n}\n","import { cpResources } from './cpResources'\nimport { createMainifest } from './mainifest'\nimport { pack } from './pack'\nimport { state } from './state'\nimport { build, getConfig, loadEnvFile } from './utils'\nimport createConfigs from './vite.config'\n\nconst run = async () => {\n await loadEnvFile()\n const config = await getConfig()\n const appConfigs = createConfigs(state.isIsolateMode)\n await Promise.all(appConfigs.map(async (appConfig) => build(appConfig)))\n await Promise.all([cpResources(), createMainifest(config)])\n await pack(config)\n}\n\nvoid run()\n"],"mappings":";;;;;;AAKA,IAAa,cAAc,YAAY;CACrC,MAAM,aAAa,MAAM;CACzB,MAAM,aAAa,KAAK,KAAK,MAAM,SAAS,YAAY;CACxD,MAAM,iBAAiB,MAAM;CAC7B,MAAM,iBAAiB,KAAK,KAAK,MAAM,SAAS,OAAO;AAEvD,OAAM,QAAQ,IAAI,CAChB,GAAG,SAAS,GAAG,YAAY,YAAY,EAAE,WAAW,MAAM,CAAC,EAC3D,GAAG,SAAS,GAAG,gBAAgB,gBAAgB,EAAE,WAAW,MAAM,CAAC,CACpE,CAAC;;;;ACPJ,IAAa,kBAAkB,OAAO,WAA4B;CAChE,MAAM,YAAY;EAChB,IAAI,OAAO;EACX,MAAM,OAAO;EACb,aAAa,OAAO;EACpB,MAAM,OAAO;EACb,SAAS,OAAO;EAChB,eAAe,OAAO;EACtB,QAAQ,OAAO;EACf,UAAU,OAAO;EACjB,SAAS,OAAO;EAChB,YAAY,OAAO;EACnB,MAAM,OAAO;EACb,OAAO,OAAO;EACd,aAAa,OAAO;EACpB,MAAM,UAAU;EACjB;AAED,OAAM,GAAG,SAAS,UAAU,KAAK,KAAK,MAAM,SAAS,UAAU,cAAc,EAAE,KAAK,UAAU,WAAW,MAAM,EAAE,EAAE,OAAO;;;;AChB5H,IAAM,kBAAkB,cAAsB;AAC5C,KAAI,CAAC,UAAU,SAAS,6BAA6B,CACnD,QAAO,+BAA+B,UAAU;AAElD,QAAO;;AAGT,IAAM,YAAY,MAAc,eAAuB;CACrD,MAAM,OAAO,OAAO,WAAW,SAAS;AACxC,MAAK,OAAO,KAAK;AACjB,MAAK,KAAK;AAEV,QADkB,KAAK,KAAK,YAAY,MAAM;;AAGhD,IAAM,mBAAmB,MAAc,WAAmB,cAAsB;CAC9E,MAAM,SAAS,OAAO,aAAa,SAAS;AAC5C,QAAO,OAAO,KAAK;AACnB,QAAO,KAAK;AAEZ,QADgB,OAAO,OAAO,WAAW,WAAW,MAAM;;AAI5D,IAAM,WAAW,OAAO,EAAE,MAAM,KAAK,OAAO,WAA0E;CACpH,MAAM,EAAE,MAAM,MAAM,OAAO;AAC3B,QAAO,IAAI,SAAe,SAAS,WAAW;AAC5C,IACE;GACE;GACA;GACD,EACD,MACD,CACE,KAAK,GAAG,kBAAkB,KAAK,CAAC,CAChC,GAAG,gBAAgB;AAClB,YAAS;IACT,CACD,GAAG,SAAS,OAAO;GACtB;;AAGJ,IAAa,OAAO,OAAO,WAA4B;;CACrD,IAAI,cAAA,uBAAa,QAAQ,IAAI,aAAA,QAAA,yBAAA,KAAA,IAAA,KAAA,IAAA,qBAAS,MAAM;CAC5C,IAAI,aAAA,uBAAY,QAAQ,IAAI,aAAA,QAAA,yBAAA,KAAA,IAAA,KAAA,IAAA,qBAAS,MAAM;AAC3C,KAAI,CAAC,cAAc,CAAC,UAAW,OAAM,IAAI,MAAM,oCAAoC;AACnF,KAAI,CAAC,WAAW,SAAS,8BAA8B,CACrD,cAAa,gCAAgC,WAAW;CAG1D,MAAM,cAAc,KAAK,KAAK,MAAM,WAAW,WAAW;AAC1D,OAAM,GAAG,SAAS,GAAG,aAAa,EAAE,WAAW,MAAM,CAAC,CAAC,YAAY,GAAG;AACtE,OAAM,GAAG,SAAS,MAAM,aAAa,EAAE,WAAW,MAAM,CAAC,CAAC,YAAY,GAAG;CACzE,MAAM,oBAAoB,KAAK,KAAK,aAAa,UAAU,kBAAkB;AAC7E,OAAM,SAAS;EACb,MAAM;EACN,KAAK,MAAM;EACX,OAAO;GAAC,UAAU;GAAe,UAAU;GAAe;GAAa;GAAO;EAC9E,MAAM;EACP,CAAC;CACF,MAAM,MAAM,MAAM,GAAG,SAAS,SAAS,kBAAkB;CACzD,MAAM,YAAY,SAAS,KAAK,WAAW;AAC3C,KAAI,CAAC,gBAAgB,KAAK,eAAe,UAAU,EAAE,UAAU,CAC7D,OAAM,IAAI,MAAM,mDAAmD;AAErE,OAAM,GAAG,SAAS,UAAU,KAAK,KAAK,aAAa,UAAU,aAAa,EAAE,GAAG,UAAU,IAAI,YAAY;AACzG,OAAM,SAAS;EACb,MAAM;EACN,KAAK;EACL,OAAO,CAAC,UAAU,mBAAmB,UAAU,aAAa;EAC5D,MAAM,KAAK,KAAK,MAAM,WAAW,iBAAiB,OAAO,CAAC;EAC3D,CAAC;;;;ACzEJ,IAAM,SAAA,QAAA,IAAA,YAAiC;AAEvC,IAAM,qBAAqB,MAAc,aAAqB;AAC5D,QAAO,aAAa;EAClB,MAAM;EACN,MAAA,QAAA,IAAA;EACA,WAAW;EACX,SAAS,EACP,OAAO,EACL,KAAK,MAAM,QACZ,EACF;EACD,OAAO;GACL,QAAQ;GACR,aAAa;GACb,QAAQ;GACR,OAAO,SACH,OACA,EACE,YAAY,KACb;GACL,QAAQ,MAAM;GACd,iBAAiB;IACf,UAAU,CAAC,aAAa;IACxB,OAAO,GACJ,OAAO,UACT;IACD,QAAQ;KACN,gBAAgB;KAChB,QAAQ;KACT;IACF;GACF;EACF,CAAC;;AAGJ,IAAA,uBAAgB,kBAA4B;CAC1C,MAAM,SAAS,gBACX;GACG,UAAU,gBAAgB,MAAM;EACjC,gCAAgC,MAAM;EACvC,GACD,GACG,UAAU,gBAAgB,MAAM,WAClC;AACL,QAAO,OAAO,QAAQ,OAAO,CAAC,KAAK,CAAC,MAAM,cAAc,kBAAkB,MAAM,SAAS,CAAC;;;;AC3C5F,IAAM,MAAM,YAAY;AACtB,OAAM,aAAa;CACnB,MAAM,SAAS,MAAM,WAAW;CAChC,MAAM,aAAa,oBAAc,MAAM,cAAc;AACrD,OAAM,QAAQ,IAAI,WAAW,IAAI,OAAO,cAAc,QAAM,UAAU,CAAC,CAAC;AACxE,OAAM,QAAQ,IAAI,CAAC,aAAa,EAAE,gBAAgB,OAAO,CAAC,CAAC;AAC3D,OAAM,KAAK,OAAO;;AAGf,KAAK"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"publish-BUpufhVY.js","names":[],"sources":["../src/publish.ts"],"sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\n\nimport type { VersionInfo } from './types/build'\nimport { buildPackageName, getConfig, ROOT_DIR } from './utils'\n\nexport const run = async () => {\n const config = await getConfig()\n const filePath = path.join(ROOT_DIR, 'publish/version.json')\n let versionInfo = await fs.promises\n .readFile(filePath, 'utf-8')\n .then((d) => JSON.parse(d) as VersionInfo)\n .catch(() => null)\n if (versionInfo) {\n if (versionInfo.version === config.version) {\n console.warn(`Version (v${config.version}) already published`)\n process.exit(1)\n }\n versionInfo.history ||= []\n versionInfo.history.push({\n version: versionInfo.version,\n download_url: versionInfo.download_url,\n log: versionInfo.log,\n date: versionInfo.date,\n })\n } else {\n versionInfo = { version: '', download_url: '', log: '', date: new Date().toISOString() }\n }\n versionInfo.version = config.version\n if (config.download_url_template) {\n versionInfo.download_url = `${config.download_url_template.replaceAll('{version}', config.version)}/${buildPackageName(config)}`\n }\n versionInfo.log = await fs.promises\n .readFile(path.join(ROOT_DIR, 'publish/changeLog.md'), 'utf-8')\n .then((d) => d.toString().trim())\n .catch(() => '')\n versionInfo.date = new Date().toISOString()\n\n await fs.promises.rm(filePath, { recursive: true, force: true })\n await fs.promises.writeFile(filePath, JSON.stringify(versionInfo))\n}\n\nvoid run()\n"],"mappings":";;;;AAMA,IAAa,MAAM,YAAY;CAC7B,MAAM,SAAS,MAAM,WAAW;CAChC,MAAM,WAAW,KAAK,KAAK,UAAU,uBAAuB;CAC5D,IAAI,cAAc,MAAM,GAAG,SACxB,SAAS,UAAU,QAAQ,CAC3B,MAAM,MAAM,KAAK,MAAM,EAAE,CAAgB,CACzC,YAAY,KAAK;AACpB,KAAI,aAAa;AACf,MAAI,YAAY,YAAY,OAAO,SAAS;AAC1C,WAAQ,KAAK,aAAa,OAAO,QAAQ,qBAAqB;AAC9D,WAAQ,KAAK,EAAE;;AAEjB,cAAY,YAAY,EAAE;AAC1B,cAAY,QAAQ,KAAK;GACvB,SAAS,YAAY;GACrB,cAAc,YAAY;GAC1B,KAAK,YAAY;GACjB,MAAM,YAAY;GACnB,CAAC;OAEF,eAAc;EAAE,SAAS;EAAI,cAAc;EAAI,KAAK;EAAI,uBAAM,IAAI,MAAM,EAAC,aAAa;EAAE;AAE1F,aAAY,UAAU,OAAO;AAC7B,KAAI,OAAO,sBACT,aAAY,eAAe,GAAG,OAAO,sBAAsB,WAAW,aAAa,OAAO,QAAQ,CAAC,GAAG,iBAAiB,OAAO;AAEhI,aAAY,MAAM,MAAM,GAAG,SACxB,SAAS,KAAK,KAAK,UAAU,uBAAuB,EAAE,QAAQ,CAC9D,MAAM,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,CAChC,YAAY,GAAG;AAClB,aAAY,wBAAO,IAAI,MAAM,EAAC,aAAa;AAE3C,OAAM,GAAG,SAAS,GAAG,UAAU;EAAE,WAAW;EAAM,OAAO;EAAM,CAAC;AAChE,OAAM,GAAG,SAAS,UAAU,UAAU,KAAK,UAAU,YAAY,CAAC;;AAG/D,KAAK"}