@fredlackey/devutils 0.0.14 → 0.0.15

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.
@@ -0,0 +1,913 @@
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * @fileoverview Install Google Antigravity - AI-powered IDE developed by Google.
5
+ * @module installs/google-antigravity
6
+ *
7
+ * Google Antigravity is an AI-powered integrated development environment (IDE)
8
+ * developed by Google, announced on November 18, 2025 alongside Gemini 3. It
9
+ * is a heavily modified fork of Visual Studio Code that provides autonomous
10
+ * AI agents powered by Gemini 3 Pro, Gemini 3 Deep Think, and Gemini 3 Flash.
11
+ *
12
+ * Key features:
13
+ * - Agent Manager View: Spawn multiple AI agents to work on tasks simultaneously
14
+ * - Browser Orchestration: Headless Chrome instance for automatic web testing
15
+ * - Artifacts System: Agents generate task lists, plans, screenshots, and recordings
16
+ * - 1 Million Token Context Window: Understand entire codebases
17
+ * - MCP Integration: Connect to databases, APIs, and external tools
18
+ *
19
+ * This installer provides:
20
+ * - macOS: Antigravity via Homebrew cask
21
+ * - Ubuntu/Debian: Antigravity via Google's APT repository
22
+ * - Raspberry Pi OS: Antigravity via Google's APT repository (ARM64 only)
23
+ * - Amazon Linux/RHEL: Antigravity via Google's RPM repository
24
+ * - Windows: Antigravity via winget (preferred) or Chocolatey
25
+ * - WSL (Ubuntu): Installs on Windows host via winget
26
+ * - Git Bash: Installs on Windows host via winget
27
+ *
28
+ * IMPORTANT PLATFORM NOTES:
29
+ * - All platforms require 64-bit architecture
30
+ * - Raspberry Pi OS requires 64-bit (ARM64/aarch64) - 32-bit is not supported
31
+ * - A Google Account is required to activate Gemini 3 Pro features
32
+ * - At least 8 GB RAM recommended (16 GB for optimal performance)
33
+ */
34
+
35
+ const os = require('../utils/common/os');
36
+ const shell = require('../utils/common/shell');
37
+ const brew = require('../utils/macos/brew');
38
+ const winget = require('../utils/windows/winget');
39
+ const macosApps = require('../utils/macos/apps');
40
+
41
+ /**
42
+ * Indicates whether this installer requires a desktop environment.
43
+ * Google Antigravity is a GUI application and requires a display.
44
+ * @type {boolean}
45
+ */
46
+ const REQUIRES_DESKTOP = true;
47
+
48
+ /**
49
+ * The name of the Antigravity application bundle on macOS.
50
+ * Used to check if Antigravity is already installed in /Applications.
51
+ */
52
+ const MACOS_APP_NAME = 'Antigravity';
53
+
54
+ /**
55
+ * The Homebrew cask name for Google Antigravity on macOS.
56
+ * This installs the full Antigravity application to /Applications.
57
+ */
58
+ const HOMEBREW_CASK_NAME = 'antigravity';
59
+
60
+ /**
61
+ * The winget package ID for Google Antigravity on Windows.
62
+ * This is the official Antigravity package from Google.
63
+ */
64
+ const WINGET_PACKAGE_ID = 'Google.Antigravity';
65
+
66
+ /**
67
+ * The Chocolatey package name for Google Antigravity on Windows.
68
+ * This is an alternative to winget for Windows installations.
69
+ */
70
+ const CHOCO_PACKAGE_NAME = 'antigravity';
71
+
72
+ /**
73
+ * The APT package name for Google Antigravity on Debian-based systems.
74
+ * This is the package name used in Google's repository.
75
+ */
76
+ const APT_PACKAGE_NAME = 'antigravity';
77
+
78
+ /**
79
+ * Google's GPG key URL for package verification.
80
+ * This key is used to verify the authenticity of Antigravity packages.
81
+ */
82
+ const GOOGLE_GPG_KEY_URL = 'https://us-central1-apt.pkg.dev/doc/repo-signing-key.gpg';
83
+
84
+ /**
85
+ * Google's APT repository URL for Antigravity.
86
+ * This repository contains the Antigravity packages for Debian-based systems.
87
+ */
88
+ const GOOGLE_APT_REPO_URL = 'https://us-central1-apt.pkg.dev/projects/antigravity-auto-updater-dev/';
89
+
90
+ /**
91
+ * Google's RPM repository URL for Antigravity.
92
+ * This repository contains the Antigravity packages for RHEL-based systems.
93
+ */
94
+ const GOOGLE_RPM_REPO_URL = 'https://us-central1-yum.pkg.dev/projects/antigravity-auto-updater-dev/antigravity-rpm';
95
+
96
+ /**
97
+ * Check if the Antigravity CLI command is available in PATH.
98
+ *
99
+ * Antigravity provides two command names: 'antigravity' and 'agy' (short alias).
100
+ * This function checks for either command.
101
+ *
102
+ * @returns {boolean} True if the antigravity or agy command is available
103
+ */
104
+ function isAntigravityCommandAvailable() {
105
+ return shell.commandExists('antigravity') || shell.commandExists('agy');
106
+ }
107
+
108
+ /**
109
+ * Check if Antigravity is installed and get the version.
110
+ *
111
+ * Executes 'antigravity --version' to verify Antigravity is properly installed
112
+ * and operational. Returns the version string if successful.
113
+ *
114
+ * @returns {Promise<string|null>} Antigravity version string, or null if not installed
115
+ */
116
+ async function getAntigravityVersion() {
117
+ // Try the full command name first, then the short alias
118
+ const commands = ['antigravity', 'agy'];
119
+
120
+ for (const cmd of commands) {
121
+ if (shell.commandExists(cmd)) {
122
+ const result = await shell.exec(`${cmd} --version`);
123
+ if (result.code === 0 && result.stdout) {
124
+ // Output format: First line is typically the version
125
+ const lines = result.stdout.trim().split('\n');
126
+ return lines[0] || null;
127
+ }
128
+ }
129
+ }
130
+
131
+ return null;
132
+ }
133
+
134
+ /**
135
+ * Set up Google's APT repository for Antigravity on Ubuntu/Debian.
136
+ *
137
+ * This function:
138
+ * 1. Installs prerequisites (curl, gpg, apt-transport-https)
139
+ * 2. Creates the keyrings directory if it doesn't exist
140
+ * 3. Imports Google's GPG key for package verification
141
+ * 4. Adds Google's Antigravity repository to APT sources
142
+ * 5. Updates the package cache
143
+ *
144
+ * @param {boolean} [isArm64=false] - Whether to specify ARM64 architecture
145
+ * @returns {Promise<void>}
146
+ * @throws {Error} If any step fails
147
+ */
148
+ async function setupGoogleAptRepository(isArm64 = false) {
149
+ console.log('Setting up Google APT repository for Antigravity...');
150
+
151
+ // Install prerequisites needed to download and verify the repository
152
+ console.log('Installing prerequisites (curl, gpg, apt-transport-https)...');
153
+ const prereqResult = await shell.exec(
154
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get update -y && ' +
155
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y curl gpg apt-transport-https'
156
+ );
157
+ if (prereqResult.code !== 0) {
158
+ throw new Error(`Failed to install prerequisites: ${prereqResult.stderr}`);
159
+ }
160
+
161
+ // Create the keyrings directory if it doesn't exist
162
+ console.log('Creating keyrings directory...');
163
+ const mkdirResult = await shell.exec('sudo mkdir -p /etc/apt/keyrings');
164
+ if (mkdirResult.code !== 0) {
165
+ throw new Error(`Failed to create keyrings directory: ${mkdirResult.stderr}`);
166
+ }
167
+
168
+ // Download and import Google's GPG key
169
+ console.log('Importing Google GPG key...');
170
+ const gpgResult = await shell.exec(
171
+ `curl -fsSL ${GOOGLE_GPG_KEY_URL} | sudo gpg --dearmor -o /etc/apt/keyrings/antigravity-repo-key.gpg`
172
+ );
173
+ if (gpgResult.code !== 0) {
174
+ throw new Error(`Failed to import Google GPG key: ${gpgResult.stderr}`);
175
+ }
176
+
177
+ // Set proper permissions on the keyring file
178
+ await shell.exec('sudo chmod 644 /etc/apt/keyrings/antigravity-repo-key.gpg');
179
+
180
+ // Add Google's APT repository
181
+ // For ARM64 systems (Raspberry Pi), specify the architecture explicitly
182
+ console.log('Adding Google Antigravity repository...');
183
+ const archSpec = isArm64 ? ' arch=arm64' : '';
184
+ const repoEntry = `deb [signed-by=/etc/apt/keyrings/antigravity-repo-key.gpg${archSpec}] ${GOOGLE_APT_REPO_URL} antigravity-debian main`;
185
+
186
+ const repoResult = await shell.exec(
187
+ `echo "${repoEntry}" | sudo tee /etc/apt/sources.list.d/antigravity.list > /dev/null`
188
+ );
189
+ if (repoResult.code !== 0) {
190
+ throw new Error(`Failed to add Google repository: ${repoResult.stderr}`);
191
+ }
192
+
193
+ // Update package cache to include the new repository
194
+ console.log('Updating package cache...');
195
+ const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
196
+ if (updateResult.code !== 0) {
197
+ throw new Error(`Failed to update package cache: ${updateResult.stderr}`);
198
+ }
199
+
200
+ console.log('Google APT repository configured successfully.');
201
+ }
202
+
203
+ /**
204
+ * Set up Google's RPM repository for Antigravity on Amazon Linux/RHEL.
205
+ *
206
+ * This function creates the repository configuration file that points
207
+ * to Google's RPM repository for Antigravity packages.
208
+ *
209
+ * @returns {Promise<void>}
210
+ * @throws {Error} If any step fails
211
+ */
212
+ async function setupGoogleRpmRepository() {
213
+ console.log('Setting up Google RPM repository for Antigravity...');
214
+
215
+ // Create the repository configuration file
216
+ // Note: gpgcheck is disabled as per the installation documentation
217
+ const repoContent = `[antigravity-rpm]
218
+ name=Antigravity RPM Repository
219
+ baseurl=${GOOGLE_RPM_REPO_URL}
220
+ enabled=1
221
+ gpgcheck=0`;
222
+
223
+ console.log('Adding Google Antigravity repository...');
224
+ const repoResult = await shell.exec(
225
+ `sudo tee /etc/yum.repos.d/antigravity.repo << 'EOF' > /dev/null
226
+ ${repoContent}
227
+ EOF`
228
+ );
229
+ if (repoResult.code !== 0) {
230
+ throw new Error(`Failed to add Google repository: ${repoResult.stderr}`);
231
+ }
232
+
233
+ console.log('Google RPM repository configured successfully.');
234
+ }
235
+
236
+ /**
237
+ * Install Google Antigravity on macOS using Homebrew cask.
238
+ *
239
+ * Prerequisites:
240
+ * - macOS 11 (Big Sur) or later
241
+ * - Homebrew package manager installed
242
+ * - Apple Silicon (M1/M2/M3/M4) or Intel processor (both x64 and ARM64 supported)
243
+ *
244
+ * This function installs Antigravity as a macOS application via Homebrew cask.
245
+ * After installation, Antigravity is available in /Applications/Antigravity.app.
246
+ *
247
+ * @returns {Promise<void>}
248
+ */
249
+ async function install_macos() {
250
+ console.log('Checking if Google Antigravity is already installed...');
251
+
252
+ // Check if Antigravity app bundle exists in /Applications
253
+ const isAppInstalled = macosApps.isAppInstalled(MACOS_APP_NAME);
254
+ if (isAppInstalled) {
255
+ const version = await getAntigravityVersion();
256
+ console.log(`Google Antigravity ${version || 'unknown version'} is already installed, skipping...`);
257
+ return;
258
+ }
259
+
260
+ // Also check if Antigravity is installed via Homebrew cask
261
+ const isCaskInstalled = await brew.isCaskInstalled(HOMEBREW_CASK_NAME);
262
+ if (isCaskInstalled) {
263
+ console.log('Google Antigravity is already installed via Homebrew, skipping...');
264
+ return;
265
+ }
266
+
267
+ // Verify Homebrew is available - it is required for macOS installation
268
+ if (!brew.isInstalled()) {
269
+ console.log('Homebrew is not installed. Please install Homebrew first.');
270
+ console.log('Run: dev install homebrew');
271
+ return;
272
+ }
273
+
274
+ // Install Antigravity using Homebrew cask
275
+ console.log('Installing Google Antigravity via Homebrew...');
276
+ const result = await brew.installCask(HOMEBREW_CASK_NAME);
277
+
278
+ if (!result.success) {
279
+ console.log('Failed to install Google Antigravity via Homebrew.');
280
+ console.log(result.output);
281
+ console.log('');
282
+ console.log('Troubleshooting:');
283
+ console.log(' 1. Run "brew update && brew cleanup" and retry');
284
+ console.log(' 2. If the cask is unavailable, try updating Homebrew: brew update');
285
+ console.log(' 3. Try manual installation: brew install --cask antigravity');
286
+ return;
287
+ }
288
+
289
+ // Verify the installation succeeded
290
+ const verified = macosApps.isAppInstalled(MACOS_APP_NAME);
291
+ if (!verified) {
292
+ console.log('Installation may have failed: Antigravity.app not found after install.');
293
+ return;
294
+ }
295
+
296
+ console.log('Google Antigravity installed successfully via Homebrew.');
297
+ console.log('');
298
+ console.log('The application is available at /Applications/Antigravity.app');
299
+ console.log('');
300
+ console.log('NOTE: If "antigravity" or "agy" command is not found, you can add it to PATH by:');
301
+ console.log(' 1. Launch Antigravity');
302
+ console.log(' 2. Open Command Palette (Cmd+Shift+P)');
303
+ console.log(' 3. Run "Shell Command: Install \'antigravity\' command in PATH"');
304
+ console.log('');
305
+ console.log('After first launch, sign in with your Google Account to activate Gemini 3 Pro features.');
306
+ }
307
+
308
+ /**
309
+ * Install Google Antigravity on Ubuntu/Debian using APT with Google's repository.
310
+ *
311
+ * Prerequisites:
312
+ * - Ubuntu 20.04 (Focal) or later, or Debian 10 (Buster) or later (64-bit)
313
+ * - glibc >= 2.28 and glibcxx >= 3.4.25 (met by Ubuntu 20.04+, Debian 10+)
314
+ * - sudo privileges
315
+ * - Active internet connection
316
+ *
317
+ * This function adds Google's APT repository and installs Antigravity.
318
+ * After installation, Antigravity is available via the 'antigravity' or 'agy' command.
319
+ *
320
+ * @returns {Promise<void>}
321
+ */
322
+ async function install_ubuntu() {
323
+ console.log('Checking if Google Antigravity is already installed...');
324
+
325
+ // Check if Antigravity command is already available
326
+ if (isAntigravityCommandAvailable()) {
327
+ const version = await getAntigravityVersion();
328
+ console.log(`Google Antigravity ${version || 'unknown version'} is already installed, skipping...`);
329
+ return;
330
+ }
331
+
332
+ // Set up Google's APT repository
333
+ try {
334
+ await setupGoogleAptRepository();
335
+ } catch (error) {
336
+ console.log(`Failed to set up Google repository: ${error.message}`);
337
+ return;
338
+ }
339
+
340
+ // Install Antigravity from the Google repository
341
+ console.log('Installing Google Antigravity via APT...');
342
+ const installResult = await shell.exec(
343
+ `sudo DEBIAN_FRONTEND=noninteractive apt-get install -y ${APT_PACKAGE_NAME}`
344
+ );
345
+
346
+ if (installResult.code !== 0) {
347
+ console.log('Failed to install Google Antigravity via APT.');
348
+ console.log(installResult.stderr || installResult.stdout);
349
+ console.log('');
350
+ console.log('Troubleshooting:');
351
+ console.log(' 1. Run "sudo apt-get update" and retry');
352
+ console.log(' 2. Check if the Google repository was added:');
353
+ console.log(' cat /etc/apt/sources.list.d/antigravity.list');
354
+ console.log(' 3. Verify the GPG key exists: ls -la /etc/apt/keyrings/antigravity-repo-key.gpg');
355
+ return;
356
+ }
357
+
358
+ // Verify the installation succeeded
359
+ const version = await getAntigravityVersion();
360
+ if (!version) {
361
+ console.log('Installation may have failed: antigravity command not found after install.');
362
+ return;
363
+ }
364
+
365
+ console.log('Google Antigravity installed successfully.');
366
+ console.log('');
367
+ console.log(`Antigravity version: ${version}`);
368
+ console.log('');
369
+ console.log('Launch Antigravity with: antigravity (or agy)');
370
+ console.log('');
371
+ console.log('After first launch, sign in with your Google Account to activate Gemini 3 Pro features.');
372
+ }
373
+
374
+ /**
375
+ * Install Google Antigravity on Ubuntu running in WSL (Windows Subsystem for Linux).
376
+ *
377
+ * Prerequisites:
378
+ * - Windows 10 version 2004 or later, or Windows 11
379
+ * - WSL 2 enabled with Ubuntu distribution installed
380
+ * - Antigravity installed on Windows host (this function handles the installation)
381
+ *
382
+ * IMPORTANT: Antigravity runs on Windows and connects to WSL using remote
383
+ * development capabilities. You do not install Antigravity inside WSL itself.
384
+ * This function installs Antigravity on the Windows host via winget.
385
+ *
386
+ * @returns {Promise<void>}
387
+ */
388
+ async function install_ubuntu_wsl() {
389
+ console.log('Detected Ubuntu running in WSL (Windows Subsystem for Linux).');
390
+ console.log('');
391
+ console.log('Antigravity should be installed on Windows and connected to WSL');
392
+ console.log('using remote development capabilities.');
393
+ console.log('');
394
+
395
+ // Check if Antigravity is already installed on Windows host
396
+ const checkResult = await shell.exec(
397
+ `winget.exe list --exact --id "${WINGET_PACKAGE_ID}" 2>/dev/null`
398
+ );
399
+
400
+ if (checkResult.code === 0 && checkResult.stdout.includes(WINGET_PACKAGE_ID)) {
401
+ console.log('Google Antigravity is already installed on Windows.');
402
+ console.log('');
403
+ console.log('To connect to WSL from Antigravity:');
404
+ console.log(' 1. Launch Antigravity on Windows');
405
+ console.log(' 2. Click the green remote icon in the bottom-left corner');
406
+ console.log(' 3. Select "Connect to WSL" and choose your distribution');
407
+ return;
408
+ }
409
+
410
+ // Verify winget is accessible from WSL
411
+ const wingetExists = shell.commandExists('winget.exe');
412
+ if (!wingetExists) {
413
+ console.log('winget is required to install Antigravity from WSL.');
414
+ console.log('winget should be available if you are running Windows 10 1809+ or Windows 11.');
415
+ console.log('');
416
+ console.log('Alternatively, install Antigravity directly from Windows PowerShell:');
417
+ console.log(' winget install --id Google.Antigravity --silent --accept-package-agreements --accept-source-agreements');
418
+ return;
419
+ }
420
+
421
+ console.log('Installing Google Antigravity on Windows host via winget...');
422
+
423
+ // Install Antigravity on Windows using winget.exe from within WSL
424
+ const installResult = await shell.exec(
425
+ `winget.exe install --id "${WINGET_PACKAGE_ID}" --silent --accept-package-agreements --accept-source-agreements`
426
+ );
427
+
428
+ if (installResult.code !== 0) {
429
+ console.log('Failed to install Google Antigravity.');
430
+ console.log(installResult.stderr || installResult.stdout);
431
+ return;
432
+ }
433
+
434
+ console.log('Google Antigravity installed successfully on Windows.');
435
+ console.log('');
436
+ console.log('To use Antigravity with WSL:');
437
+ console.log(' 1. Open Antigravity on Windows');
438
+ console.log(' 2. Click the green remote icon in the bottom-left corner');
439
+ console.log(' 3. Select "Connect to WSL" and choose your distribution');
440
+ console.log('');
441
+ console.log('After first launch, sign in with your Google Account to activate Gemini 3 Pro features.');
442
+ }
443
+
444
+ /**
445
+ * Install Google Antigravity on Raspberry Pi OS using APT.
446
+ *
447
+ * Prerequisites:
448
+ * - Raspberry Pi OS (64-bit) - ARM64/aarch64 architecture REQUIRED
449
+ * - Raspberry Pi 4 or later with 4 GB or more RAM (8 GB strongly recommended)
450
+ * - Raspberry Pi OS Bullseye (11) or later
451
+ * - sudo privileges
452
+ * - Active internet connection
453
+ *
454
+ * CRITICAL: Antigravity requires a 64-bit operating system. 32-bit Raspberry Pi OS
455
+ * (armv7l architecture) is NOT supported.
456
+ *
457
+ * @returns {Promise<void>}
458
+ */
459
+ async function install_raspbian() {
460
+ console.log('Checking if Google Antigravity is already installed...');
461
+
462
+ // Check if Antigravity command is already available
463
+ if (isAntigravityCommandAvailable()) {
464
+ const version = await getAntigravityVersion();
465
+ console.log(`Google Antigravity ${version || 'unknown version'} is already installed, skipping...`);
466
+ return;
467
+ }
468
+
469
+ // Critical architecture check - Antigravity requires 64-bit ARM
470
+ const arch = os.getArch();
471
+ console.log(`Detected architecture: ${arch}`);
472
+
473
+ if (arch !== 'arm64') {
474
+ console.log('');
475
+ console.log('Google Antigravity requires 64-bit Raspberry Pi OS (ARM64/aarch64).');
476
+ console.log(`Your system architecture is ${arch}.`);
477
+ console.log('');
478
+ console.log('Please install 64-bit Raspberry Pi OS from:');
479
+ console.log(' https://www.raspberrypi.com/software/');
480
+ return;
481
+ }
482
+
483
+ // Set up Google's APT repository with ARM64 architecture specified
484
+ try {
485
+ await setupGoogleAptRepository(true); // true = ARM64
486
+ } catch (error) {
487
+ console.log(`Failed to set up Google repository: ${error.message}`);
488
+ return;
489
+ }
490
+
491
+ // Install Antigravity from the Google repository
492
+ console.log('Installing Google Antigravity via APT...');
493
+ const installResult = await shell.exec(
494
+ `sudo DEBIAN_FRONTEND=noninteractive apt-get install -y ${APT_PACKAGE_NAME}`
495
+ );
496
+
497
+ if (installResult.code !== 0) {
498
+ console.log('Failed to install Google Antigravity via APT.');
499
+ console.log(installResult.stderr || installResult.stdout);
500
+ console.log('');
501
+ console.log('Troubleshooting:');
502
+ console.log(' 1. Ensure you are running 64-bit Raspberry Pi OS (uname -m should show aarch64)');
503
+ console.log(' 2. Run "sudo apt-get update" and retry');
504
+ console.log(' 3. Check if the Google repository was added:');
505
+ console.log(' cat /etc/apt/sources.list.d/antigravity.list');
506
+ return;
507
+ }
508
+
509
+ // Verify the installation succeeded
510
+ const version = await getAntigravityVersion();
511
+ if (!version) {
512
+ console.log('Installation may have failed: antigravity command not found after install.');
513
+ return;
514
+ }
515
+
516
+ console.log('Google Antigravity installed successfully.');
517
+ console.log('');
518
+ console.log(`Antigravity version: ${version}`);
519
+ console.log('');
520
+ console.log('NOTE: Raspberry Pi has limited resources compared to desktop systems.');
521
+ console.log('For best performance:');
522
+ console.log(' - Ensure you have at least 4 GB RAM (8 GB recommended)');
523
+ console.log(' - Close other applications when using AI features');
524
+ console.log(' - Consider increasing swap if you experience memory issues');
525
+ console.log('');
526
+ console.log('Launch Antigravity with: antigravity (or agy)');
527
+ console.log('');
528
+ console.log('After first launch, sign in with your Google Account to activate Gemini 3 Pro features.');
529
+ }
530
+
531
+ /**
532
+ * Install Google Antigravity on Amazon Linux/RHEL using DNF or YUM.
533
+ *
534
+ * Prerequisites:
535
+ * - Amazon Linux 2023 (AL2023), RHEL 8+, Fedora 36+, or CentOS Stream 8+
536
+ * - glibc >= 2.28 (Amazon Linux 2023, RHEL 8+, Fedora 36+ meet this requirement)
537
+ * - sudo privileges
538
+ * - Active internet connection
539
+ * - Desktop environment (Antigravity is a GUI application)
540
+ *
541
+ * This function automatically detects whether the system uses DNF (AL2023, RHEL 8+)
542
+ * or YUM (older systems) and uses the appropriate package manager.
543
+ *
544
+ * @returns {Promise<void>}
545
+ */
546
+ async function install_amazon_linux() {
547
+ console.log('Checking if Google Antigravity is already installed...');
548
+
549
+ // Check if Antigravity command is already available
550
+ if (isAntigravityCommandAvailable()) {
551
+ const version = await getAntigravityVersion();
552
+ console.log(`Google Antigravity ${version || 'unknown version'} is already installed, skipping...`);
553
+ return;
554
+ }
555
+
556
+ // Detect package manager (dnf for AL2023/RHEL8+, yum for AL2)
557
+ const hasDnf = shell.commandExists('dnf');
558
+ const hasYum = shell.commandExists('yum');
559
+ const packageManager = hasDnf ? 'dnf' : (hasYum ? 'yum' : null);
560
+
561
+ if (!packageManager) {
562
+ console.log('Neither dnf nor yum package manager found.');
563
+ console.log('This installer supports Amazon Linux 2023 (dnf), Amazon Linux 2 (yum), RHEL 8+, and Fedora.');
564
+ return;
565
+ }
566
+
567
+ console.log(`Detected package manager: ${packageManager}`);
568
+
569
+ // Set up Google's RPM repository
570
+ try {
571
+ await setupGoogleRpmRepository();
572
+ } catch (error) {
573
+ console.log(`Failed to set up Google repository: ${error.message}`);
574
+ return;
575
+ }
576
+
577
+ // Update package cache
578
+ console.log('Updating package cache...');
579
+ await shell.exec(`sudo ${packageManager} makecache`);
580
+
581
+ // Install Antigravity
582
+ console.log(`Installing Google Antigravity via ${packageManager}...`);
583
+ const installResult = await shell.exec(
584
+ `sudo ${packageManager} install -y ${APT_PACKAGE_NAME}`
585
+ );
586
+
587
+ if (installResult.code !== 0) {
588
+ console.log(`Failed to install Google Antigravity via ${packageManager}.`);
589
+ console.log(installResult.stderr || installResult.stdout);
590
+ console.log('');
591
+ console.log('Troubleshooting:');
592
+ console.log(' 1. Verify the repository was added correctly:');
593
+ console.log(' cat /etc/yum.repos.d/antigravity.repo');
594
+ console.log(` 2. Try: sudo ${packageManager} install -y antigravity`);
595
+ console.log(' 3. Ensure you have a desktop environment installed for GUI applications');
596
+ return;
597
+ }
598
+
599
+ // Verify the installation succeeded
600
+ const version = await getAntigravityVersion();
601
+ if (!version) {
602
+ console.log('Installation may have failed: antigravity command not found after install.');
603
+ return;
604
+ }
605
+
606
+ console.log('Google Antigravity installed successfully.');
607
+ console.log('');
608
+ console.log(`Antigravity version: ${version}`);
609
+ console.log('');
610
+ console.log('NOTE: Antigravity is a GUI application and requires a desktop environment.');
611
+ console.log('If you are on a headless server, you can use X11 forwarding:');
612
+ console.log(' ssh -X user@server');
613
+ console.log(' antigravity');
614
+ console.log('');
615
+ console.log('Launch Antigravity with: antigravity (or agy)');
616
+ console.log('');
617
+ console.log('After first launch, sign in with your Google Account to activate Gemini 3 Pro features.');
618
+ }
619
+
620
+ /**
621
+ * Install Google Antigravity on Windows using winget (preferred) or Chocolatey.
622
+ *
623
+ * Prerequisites:
624
+ * - Windows 10 version 1809 or later (64-bit), or Windows 11
625
+ * - winget package manager (pre-installed on Windows 10 1809+ and Windows 11)
626
+ * - Administrator privileges recommended
627
+ * - Active internet connection
628
+ *
629
+ * This function uses winget to install Antigravity. Winget is the preferred
630
+ * package manager as it is built into modern Windows versions.
631
+ *
632
+ * @returns {Promise<void>}
633
+ */
634
+ async function install_windows() {
635
+ console.log('Checking if Google Antigravity is already installed...');
636
+
637
+ // Check if Antigravity is already installed via winget
638
+ const isInstalledViaWinget = await winget.isPackageInstalled(WINGET_PACKAGE_ID);
639
+ if (isInstalledViaWinget) {
640
+ const version = await getAntigravityVersion();
641
+ console.log(`Google Antigravity ${version || 'unknown version'} is already installed via winget, skipping...`);
642
+ return;
643
+ }
644
+
645
+ // Also check if the antigravity command exists (may have been installed by other means)
646
+ if (isAntigravityCommandAvailable()) {
647
+ const version = await getAntigravityVersion();
648
+ console.log(`Google Antigravity ${version || 'unknown version'} is already installed, skipping...`);
649
+ console.log('');
650
+ console.log('Note: Antigravity was not installed via winget.');
651
+ console.log('If you want to manage it with winget, first uninstall the existing version.');
652
+ return;
653
+ }
654
+
655
+ // Verify winget is available
656
+ if (!winget.isInstalled()) {
657
+ console.log('winget is required to install Google Antigravity on Windows.');
658
+ console.log('winget is included with Windows 10 version 1809 and later.');
659
+ console.log('');
660
+ console.log('You can install it from the Microsoft Store (App Installer):');
661
+ console.log(' start ms-windows-store://pdp/?productid=9NBLGGH4NNS1');
662
+ console.log('');
663
+ console.log('Alternatively, you can use Chocolatey if installed:');
664
+ console.log(' choco install antigravity -y');
665
+ return;
666
+ }
667
+
668
+ console.log('Installing Google Antigravity via winget...');
669
+ console.log('This may take a few minutes...');
670
+
671
+ // Install Antigravity using winget with silent flags and auto-accept agreements
672
+ const result = await winget.install(WINGET_PACKAGE_ID);
673
+
674
+ if (!result.success) {
675
+ console.log('Failed to install Google Antigravity via winget.');
676
+ console.log(result.output);
677
+ console.log('');
678
+ console.log('Troubleshooting:');
679
+ console.log(' 1. Ensure you are running as Administrator');
680
+ console.log(' 2. Try: winget install --id Google.Antigravity --silent --accept-package-agreements --accept-source-agreements');
681
+ console.log(' 3. Alternatively, use Chocolatey: choco install antigravity -y');
682
+ return;
683
+ }
684
+
685
+ console.log('Google Antigravity installed successfully via winget.');
686
+ console.log('');
687
+ console.log('IMPORTANT: Close and reopen your terminal for PATH changes to take effect.');
688
+ console.log('');
689
+ console.log('You can launch Antigravity from:');
690
+ console.log(' - The Start Menu (search for "Antigravity")');
691
+ console.log(' - The command line: antigravity (or agy)');
692
+ console.log('');
693
+ console.log('After first launch, sign in with your Google Account to activate Gemini 3 Pro features.');
694
+ }
695
+
696
+ /**
697
+ * Install Google Antigravity from Git Bash on Windows.
698
+ *
699
+ * Git Bash runs within Windows and inherits the Windows PATH, so once
700
+ * Antigravity is installed on Windows, the 'antigravity' command is
701
+ * automatically available in Git Bash.
702
+ *
703
+ * This function installs Antigravity on the Windows host using winget
704
+ * via the winget.exe command available from Git Bash.
705
+ *
706
+ * Prerequisites:
707
+ * - Windows 10 or Windows 11 (64-bit)
708
+ * - Git Bash installed (comes with Git for Windows)
709
+ * - winget available (pre-installed on Windows 10 1809+ and Windows 11)
710
+ *
711
+ * @returns {Promise<void>}
712
+ */
713
+ async function install_gitbash() {
714
+ console.log('Detected Git Bash on Windows.');
715
+ console.log('');
716
+
717
+ // Check if Antigravity is already installed
718
+ // Try winget first (works in Git Bash as winget.exe)
719
+ const checkResult = await shell.exec(
720
+ `winget.exe list --exact --id "${WINGET_PACKAGE_ID}" 2>/dev/null`
721
+ );
722
+
723
+ if (checkResult.code === 0 && checkResult.stdout.includes(WINGET_PACKAGE_ID)) {
724
+ console.log('Google Antigravity is already installed.');
725
+ return;
726
+ }
727
+
728
+ // Also check for the command directly
729
+ if (isAntigravityCommandAvailable()) {
730
+ const version = await getAntigravityVersion();
731
+ console.log(`Google Antigravity ${version || 'unknown version'} is already installed, skipping...`);
732
+ return;
733
+ }
734
+
735
+ // Verify winget is accessible from Git Bash
736
+ const wingetExists = shell.commandExists('winget.exe');
737
+ if (!wingetExists) {
738
+ console.log('winget is required to install Google Antigravity.');
739
+ console.log('winget should be available if you are running Windows 10 1809+ or Windows 11.');
740
+ console.log('');
741
+ console.log('Alternatively, you can use Chocolatey if installed:');
742
+ console.log(' choco.exe install antigravity -y');
743
+ return;
744
+ }
745
+
746
+ console.log('Installing Google Antigravity via winget...');
747
+ console.log('This may take a few minutes...');
748
+
749
+ // Install Antigravity using winget.exe
750
+ const installResult = await shell.exec(
751
+ `winget.exe install --id "${WINGET_PACKAGE_ID}" --silent --accept-package-agreements --accept-source-agreements`
752
+ );
753
+
754
+ if (installResult.code !== 0) {
755
+ console.log('Failed to install Google Antigravity.');
756
+ console.log(installResult.stderr || installResult.stdout);
757
+ console.log('');
758
+ console.log('Troubleshooting:');
759
+ console.log(' 1. Run Git Bash as Administrator and retry');
760
+ console.log(' 2. Try installing directly from PowerShell:');
761
+ console.log(' winget install --id Google.Antigravity --silent --accept-package-agreements --accept-source-agreements');
762
+ return;
763
+ }
764
+
765
+ console.log('Google Antigravity installed successfully.');
766
+ console.log('');
767
+ console.log('IMPORTANT: Close and reopen Git Bash for PATH changes to take effect.');
768
+ console.log('');
769
+ console.log('Git Bash tips:');
770
+ console.log(' - Launch Antigravity: antigravity (or agy)');
771
+ console.log(' - For interactive features, you may need: winpty antigravity');
772
+ console.log('');
773
+ console.log('After first launch, sign in with your Google Account to activate Gemini 3 Pro features.');
774
+ }
775
+
776
+ /**
777
+ * Check if Google Antigravity is installed on the current system.
778
+ *
779
+ * This function performs platform-specific checks to determine if Antigravity
780
+ * is already installed:
781
+ * - macOS: Checks for Antigravity.app in /Applications
782
+ * - Windows: Checks for winget package
783
+ * - WSL/Git Bash: Checks for winget.exe package on Windows host
784
+ * - Ubuntu/Debian/Raspberry Pi/Amazon Linux: Checks for antigravity command
785
+ *
786
+ * @returns {Promise<boolean>} True if Antigravity is installed
787
+ */
788
+ async function isInstalled() {
789
+ const platform = os.detect();
790
+
791
+ // macOS: Check for Antigravity.app
792
+ if (platform.type === 'macos') {
793
+ return macosApps.isAppInstalled(MACOS_APP_NAME);
794
+ }
795
+
796
+ // Windows: Check via winget
797
+ if (platform.type === 'windows') {
798
+ return await winget.isPackageInstalled(WINGET_PACKAGE_ID);
799
+ }
800
+
801
+ // WSL and Git Bash: Check via winget.exe on Windows host
802
+ if (platform.type === 'wsl' || platform.type === 'gitbash') {
803
+ const checkResult = await shell.exec(
804
+ `winget.exe list --exact --id "${WINGET_PACKAGE_ID}" 2>/dev/null`
805
+ );
806
+ return checkResult.code === 0 && checkResult.stdout.includes(WINGET_PACKAGE_ID);
807
+ }
808
+
809
+ // Ubuntu/Debian/Raspberry Pi/Amazon Linux: Check for antigravity command
810
+ if (['ubuntu', 'debian', 'raspbian', 'amazon_linux', 'rhel', 'fedora'].includes(platform.type)) {
811
+ return isAntigravityCommandAvailable();
812
+ }
813
+
814
+ return false;
815
+ }
816
+
817
+ /**
818
+ * Check if this installer is supported on the current platform.
819
+ *
820
+ * Google Antigravity is supported on all major platforms but requires a desktop
821
+ * environment since it is a GUI application. On headless servers or containers
822
+ * without a display, this function returns false.
823
+ *
824
+ * @returns {boolean} True if installation is supported on this platform
825
+ */
826
+ function isEligible() {
827
+ const platform = os.detect();
828
+
829
+ // First check if the platform is supported
830
+ const supportedPlatforms = ['macos', 'ubuntu', 'debian', 'wsl', 'raspbian', 'amazon_linux', 'fedora', 'rhel', 'windows', 'gitbash'];
831
+ if (!supportedPlatforms.includes(platform.type)) {
832
+ return false;
833
+ }
834
+
835
+ // This installer requires a desktop environment
836
+ if (REQUIRES_DESKTOP && !os.isDesktopAvailable()) {
837
+ return false;
838
+ }
839
+
840
+ return true;
841
+ }
842
+
843
+ /**
844
+ * Main installation entry point - detects platform and runs appropriate installer.
845
+ *
846
+ * This function detects the current operating system and dispatches to the
847
+ * appropriate platform-specific installer function. Google Antigravity is
848
+ * supported on all major platforms:
849
+ *
850
+ * - macOS: Homebrew cask
851
+ * - Ubuntu/Debian: APT with Google repository
852
+ * - Ubuntu on WSL: winget on Windows host
853
+ * - Raspberry Pi OS: APT with Google repository (ARM64 only)
854
+ * - Amazon Linux/RHEL: DNF/YUM with Google repository
855
+ * - Windows: winget (preferred)
856
+ * - Git Bash: winget on Windows host
857
+ *
858
+ * @returns {Promise<void>}
859
+ */
860
+ async function install() {
861
+ const platform = os.detect();
862
+
863
+ // Map platform types to their corresponding installer functions
864
+ // Multiple platform types can map to the same installer (e.g., debian and ubuntu)
865
+ const installers = {
866
+ 'macos': install_macos,
867
+ 'ubuntu': install_ubuntu,
868
+ 'debian': install_ubuntu,
869
+ 'wsl': install_ubuntu_wsl,
870
+ 'raspbian': install_raspbian,
871
+ 'amazon_linux': install_amazon_linux,
872
+ 'fedora': install_amazon_linux,
873
+ 'rhel': install_amazon_linux,
874
+ 'windows': install_windows,
875
+ 'gitbash': install_gitbash,
876
+ };
877
+
878
+ // Look up the installer for the detected platform
879
+ const installer = installers[platform.type];
880
+
881
+ // If no installer exists for this platform, inform the user gracefully
882
+ // Do NOT throw an error - per project requirements
883
+ if (!installer) {
884
+ console.log(`Google Antigravity is not available for ${platform.type}.`);
885
+ return;
886
+ }
887
+
888
+ // Run the platform-specific installer
889
+ await installer();
890
+ }
891
+
892
+ // Export all functions for use as a module and for testing
893
+ module.exports = {
894
+ REQUIRES_DESKTOP,
895
+ install,
896
+ isInstalled,
897
+ isEligible,
898
+ install_macos,
899
+ install_ubuntu,
900
+ install_ubuntu_wsl,
901
+ install_raspbian,
902
+ install_amazon_linux,
903
+ install_windows,
904
+ install_gitbash,
905
+ };
906
+
907
+ // Allow direct execution: node google-antigravity.js
908
+ if (require.main === module) {
909
+ install().catch(err => {
910
+ console.error(err.message);
911
+ process.exit(1);
912
+ });
913
+ }