@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({
|
package/dist/utils/error.js
CHANGED
|
@@ -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?.
|
|
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.
|
|
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.
|
|
59
|
+
"axios": "1.15.0",
|
|
60
60
|
"axios-retry": "4.5.0",
|
|
61
61
|
"c12": "3.3.3",
|
|
62
62
|
"consola": "3.3.0",
|