zixulu 1.53.1 → 1.53.2

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.
@@ -1,6 +1,8 @@
1
+ var __create = Object.create;
1
2
  var __defProp = Object.defineProperty;
2
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
4
6
  var __hasOwnProp = Object.prototype.hasOwnProperty;
5
7
  var __export = (target, all) => {
6
8
  for (var name in all)
@@ -14,6 +16,14 @@ var __copyProps = (to, from, except, desc) => {
14
16
  }
15
17
  return to;
16
18
  };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
17
27
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
28
 
19
29
  // src/utils/docker.ts
@@ -22,9 +32,13 @@ __export(docker_exports, {
22
32
  docker: () => docker
23
33
  });
24
34
  module.exports = __toCommonJS(docker_exports);
35
+ var import_promises = require("fs/promises");
25
36
  var import_jsdom = require("jsdom");
26
37
  var import_soda_nodejs = require("soda-nodejs");
27
38
  async function docker() {
39
+ const isRoot = !!process.env.SUDO_USER;
40
+ if (!isRoot)
41
+ throw new Error("请使用 root 用户执行命令");
28
42
  const info = await (0, import_soda_nodejs.execAsync)("lsb_release -a");
29
43
  const distributorId = info.match(/Distributor ID:\s+(.+)/)?.[1];
30
44
  if (distributorId !== "Ubuntu")
@@ -42,8 +56,28 @@ async function docker() {
42
56
  const deb4 = hrefs.findLast((item) => item.startsWith("docker-buildx-plugin_"));
43
57
  const deb5 = hrefs.findLast((item) => item.startsWith("docker-compose-plugin_"));
44
58
  const debs = [deb, deb2, deb3, deb4, deb5];
45
- await Promise.all(debs.map((deb6) => (0, import_soda_nodejs.execAsync)(`wget -q https://download.docker.com/linux/ubuntu/dists/${codename}/pool/stable/amd64/${deb6}`)));
46
- await (0, import_soda_nodejs.execAsync)(`sudo dpkg -i ${debs.join(" ")}`);
59
+ const dir = await (0, import_promises.readdir)(".");
60
+ await Promise.all(
61
+ debs.filter((deb6) => !dir.includes(deb6)).map((deb6) => (0, import_soda_nodejs.execAsync)(`wget -q https://download.docker.com/linux/ubuntu/dists/${codename}/pool/stable/amd64/${deb6}`))
62
+ );
63
+ await (0, import_soda_nodejs.execAsync)(`dpkg -i ${debs.join(" ")}`);
64
+ await (0, import_promises.mkdir)("/etc/docker", { recursive: true });
65
+ const daemon = {
66
+ "registry-mirrors": ["https://docker.sunzishaokao.com", "https://hub.hxui.site", "https://docker.1ms.run"],
67
+ "exec-opts": ["native.cgroupdriver=systemd"]
68
+ };
69
+ const { default: inquirer } = await import("inquirer");
70
+ const { mirrors } = await inquirer.prompt([
71
+ {
72
+ type: "input",
73
+ name: "mirrors",
74
+ message: "请输入镜像地址,多个用逗号分隔,留空则跳过"
75
+ }
76
+ ]);
77
+ daemon["registry-mirrors"].push(...mirrors.split(/,,/));
78
+ await (0, import_promises.writeFile)("/etc/docker/daemon.json", JSON.stringify(daemon, null, 4));
79
+ await (0, import_soda_nodejs.execAsync)("systemctl daemon-reload");
80
+ await (0, import_soda_nodejs.execAsync)("systemctl restart docker");
47
81
  }
48
82
  // Annotate the CommonJS export names for ESM import in node:
49
83
  0 && (module.exports = {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/utils/docker.ts"],
4
- "sourcesContent": ["import { JSDOM } from \"jsdom\"\nimport { execAsync } from \"soda-nodejs\"\n\nexport async function docker() {\n const info = await execAsync(\"lsb_release -a\")\n const distributorId = info.match(/Distributor ID:\\s+(.+)/)?.[1]\n if (distributorId !== \"Ubuntu\") throw new Error(\"暂不支持 Ubuntu 以外的系统\")\n const codename = info.trim().match(/Codename:\\s+(.+)/)?.[1]\n if (!codename) throw new Error(\"无法获取 codename\")\n const response = await fetch(`https://download.docker.com/linux/ubuntu/dists/${codename}/pool/stable/amd64/`)\n const data = await response.text()\n const dom = new JSDOM(data)\n const hrefs = Array.from(dom.window.document.querySelectorAll(\"a\")).map(({ href }) => href)\n const deb = hrefs.findLast(item => item.startsWith(\"containerd.io_\"))!\n const deb2 = hrefs.findLast(item => item.startsWith(\"docker-ce_\"))!\n const deb3 = hrefs.findLast(item => item.startsWith(\"docker-ce-cli_\"))!\n const deb4 = hrefs.findLast(item => item.startsWith(\"docker-buildx-plugin_\"))!\n const deb5 = hrefs.findLast(item => item.startsWith(\"docker-compose-plugin_\"))!\n const debs = [deb, deb2, deb3, deb4, deb5]\n await Promise.all(debs.map(deb => execAsync(`wget -q https://download.docker.com/linux/ubuntu/dists/${codename}/pool/stable/amd64/${deb}`)))\n await execAsync(`sudo dpkg -i ${debs.join(\" \")}`)\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAsB;AACtB,yBAA0B;AAE1B,eAAsB,SAAS;AAC3B,QAAM,OAAO,UAAM,8BAAU,gBAAgB;AAC7C,QAAM,gBAAgB,KAAK,MAAM,wBAAwB,IAAI,CAAC;AAC9D,MAAI,kBAAkB;AAAU,UAAM,IAAI,MAAM,mBAAmB;AACnE,QAAM,WAAW,KAAK,KAAK,EAAE,MAAM,kBAAkB,IAAI,CAAC;AAC1D,MAAI,CAAC;AAAU,UAAM,IAAI,MAAM,eAAe;AAC9C,QAAM,WAAW,MAAM,MAAM,kDAAkD,6BAA6B;AAC5G,QAAM,OAAO,MAAM,SAAS,KAAK;AACjC,QAAM,MAAM,IAAI,mBAAM,IAAI;AAC1B,QAAM,QAAQ,MAAM,KAAK,IAAI,OAAO,SAAS,iBAAiB,GAAG,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,MAAM,IAAI;AAC1F,QAAM,MAAM,MAAM,SAAS,UAAQ,KAAK,WAAW,gBAAgB,CAAC;AACpE,QAAM,OAAO,MAAM,SAAS,UAAQ,KAAK,WAAW,YAAY,CAAC;AACjE,QAAM,OAAO,MAAM,SAAS,UAAQ,KAAK,WAAW,gBAAgB,CAAC;AACrE,QAAM,OAAO,MAAM,SAAS,UAAQ,KAAK,WAAW,uBAAuB,CAAC;AAC5E,QAAM,OAAO,MAAM,SAAS,UAAQ,KAAK,WAAW,wBAAwB,CAAC;AAC7E,QAAM,OAAO,CAAC,KAAK,MAAM,MAAM,MAAM,IAAI;AACzC,QAAM,QAAQ,IAAI,KAAK,IAAI,CAAAA,aAAO,8BAAU,0DAA0D,8BAA8BA,MAAK,CAAC,CAAC;AAC3I,YAAM,8BAAU,gBAAgB,KAAK,KAAK,GAAG,GAAG;AACpD;",
4
+ "sourcesContent": ["import { mkdir, readdir, writeFile } from \"fs/promises\"\nimport { JSDOM } from \"jsdom\"\nimport { execAsync } from \"soda-nodejs\"\n\nexport async function docker() {\n const isRoot = !!process.env.SUDO_USER\n if (!isRoot) throw new Error(\"请使用 root 用户执行命令\")\n const info = await execAsync(\"lsb_release -a\")\n const distributorId = info.match(/Distributor ID:\\s+(.+)/)?.[1]\n if (distributorId !== \"Ubuntu\") throw new Error(\"暂不支持 Ubuntu 以外的系统\")\n const codename = info.trim().match(/Codename:\\s+(.+)/)?.[1]\n if (!codename) throw new Error(\"无法获取 codename\")\n const response = await fetch(`https://download.docker.com/linux/ubuntu/dists/${codename}/pool/stable/amd64/`)\n const data = await response.text()\n const dom = new JSDOM(data)\n const hrefs = Array.from(dom.window.document.querySelectorAll(\"a\")).map(({ href }) => href)\n const deb = hrefs.findLast(item => item.startsWith(\"containerd.io_\"))!\n const deb2 = hrefs.findLast(item => item.startsWith(\"docker-ce_\"))!\n const deb3 = hrefs.findLast(item => item.startsWith(\"docker-ce-cli_\"))!\n const deb4 = hrefs.findLast(item => item.startsWith(\"docker-buildx-plugin_\"))!\n const deb5 = hrefs.findLast(item => item.startsWith(\"docker-compose-plugin_\"))!\n const debs = [deb, deb2, deb3, deb4, deb5]\n const dir = await readdir(\".\")\n await Promise.all(\n debs\n .filter(deb => !dir.includes(deb))\n .map(deb => execAsync(`wget -q https://download.docker.com/linux/ubuntu/dists/${codename}/pool/stable/amd64/${deb}`)),\n )\n await execAsync(`dpkg -i ${debs.join(\" \")}`)\n await mkdir(\"/etc/docker\", { recursive: true })\n const daemon = {\n \"registry-mirrors\": [\"https://docker.sunzishaokao.com\", \"https://hub.hxui.site\", \"https://docker.1ms.run\"],\n \"exec-opts\": [\"native.cgroupdriver=systemd\"],\n }\n const { default: inquirer } = await import(\"inquirer\")\n type Answer = {\n mirrors: string\n }\n const { mirrors } = await inquirer.prompt<Answer>([\n {\n type: \"input\",\n name: \"mirrors\",\n message: \"请输入镜像地址,多个用逗号分隔,留空则跳过\",\n },\n ])\n daemon[\"registry-mirrors\"].push(...mirrors.split(/,,/))\n await writeFile(\"/etc/docker/daemon.json\", JSON.stringify(daemon, null, 4))\n await execAsync(\"systemctl daemon-reload\")\n await execAsync(\"systemctl restart docker\")\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAA0C;AAC1C,mBAAsB;AACtB,yBAA0B;AAE1B,eAAsB,SAAS;AAC3B,QAAM,SAAS,CAAC,CAAC,QAAQ,IAAI;AAC7B,MAAI,CAAC;AAAQ,UAAM,IAAI,MAAM,iBAAiB;AAC9C,QAAM,OAAO,UAAM,8BAAU,gBAAgB;AAC7C,QAAM,gBAAgB,KAAK,MAAM,wBAAwB,IAAI,CAAC;AAC9D,MAAI,kBAAkB;AAAU,UAAM,IAAI,MAAM,mBAAmB;AACnE,QAAM,WAAW,KAAK,KAAK,EAAE,MAAM,kBAAkB,IAAI,CAAC;AAC1D,MAAI,CAAC;AAAU,UAAM,IAAI,MAAM,eAAe;AAC9C,QAAM,WAAW,MAAM,MAAM,kDAAkD,6BAA6B;AAC5G,QAAM,OAAO,MAAM,SAAS,KAAK;AACjC,QAAM,MAAM,IAAI,mBAAM,IAAI;AAC1B,QAAM,QAAQ,MAAM,KAAK,IAAI,OAAO,SAAS,iBAAiB,GAAG,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,MAAM,IAAI;AAC1F,QAAM,MAAM,MAAM,SAAS,UAAQ,KAAK,WAAW,gBAAgB,CAAC;AACpE,QAAM,OAAO,MAAM,SAAS,UAAQ,KAAK,WAAW,YAAY,CAAC;AACjE,QAAM,OAAO,MAAM,SAAS,UAAQ,KAAK,WAAW,gBAAgB,CAAC;AACrE,QAAM,OAAO,MAAM,SAAS,UAAQ,KAAK,WAAW,uBAAuB,CAAC;AAC5E,QAAM,OAAO,MAAM,SAAS,UAAQ,KAAK,WAAW,wBAAwB,CAAC;AAC7E,QAAM,OAAO,CAAC,KAAK,MAAM,MAAM,MAAM,IAAI;AACzC,QAAM,MAAM,UAAM,yBAAQ,GAAG;AAC7B,QAAM,QAAQ;AAAA,IACV,KACK,OAAO,CAAAA,SAAO,CAAC,IAAI,SAASA,IAAG,CAAC,EAChC,IAAI,CAAAA,aAAO,8BAAU,0DAA0D,8BAA8BA,MAAK,CAAC;AAAA,EAC5H;AACA,YAAM,8BAAU,WAAW,KAAK,KAAK,GAAG,GAAG;AAC3C,YAAM,uBAAM,eAAe,EAAE,WAAW,KAAK,CAAC;AAC9C,QAAM,SAAS;AAAA,IACX,oBAAoB,CAAC,mCAAmC,yBAAyB,wBAAwB;AAAA,IACzG,aAAa,CAAC,6BAA6B;AAAA,EAC/C;AACA,QAAM,EAAE,SAAS,SAAS,IAAI,MAAM,OAAO,UAAU;AAIrD,QAAM,EAAE,QAAQ,IAAI,MAAM,SAAS,OAAe;AAAA,IAC9C;AAAA,MACI,MAAM;AAAA,MACN,MAAM;AAAA,MACN,SAAS;AAAA,IACb;AAAA,EACJ,CAAC;AACD,SAAO,kBAAkB,EAAE,KAAK,GAAG,QAAQ,MAAM,IAAI,CAAC;AACtD,YAAM,2BAAU,2BAA2B,KAAK,UAAU,QAAQ,MAAM,CAAC,CAAC;AAC1E,YAAM,8BAAU,yBAAyB;AACzC,YAAM,8BAAU,0BAA0B;AAC9C;",
6
6
  "names": ["deb"]
7
7
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "zixulu",
3
- "version": "1.53.1",
3
+ "version": "1.53.2",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "bin": {
@@ -1,7 +1,10 @@
1
+ import { mkdir, readdir, writeFile } from "fs/promises"
1
2
  import { JSDOM } from "jsdom"
2
3
  import { execAsync } from "soda-nodejs"
3
4
 
4
5
  export async function docker() {
6
+ const isRoot = !!process.env.SUDO_USER
7
+ if (!isRoot) throw new Error("请使用 root 用户执行命令")
5
8
  const info = await execAsync("lsb_release -a")
6
9
  const distributorId = info.match(/Distributor ID:\s+(.+)/)?.[1]
7
10
  if (distributorId !== "Ubuntu") throw new Error("暂不支持 Ubuntu 以外的系统")
@@ -17,6 +20,31 @@ export async function docker() {
17
20
  const deb4 = hrefs.findLast(item => item.startsWith("docker-buildx-plugin_"))!
18
21
  const deb5 = hrefs.findLast(item => item.startsWith("docker-compose-plugin_"))!
19
22
  const debs = [deb, deb2, deb3, deb4, deb5]
20
- await Promise.all(debs.map(deb => execAsync(`wget -q https://download.docker.com/linux/ubuntu/dists/${codename}/pool/stable/amd64/${deb}`)))
21
- await execAsync(`sudo dpkg -i ${debs.join(" ")}`)
23
+ const dir = await readdir(".")
24
+ await Promise.all(
25
+ debs
26
+ .filter(deb => !dir.includes(deb))
27
+ .map(deb => execAsync(`wget -q https://download.docker.com/linux/ubuntu/dists/${codename}/pool/stable/amd64/${deb}`)),
28
+ )
29
+ await execAsync(`dpkg -i ${debs.join(" ")}`)
30
+ await mkdir("/etc/docker", { recursive: true })
31
+ const daemon = {
32
+ "registry-mirrors": ["https://docker.sunzishaokao.com", "https://hub.hxui.site", "https://docker.1ms.run"],
33
+ "exec-opts": ["native.cgroupdriver=systemd"],
34
+ }
35
+ const { default: inquirer } = await import("inquirer")
36
+ type Answer = {
37
+ mirrors: string
38
+ }
39
+ const { mirrors } = await inquirer.prompt<Answer>([
40
+ {
41
+ type: "input",
42
+ name: "mirrors",
43
+ message: "请输入镜像地址,多个用逗号分隔,留空则跳过",
44
+ },
45
+ ])
46
+ daemon["registry-mirrors"].push(...mirrors.split(/,,/))
47
+ await writeFile("/etc/docker/daemon.json", JSON.stringify(daemon, null, 4))
48
+ await execAsync("systemctl daemon-reload")
49
+ await execAsync("systemctl restart docker")
22
50
  }