@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,145 +1,145 @@
1
- import Console from "../utils/console"
2
- import api from "../utils/api"
3
-
4
- import v from "validator"
5
- import { ValidationError, InternalError } from "../utils/errors"
6
-
7
- import * as fs from "fs"
8
- import cli from "cli-ux"
9
- import * as storage from "node-persist"
10
-
11
- import { IPayload, ISession, IStartProps } from "../models/session"
12
- import { IConfigObj } from "../models/config"
13
- import TelemetryManager from "./telemetry"
14
-
15
- const Session: ISession = {
16
- sessionStarted: false,
17
- token: null,
18
- config: null,
19
- currentCohort: null,
20
- initialize: async function () {
21
- if (!this.sessionStarted) {
22
- if (!this.config) {
23
- throw InternalError("Configuration not found")
24
- }
25
-
26
- if (!fs.existsSync(this.config.dirPath)) {
27
- fs.mkdirSync(this.config.dirPath)
28
- }
29
-
30
- await storage.init({ dir: `${this.config.dirPath}/.session` })
31
- this.sessionStarted = true
32
- }
33
-
34
- return true
35
- },
36
-
37
- setRigoToken: async function (token: string) {
38
- await this.initialize()
39
- const payload = await storage.getItem("bc-payload")
40
- await storage.setItem("bc-payload", {
41
- ...payload,
42
- rigobot: { key: token },
43
- })
44
- Console.debug("Rigobot token successfuly set")
45
- return true
46
- },
47
- setPayload: async function (value: IPayload) {
48
- await this.initialize()
49
- await storage.setItem("bc-payload", { token: this.token, ...value })
50
- Console.debug("Payload successfuly found and set for " + value.email)
51
- return true
52
- },
53
- getPayload: async function () {
54
- await this.initialize()
55
- let payload = null
56
- try {
57
- payload = await storage.getItem("bc-payload")
58
- } catch {
59
- Console.debug("Error retriving session payload")
60
- }
61
-
62
- return payload
63
- },
64
- isActive: function () {
65
- /* if (this.token) {
66
- return true
67
- } else {
68
- return false
69
- } */
70
- return !!this.token
71
- },
72
- get: async function (configObj?: IConfigObj) {
73
- if (configObj && configObj.config) {
74
- this.config = configObj.config
75
- }
76
-
77
- await this.sync()
78
- if (!this.isActive()) {
79
- return null
80
- }
81
-
82
- const payload = await this.getPayload()
83
-
84
- return {
85
- payload,
86
- token: this.token,
87
- }
88
- },
89
- login: async function () {
90
- const email = await cli.prompt("What is your email?")
91
- if (!v.isEmail(email)) {
92
- throw ValidationError("Invalid email")
93
- }
94
-
95
- const password = await cli.prompt("What is your password?", {
96
- type: "hide",
97
- })
98
-
99
- const data = await api.login(email, password)
100
- if (data) {
101
- cli.log(data)
102
- this.start({ token: data.token, payload: data })
103
- }
104
- },
105
- loginWeb: async function (email, password) {
106
- if (!v.isEmail(email)) {
107
- throw ValidationError("Invalid email")
108
- }
109
-
110
- const data = await api.login(email, password)
111
- if (data) {
112
- this.start({ token: data.token, payload: data })
113
- TelemetryManager.setStudent({
114
- user_id: data.user_id,
115
- email: data.email,
116
- token: data.token,
117
- })
118
- return data
119
- }
120
- },
121
- sync: async function () {
122
- const payload = await this.getPayload()
123
- if (payload) {
124
- this.token = payload.token
125
- }
126
- },
127
- start: async function ({ token, payload = null }: IStartProps) {
128
- if (!token) {
129
- throw new Error("A token and email is needed to start a session")
130
- }
131
-
132
- this.token = token
133
-
134
- if (payload && (await this.setPayload(payload))) {
135
- Console.success(`Successfully logged in as ${payload.email}`)
136
- }
137
- },
138
- destroy: async function () {
139
- await storage.clear()
140
- this.token = null
141
- Console.success("You have logged out")
142
- },
143
- }
144
-
145
- export default Session
1
+ import Console from "../utils/console"
2
+ import api from "../utils/api"
3
+
4
+ import v from "validator"
5
+ import { ValidationError, InternalError } from "../utils/errors"
6
+
7
+ import * as fs from "fs"
8
+ import cli from "cli-ux"
9
+ import * as storage from "node-persist"
10
+
11
+ import { IPayload, ISession, IStartProps } from "../models/session"
12
+ import { IConfigObj } from "../models/config"
13
+ import TelemetryManager from "./telemetry"
14
+
15
+ const Session: ISession = {
16
+ sessionStarted: false,
17
+ token: null,
18
+ config: null,
19
+ currentCohort: null,
20
+ initialize: async function () {
21
+ if (!this.sessionStarted) {
22
+ if (!this.config) {
23
+ throw InternalError("Configuration not found")
24
+ }
25
+
26
+ if (!fs.existsSync(this.config.dirPath)) {
27
+ fs.mkdirSync(this.config.dirPath)
28
+ }
29
+
30
+ await storage.init({ dir: `${this.config.dirPath}/.session` })
31
+ this.sessionStarted = true
32
+ }
33
+
34
+ return true
35
+ },
36
+
37
+ setRigoToken: async function (token: string) {
38
+ await this.initialize()
39
+ const payload = await storage.getItem("bc-payload")
40
+ await storage.setItem("bc-payload", {
41
+ ...payload,
42
+ rigobot: { key: token },
43
+ })
44
+ Console.debug("Rigobot token successfuly set")
45
+ return true
46
+ },
47
+ setPayload: async function (value: IPayload) {
48
+ await this.initialize()
49
+ await storage.setItem("bc-payload", { token: this.token, ...value })
50
+ Console.debug("Payload successfuly found and set for " + value.email)
51
+ return true
52
+ },
53
+ getPayload: async function () {
54
+ await this.initialize()
55
+ let payload = null
56
+ try {
57
+ payload = await storage.getItem("bc-payload")
58
+ } catch {
59
+ Console.debug("Error retriving session payload")
60
+ }
61
+
62
+ return payload
63
+ },
64
+ isActive: function () {
65
+ /* if (this.token) {
66
+ return true
67
+ } else {
68
+ return false
69
+ } */
70
+ return !!this.token
71
+ },
72
+ get: async function (configObj?: IConfigObj) {
73
+ if (configObj && configObj.config) {
74
+ this.config = configObj.config
75
+ }
76
+
77
+ await this.sync()
78
+ if (!this.isActive()) {
79
+ return null
80
+ }
81
+
82
+ const payload = await this.getPayload()
83
+
84
+ return {
85
+ payload,
86
+ token: this.token,
87
+ }
88
+ },
89
+ login: async function () {
90
+ const email = await cli.prompt("What is your email?")
91
+ if (!v.isEmail(email)) {
92
+ throw ValidationError("Invalid email")
93
+ }
94
+
95
+ const password = await cli.prompt("What is your password?", {
96
+ type: "hide",
97
+ })
98
+
99
+ const data = await api.login(email, password)
100
+ if (data) {
101
+ // cli.log(data)
102
+ this.start({ token: data.token, payload: data })
103
+ }
104
+ },
105
+ loginWeb: async function (email, password) {
106
+ if (!v.isEmail(email)) {
107
+ throw ValidationError("Invalid email")
108
+ }
109
+
110
+ const data = await api.login(email, password)
111
+ if (data) {
112
+ this.start({ token: data.token, payload: data })
113
+ TelemetryManager.setStudent({
114
+ user_id: data.user_id,
115
+ email: data.email,
116
+ token: data.token,
117
+ })
118
+ return data
119
+ }
120
+ },
121
+ sync: async function () {
122
+ const payload = await this.getPayload()
123
+ if (payload) {
124
+ this.token = payload.token
125
+ }
126
+ },
127
+ start: async function ({ token, payload = null }: IStartProps) {
128
+ if (!token) {
129
+ throw new Error("A token and email is needed to start a session")
130
+ }
131
+
132
+ this.token = token
133
+
134
+ if (payload && (await this.setPayload(payload))) {
135
+ Console.success(`Successfully logged in as ${payload.email}`)
136
+ }
137
+ },
138
+ destroy: async function () {
139
+ await storage.clear()
140
+ this.token = null
141
+ Console.success("You have logged out")
142
+ },
143
+ }
144
+
145
+ export default Session