@eik/cli 3.1.2 → 3.1.4

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.
Files changed (79) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/classes/alias.js +108 -114
  3. package/classes/index.js +58 -58
  4. package/classes/integrity.js +89 -97
  5. package/classes/login.js +47 -47
  6. package/classes/meta.js +75 -77
  7. package/classes/ping.js +53 -53
  8. package/classes/publish/map.js +90 -91
  9. package/classes/publish/package/index.js +130 -130
  10. package/classes/publish/package/tasks/check-bundle-sizes.js +19 -21
  11. package/classes/publish/package/tasks/check-if-already-published.js +67 -72
  12. package/classes/publish/package/tasks/cleanup.js +17 -13
  13. package/classes/publish/package/tasks/create-temp-directory.js +17 -17
  14. package/classes/publish/package/tasks/create-zip-file.js +60 -65
  15. package/classes/publish/package/tasks/dry-run.js +15 -15
  16. package/classes/publish/package/tasks/save-metafile.js +17 -17
  17. package/classes/publish/package/tasks/task.js +7 -7
  18. package/classes/publish/package/tasks/upload-files.js +53 -56
  19. package/classes/publish/package/tasks/validate-input.js +24 -24
  20. package/classes/version.js +152 -163
  21. package/commands/alias.js +87 -87
  22. package/commands/index.js +24 -24
  23. package/commands/init.js +98 -105
  24. package/commands/integrity.js +52 -52
  25. package/commands/login.js +96 -98
  26. package/commands/map-alias.js +73 -73
  27. package/commands/map.js +72 -72
  28. package/commands/meta.js +49 -50
  29. package/commands/npm-alias.js +69 -69
  30. package/commands/package-alias.js +79 -80
  31. package/commands/ping.js +25 -25
  32. package/commands/publish.js +120 -124
  33. package/commands/version.js +86 -88
  34. package/formatters/alias.js +60 -63
  35. package/formatters/artifact.js +77 -77
  36. package/formatters/file.js +25 -25
  37. package/formatters/index.js +4 -4
  38. package/formatters/version.js +49 -51
  39. package/index.js +61 -61
  40. package/package.json +4 -7
  41. package/types/classes/alias.d.ts +1 -1
  42. package/types/classes/integrity.d.ts +1 -1
  43. package/types/classes/login.d.ts +1 -1
  44. package/types/classes/meta.d.ts +1 -1
  45. package/types/classes/ping.d.ts +1 -1
  46. package/types/classes/publish/map.d.ts +1 -1
  47. package/types/classes/publish/package/index.d.ts +11 -11
  48. package/types/classes/publish/package/tasks/check-bundle-sizes.d.ts +1 -1
  49. package/types/classes/publish/package/tasks/check-if-already-published.d.ts +1 -1
  50. package/types/classes/publish/package/tasks/cleanup.d.ts +1 -1
  51. package/types/classes/publish/package/tasks/create-temp-directory.d.ts +1 -1
  52. package/types/classes/publish/package/tasks/create-zip-file.d.ts +1 -1
  53. package/types/classes/publish/package/tasks/dry-run.d.ts +1 -1
  54. package/types/classes/publish/package/tasks/save-metafile.d.ts +1 -1
  55. package/types/classes/publish/package/tasks/task.d.ts +1 -1
  56. package/types/classes/publish/package/tasks/upload-files.d.ts +1 -1
  57. package/types/classes/publish/package/tasks/validate-input.d.ts +1 -1
  58. package/types/classes/version.d.ts +3 -3
  59. package/types/utils/hash/index.d.ts +3 -3
  60. package/types/utils/http/index.d.ts +4 -4
  61. package/types/utils/index.d.ts +3 -3
  62. package/types/utils/json/index.d.ts +3 -3
  63. package/types/utils/url.d.ts +6 -0
  64. package/utils/hash/file.js +4 -4
  65. package/utils/hash/files.js +9 -9
  66. package/utils/hash/index.js +3 -3
  67. package/utils/http/index.js +4 -4
  68. package/utils/http/integrity.js +18 -18
  69. package/utils/http/latest-version.js +37 -37
  70. package/utils/http/request.js +42 -42
  71. package/utils/http/versions.js +20 -20
  72. package/utils/index.js +3 -3
  73. package/utils/json/index.js +3 -3
  74. package/utils/json/read.js +26 -26
  75. package/utils/json/write-eik.js +17 -17
  76. package/utils/json/write.js +26 -28
  77. package/utils/logger.js +43 -43
  78. package/utils/type-title.js +3 -3
  79. package/utils/url.js +10 -0
@@ -1,102 +1,101 @@
1
1
  // @deprecated in favor of `alias` command
2
2
 
3
- import ora from 'ora';
4
- import semver from 'semver';
5
- import Alias from '../classes/alias.js';
6
- import { logger, getDefaults } from '../utils/index.js';
7
- import { Alias as AliasFormatter } from '../formatters/index.js';
3
+ import ora from "ora";
4
+ import semver from "semver";
5
+ import Alias from "../classes/alias.js";
6
+ import { logger, getDefaults } from "../utils/index.js";
7
+ import { Alias as AliasFormatter } from "../formatters/index.js";
8
8
 
9
- export const command = 'package-alias [name] [version] [alias]';
9
+ export const command = "package-alias [name] [version] [alias]";
10
10
 
11
- export const aliases = ['pkg-alias', 'pa'];
11
+ export const aliases = ["pkg-alias", "pa"];
12
12
 
13
13
  export const describe = `DEPRECATED: This command has been replaced by the alias command and will be removed in a future version. Create a semver major alias for a package as identified by its name and version. A package with the given name and version must already exist on asset server. Alias should be the semver major part of the package version. Eg. For a package of version 5.4.3, you should use 5 as the alias`;
14
14
 
15
15
  export const builder = (yargs) => {
16
- const defaults = getDefaults(yargs.argv.config || yargs.argv.cwd);
16
+ const defaults = getDefaults(yargs.argv.config || yargs.argv.cwd);
17
17
 
18
- yargs
19
- .positional('name', {
20
- describe: 'Name matching existing name for a package on Eik server',
21
- type: 'string',
22
- // @ts-expect-error
23
- default: defaults.name,
24
- })
25
- .positional('version', {
26
- describe:
27
- 'Version matching existing version for a package on Eik server',
28
- type: 'string',
29
- // @ts-expect-error
30
- default: defaults.version,
31
- })
32
- .positional('alias', {
33
- describe:
34
- 'Alias for a semver version. Must be the semver major component of version. Eg. 1.0.0 should be given as 1',
35
- type: 'string',
36
- // @ts-expect-error
37
- default: defaults.version ? semver.major(defaults.version) : null,
38
- });
18
+ yargs
19
+ .positional("name", {
20
+ describe: "Name matching existing name for a package on Eik server",
21
+ type: "string",
22
+ // @ts-expect-error
23
+ default: defaults.name,
24
+ })
25
+ .positional("version", {
26
+ describe: "Version matching existing version for a package on Eik server",
27
+ type: "string",
28
+ // @ts-expect-error
29
+ default: defaults.version,
30
+ })
31
+ .positional("alias", {
32
+ describe:
33
+ "Alias for a semver version. Must be the semver major component of version. Eg. 1.0.0 should be given as 1",
34
+ type: "string",
35
+ // @ts-expect-error
36
+ default: defaults.version ? semver.major(defaults.version) : null,
37
+ });
39
38
 
40
- yargs.options({
41
- server: {
42
- alias: 's',
43
- describe: 'Specify location of Eik asset server.',
44
- // @ts-expect-error
45
- default: defaults.server,
46
- },
47
- token: {
48
- describe:
49
- 'Provide a jwt token to be used to authenticate with the Eik server.',
50
- default: '',
51
- alias: 't',
52
- },
53
- });
39
+ yargs.options({
40
+ server: {
41
+ alias: "s",
42
+ describe: "Specify location of Eik asset server.",
43
+ // @ts-expect-error
44
+ default: defaults.server,
45
+ },
46
+ token: {
47
+ describe:
48
+ "Provide a jwt token to be used to authenticate with the Eik server.",
49
+ default: "",
50
+ alias: "t",
51
+ },
52
+ });
54
53
 
55
- // @ts-expect-error
56
- yargs.default('token', defaults.token, defaults.token ? '######' : '');
54
+ // @ts-expect-error
55
+ yargs.default("token", defaults.token, defaults.token ? "######" : "");
57
56
 
58
- yargs.example(`eik package-alias my-app 1.0.0 1`);
59
- yargs.example(`eik package-alias my-app 1.7.3 1`);
60
- yargs.example(`eik package-alias my-app 6.3.1 6`);
61
- yargs.example(
62
- `eik package-alias my-app 6.3.1 6 --server https://assets.myeikserver.com`,
63
- );
64
- yargs.example(`eik package-alias my-app 4.2.2 4 --debug`);
57
+ yargs.example(`eik package-alias my-app 1.0.0 1`);
58
+ yargs.example(`eik package-alias my-app 1.7.3 1`);
59
+ yargs.example(`eik package-alias my-app 6.3.1 6`);
60
+ yargs.example(
61
+ `eik package-alias my-app 6.3.1 6 --server https://assets.myeikserver.com`,
62
+ );
63
+ yargs.example(`eik package-alias my-app 4.2.2 4 --debug`);
65
64
  };
66
65
 
67
66
  export const handler = async (argv) => {
68
- const spinner = ora({ stream: process.stdout }).start('working...');
69
- let success = false;
70
- const { debug, server } = argv;
71
- const log = logger(spinner, debug);
72
- let af;
67
+ const spinner = ora({ stream: process.stdout }).start("working...");
68
+ let success = false;
69
+ const { debug, server } = argv;
70
+ const log = logger(spinner, debug);
71
+ let af;
73
72
 
74
- try {
75
- const data = await new Alias({
76
- type: 'pkg',
77
- logger: log,
78
- ...argv,
79
- }).run();
73
+ try {
74
+ const data = await new Alias({
75
+ type: "pkg",
76
+ logger: log,
77
+ ...argv,
78
+ }).run();
80
79
 
81
- af = new AliasFormatter(data);
80
+ af = new AliasFormatter(data);
82
81
 
83
- const createdOrUpdated = data.update ? 'Updated' : 'Created';
84
- log.info(
85
- `${createdOrUpdated} alias for package "${data.name}". ("${data.version}" => "v${data.alias}")`,
86
- );
87
- success = true;
88
- } catch (err) {
89
- log.warn(err.message);
90
- }
82
+ const createdOrUpdated = data.update ? "Updated" : "Created";
83
+ log.info(
84
+ `${createdOrUpdated} alias for package "${data.name}". ("${data.version}" => "v${data.alias}")`,
85
+ );
86
+ success = true;
87
+ } catch (err) {
88
+ log.warn(err.message);
89
+ }
91
90
 
92
- spinner.text = '';
93
- spinner.stopAndPersist();
94
- if (success) {
95
- af?.format(server);
96
- } else {
97
- process.exit(1);
98
- }
91
+ spinner.text = "";
92
+ spinner.stopAndPersist();
93
+ if (success) {
94
+ af?.format(server);
95
+ } else {
96
+ process.exit(1);
97
+ }
99
98
  };
100
99
 
101
100
  export const deprecated =
102
- '"package-alias" will be removed in a future version. Please use "alias" instead';
101
+ '"package-alias" will be removed in a future version. Please use "alias" instead';
package/commands/ping.js CHANGED
@@ -1,38 +1,38 @@
1
- import ora from 'ora';
2
- import Ping from '../classes/ping.js';
3
- import { logger, getDefaults } from '../utils/index.js';
1
+ import ora from "ora";
2
+ import Ping from "../classes/ping.js";
3
+ import { logger, getDefaults } from "../utils/index.js";
4
4
 
5
- export const command = 'ping [server]';
5
+ export const command = "ping [server]";
6
6
 
7
7
  export const aliases = [];
8
8
 
9
9
  export const describe = `Ping an Eik server to check that it is responding.`;
10
10
 
11
11
  export const builder = (yargs) => {
12
- const defaults = getDefaults(yargs.argv.config || yargs.argv.cwd);
12
+ const defaults = getDefaults(yargs.argv.config || yargs.argv.cwd);
13
13
 
14
- yargs.positional('server', {
15
- describe: 'Specify location of Eik server to ping.',
16
- // @ts-expect-error
17
- default: defaults.server,
18
- });
14
+ yargs.positional("server", {
15
+ describe: "Specify location of Eik server to ping.",
16
+ // @ts-expect-error
17
+ default: defaults.server,
18
+ });
19
19
 
20
- yargs.example(`eik ping`);
21
- yargs.example(`eik ping http://assets.myeikserver.com`);
22
- yargs.example(`eik ping http://assets.myeikserver.com --debug`);
20
+ yargs.example(`eik ping`);
21
+ yargs.example(`eik ping http://assets.myeikserver.com`);
22
+ yargs.example(`eik ping http://assets.myeikserver.com --debug`);
23
23
  };
24
24
 
25
25
  export const handler = async (argv) => {
26
- const spinner = ora({ stream: process.stdout }).start('working...');
27
- const { debug, server } = argv;
28
-
29
- try {
30
- await new Ping({ logger: logger(spinner, debug), server }).run();
31
- } catch (err) {
32
- // @ts-expect-error
33
- logger.warn(err.message);
34
- }
35
-
36
- spinner.text = '';
37
- spinner.stopAndPersist();
26
+ const spinner = ora({ stream: process.stdout }).start("working...");
27
+ const { debug, server } = argv;
28
+
29
+ try {
30
+ await new Ping({ logger: logger(spinner, debug), server }).run();
31
+ } catch (err) {
32
+ // @ts-expect-error
33
+ logger.warn(err.message);
34
+ }
35
+
36
+ spinner.text = "";
37
+ spinner.stopAndPersist();
38
38
  };
@@ -1,134 +1,130 @@
1
- import { join } from 'path';
2
- import ora from 'ora';
3
- import chalk from 'chalk';
4
- import PublishPackage from '../classes/publish/package/index.js';
5
- import { logger, getDefaults, typeSlug, typeTitle } from '../utils/index.js';
6
- import { Artifact } from '../formatters/index.js';
1
+ import { join } from "path";
2
+ import ora from "ora";
3
+ import chalk from "chalk";
4
+ import PublishPackage from "../classes/publish/package/index.js";
5
+ import { logger, getDefaults, typeSlug, typeTitle } from "../utils/index.js";
6
+ import { Artifact } from "../formatters/index.js";
7
7
 
8
- export const command = 'publish';
8
+ export const command = "publish";
9
9
 
10
- export const aliases = ['pkg', 'package', 'pub'];
10
+ export const aliases = ["pkg", "package", "pub"];
11
11
 
12
12
  export const describe = `Publish an app package to an Eik server. Reads configuration from eik.json or package.json files. See https://eik.dev for more details.`;
13
13
 
14
14
  export const builder = (yargs) => {
15
- const defaults = getDefaults(yargs.argv.config || yargs.argv.cwd);
16
-
17
- yargs.options({
18
- dryRun: {
19
- alias: 'd',
20
- describe:
21
- 'Terminates the publish early (before upload) and provides information about created bundles for inspection.',
22
- default: false,
23
- type: 'boolean',
24
- },
25
- token: {
26
- describe: `Provide a jwt token to be used to authenticate with the Eik server. Automatically determined if authenticated (via eik login)`,
27
- type: 'string',
28
- alias: 't',
29
- },
30
- });
31
-
32
- // @ts-expect-error
33
- yargs.default('token', defaults.token, defaults.token ? '######' : '');
34
-
35
- yargs.example(`eik publish`);
36
- yargs.example(`eik package`);
37
- yargs.example(`eik pub --dry-run`);
38
- yargs.example(`eik pkg --token ######`);
39
- yargs.example(`eik pkg --debug`);
15
+ const defaults = getDefaults(yargs.argv.config || yargs.argv.cwd);
16
+
17
+ yargs.options({
18
+ dryRun: {
19
+ alias: "d",
20
+ describe:
21
+ "Terminates the publish early (before upload) and provides information about created bundles for inspection.",
22
+ default: false,
23
+ type: "boolean",
24
+ },
25
+ token: {
26
+ describe: `Provide a jwt token to be used to authenticate with the Eik server. Automatically determined if authenticated (via eik login)`,
27
+ type: "string",
28
+ alias: "t",
29
+ },
30
+ });
31
+
32
+ // @ts-expect-error
33
+ yargs.default("token", defaults.token, defaults.token ? "######" : "");
34
+
35
+ yargs.example(`eik publish`);
36
+ yargs.example(`eik package`);
37
+ yargs.example(`eik pub --dry-run`);
38
+ yargs.example(`eik pkg --token ######`);
39
+ yargs.example(`eik pkg --debug`);
40
40
  };
41
41
 
42
42
  export const handler = async (argv) => {
43
- const spinner = ora({ stream: process.stdout }).start('working...');
44
- const { debug, dryRun, cwd, token, config } = argv;
45
- // @ts-expect-error
46
- const { name, version, server, map, out, files, type } = getDefaults(
47
- config || cwd,
48
- );
49
-
50
- if (type === 'map') {
51
- spinner.warn(
52
- '"type" is set to "map", which is not supported by the publish command. Please use the "eik map" command instead',
53
- );
54
- process.stdout.write('\n');
55
- process.exit(0);
56
- }
57
-
58
- try {
59
- const options = {
60
- logger: logger(spinner, debug),
61
- cwd,
62
- token,
63
- dryRun,
64
- debug,
65
- name,
66
- server,
67
- version,
68
- type,
69
- map,
70
- out,
71
- files,
72
- };
73
-
74
- const publish = await new PublishPackage(options).run();
75
-
76
- if (!publish) {
77
- spinner.warn(
78
- 'Version in eik.json has not changed since last publish, publishing is not necessary',
79
- );
80
- process.stdout.write('\n');
81
- process.exit(0);
82
- }
83
-
84
- const { files: fls } = publish;
85
-
86
- if (!dryRun) {
87
- let url = new URL(join(typeSlug(type), name), server);
88
- let res = await fetch(url);
89
- const pkgMeta = await res.json();
90
-
91
- url = new URL(join(typeSlug(type), name, version), server);
92
- res = await fetch(url);
93
- const pkgVersionMeta = await res.json();
94
-
95
- const artifact = new Artifact(pkgMeta);
96
- artifact.versions = [pkgVersionMeta];
97
-
98
- spinner.text = '';
99
- spinner.stopAndPersist();
100
-
101
- artifact.format(server);
102
- process.stdout.write('\n');
103
- } else {
104
- spinner.text = '';
105
- spinner.stopAndPersist();
106
-
107
- process.stdout.write(
108
- `:: ${chalk.bgYellow.white.bold(
109
- typeTitle(type),
110
- )} > ${chalk.green(name)} | ${chalk.bold('dry run')}`,
111
- );
112
- process.stdout.write('\n\n');
113
- process.stdout.write(' files (local temporary):\n');
114
- for (const file of fls) {
115
- process.stdout.write(
116
- ` - ${chalk.bold('type')}: ${file.type}\n`,
117
- );
118
- process.stdout.write(
119
- ` ${chalk.bold('path')}: ${file.pathname}\n\n`,
120
- );
121
- }
122
- process.stdout.write(
123
- ` ${chalk.bold(
124
- 'No files were published to remote server',
125
- )}\n\n`,
126
- );
127
- }
128
- } catch (err) {
129
- spinner.warn(err.message);
130
- spinner.text = '';
131
- spinner.stopAndPersist();
132
- process.exit(1);
133
- }
43
+ const spinner = ora({ stream: process.stdout }).start("working...");
44
+ const { debug, dryRun, cwd, token, config } = argv;
45
+ // @ts-expect-error
46
+ const { name, version, server, map, out, files, type } = getDefaults(
47
+ config || cwd,
48
+ );
49
+
50
+ if (type === "map") {
51
+ spinner.warn(
52
+ '"type" is set to "map", which is not supported by the publish command. Please use the "eik map" command instead',
53
+ );
54
+ process.stdout.write("\n");
55
+ process.exit(0);
56
+ }
57
+
58
+ try {
59
+ const options = {
60
+ logger: logger(spinner, debug),
61
+ cwd,
62
+ token,
63
+ dryRun,
64
+ debug,
65
+ name,
66
+ server,
67
+ version,
68
+ type,
69
+ map,
70
+ out,
71
+ files,
72
+ };
73
+
74
+ const publish = await new PublishPackage(options).run();
75
+
76
+ if (!publish) {
77
+ spinner.warn(
78
+ "Version in eik.json has not changed since last publish, publishing is not necessary",
79
+ );
80
+ process.stdout.write("\n");
81
+ process.exit(0);
82
+ }
83
+
84
+ const { files: fls } = publish;
85
+
86
+ if (!dryRun) {
87
+ let url = new URL(join(typeSlug(type), name), server);
88
+ let res = await fetch(url);
89
+ const pkgMeta = await res.json();
90
+
91
+ url = new URL(join(typeSlug(type), name, version), server);
92
+ res = await fetch(url);
93
+ const pkgVersionMeta = await res.json();
94
+
95
+ const artifact = new Artifact(pkgMeta);
96
+ artifact.versions = [pkgVersionMeta];
97
+
98
+ spinner.text = "";
99
+ spinner.stopAndPersist();
100
+
101
+ artifact.format(server);
102
+ process.stdout.write("\n");
103
+ } else {
104
+ spinner.text = "";
105
+ spinner.stopAndPersist();
106
+
107
+ process.stdout.write(
108
+ `:: ${chalk.bgYellow.white.bold(
109
+ typeTitle(type),
110
+ )} > ${chalk.green(name)} | ${chalk.bold("dry run")}`,
111
+ );
112
+ process.stdout.write("\n\n");
113
+ process.stdout.write(" files (local temporary):\n");
114
+ for (const file of fls) {
115
+ process.stdout.write(` - ${chalk.bold("type")}: ${file.type}\n`);
116
+ process.stdout.write(
117
+ ` ${chalk.bold("path")}: ${file.pathname}\n\n`,
118
+ );
119
+ }
120
+ process.stdout.write(
121
+ ` ${chalk.bold("No files were published to remote server")}\n\n`,
122
+ );
123
+ }
124
+ } catch (err) {
125
+ spinner.warn(err.message);
126
+ spinner.text = "";
127
+ spinner.stopAndPersist();
128
+ process.exit(1);
129
+ }
134
130
  };