@learnpack/learnpack 4.0.10 → 4.0.13

Sign up to get free protection for your applications and to get access to all the features.
Files changed (126) hide show
  1. package/README.md +16 -20
  2. package/lib/commands/audit.d.ts +6 -6
  3. package/lib/commands/audit.js +327 -327
  4. package/lib/commands/clean.d.ts +8 -8
  5. package/lib/commands/clean.js +22 -22
  6. package/lib/commands/download.d.ts +13 -13
  7. package/lib/commands/download.js +52 -52
  8. package/lib/commands/init.d.ts +9 -9
  9. package/lib/commands/init.js +127 -127
  10. package/lib/commands/login.d.ts +14 -14
  11. package/lib/commands/login.js +34 -34
  12. package/lib/commands/logout.d.ts +14 -14
  13. package/lib/commands/logout.js +34 -34
  14. package/lib/commands/publish.d.ts +11 -14
  15. package/lib/commands/publish.js +160 -82
  16. package/lib/commands/start.d.ts +7 -7
  17. package/lib/commands/start.js +252 -250
  18. package/lib/commands/test.d.ts +6 -6
  19. package/lib/commands/test.js +62 -62
  20. package/lib/index.d.ts +1 -1
  21. package/lib/index.js +4 -4
  22. package/lib/managers/config/allowed_files.d.ts +5 -5
  23. package/lib/managers/config/allowed_files.js +30 -30
  24. package/lib/managers/config/defaults.d.ts +47 -48
  25. package/lib/managers/config/defaults.js +51 -51
  26. package/lib/managers/config/exercise.d.ts +36 -36
  27. package/lib/managers/config/exercise.js +243 -236
  28. package/lib/managers/config/index.d.ts +3 -3
  29. package/lib/managers/config/index.js +464 -459
  30. package/lib/managers/file.d.ts +14 -14
  31. package/lib/managers/file.js +190 -184
  32. package/lib/managers/gitpod.d.ts +3 -3
  33. package/lib/managers/gitpod.js +67 -67
  34. package/lib/managers/server/index.d.ts +5 -6
  35. package/lib/managers/server/index.js +58 -58
  36. package/lib/managers/server/routes.d.ts +4 -4
  37. package/lib/managers/server/routes.js +228 -220
  38. package/lib/managers/session.d.ts +3 -3
  39. package/lib/managers/session.js +125 -125
  40. package/lib/managers/socket.d.ts +3 -3
  41. package/lib/managers/socket.js +188 -186
  42. package/lib/managers/telemetry.d.ts +74 -74
  43. package/lib/managers/telemetry.js +215 -214
  44. package/lib/managers/test.js +84 -84
  45. package/lib/models/action.d.ts +2 -2
  46. package/lib/models/action.js +2 -2
  47. package/lib/models/audit.d.ts +15 -15
  48. package/lib/models/audit.js +2 -2
  49. package/lib/models/config-manager.d.ts +21 -21
  50. package/lib/models/config-manager.js +2 -2
  51. package/lib/models/config.d.ts +86 -86
  52. package/lib/models/config.js +2 -2
  53. package/lib/models/counter.d.ts +11 -11
  54. package/lib/models/counter.js +2 -2
  55. package/lib/models/errors.d.ts +15 -15
  56. package/lib/models/errors.js +2 -2
  57. package/lib/models/exercise-obj.d.ts +29 -30
  58. package/lib/models/exercise-obj.js +2 -2
  59. package/lib/models/file.d.ts +5 -5
  60. package/lib/models/file.js +2 -2
  61. package/lib/models/findings.d.ts +17 -17
  62. package/lib/models/findings.js +2 -2
  63. package/lib/models/flags.d.ts +10 -10
  64. package/lib/models/flags.js +2 -2
  65. package/lib/models/front-matter.d.ts +11 -11
  66. package/lib/models/front-matter.js +2 -2
  67. package/lib/models/gitpod-data.d.ts +16 -16
  68. package/lib/models/gitpod-data.js +2 -2
  69. package/lib/models/language.d.ts +4 -4
  70. package/lib/models/language.js +2 -2
  71. package/lib/models/package.d.ts +7 -7
  72. package/lib/models/package.js +2 -2
  73. package/lib/models/plugin-config.d.ts +16 -16
  74. package/lib/models/plugin-config.js +2 -2
  75. package/lib/models/session.d.ts +31 -31
  76. package/lib/models/session.js +2 -2
  77. package/lib/models/socket.d.ts +37 -37
  78. package/lib/models/socket.js +2 -2
  79. package/lib/models/status.d.ts +1 -1
  80. package/lib/models/status.js +2 -2
  81. package/lib/models/success-types.d.ts +1 -1
  82. package/lib/models/success-types.js +2 -2
  83. package/lib/plugin/command/compile.d.ts +6 -6
  84. package/lib/plugin/command/compile.js +18 -18
  85. package/lib/plugin/command/test.d.ts +6 -6
  86. package/lib/plugin/command/test.js +25 -25
  87. package/lib/plugin/index.d.ts +27 -27
  88. package/lib/plugin/index.js +7 -7
  89. package/lib/plugin/plugin.d.ts +8 -8
  90. package/lib/plugin/plugin.js +68 -68
  91. package/lib/plugin/utils.d.ts +16 -16
  92. package/lib/plugin/utils.js +58 -58
  93. package/lib/ui/download.d.ts +5 -5
  94. package/lib/ui/download.js +62 -61
  95. package/lib/utils/BaseCommand.d.ts +8 -8
  96. package/lib/utils/BaseCommand.js +41 -41
  97. package/lib/utils/SessionCommand.d.ts +10 -10
  98. package/lib/utils/SessionCommand.js +43 -43
  99. package/lib/utils/api.d.ts +14 -14
  100. package/lib/utils/api.js +255 -255
  101. package/lib/utils/audit.d.ts +16 -16
  102. package/lib/utils/audit.js +303 -303
  103. package/lib/utils/checkNotInstalled.d.ts +8 -8
  104. package/lib/utils/checkNotInstalled.js +185 -181
  105. package/lib/utils/console.d.ts +12 -12
  106. package/lib/utils/console.js +19 -19
  107. package/lib/utils/errors.d.ts +17 -17
  108. package/lib/utils/errors.js +107 -100
  109. package/lib/utils/exercisesQueue.d.ts +9 -9
  110. package/lib/utils/exercisesQueue.js +38 -38
  111. package/lib/utils/fileQueue.d.ts +43 -43
  112. package/lib/utils/fileQueue.js +169 -169
  113. package/lib/utils/misc.d.ts +1 -1
  114. package/lib/utils/misc.js +24 -23
  115. package/lib/utils/osOperations.d.ts +5 -5
  116. package/lib/utils/osOperations.js +72 -72
  117. package/lib/utils/validators.d.ts +5 -5
  118. package/lib/utils/validators.js +16 -17
  119. package/lib/utils/watcher.d.ts +2 -2
  120. package/lib/utils/watcher.js +25 -25
  121. package/oclif.manifest.json +1 -1
  122. package/package.json +6 -4
  123. package/src/commands/publish.ts +181 -107
  124. package/src/managers/config/index.ts +5 -0
  125. package/src/managers/server/routes.ts +10 -0
  126. package/src/managers/session.ts +145 -145
@@ -1,68 +1,68 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const shell = require("shelljs");
4
- /**
5
- * Main Plugin Runner, it defines the behavior of a learnpack plugin
6
- * dividing it in "actions" like: Compile, test, etc.
7
- * @param {object} pluginConfig Configuration object that must defined language and each possible action.
8
- */
9
- exports.default = (pluginConfig) => {
10
- return async (args) => {
11
- const { action, exercise, socket, configuration } = args;
12
- if (pluginConfig.language === undefined)
13
- throw new Error(`Missing language on the plugin configuration object`);
14
- if (typeof action !== "string") {
15
- throw new TypeError("Missing action property on hook details");
16
- }
17
- if (!exercise || exercise === undefined) {
18
- throw new Error("Missing exercise information");
19
- }
20
- // if the action does not exist I don't do anything
21
- if (pluginConfig[action] === undefined) {
22
- console.log(`Ignoring ${action}`);
23
- return () => null;
24
- }
25
- // ignore if the plugin language its not the same as the exercise language
26
- if (exercise.language !== pluginConfig.language) {
27
- return () => null;
28
- }
29
- if (!exercise.files || exercise.files.length === 0) {
30
- throw new Error(`No files to process`);
31
- }
32
- try {
33
- const _action = pluginConfig[action];
34
- if (_action === null || typeof _action !== "object")
35
- throw new Error(`The ${pluginConfig.language} ${action} module must export an object configuration`);
36
- if (_action.validate === undefined)
37
- throw new Error(`Missing validate method for ${pluginConfig.language} ${action}`);
38
- if (_action.run === undefined)
39
- throw new Error(`Missing run method for ${pluginConfig.language} ${action}`);
40
- if (_action.dependencies !== undefined) {
41
- if (!Array.isArray(_action.dependencies))
42
- throw new Error(`${action}.dependencies must be an array of package names`);
43
- for (const packageName of _action.dependencies) {
44
- if (!shell.which(packageName)) {
45
- throw new Error(`🚫 You need to have ${packageName} installed to run test the exercises`);
46
- }
47
- }
48
- }
49
- const valid = await _action.validate({ exercise, configuration });
50
- if (valid) {
51
- // look for the command standard implementation and execute it
52
- const execute = require("./command/" + action + ".js").default;
53
- // no matter the command, the response must always be a stdout
54
- const stdout = await execute(Object.assign(Object.assign({}, args), { action: _action, configuration }));
55
- // Map the action names to socket messaging standards
56
- const actionToSuccessMapper = { compile: "compiler", test: "testing" };
57
- socket.success(actionToSuccessMapper[action], stdout);
58
- return stdout;
59
- }
60
- }
61
- catch (error) {
62
- if (error.type === undefined)
63
- socket.fatal(error);
64
- else
65
- socket.error(error.type, error.stdout);
66
- }
67
- };
68
- };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const shell = require("shelljs");
4
+ /**
5
+ * Main Plugin Runner, it defines the behavior of a learnpack plugin
6
+ * dividing it in "actions" like: Compile, test, etc.
7
+ * @param {object} pluginConfig Configuration object that must defined language and each possible action.
8
+ */
9
+ exports.default = (pluginConfig) => {
10
+ return async (args) => {
11
+ const { action, exercise, socket, configuration } = args;
12
+ if (pluginConfig.language === undefined)
13
+ throw new Error(`Missing language on the plugin configuration object`);
14
+ if (typeof action !== "string") {
15
+ throw new TypeError("Missing action property on hook details");
16
+ }
17
+ if (!exercise || exercise === undefined) {
18
+ throw new Error("Missing exercise information");
19
+ }
20
+ // if the action does not exist I don't do anything
21
+ if (pluginConfig[action] === undefined) {
22
+ console.log(`Ignoring ${action}`);
23
+ return () => null;
24
+ }
25
+ // ignore if the plugin language its not the same as the exercise language
26
+ if (exercise.language !== pluginConfig.language) {
27
+ return () => null;
28
+ }
29
+ if (!exercise.files || exercise.files.length === 0) {
30
+ throw new Error(`No files to process`);
31
+ }
32
+ try {
33
+ const _action = pluginConfig[action];
34
+ if (_action === null || typeof _action !== "object")
35
+ throw new Error(`The ${pluginConfig.language} ${action} module must export an object configuration`);
36
+ if (_action.validate === undefined)
37
+ throw new Error(`Missing validate method for ${pluginConfig.language} ${action}`);
38
+ if (_action.run === undefined)
39
+ throw new Error(`Missing run method for ${pluginConfig.language} ${action}`);
40
+ if (_action.dependencies !== undefined) {
41
+ if (!Array.isArray(_action.dependencies))
42
+ throw new Error(`${action}.dependencies must be an array of package names`);
43
+ for (const packageName of _action.dependencies) {
44
+ if (!shell.which(packageName)) {
45
+ throw new Error(`🚫 You need to have ${packageName} installed to run test the exercises`);
46
+ }
47
+ }
48
+ }
49
+ const valid = await _action.validate({ exercise, configuration });
50
+ if (valid) {
51
+ // look for the command standard implementation and execute it
52
+ const execute = require("./command/" + action + ".js").default;
53
+ // no matter the command, the response must always be a stdout
54
+ const stdout = await execute(Object.assign(Object.assign({}, args), { action: _action, configuration }));
55
+ // Map the action names to socket messaging standards
56
+ const actionToSuccessMapper = { compile: "compiler", test: "testing" };
57
+ socket.success(actionToSuccessMapper[action], stdout);
58
+ return stdout;
59
+ }
60
+ }
61
+ catch (error) {
62
+ if (error.type === undefined)
63
+ socket.fatal(error);
64
+ else
65
+ socket.error(error.type, error.stdout);
66
+ }
67
+ };
68
+ };
@@ -1,16 +1,16 @@
1
- declare const _default: {
2
- getMatches: (reg: RegExp, content: string) => (string | null)[];
3
- cleanStdout: (buffer: string, inputs: string[]) => string;
4
- indent: (string: string, options: any, count?: number) => string;
5
- Console: {
6
- _debug: boolean;
7
- startDebug: () => void;
8
- log: (msg: string, ...args: any[]) => void;
9
- error: (msg: string, ...args: any[]) => void;
10
- success: (msg: string, ...args: any[]) => void;
11
- info: (msg: string, ...args: any[]) => void;
12
- help: (msg: string) => void;
13
- debug(...args: any[]): void;
14
- };
15
- };
16
- export default _default;
1
+ declare const _default: {
2
+ getMatches: (reg: RegExp, content: string) => (string | null)[];
3
+ cleanStdout: (buffer: string, inputs: string[]) => string;
4
+ indent: (string: string, options: any, count?: number) => string;
5
+ Console: {
6
+ _debug: boolean;
7
+ startDebug: () => void;
8
+ log: (msg: string, ...args: any[]) => void;
9
+ error: (msg: string, ...args: any[]) => void;
10
+ success: (msg: string, ...args: any[]) => void;
11
+ info: (msg: string, ...args: any[]) => void;
12
+ help: (msg: string) => void;
13
+ debug(...args: any[]): void;
14
+ };
15
+ };
16
+ export default _default;
@@ -1,58 +1,58 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const chalk = require("chalk");
4
- const getMatches = (reg, content) => {
5
- const inputs = [];
6
- let m;
7
- while ((m = reg.exec(content)) !== null) {
8
- // This is necessary to avoid infinite loops with zero-width matches
9
- if (m.index === reg.lastIndex)
10
- reg.lastIndex++;
11
- // The result can be accessed through the `m`-variable.
12
- inputs.push(m[1] || null);
13
- }
14
- return inputs;
15
- };
16
- const cleanStdout = (buffer, inputs) => {
17
- if (Array.isArray(inputs))
18
- for (let i = 0; i < inputs.length; i++)
19
- if (inputs[i])
20
- buffer = buffer.replace(inputs[i], "");
21
- return buffer;
22
- };
23
- const indent = (string, options, count = 1) => {
24
- options = Object.assign({ indent: " ", includeEmptyLines: false }, options);
25
- if (typeof string !== "string") {
26
- throw new TypeError(`Expected \`input\` to be a \`string\`, got \`${typeof string}\``);
27
- }
28
- if (typeof count !== "number") {
29
- throw new TypeError(`Expected \`count\` to be a \`number\`, got \`${typeof count}\``);
30
- }
31
- if (count < 0) {
32
- throw new RangeError(`Expected \`count\` to be at least 0, got \`${count}\``);
33
- }
34
- if (typeof options.indent !== "string") {
35
- throw new TypeError(`Expected \`options.indent\` to be a \`string\`, got \`${typeof options.indent}\``);
36
- }
37
- if (count === 0) {
38
- return string;
39
- }
40
- const regex = options.includeEmptyLines ? /^/gm : /^(?!\s*$)/gm;
41
- return string.replace(regex, options.indent.repeat(count));
42
- };
43
- const Console = {
44
- // _debug: true,
45
- _debug: process.env.DEBUG === "true",
46
- startDebug: function () {
47
- this._debug = true;
48
- },
49
- log: (msg, ...args) => console.log(chalk.gray(msg), ...args),
50
- error: (msg, ...args) => console.log(chalk.red("⨉ " + msg), ...args),
51
- success: (msg, ...args) => console.log(chalk.green("✓ " + msg), ...args),
52
- info: (msg, ...args) => console.log(chalk.blue("ⓘ " + msg), ...args),
53
- help: (msg) => console.log(`${chalk.white.bold("⚠ help:")} ${chalk.white(msg)}`),
54
- debug(...args) {
55
- this._debug && console.log(chalk.magentaBright(`⚠ debug: `), args);
56
- },
57
- };
58
- exports.default = { getMatches, cleanStdout, indent, Console };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const chalk = require("chalk");
4
+ const getMatches = (reg, content) => {
5
+ const inputs = [];
6
+ let m;
7
+ while ((m = reg.exec(content)) !== null) {
8
+ // This is necessary to avoid infinite loops with zero-width matches
9
+ if (m.index === reg.lastIndex)
10
+ reg.lastIndex++;
11
+ // The result can be accessed through the `m`-variable.
12
+ inputs.push(m[1] || null);
13
+ }
14
+ return inputs;
15
+ };
16
+ const cleanStdout = (buffer, inputs) => {
17
+ if (Array.isArray(inputs))
18
+ for (let i = 0; i < inputs.length; i++)
19
+ if (inputs[i])
20
+ buffer = buffer.replace(inputs[i], "");
21
+ return buffer;
22
+ };
23
+ const indent = (string, options, count = 1) => {
24
+ options = Object.assign({ indent: " ", includeEmptyLines: false }, options);
25
+ if (typeof string !== "string") {
26
+ throw new TypeError(`Expected \`input\` to be a \`string\`, got \`${typeof string}\``);
27
+ }
28
+ if (typeof count !== "number") {
29
+ throw new TypeError(`Expected \`count\` to be a \`number\`, got \`${typeof count}\``);
30
+ }
31
+ if (count < 0) {
32
+ throw new RangeError(`Expected \`count\` to be at least 0, got \`${count}\``);
33
+ }
34
+ if (typeof options.indent !== "string") {
35
+ throw new TypeError(`Expected \`options.indent\` to be a \`string\`, got \`${typeof options.indent}\``);
36
+ }
37
+ if (count === 0) {
38
+ return string;
39
+ }
40
+ const regex = options.includeEmptyLines ? /^/gm : /^(?!\s*$)/gm;
41
+ return string.replace(regex, options.indent.repeat(count));
42
+ };
43
+ const Console = {
44
+ // _debug: true,
45
+ _debug: process.env.DEBUG === "true",
46
+ startDebug: function () {
47
+ this._debug = true;
48
+ },
49
+ log: (msg, ...args) => console.log(chalk.gray(msg), ...args),
50
+ error: (msg, ...args) => console.log(chalk.red("⨉ " + msg), ...args),
51
+ success: (msg, ...args) => console.log(chalk.green("✓ " + msg), ...args),
52
+ info: (msg, ...args) => console.log(chalk.blue("ⓘ " + msg), ...args),
53
+ help: (msg) => console.log(`${chalk.white.bold("⚠ help:")} ${chalk.white(msg)}`),
54
+ debug(...args) {
55
+ this._debug && console.log(chalk.magentaBright(`⚠ debug: `), args);
56
+ },
57
+ };
58
+ exports.default = { getMatches, cleanStdout, indent, Console };
@@ -1,5 +1,5 @@
1
- export declare const askPackage: () => Promise<unknown>;
2
- declare const _default: {
3
- askPackage: () => Promise<unknown>;
4
- };
5
- export default _default;
1
+ export declare const askPackage: () => Promise<unknown>;
2
+ declare const _default: {
3
+ askPackage: () => Promise<unknown>;
4
+ };
5
+ export default _default;
@@ -1,61 +1,62 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.askPackage = void 0;
4
- const enquirer_1 = require("enquirer");
5
- const console_1 = require("../utils/console");
6
- const api_1 = require("../utils/api");
7
- exports.askPackage = async () => {
8
- console_1.default.info('No package was specified');
9
- const languages = await api_1.default.getLangs();
10
- return new Promise((resolve, reject) => {
11
- if (languages.length === 0) {
12
- // reject(new Error('No categories available'))
13
- reject('No categories available');
14
- // return null;
15
- }
16
- // let packages = []
17
- enquirer_1.prompt([
18
- {
19
- type: 'select',
20
- name: 'lang',
21
- message: 'What language do you want to practice?',
22
- choices: languages.map((l) => ({
23
- message: l.title,
24
- name: l.slug,
25
- })),
26
- },
27
- ])
28
- .then(({ lang }) => {
29
- return (async () => {
30
- const response = await api_1.default.getAllPackages({ lang });
31
- const packages = response.results;
32
- if (packages.length === 0) {
33
- const error = new Error(`No packages found for language ${lang}`);
34
- console_1.default.error(error.message); // TODO: Look this
35
- return error;
36
- }
37
- return enquirer_1.prompt([
38
- {
39
- type: 'select',
40
- name: 'pack',
41
- message: 'Choose one of the packages available',
42
- choices: packages.map((l) => ({
43
- message: `${l.title}, difficulty: ${l.difficulty}, downloads: ${l.downloads} ${l.skills.length > 0 ? `(Skills: ${l.skills.join(',')})` : ''}`,
44
- name: l.slug,
45
- })),
46
- },
47
- ]);
48
- })();
49
- })
50
- .then((resp) => {
51
- if (!resp)
52
- reject(resp.message || resp);
53
- else
54
- resolve(resp.pack);
55
- })
56
- .catch(error => {
57
- console_1.default.error(error.message || error);
58
- });
59
- });
60
- };
61
- exports.default = { askPackage: exports.askPackage };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.askPackage = void 0;
4
+ const enquirer_1 = require("enquirer");
5
+ const console_1 = require("../utils/console");
6
+ const api_1 = require("../utils/api");
7
+ const askPackage = async () => {
8
+ console_1.default.info('No package was specified');
9
+ const languages = await api_1.default.getLangs();
10
+ return new Promise((resolve, reject) => {
11
+ if (languages.length === 0) {
12
+ // reject(new Error('No categories available'))
13
+ reject('No categories available');
14
+ // return null;
15
+ }
16
+ // let packages = []
17
+ (0, enquirer_1.prompt)([
18
+ {
19
+ type: 'select',
20
+ name: 'lang',
21
+ message: 'What language do you want to practice?',
22
+ choices: languages.map((l) => ({
23
+ message: l.title,
24
+ name: l.slug,
25
+ })),
26
+ },
27
+ ])
28
+ .then(({ lang }) => {
29
+ return (async () => {
30
+ const response = await api_1.default.getAllPackages({ lang });
31
+ const packages = response.results;
32
+ if (packages.length === 0) {
33
+ const error = new Error(`No packages found for language ${lang}`);
34
+ console_1.default.error(error.message); // TODO: Look this
35
+ return error;
36
+ }
37
+ return (0, enquirer_1.prompt)([
38
+ {
39
+ type: 'select',
40
+ name: 'pack',
41
+ message: 'Choose one of the packages available',
42
+ choices: packages.map((l) => ({
43
+ message: `${l.title}, difficulty: ${l.difficulty}, downloads: ${l.downloads} ${l.skills.length > 0 ? `(Skills: ${l.skills.join(',')})` : ''}`,
44
+ name: l.slug,
45
+ })),
46
+ },
47
+ ]);
48
+ })();
49
+ })
50
+ .then((resp) => {
51
+ if (!resp)
52
+ reject(resp.message || resp);
53
+ else
54
+ resolve(resp.pack);
55
+ })
56
+ .catch(error => {
57
+ console_1.default.error(error.message || error);
58
+ });
59
+ });
60
+ };
61
+ exports.askPackage = askPackage;
62
+ exports.default = { askPackage: exports.askPackage };
@@ -1,8 +1,8 @@
1
- import { Command } from "@oclif/command";
2
- declare class BaseCommand extends Command {
3
- catch(err: any): Promise<void>;
4
- init(): Promise<void>;
5
- finally(): Promise<void>;
6
- run(): Promise<void>;
7
- }
8
- export default BaseCommand;
1
+ import { Command } from "@oclif/command";
2
+ declare class BaseCommand extends Command {
3
+ catch(err: any): Promise<void>;
4
+ init(): Promise<void>;
5
+ finally(): Promise<void>;
6
+ run(): Promise<void>;
7
+ }
8
+ export default BaseCommand;
@@ -1,41 +1,41 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const command_1 = require("@oclif/command");
4
- const console_1 = require("./console");
5
- const readline_1 = require("readline");
6
- // import SessionManager from '../managers/session'
7
- class BaseCommand extends command_1.Command {
8
- async catch(err) {
9
- console_1.default.debug("COMMAND CATCH", err);
10
- throw err;
11
- }
12
- async init() {
13
- const { flags, args } = this.parse(BaseCommand);
14
- console_1.default.debug("COMMAND INIT");
15
- console_1.default.debug("These are your flags: ", flags);
16
- console_1.default.debug("These are your args: ", args);
17
- // quick fix for listening to the process termination on windows
18
- if (process.platform === "win32") {
19
- const rl = readline_1.createInterface({
20
- input: process.stdin,
21
- output: process.stdout,
22
- });
23
- rl.on("SIGINT", function () {
24
- // process.emit('SIGINT')
25
- // process.emit('SIGINT')
26
- });
27
- }
28
- process.on("SIGINT", function () {
29
- console_1.default.debug("Terminated (SIGINT)");
30
- process.exit();
31
- });
32
- }
33
- async finally() {
34
- console_1.default.debug("COMMAND FINALLY");
35
- // called after run and catch regardless of whether or not the command errored
36
- }
37
- async run() {
38
- // console.log('running my command')
39
- }
40
- }
41
- exports.default = BaseCommand;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const command_1 = require("@oclif/command");
4
+ const console_1 = require("./console");
5
+ const readline_1 = require("readline");
6
+ // import SessionManager from '../managers/session'
7
+ class BaseCommand extends command_1.Command {
8
+ async catch(err) {
9
+ console_1.default.debug("COMMAND CATCH", err);
10
+ throw err;
11
+ }
12
+ async init() {
13
+ const { flags, args } = this.parse(BaseCommand);
14
+ console_1.default.debug("COMMAND INIT");
15
+ console_1.default.debug("These are your flags: ", flags);
16
+ console_1.default.debug("These are your args: ", args);
17
+ // quick fix for listening to the process termination on windows
18
+ if (process.platform === "win32") {
19
+ const rl = (0, readline_1.createInterface)({
20
+ input: process.stdin,
21
+ output: process.stdout,
22
+ });
23
+ rl.on("SIGINT", function () {
24
+ // process.emit('SIGINT')
25
+ // process.emit('SIGINT')
26
+ });
27
+ }
28
+ process.on("SIGINT", function () {
29
+ console_1.default.debug("Terminated (SIGINT)");
30
+ process.exit();
31
+ });
32
+ }
33
+ async finally() {
34
+ console_1.default.debug("COMMAND FINALLY");
35
+ // called after run and catch regardless of whether or not the command errored
36
+ }
37
+ async run() {
38
+ // console.log('running my command')
39
+ }
40
+ }
41
+ exports.default = BaseCommand;
@@ -1,10 +1,10 @@
1
- import BaseCommand from "./BaseCommand";
2
- import { IConfigManager } from "../models/config-manager";
3
- export default class SessionCommand extends BaseCommand {
4
- session: any;
5
- configManager: IConfigManager | null;
6
- static flags: any;
7
- initSession(flags: any, _private?: boolean): Promise<void>;
8
- buildConfig(flags: any): Promise<void>;
9
- catch(err: any): Promise<void>;
10
- }
1
+ import BaseCommand from "./BaseCommand";
2
+ import { IConfigManager } from "../models/config-manager";
3
+ export default class SessionCommand extends BaseCommand {
4
+ session: any;
5
+ configManager: IConfigManager | null;
6
+ static flags: any;
7
+ initSession(flags: any, _private?: boolean): Promise<void>;
8
+ buildConfig(flags: any): Promise<void>;
9
+ catch(err: any): Promise<void>;
10
+ }
@@ -1,43 +1,43 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- // import { flags } from "@oclif/command";
4
- const BaseCommand_1 = require("./BaseCommand");
5
- const console_1 = require("./console");
6
- const session_1 = require("../managers/session");
7
- const index_1 = require("../managers/config/index");
8
- const errors_1 = require("./errors");
9
- class SessionCommand extends BaseCommand_1.default {
10
- constructor() {
11
- super(...arguments);
12
- this.session = null;
13
- this.configManager = null;
14
- }
15
- async initSession(flags, _private = false) {
16
- var _a;
17
- try {
18
- if (!this.configManager) {
19
- await this.buildConfig(flags);
20
- }
21
- this.session = await session_1.default.get((_a = this.configManager) === null || _a === void 0 ? void 0 : _a.get());
22
- if (this.session) {
23
- console_1.default.debug(`Session open for ${this.session.payload.email}.`);
24
- }
25
- else {
26
- if (_private)
27
- throw errors_1.AuthError("You need to log in, run the following command to continue: $ learnpack login");
28
- console_1.default.debug("No active session available", _private);
29
- }
30
- }
31
- catch (error) {
32
- console_1.default.error(error.message);
33
- }
34
- }
35
- async buildConfig(flags) {
36
- this.configManager = await index_1.default(flags);
37
- }
38
- async catch(err) {
39
- console_1.default.debug("COMMAND CATCH", err);
40
- throw err;
41
- }
42
- }
43
- exports.default = SessionCommand;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ // import { flags } from "@oclif/command";
4
+ const BaseCommand_1 = require("./BaseCommand");
5
+ const console_1 = require("./console");
6
+ const session_1 = require("../managers/session");
7
+ const index_1 = require("../managers/config/index");
8
+ const errors_1 = require("./errors");
9
+ class SessionCommand extends BaseCommand_1.default {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.session = null;
13
+ this.configManager = null;
14
+ }
15
+ async initSession(flags, _private = false) {
16
+ var _a;
17
+ try {
18
+ if (!this.configManager) {
19
+ await this.buildConfig(flags);
20
+ }
21
+ this.session = await session_1.default.get((_a = this.configManager) === null || _a === void 0 ? void 0 : _a.get());
22
+ if (this.session) {
23
+ console_1.default.debug(`Session open for ${this.session.payload.email}.`);
24
+ }
25
+ else {
26
+ if (_private)
27
+ throw (0, errors_1.AuthError)("You need to log in, run the following command to continue: $ learnpack login");
28
+ console_1.default.debug("No active session available", _private);
29
+ }
30
+ }
31
+ catch (error) {
32
+ console_1.default.error(error.message);
33
+ }
34
+ }
35
+ async buildConfig(flags) {
36
+ this.configManager = await (0, index_1.default)(flags);
37
+ }
38
+ async catch(err) {
39
+ console_1.default.debug("COMMAND CATCH", err);
40
+ throw err;
41
+ }
42
+ }
43
+ exports.default = SessionCommand;