@capawesome/cli 4.8.0 → 4.8.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.
package/CHANGELOG.md CHANGED
@@ -2,6 +2,22 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [commit-and-tag-version](https://github.com/absolute-version/commit-and-tag-version) for commit guidelines.
4
4
 
5
+ ## [4.8.2](https://github.com/capawesome-team/cli/compare/v4.8.1...v4.8.2) (2026-04-20)
6
+
7
+
8
+ ### Bug Fixes
9
+
10
+ * validate file existence before reading in `apps:certificates:create` and `apps:destinations:create` ([#151](https://github.com/capawesome-team/cli/issues/151)) ([5e9e405](https://github.com/capawesome-team/cli/commit/5e9e4055bce3f91026daba576c0c7a97b581c1ae))
11
+
12
+ ## [4.8.1](https://github.com/capawesome-team/cli/compare/v4.8.0...v4.8.1) (2026-04-12)
13
+
14
+
15
+ ### Bug Fixes
16
+
17
+ * **apps:** validate file count before zipping in `apps:builds:create` ([#149](https://github.com/capawesome-team/cli/issues/149)) ([75c20f3](https://github.com/capawesome-team/cli/commit/75c20f3716097c23f1698d000f04646fd93201a1))
18
+ * **deps:** update `axios` to version 1.15.0 ([9f3a801](https://github.com/capawesome-team/cli/commit/9f3a8014f4bd468ede3e40add3e98b79bec76634))
19
+ * improve error message handling for Axios v4 errors ([#150](https://github.com/capawesome-team/cli/issues/150)) ([ca7be4b](https://github.com/capawesome-team/cli/commit/ca7be4bcf75c7d6cb78eb39997b0b101e7e3eef7))
20
+
5
21
  ## [4.8.0](https://github.com/capawesome-team/cli/compare/v4.7.0...v4.8.0) (2026-04-08)
6
22
 
7
23
 
@@ -2,6 +2,7 @@ import appCertificatesService from '../../../services/app-certificates.js';
2
2
  import appProvisioningProfilesService from '../../../services/app-provisioning-profiles.js';
3
3
  import { withAuth } from '../../../utils/auth.js';
4
4
  import { isInteractive } from '../../../utils/environment.js';
5
+ import { fileExistsAtPath } from '../../../utils/file.js';
5
6
  import { prompt, promptAppSelection, promptOrganizationSelection } from '../../../utils/prompt.js';
6
7
  import { defineCommand, defineOptions } from '@robingenz/zli';
7
8
  import consola from 'consola';
@@ -130,12 +131,22 @@ export default defineCommand({
130
131
  provisioningProfile = [profilePath];
131
132
  }
132
133
  }
134
+ const fileExists = await fileExistsAtPath(file);
135
+ if (!fileExists) {
136
+ consola.error(`The certificate file was not found or is not accessible: ${file}`);
137
+ process.exit(1);
138
+ }
133
139
  const buffer = fs.readFileSync(file);
134
140
  const fileName = path.basename(file);
135
141
  // Upload provisioning profiles first
136
142
  const provisioningProfileIds = [];
137
143
  if (provisioningProfile && provisioningProfile.length > 0) {
138
144
  for (const profilePath of provisioningProfile) {
145
+ const profileExists = await fileExistsAtPath(profilePath);
146
+ if (!profileExists) {
147
+ consola.error(`The provisioning profile file was not found or is not accessible: ${profilePath}`);
148
+ process.exit(1);
149
+ }
139
150
  const profileBuffer = fs.readFileSync(profilePath);
140
151
  const profileFileName = path.basename(profilePath);
141
152
  const profile = await appProvisioningProfilesService.create({
@@ -3,6 +3,7 @@ import appDestinationsService from '../../../services/app-destinations.js';
3
3
  import appGoogleServiceAccountKeysService from '../../../services/app-google-service-account-keys.js';
4
4
  import { withAuth } from '../../../utils/auth.js';
5
5
  import { isInteractive } from '../../../utils/environment.js';
6
+ import { fileExistsAtPath } from '../../../utils/file.js';
6
7
  import { prompt, promptAppSelection, promptOrganizationSelection } from '../../../utils/prompt.js';
7
8
  import { defineCommand, defineOptions } from '@robingenz/zli';
8
9
  import consola from 'consola';
@@ -153,6 +154,11 @@ export default defineCommand({
153
154
  }
154
155
  }
155
156
  // Upload Google service account key file
157
+ const googleServiceAccountKeyFileExists = await fileExistsAtPath(googleServiceAccountKeyFile);
158
+ if (!googleServiceAccountKeyFileExists) {
159
+ consola.error(`The Google service account key file was not found or is not accessible: ${googleServiceAccountKeyFile}`);
160
+ process.exit(1);
161
+ }
156
162
  const buffer = fs.readFileSync(googleServiceAccountKeyFile);
157
163
  const fileName = path.basename(googleServiceAccountKeyFile);
158
164
  const key = await appGoogleServiceAccountKeysService.create({
@@ -205,6 +211,11 @@ export default defineCommand({
205
211
  }
206
212
  }
207
213
  // Upload Apple API key file
214
+ const appleApiKeyFileExists = await fileExistsAtPath(appleApiKeyFile);
215
+ if (!appleApiKeyFileExists) {
216
+ consola.error(`The Apple API key file was not found or is not accessible: ${appleApiKeyFile}`);
217
+ process.exit(1);
218
+ }
208
219
  const buffer = fs.readFileSync(appleApiKeyFile);
209
220
  const fileName = path.basename(appleApiKeyFile);
210
221
  const key = await appAppleApiKeysService.create({
@@ -40,7 +40,10 @@ const getErrorMessageFromAxiosError = (error) => {
40
40
  else if (error.response?.data?.message) {
41
41
  message = error.response?.data?.message;
42
42
  }
43
- else if (error.response?.data?.error?.issues[0]?.message) {
43
+ else if (Array.isArray(error.response?.data?.error) && (error.response?.data).error[0]?.message) {
44
+ message = (error.response?.data).error[0].message;
45
+ }
46
+ else if (error.response?.data?.error?.issues?.[0]?.message) {
44
47
  message = (error.response?.data).error.issues[0].message;
45
48
  }
46
49
  else if (error.response?.data && typeof error.response?.data === 'string') {
package/dist/utils/zip.js CHANGED
@@ -1,6 +1,8 @@
1
+ import { UserError } from '../utils/error.js';
1
2
  import AdmZip from 'adm-zip';
2
3
  import { globby } from 'globby';
3
4
  import path from 'path';
5
+ const MAX_ZIP_ENTRIES = 65535;
4
6
  class ZipImpl {
5
7
  async zipFolder(sourceFolder) {
6
8
  const zip = new AdmZip();
@@ -14,6 +16,10 @@ class ZipImpl {
14
16
  ignore: ['.git/**'],
15
17
  dot: true,
16
18
  });
19
+ if (files.length > MAX_ZIP_ENTRIES) {
20
+ throw new UserError(`The source folder contains ${files.length} files, which exceeds the ZIP limit of ${MAX_ZIP_ENTRIES} entries. ` +
21
+ `Make sure your .gitignore excludes large directories such as node_modules.`);
22
+ }
17
23
  const zip = new AdmZip();
18
24
  for (const file of files) {
19
25
  const filePath = path.join(sourceFolder, file);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@capawesome/cli",
3
- "version": "4.8.0",
3
+ "version": "4.8.2",
4
4
  "description": "The Capawesome Cloud Command Line Interface (CLI) to manage Live Updates and more.",
5
5
  "type": "module",
6
6
  "scripts": {
@@ -56,7 +56,7 @@
56
56
  "@robingenz/zli": "0.2.0",
57
57
  "@sentry/node": "8.55.0",
58
58
  "adm-zip": "0.5.16",
59
- "axios": "1.13.5",
59
+ "axios": "1.15.0",
60
60
  "axios-retry": "4.5.0",
61
61
  "c12": "3.3.3",
62
62
  "consola": "3.3.0",