@learnpack/learnpack 2.0.16 → 2.0.19

Sign up to get free protection for your applications and to get access to all the features.
Files changed (115) hide show
  1. package/README.md +10 -10
  2. package/oclif.manifest.json +1 -1
  3. package/package.json +1 -1
  4. package/lib/commands/audit.d.ts +0 -6
  5. package/lib/commands/audit.js +0 -369
  6. package/lib/commands/clean.d.ts +0 -8
  7. package/lib/commands/clean.js +0 -25
  8. package/lib/commands/download.d.ts +0 -13
  9. package/lib/commands/download.js +0 -55
  10. package/lib/commands/init.d.ts +0 -9
  11. package/lib/commands/init.js +0 -117
  12. package/lib/commands/login.d.ts +0 -14
  13. package/lib/commands/login.js +0 -37
  14. package/lib/commands/logout.d.ts +0 -14
  15. package/lib/commands/logout.js +0 -37
  16. package/lib/commands/publish.d.ts +0 -14
  17. package/lib/commands/publish.js +0 -82
  18. package/lib/commands/start.d.ts +0 -7
  19. package/lib/commands/start.js +0 -165
  20. package/lib/commands/test.d.ts +0 -6
  21. package/lib/commands/test.js +0 -62
  22. package/lib/managers/config/allowed_files.d.ts +0 -5
  23. package/lib/managers/config/allowed_files.js +0 -30
  24. package/lib/managers/config/defaults.d.ts +0 -34
  25. package/lib/managers/config/defaults.js +0 -35
  26. package/lib/managers/config/exercise.d.ts +0 -36
  27. package/lib/managers/config/exercise.js +0 -230
  28. package/lib/managers/config/index.d.ts +0 -3
  29. package/lib/managers/config/index.js +0 -307
  30. package/lib/managers/file.d.ts +0 -13
  31. package/lib/managers/file.js +0 -134
  32. package/lib/managers/gitpod.d.ts +0 -3
  33. package/lib/managers/gitpod.js +0 -67
  34. package/lib/managers/server/index.d.ts +0 -6
  35. package/lib/managers/server/index.js +0 -51
  36. package/lib/managers/server/routes.d.ts +0 -4
  37. package/lib/managers/server/routes.js +0 -160
  38. package/lib/managers/session.d.ts +0 -3
  39. package/lib/managers/session.js +0 -104
  40. package/lib/managers/socket.d.ts +0 -3
  41. package/lib/managers/socket.js +0 -164
  42. package/lib/managers/test.d.ts +0 -0
  43. package/lib/managers/test.js +0 -84
  44. package/lib/models/action.d.ts +0 -2
  45. package/lib/models/action.js +0 -2
  46. package/lib/models/audit-errors.d.ts +0 -4
  47. package/lib/models/audit-errors.js +0 -2
  48. package/lib/models/config-manager.d.ts +0 -21
  49. package/lib/models/config-manager.js +0 -2
  50. package/lib/models/config.d.ts +0 -57
  51. package/lib/models/config.js +0 -2
  52. package/lib/models/counter.d.ts +0 -11
  53. package/lib/models/counter.js +0 -2
  54. package/lib/models/errors.d.ts +0 -15
  55. package/lib/models/errors.js +0 -2
  56. package/lib/models/exercise-obj.d.ts +0 -27
  57. package/lib/models/exercise-obj.js +0 -2
  58. package/lib/models/file.d.ts +0 -5
  59. package/lib/models/file.js +0 -2
  60. package/lib/models/findings.d.ts +0 -17
  61. package/lib/models/findings.js +0 -2
  62. package/lib/models/flags.d.ts +0 -10
  63. package/lib/models/flags.js +0 -2
  64. package/lib/models/front-matter.d.ts +0 -11
  65. package/lib/models/front-matter.js +0 -2
  66. package/lib/models/gitpod-data.d.ts +0 -16
  67. package/lib/models/gitpod-data.js +0 -2
  68. package/lib/models/language.d.ts +0 -4
  69. package/lib/models/language.js +0 -2
  70. package/lib/models/package.d.ts +0 -7
  71. package/lib/models/package.js +0 -2
  72. package/lib/models/plugin-config.d.ts +0 -16
  73. package/lib/models/plugin-config.js +0 -2
  74. package/lib/models/session.d.ts +0 -23
  75. package/lib/models/session.js +0 -2
  76. package/lib/models/socket.d.ts +0 -31
  77. package/lib/models/socket.js +0 -2
  78. package/lib/models/status.d.ts +0 -1
  79. package/lib/models/status.js +0 -2
  80. package/lib/models/success-types.d.ts +0 -1
  81. package/lib/models/success-types.js +0 -2
  82. package/lib/plugin/command/compile.d.ts +0 -6
  83. package/lib/plugin/command/compile.js +0 -18
  84. package/lib/plugin/command/test.d.ts +0 -6
  85. package/lib/plugin/command/test.js +0 -25
  86. package/lib/plugin/index.d.ts +0 -27
  87. package/lib/plugin/index.js +0 -7
  88. package/lib/plugin/plugin.d.ts +0 -8
  89. package/lib/plugin/plugin.js +0 -68
  90. package/lib/plugin/utils.d.ts +0 -16
  91. package/lib/plugin/utils.js +0 -58
  92. package/lib/ui/download.d.ts +0 -5
  93. package/lib/ui/download.js +0 -61
  94. package/lib/utils/BaseCommand.d.ts +0 -8
  95. package/lib/utils/BaseCommand.js +0 -41
  96. package/lib/utils/SessionCommand.d.ts +0 -10
  97. package/lib/utils/SessionCommand.js +0 -47
  98. package/lib/utils/api.d.ts +0 -12
  99. package/lib/utils/api.js +0 -173
  100. package/lib/utils/audit.d.ts +0 -13
  101. package/lib/utils/audit.js +0 -129
  102. package/lib/utils/console.d.ts +0 -12
  103. package/lib/utils/console.js +0 -19
  104. package/lib/utils/errors.d.ts +0 -17
  105. package/lib/utils/errors.js +0 -100
  106. package/lib/utils/exercisesQueue.d.ts +0 -9
  107. package/lib/utils/exercisesQueue.js +0 -38
  108. package/lib/utils/fileQueue.d.ts +0 -40
  109. package/lib/utils/fileQueue.js +0 -168
  110. package/lib/utils/misc.d.ts +0 -1
  111. package/lib/utils/misc.js +0 -23
  112. package/lib/utils/validators.d.ts +0 -5
  113. package/lib/utils/validators.js +0 -17
  114. package/lib/utils/watcher.d.ts +0 -2
  115. package/lib/utils/watcher.js +0 -24
@@ -1,18 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const tslib_1 = require("tslib");
4
- const CompilationError = (messages) => {
5
- const _err = new Error(messages);
6
- _err.status = 400;
7
- _err.stdout = messages;
8
- _err.type = "compiler-error";
9
- return _err;
10
- };
11
- exports.default = {
12
- CompilationError,
13
- default: async (_a) => {
14
- var { action } = _a, rest = tslib_1.__rest(_a, ["action"]);
15
- const stdout = await action.run(rest);
16
- return stdout;
17
- },
18
- };
@@ -1,6 +0,0 @@
1
- import { IError } from "../../models/errors";
2
- declare const _default: {
3
- TestingError: (messages: string) => IError;
4
- default: (args: any) => Promise<any>;
5
- };
6
- export default _default;
@@ -1,25 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const fs = require("fs");
4
- const TestingError = (messages) => {
5
- const _err = new Error(messages);
6
- _err.status = 400;
7
- _err.stdout = messages;
8
- _err.type = "testing-error";
9
- return _err;
10
- };
11
- exports.default = {
12
- TestingError,
13
- default: async function (args) {
14
- const { action, configuration, socket, exercise } = args;
15
- if (!fs.existsSync(`${configuration.dirPath}/reports`)) {
16
- // reports directory
17
- fs.mkdirSync(`${configuration.dirPath}/reports`);
18
- }
19
- // compile
20
- const stdout = await action.run(args);
21
- // mark exercise as done
22
- exercise.done = true;
23
- return stdout;
24
- },
25
- };
@@ -1,27 +0,0 @@
1
- declare const _default: {
2
- CompilationError: {
3
- CompilationError: (messages: string) => import("../models/errors").IError;
4
- default: ({ action, ...rest }: any) => Promise<any>;
5
- };
6
- TestingError: {
7
- TestingError: (messages: string) => import("../models/errors").IError;
8
- default: (args: any) => Promise<any>;
9
- };
10
- Utils: {
11
- getMatches: (reg: RegExp, content: string) => (string | null)[];
12
- cleanStdout: (buffer: string, inputs: string[]) => string;
13
- indent: (string: string, options: any, count?: number) => string;
14
- Console: {
15
- _debug: boolean;
16
- startDebug: () => void;
17
- log: (msg: string, ...args: any[]) => void;
18
- error: (msg: string, ...args: any[]) => void;
19
- success: (msg: string, ...args: any[]) => void;
20
- info: (msg: string, ...args: any[]) => void;
21
- help: (msg: string) => void;
22
- debug(...args: any[]): void;
23
- };
24
- };
25
- plugin: (pluginConfig: import("../models/plugin-config").IPluginConfig) => (args: any) => Promise<any>;
26
- };
27
- export default _default;
@@ -1,7 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const compile_1 = require("./command/compile");
4
- const test_1 = require("./command/test");
5
- const utils_1 = require("./utils");
6
- const plugin_1 = require("./plugin");
7
- exports.default = { CompilationError: compile_1.default, TestingError: test_1.default, Utils: utils_1.default, plugin: plugin_1.default };
@@ -1,8 +0,0 @@
1
- import { IPluginConfig } from "../models/plugin-config";
2
- declare const _default: (pluginConfig: IPluginConfig) => (args: any) => Promise<any>;
3
- /**
4
- * Main Plugin Runner, it defines the behavior of a learnpack plugin
5
- * dividing it in "actions" like: Compile, test, etc.
6
- * @param {object} pluginConfig Configuration object that must defined language and each possible action.
7
- */
8
- export default _default;
@@ -1,68 +0,0 @@
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 +0,0 @@
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 +0,0 @@
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 +0,0 @@
1
- export declare const askPackage: () => Promise<unknown>;
2
- declare const _default: {
3
- askPackage: () => Promise<unknown>;
4
- };
5
- export default _default;
@@ -1,61 +0,0 @@
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,8 +0,0 @@
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 +0,0 @@
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,10 +0,0 @@
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,47 +0,0 @@
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;
44
- // SessionCommand.description = `Describe the command here
45
- // ...
46
- // Extra documentation goes here
47
- // `
@@ -1,12 +0,0 @@
1
- declare const _default: {
2
- login: (identification: string, password: string) => Promise<any>;
3
- publish: (config: any) => Promise<any>;
4
- update: (config: any) => Promise<any>;
5
- getPackage: (slug: string) => Promise<any>;
6
- getLangs: () => Promise<any>;
7
- getAllPackages: ({ lang, slug, }: {
8
- lang?: string | undefined;
9
- slug?: string | undefined;
10
- }) => Promise<any>;
11
- };
12
- export default _default;
package/lib/utils/api.js DELETED
@@ -1,173 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const console_1 = require("../utils/console");
4
- const storage = require("node-persist");
5
- const cli_ux_1 = require("cli-ux");
6
- const HOST = "https://learnpack.herokuapp.com";
7
- // eslint-disable-next-line
8
- const _fetch = require("node-fetch");
9
- const fetch = async (url, options = {}) => {
10
- const headers = { "Content-Type": "application/json" };
11
- let session = null;
12
- try {
13
- session = await storage.getItem("bc-payload");
14
- if (session.token && session.token !== "" && !url.includes("/token"))
15
- headers.Authorization = "Token " + session.token;
16
- }
17
- catch (_a) { }
18
- try {
19
- const resp = await _fetch(url, Object.assign(Object.assign({}, options), { headers: Object.assign(Object.assign({}, headers), options.headers) }));
20
- if (resp.status >= 200 && resp.status < 300)
21
- return await resp.json();
22
- if (resp.status === 401)
23
- throw APIError("Invalid authentication credentials", 401);
24
- else if (resp.status === 404)
25
- throw APIError("Package not found", 404);
26
- else if (resp.status >= 500)
27
- throw APIError("Impossible to connect with the server", 500);
28
- else if (resp.status >= 400) {
29
- const error = await resp.json();
30
- if (error.detail || error.error) {
31
- throw APIError(error.detail || error.error);
32
- }
33
- else if (error.nonFieldErrors) {
34
- throw APIError(error.nonFieldErrors[0], error);
35
- }
36
- else if (typeof error === "object") {
37
- if (Object.keys(error).length > 0) {
38
- const key = error[Object.keys(error)[0]];
39
- throw APIError(`${key}: ${error[key][0]}`, error);
40
- }
41
- }
42
- else {
43
- throw APIError("Uknown error");
44
- }
45
- }
46
- else
47
- throw APIError("Uknown error");
48
- }
49
- catch (error) {
50
- console_1.default.error(error.message);
51
- throw error;
52
- }
53
- };
54
- const login = async (identification, password) => {
55
- try {
56
- cli_ux_1.default.action.start("Looking for credentials...");
57
- await cli_ux_1.default.wait(1000);
58
- const data = await fetch(`${HOST}/v1/auth/token/`, {
59
- body: JSON.stringify({ identification, password }),
60
- method: "post",
61
- });
62
- cli_ux_1.default.action.stop("ready");
63
- return data;
64
- }
65
- catch (error) {
66
- console_1.default.error(error.message);
67
- console_1.default.debug(error);
68
- }
69
- };
70
- const publish = async (config) => {
71
- const keys = [
72
- "difficulty",
73
- "language",
74
- "skills",
75
- "technologies",
76
- "slug",
77
- "repository",
78
- "author",
79
- "title",
80
- ];
81
- const payload = {};
82
- for (const k of keys)
83
- config[k] ? (payload[k] = config[k]) : null;
84
- try {
85
- console.log("Package to publish:", payload);
86
- cli_ux_1.default.action.start("Updating package information...");
87
- await cli_ux_1.default.wait(1000);
88
- const data = await fetch(`${HOST}/v1/package/${config.slug}`, {
89
- method: "PUT",
90
- body: JSON.stringify(payload),
91
- });
92
- cli_ux_1.default.action.stop("ready");
93
- return data;
94
- }
95
- catch (error) {
96
- console.log("payload", payload);
97
- console_1.default.error(error.message);
98
- console_1.default.debug(error);
99
- throw error;
100
- }
101
- };
102
- const update = async (config) => {
103
- try {
104
- cli_ux_1.default.action.start("Updating package information...");
105
- await cli_ux_1.default.wait(1000);
106
- const data = await fetch(`${HOST}/v1/package/`, {
107
- method: "POST",
108
- body: JSON.stringify(config),
109
- });
110
- cli_ux_1.default.action.stop("ready");
111
- return data;
112
- }
113
- catch (error) {
114
- console_1.default.error(error.message);
115
- console_1.default.debug(error);
116
- throw error;
117
- }
118
- };
119
- const getPackage = async (slug) => {
120
- try {
121
- cli_ux_1.default.action.start("Downloading package information...");
122
- await cli_ux_1.default.wait(1000);
123
- const data = await fetch(`${HOST}/v1/package/${slug}`);
124
- cli_ux_1.default.action.stop("ready");
125
- return data;
126
- }
127
- catch (error) {
128
- if (error.status === 404)
129
- console_1.default.error(`Package ${slug} does not exist`);
130
- else
131
- console_1.default.error(`Package ${slug} does not exist`);
132
- console_1.default.debug(error);
133
- throw error;
134
- }
135
- };
136
- const getLangs = async () => {
137
- try {
138
- cli_ux_1.default.action.start("Downloading language options...");
139
- await cli_ux_1.default.wait(1000);
140
- const data = await fetch(`${HOST}/v1/package/language`);
141
- cli_ux_1.default.action.stop("ready");
142
- return data;
143
- }
144
- catch (error) {
145
- if (error.status === 404)
146
- console_1.default.error("Package slug does not exist");
147
- else
148
- console_1.default.error("Package slug does not exist");
149
- console_1.default.debug(error);
150
- throw error;
151
- }
152
- };
153
- const getAllPackages = async ({ lang = "", slug = "", }) => {
154
- try {
155
- cli_ux_1.default.action.start("Downloading packages...");
156
- await cli_ux_1.default.wait(1000);
157
- const data = await fetch(`${HOST}/v1/package/all?limit=100&language=${lang}&slug=${slug}`);
158
- cli_ux_1.default.action.stop("ready");
159
- return data;
160
- }
161
- catch (error) {
162
- console_1.default.error(`Package ${slug} does not exist`);
163
- console_1.default.debug(error);
164
- throw error;
165
- }
166
- };
167
- const APIError = (error, code) => {
168
- const message = error.message || error;
169
- const _err = new Error(message);
170
- _err.status = code || 400;
171
- return _err;
172
- };
173
- exports.default = { login, publish, update, getPackage, getLangs, getAllPackages };
@@ -1,13 +0,0 @@
1
- import { IAuditErrors } from '../models/audit-errors';
2
- import { IConfigObj } from '../models/config';
3
- import { ICounter } from '../models/counter';
4
- import { IFindings } from '../models/findings';
5
- declare const _default: {
6
- isUrl: (url: string, errors: IAuditErrors[], counter: ICounter) => Promise<boolean>;
7
- checkForEmptySpaces: (str: string) => boolean;
8
- checkLearnpackClean: (configObj: IConfigObj, errors: IAuditErrors[]) => void;
9
- findInFile: (types: string[], content: string) => IFindings;
10
- showErrors: (errors: IAuditErrors[], counter: ICounter) => Promise<unknown>;
11
- showWarnings: (warnings: IAuditErrors[]) => Promise<unknown>;
12
- };
13
- export default _default;