typescript-virtual-container 1.2.8 → 1.2.9
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 +359 -32
- package/dist/SSHMimic/executor.js +3 -5
- package/dist/VirtualPackageManager/index.d.ts +202 -0
- package/dist/VirtualPackageManager/index.d.ts.map +1 -0
- package/dist/VirtualPackageManager/index.js +676 -0
- package/dist/VirtualShell/index.d.ts +87 -12
- package/dist/VirtualShell/index.d.ts.map +1 -1
- package/dist/VirtualShell/index.js +83 -12
- package/dist/VirtualUserManager/index.d.ts +52 -20
- package/dist/VirtualUserManager/index.d.ts.map +1 -1
- package/dist/VirtualUserManager/index.js +54 -20
- package/dist/commands/alias.d.ts +4 -0
- package/dist/commands/alias.d.ts.map +1 -0
- package/dist/commands/alias.js +58 -0
- package/dist/commands/apt.d.ts +4 -0
- package/dist/commands/apt.d.ts.map +1 -0
- package/dist/commands/apt.js +182 -0
- package/dist/commands/cat.d.ts.map +1 -1
- package/dist/commands/cat.js +27 -8
- package/dist/commands/chmod.d.ts.map +1 -1
- package/dist/commands/chmod.js +52 -3
- package/dist/commands/command-helpers.d.ts +78 -4
- package/dist/commands/command-helpers.d.ts.map +1 -1
- package/dist/commands/command-helpers.js +78 -4
- package/dist/commands/curl.d.ts.map +1 -1
- package/dist/commands/curl.js +81 -29
- package/dist/commands/dpkg.d.ts +4 -0
- package/dist/commands/dpkg.d.ts.map +1 -0
- package/dist/commands/dpkg.js +144 -0
- package/dist/commands/echo.d.ts.map +1 -1
- package/dist/commands/echo.js +24 -12
- package/dist/commands/free.d.ts +3 -0
- package/dist/commands/free.d.ts.map +1 -0
- package/dist/commands/free.js +38 -0
- package/dist/commands/helpers.d.ts +3 -0
- package/dist/commands/helpers.d.ts.map +1 -1
- package/dist/commands/helpers.js +3 -0
- package/dist/commands/history.d.ts +3 -0
- package/dist/commands/history.d.ts.map +1 -0
- package/dist/commands/history.js +21 -0
- package/dist/commands/index.d.ts +8 -1
- package/dist/commands/index.d.ts.map +1 -1
- package/dist/commands/index.js +120 -11
- package/dist/commands/ls.d.ts.map +1 -1
- package/dist/commands/ls.js +4 -3
- package/dist/commands/lsb-release.d.ts +3 -0
- package/dist/commands/lsb-release.d.ts.map +1 -0
- package/dist/commands/lsb-release.js +50 -0
- package/dist/commands/man.d.ts +3 -0
- package/dist/commands/man.d.ts.map +1 -0
- package/dist/commands/man.js +155 -0
- package/dist/commands/neofetch.d.ts.map +1 -1
- package/dist/commands/neofetch.js +5 -0
- package/dist/commands/ping.d.ts.map +1 -1
- package/dist/commands/ping.js +5 -2
- package/dist/commands/ps.d.ts.map +1 -1
- package/dist/commands/ps.js +27 -6
- package/dist/commands/sh.d.ts.map +1 -1
- package/dist/commands/sh.js +29 -11
- package/dist/commands/source.d.ts +3 -0
- package/dist/commands/source.d.ts.map +1 -0
- package/dist/commands/source.js +31 -0
- package/dist/commands/test.d.ts +3 -0
- package/dist/commands/test.d.ts.map +1 -0
- package/dist/commands/test.js +92 -0
- package/dist/commands/type.d.ts +3 -0
- package/dist/commands/type.d.ts.map +1 -0
- package/dist/commands/type.js +34 -0
- package/dist/commands/uptime.d.ts +3 -0
- package/dist/commands/uptime.d.ts.map +1 -0
- package/dist/commands/uptime.js +40 -0
- package/dist/commands/wget.d.ts.map +1 -1
- package/dist/commands/wget.js +71 -100
- package/dist/commands/which.d.ts +3 -0
- package/dist/commands/which.d.ts.map +1 -0
- package/dist/commands/which.js +32 -0
- package/dist/index.d.ts +5 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- package/dist/modules/linuxRootfs.d.ts +24 -0
- package/dist/modules/linuxRootfs.d.ts.map +1 -0
- package/dist/modules/linuxRootfs.js +297 -0
- package/dist/modules/neofetch.d.ts.map +1 -1
- package/dist/modules/neofetch.js +1 -0
- package/package.json +2 -1
- package/src/SSHMimic/executor.ts +3 -5
- package/src/VirtualPackageManager/index.ts +820 -0
- package/src/VirtualShell/index.ts +104 -13
- package/src/VirtualUserManager/index.ts +55 -20
- package/src/commands/alias.ts +60 -0
- package/src/commands/apt.ts +198 -0
- package/src/commands/cat.ts +32 -8
- package/src/commands/chmod.ts +48 -3
- package/src/commands/command-helpers.ts +78 -4
- package/src/commands/curl.ts +78 -37
- package/src/commands/dpkg.ts +158 -0
- package/src/commands/echo.ts +30 -14
- package/src/commands/free.ts +40 -0
- package/src/commands/helpers.ts +8 -0
- package/src/commands/history.ts +29 -0
- package/src/commands/index.ts +116 -11
- package/src/commands/ls.ts +5 -4
- package/src/commands/lsb-release.ts +52 -0
- package/src/commands/man.ts +166 -0
- package/src/commands/neofetch.ts +5 -0
- package/src/commands/ping.ts +5 -2
- package/src/commands/ps.ts +28 -6
- package/src/commands/sh.ts +33 -11
- package/src/commands/source.ts +35 -0
- package/src/commands/test.ts +100 -0
- package/src/commands/type.ts +40 -0
- package/src/commands/uptime.ts +46 -0
- package/src/commands/wget.ts +70 -123
- package/src/commands/which.ts +34 -0
- package/src/index.ts +10 -0
- package/src/modules/linuxRootfs.ts +439 -0
- package/src/modules/neofetch.ts +1 -0
- package/standalone.js +418 -103
- package/standalone.js.map +4 -4
- package/tests/new-features.test.ts +626 -0
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
import type VirtualFileSystem from "../VirtualFileSystem";
|
|
2
|
+
import type { VirtualUserManager } from "../VirtualUserManager";
|
|
3
|
+
/**
|
|
4
|
+
* A single file entry written into the VFS when a package is installed.
|
|
5
|
+
*/
|
|
6
|
+
export interface PackageFile {
|
|
7
|
+
/** Absolute VFS destination path (e.g. `"/usr/bin/vim"`). */
|
|
8
|
+
path: string;
|
|
9
|
+
/** Text content to write. */
|
|
10
|
+
content: string;
|
|
11
|
+
/** POSIX mode bits (default `0o644`; use `0o755` for executables). */
|
|
12
|
+
mode?: number;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Metadata and behaviour definition for a single package in the registry.
|
|
16
|
+
*
|
|
17
|
+
* Used both for the built-in registry entries and for consumer-supplied custom
|
|
18
|
+
* packages. `files` are written to the VFS on `install()`, and `onInstall` /
|
|
19
|
+
* `onRemove` hooks allow arbitrary VFS mutations.
|
|
20
|
+
*/
|
|
21
|
+
export interface PackageDefinition {
|
|
22
|
+
/** Package name — lowercase, no spaces (e.g. `"vim"`, `"build-essential"`). */
|
|
23
|
+
name: string;
|
|
24
|
+
/** Debian-style version string (e.g. `"2:9.0.1378-2"`). */
|
|
25
|
+
version: string;
|
|
26
|
+
/** CPU architecture label (default `"amd64"`). */
|
|
27
|
+
architecture?: string;
|
|
28
|
+
/** Maintainer name and email shown in `apt show` output. */
|
|
29
|
+
maintainer?: string;
|
|
30
|
+
/** Full package description. */
|
|
31
|
+
description: string;
|
|
32
|
+
/** Short one-line summary shown in `apt search` results. */
|
|
33
|
+
shortDesc?: string;
|
|
34
|
+
/** Installed disk usage in kilobytes (informational). */
|
|
35
|
+
installedSizeKb?: number;
|
|
36
|
+
/** Other package names that must be installed first (resolved recursively). */
|
|
37
|
+
depends?: string[];
|
|
38
|
+
/** Repository section (e.g. `"utils"`, `"net"`, `"editors"`, `"devel"`). */
|
|
39
|
+
section?: string;
|
|
40
|
+
/** Files to write into the VFS during installation. */
|
|
41
|
+
files?: PackageFile[];
|
|
42
|
+
/**
|
|
43
|
+
* Hook called after all files are written.
|
|
44
|
+
* Use to create directories, write config, or register shell commands.
|
|
45
|
+
*/
|
|
46
|
+
onInstall?: (vfs: VirtualFileSystem, users: VirtualUserManager) => void;
|
|
47
|
+
/** Hook called before VFS files are removed during uninstall. */
|
|
48
|
+
onRemove?: (vfs: VirtualFileSystem) => void;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Runtime record of an installed package, persisted to `/var/lib/dpkg/status`.
|
|
52
|
+
*/
|
|
53
|
+
export interface InstalledPackage {
|
|
54
|
+
/** Package name. */
|
|
55
|
+
name: string;
|
|
56
|
+
/** Installed version string. */
|
|
57
|
+
version: string;
|
|
58
|
+
/** CPU architecture. */
|
|
59
|
+
architecture: string;
|
|
60
|
+
/** Maintainer display string. */
|
|
61
|
+
maintainer: string;
|
|
62
|
+
/** Full description. */
|
|
63
|
+
description: string;
|
|
64
|
+
/** Repository section. */
|
|
65
|
+
section: string;
|
|
66
|
+
/** Installed disk usage in kilobytes. */
|
|
67
|
+
installedSizeKb: number;
|
|
68
|
+
/** ISO-8601 timestamp of when the package was installed. */
|
|
69
|
+
installedAt: string;
|
|
70
|
+
/** Absolute VFS paths written by this package (used by `dpkg -L`). */
|
|
71
|
+
files: string[];
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Pure-TypeScript APT/dpkg package manager backed by a built-in registry.
|
|
75
|
+
*
|
|
76
|
+
* Accessed via `shell.packageManager` — not constructed directly.
|
|
77
|
+
*
|
|
78
|
+
* `install()` resolves dependencies recursively, writes declared files to the
|
|
79
|
+
* VFS, runs `onInstall` hooks, and persists state to `/var/lib/dpkg/status`.
|
|
80
|
+
* `remove()` reverses the process. All state survives VFS snapshot round-trips.
|
|
81
|
+
*
|
|
82
|
+
* @example
|
|
83
|
+
* ```ts
|
|
84
|
+
* const pm = shell.packageManager;
|
|
85
|
+
* pm.install(["vim", "git"]);
|
|
86
|
+
* console.log(pm.isInstalled("vim")); // true
|
|
87
|
+
* console.log(pm.installedCount()); // 2
|
|
88
|
+
* ```
|
|
89
|
+
*/
|
|
90
|
+
export declare class VirtualPackageManager {
|
|
91
|
+
private readonly vfs;
|
|
92
|
+
private readonly users;
|
|
93
|
+
private readonly installed;
|
|
94
|
+
private readonly registryPath;
|
|
95
|
+
private readonly logPath;
|
|
96
|
+
private readonly aptLogPath;
|
|
97
|
+
/**
|
|
98
|
+
* @param vfs Backing virtual filesystem for file I/O and dpkg status persistence.
|
|
99
|
+
* @param users User manager reference passed to `onInstall` hooks.
|
|
100
|
+
*/
|
|
101
|
+
constructor(vfs: VirtualFileSystem, users: VirtualUserManager);
|
|
102
|
+
/**
|
|
103
|
+
* Loads installed package state from `/var/lib/dpkg/status` in the VFS.
|
|
104
|
+
*
|
|
105
|
+
* Called automatically by `VirtualShell` after `bootstrapLinuxRootfs`.
|
|
106
|
+
* Safe to call again to reload state after a snapshot restore.
|
|
107
|
+
*/
|
|
108
|
+
load(): void;
|
|
109
|
+
/** Persist installed state to /var/lib/dpkg/status. */
|
|
110
|
+
private persist;
|
|
111
|
+
private parseFields;
|
|
112
|
+
private log;
|
|
113
|
+
private aptLog;
|
|
114
|
+
/**
|
|
115
|
+
* Looks up a package definition in the built-in registry by name.
|
|
116
|
+
*
|
|
117
|
+
* @param name Package name (case-insensitive).
|
|
118
|
+
* @returns The matching `PackageDefinition`, or `undefined` if not found.
|
|
119
|
+
*/
|
|
120
|
+
findInRegistry(name: string): PackageDefinition | undefined;
|
|
121
|
+
/**
|
|
122
|
+
* Returns all packages in the built-in registry, sorted alphabetically.
|
|
123
|
+
*
|
|
124
|
+
* @returns Array of `PackageDefinition` entries.
|
|
125
|
+
*/
|
|
126
|
+
listAvailable(): PackageDefinition[];
|
|
127
|
+
/**
|
|
128
|
+
* Returns all currently installed packages, sorted alphabetically.
|
|
129
|
+
*
|
|
130
|
+
* @returns Array of `InstalledPackage` records.
|
|
131
|
+
*/
|
|
132
|
+
listInstalled(): InstalledPackage[];
|
|
133
|
+
/**
|
|
134
|
+
* Returns `true` when the given package is currently installed.
|
|
135
|
+
*
|
|
136
|
+
* @param name Package name (case-insensitive).
|
|
137
|
+
*/
|
|
138
|
+
isInstalled(name: string): boolean;
|
|
139
|
+
/**
|
|
140
|
+
* Returns the total number of installed packages.
|
|
141
|
+
*
|
|
142
|
+
* Used by `neofetch` to populate the `Packages:` field.
|
|
143
|
+
*/
|
|
144
|
+
installedCount(): number;
|
|
145
|
+
/**
|
|
146
|
+
* Installs one or more packages from the registry.
|
|
147
|
+
*
|
|
148
|
+
* Dependencies listed in `PackageDefinition.depends` are resolved and
|
|
149
|
+
* installed automatically. Already-installed packages are skipped. Files
|
|
150
|
+
* declared in `PackageDefinition.files` are written to the VFS and
|
|
151
|
+
* `onInstall` hooks are called in dependency order.
|
|
152
|
+
*
|
|
153
|
+
* @param names Package names to install.
|
|
154
|
+
* @param opts Installation options.
|
|
155
|
+
* @param opts.quiet Suppress progress output lines when `true`.
|
|
156
|
+
* @returns Terminal-style `output` string and an APT-compatible `exitCode`
|
|
157
|
+
* (`0` on success, `100` when a package is not found).
|
|
158
|
+
*/
|
|
159
|
+
install(names: string[], opts?: {
|
|
160
|
+
quiet?: boolean;
|
|
161
|
+
}): {
|
|
162
|
+
output: string;
|
|
163
|
+
exitCode: number;
|
|
164
|
+
};
|
|
165
|
+
/**
|
|
166
|
+
* Removes one or more installed packages.
|
|
167
|
+
*
|
|
168
|
+
* Package files are deleted from the VFS. Config files (paths under
|
|
169
|
+
* `/etc/` or ending in `.conf`) are preserved unless `opts.purge` is set.
|
|
170
|
+
* The `onRemove` hook is called for each package.
|
|
171
|
+
*
|
|
172
|
+
* @param names Package names to remove.
|
|
173
|
+
* @param opts Removal options.
|
|
174
|
+
* @param opts.purge Also delete configuration files when `true`.
|
|
175
|
+
* @param opts.quiet Suppress progress output lines when `true`.
|
|
176
|
+
* @returns Terminal-style `output` string and exit code (`0` on success).
|
|
177
|
+
*/
|
|
178
|
+
remove(names: string[], opts?: {
|
|
179
|
+
purge?: boolean;
|
|
180
|
+
quiet?: boolean;
|
|
181
|
+
}): {
|
|
182
|
+
output: string;
|
|
183
|
+
exitCode: number;
|
|
184
|
+
};
|
|
185
|
+
/**
|
|
186
|
+
* Searches the registry for packages whose name or description contains
|
|
187
|
+
* the given term (case-insensitive). Equivalent to `apt-cache search`.
|
|
188
|
+
*
|
|
189
|
+
* @param term Search string.
|
|
190
|
+
* @returns Matching `PackageDefinition` entries sorted alphabetically.
|
|
191
|
+
*/
|
|
192
|
+
search(term: string): PackageDefinition[];
|
|
193
|
+
/**
|
|
194
|
+
* Returns a dpkg-style metadata block for a package, including its
|
|
195
|
+
* install status. Equivalent to `apt-cache show` / `dpkg -s`.
|
|
196
|
+
*
|
|
197
|
+
* @param name Package name.
|
|
198
|
+
* @returns Multi-line metadata string, or `null` if not in the registry.
|
|
199
|
+
*/
|
|
200
|
+
show(name: string): string | null;
|
|
201
|
+
}
|
|
202
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/VirtualPackageManager/index.ts"],"names":[],"mappings":"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"}
|