@learnpack/learnpack 5.0.275 → 5.0.277

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 (95) hide show
  1. package/README.md +409 -409
  2. package/lib/commands/audit.js +15 -15
  3. package/lib/commands/breakToken.js +19 -19
  4. package/lib/commands/clean.js +3 -3
  5. package/lib/commands/init.js +41 -41
  6. package/lib/commands/logout.js +3 -3
  7. package/lib/commands/publish.js +5 -10
  8. package/lib/commands/serve.js +55 -2
  9. package/lib/creatorDist/assets/index-BfLyIQVh.js +10343 -10224
  10. package/lib/managers/config/index.js +77 -77
  11. package/lib/utils/api.d.ts +1 -1
  12. package/lib/utils/api.js +12 -9
  13. package/lib/utils/creatorUtilities.js +14 -14
  14. package/lib/utils/export/epub.d.ts +2 -0
  15. package/lib/utils/export/epub.js +298 -0
  16. package/lib/utils/export/index.d.ts +3 -0
  17. package/lib/utils/export/index.js +7 -0
  18. package/lib/utils/export/scorm.d.ts +2 -0
  19. package/lib/utils/export/scorm.js +84 -0
  20. package/lib/utils/export/shared.d.ts +4 -0
  21. package/lib/utils/export/shared.js +61 -0
  22. package/lib/utils/export/types.d.ts +15 -0
  23. package/lib/utils/export/types.js +2 -0
  24. package/package.json +2 -1
  25. package/src/commands/audit.ts +487 -487
  26. package/src/commands/breakToken.ts +67 -67
  27. package/src/commands/clean.ts +30 -30
  28. package/src/commands/init.ts +650 -650
  29. package/src/commands/logout.ts +38 -38
  30. package/src/commands/publish.ts +20 -25
  31. package/src/commands/serve.ts +69 -4
  32. package/src/commands/start.ts +333 -333
  33. package/src/commands/translate.ts +123 -123
  34. package/src/creator/README.md +54 -54
  35. package/src/creator/eslint.config.js +7 -7
  36. package/src/creator/src/components/syllabus/ContentIndex.tsx +312 -312
  37. package/src/creator/src/i18n.ts +28 -28
  38. package/src/creator/src/index.css +217 -217
  39. package/src/creator/src/locales/en.json +126 -126
  40. package/src/creator/src/locales/es.json +126 -126
  41. package/src/creator/src/utils/configTypes.ts +122 -122
  42. package/src/creator/src/utils/constants.ts +13 -13
  43. package/src/creator/src/utils/creatorUtils.ts +46 -46
  44. package/src/creator/src/utils/eventBus.ts +2 -2
  45. package/src/creator/src/utils/lib.ts +468 -468
  46. package/src/creator/src/utils/socket.ts +61 -61
  47. package/src/creator/src/utils/store.ts +222 -222
  48. package/src/creator/src/vite-env.d.ts +1 -1
  49. package/src/creator/vite.config.ts +13 -13
  50. package/src/creatorDist/assets/index-BfLyIQVh.js +10343 -10224
  51. package/src/managers/config/defaults.ts +49 -49
  52. package/src/managers/config/exercise.ts +364 -364
  53. package/src/managers/config/index.ts +775 -775
  54. package/src/managers/file.ts +236 -236
  55. package/src/managers/server/routes.ts +554 -554
  56. package/src/managers/session.ts +182 -182
  57. package/src/managers/telemetry.ts +188 -188
  58. package/src/models/action.ts +13 -13
  59. package/src/models/config-manager.ts +28 -28
  60. package/src/models/config.ts +106 -106
  61. package/src/models/creator.ts +47 -47
  62. package/src/models/exercise-obj.ts +30 -30
  63. package/src/models/session.ts +39 -39
  64. package/src/models/socket.ts +61 -61
  65. package/src/models/status.ts +16 -16
  66. package/src/ui/_app/app.css +1 -1
  67. package/src/ui/_app/app.js +400 -397
  68. package/src/ui/app.tar.gz +0 -0
  69. package/src/utils/BaseCommand.ts +56 -56
  70. package/src/utils/api.ts +53 -39
  71. package/src/utils/audit.ts +392 -392
  72. package/src/utils/checkNotInstalled.ts +267 -267
  73. package/src/utils/configBuilder.ts +82 -82
  74. package/src/utils/convertCreds.js +34 -34
  75. package/src/utils/creatorUtilities.ts +504 -504
  76. package/src/utils/export/README.md +178 -0
  77. package/src/utils/export/epub.ts +400 -0
  78. package/src/utils/export/index.ts +3 -0
  79. package/src/utils/export/scorm.ts +121 -0
  80. package/src/utils/export/shared.ts +61 -0
  81. package/src/utils/export/types.ts +17 -0
  82. package/src/utils/incrementVersion.js +74 -74
  83. package/src/utils/misc.ts +58 -58
  84. package/src/utils/rigoActions.ts +500 -500
  85. package/src/utils/sidebarGenerator.ts +195 -195
  86. package/src/utils/templates/epub/epub.css +133 -0
  87. package/src/utils/templates/isolated/exercises/01-hello-world/README.es.md +26 -26
  88. package/src/utils/templates/isolated/exercises/01-hello-world/README.md +26 -26
  89. package/src/utils/templates/scorm/adlcp_rootv1p2.xsd +110 -0
  90. package/src/utils/templates/scorm/config/api.js +175 -0
  91. package/src/utils/templates/scorm/config/index.html +210 -0
  92. package/src/utils/templates/scorm/ims_xml.xsd +1 -0
  93. package/src/utils/templates/scorm/imscp_rootv1p1p2.xsd +345 -0
  94. package/src/utils/templates/scorm/imsmanifest.xml +38 -0
  95. package/src/utils/templates/scorm/imsmd_rootv1p2p1.xsd +573 -0
@@ -1,182 +1,182 @@
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
- import * as path from "path"
15
- import * as os from "os"
16
-
17
- const GLOBAL_SESSION_PATH = path.join(os.homedir(), ".learnpack-session")
18
-
19
- const Session: ISession = {
20
- sessionStarted: false,
21
- token: null,
22
- config: null,
23
- currentCohort: null,
24
- initialize: async function () {
25
- if (!this.sessionStarted) {
26
- // Use a system-wide path instead of config.dirPath
27
- if (!fs.existsSync(GLOBAL_SESSION_PATH)) {
28
- fs.mkdirSync(GLOBAL_SESSION_PATH, { recursive: true })
29
- }
30
-
31
- await storage.init({ dir: GLOBAL_SESSION_PATH })
32
- this.sessionStarted = true
33
- }
34
-
35
- return true
36
- },
37
-
38
- setRigoToken: async function (token: string) {
39
- await this.initialize()
40
- const payload = await storage.getItem("bc-payload")
41
- await storage.setItem("bc-payload", {
42
- ...payload,
43
- rigobot: { key: token },
44
- })
45
- Console.debug("Rigobot token successfuly set")
46
- return true
47
- },
48
- setTabHash: async function (hash: string) {
49
- await this.initialize()
50
- const payload = await storage.getItem("bc-payload")
51
- await storage.setItem("bc-payload", {
52
- ...payload,
53
- tabHash: hash,
54
- })
55
- Console.debug("tabHash successfuly set")
56
- return true
57
- },
58
- setSessionKey: async function (value: string) {
59
- await this.initialize()
60
- const payload = await storage.getItem("bc-payload")
61
- await storage.setItem("bc-payload", {
62
- ...payload,
63
- sessionKey: value,
64
- })
65
- Console.debug("sessionKey successfuly set")
66
- return true
67
- },
68
- setPayload: async function (value: IPayload) {
69
- await this.initialize()
70
- await storage.setItem("bc-payload", { ...value })
71
- Console.debug("Payload successfuly found and set for " + value.email)
72
-
73
- // TelemetryManager.setStudent({
74
- // user_id: value.user_id.toString(),
75
- // email: value.email,
76
- // token: value.token,
77
- // })
78
-
79
- return true
80
- },
81
- getPayload: async function () {
82
- await this.initialize()
83
- let payload = null
84
- try {
85
- payload = await storage.getItem("bc-payload")
86
- } catch {
87
- Console.debug("Error retriving session payload")
88
- }
89
-
90
- return payload
91
- },
92
- isActive: function () {
93
- return !!this.token
94
- },
95
- get: async function (configObj?: IConfigObj) {
96
- if (configObj && configObj.config) {
97
- this.config = configObj.config
98
- }
99
-
100
- await this.sync()
101
- if (!this.isActive()) {
102
- return null
103
- }
104
-
105
- const payload = await this.getPayload()
106
-
107
- return {
108
- payload,
109
- token: this.token,
110
- }
111
- },
112
- login: async function () {
113
- const email = await cli.prompt("What is your email?")
114
- if (!v.isEmail(email)) {
115
- throw ValidationError("Invalid email")
116
- }
117
-
118
- const password = await cli.prompt("What is your password?", {
119
- type: "hide",
120
- })
121
-
122
- const data = await api.login(email, password)
123
-
124
- if (data) {
125
- Console.debug("Login successfull")
126
- // cli.log(data)
127
- await this.start({ token: data.token, payload: data })
128
- return data
129
- }
130
- },
131
- loginWeb: async function (email, password) {
132
- if (!v.isEmail(email)) {
133
- throw ValidationError("Invalid email")
134
- }
135
-
136
- const data = await api.login(email, password)
137
- if (data) {
138
- this.start({ token: data.token, payload: data })
139
-
140
- return data
141
- }
142
- },
143
- sync: async function () {
144
- const payload = await this.getPayload()
145
- if (payload) {
146
- this.token = payload.token
147
- }
148
- },
149
- start: async function ({ token, payload = null }: IStartProps) {
150
- if (!token) {
151
- throw new Error("A token and email is needed to start a session")
152
- }
153
-
154
- this.token = token
155
-
156
- if (payload && (await this.setPayload(payload))) {
157
- Console.success(`Successfully logged in as ${payload.email}`)
158
- }
159
- },
160
- destroy: async function () {
161
- if (!this.sessionStarted) {
162
- await this.initialize()
163
- }
164
-
165
- await storage.clear()
166
- this.token = null
167
- Console.success("You have logged out")
168
- },
169
- breakToken: async function () {
170
- const payload = await this.getPayload()
171
- if (payload) {
172
- this.token = "asdasdasdasd"
173
- await storage.setItem("bc-payload", {
174
- ...payload,
175
- token: "asdasdsad",
176
- })
177
- Console.success("Token broken successfully")
178
- }
179
- },
180
- }
181
-
182
- 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
+ import * as path from "path"
15
+ import * as os from "os"
16
+
17
+ const GLOBAL_SESSION_PATH = path.join(os.homedir(), ".learnpack-session")
18
+
19
+ const Session: ISession = {
20
+ sessionStarted: false,
21
+ token: null,
22
+ config: null,
23
+ currentCohort: null,
24
+ initialize: async function () {
25
+ if (!this.sessionStarted) {
26
+ // Use a system-wide path instead of config.dirPath
27
+ if (!fs.existsSync(GLOBAL_SESSION_PATH)) {
28
+ fs.mkdirSync(GLOBAL_SESSION_PATH, { recursive: true })
29
+ }
30
+
31
+ await storage.init({ dir: GLOBAL_SESSION_PATH })
32
+ this.sessionStarted = true
33
+ }
34
+
35
+ return true
36
+ },
37
+
38
+ setRigoToken: async function (token: string) {
39
+ await this.initialize()
40
+ const payload = await storage.getItem("bc-payload")
41
+ await storage.setItem("bc-payload", {
42
+ ...payload,
43
+ rigobot: { key: token },
44
+ })
45
+ Console.debug("Rigobot token successfuly set")
46
+ return true
47
+ },
48
+ setTabHash: async function (hash: string) {
49
+ await this.initialize()
50
+ const payload = await storage.getItem("bc-payload")
51
+ await storage.setItem("bc-payload", {
52
+ ...payload,
53
+ tabHash: hash,
54
+ })
55
+ Console.debug("tabHash successfuly set")
56
+ return true
57
+ },
58
+ setSessionKey: async function (value: string) {
59
+ await this.initialize()
60
+ const payload = await storage.getItem("bc-payload")
61
+ await storage.setItem("bc-payload", {
62
+ ...payload,
63
+ sessionKey: value,
64
+ })
65
+ Console.debug("sessionKey successfuly set")
66
+ return true
67
+ },
68
+ setPayload: async function (value: IPayload) {
69
+ await this.initialize()
70
+ await storage.setItem("bc-payload", { ...value })
71
+ Console.debug("Payload successfuly found and set for " + value.email)
72
+
73
+ // TelemetryManager.setStudent({
74
+ // user_id: value.user_id.toString(),
75
+ // email: value.email,
76
+ // token: value.token,
77
+ // })
78
+
79
+ return true
80
+ },
81
+ getPayload: async function () {
82
+ await this.initialize()
83
+ let payload = null
84
+ try {
85
+ payload = await storage.getItem("bc-payload")
86
+ } catch {
87
+ Console.debug("Error retriving session payload")
88
+ }
89
+
90
+ return payload
91
+ },
92
+ isActive: function () {
93
+ return !!this.token
94
+ },
95
+ get: async function (configObj?: IConfigObj) {
96
+ if (configObj && configObj.config) {
97
+ this.config = configObj.config
98
+ }
99
+
100
+ await this.sync()
101
+ if (!this.isActive()) {
102
+ return null
103
+ }
104
+
105
+ const payload = await this.getPayload()
106
+
107
+ return {
108
+ payload,
109
+ token: this.token,
110
+ }
111
+ },
112
+ login: async function () {
113
+ const email = await cli.prompt("What is your email?")
114
+ if (!v.isEmail(email)) {
115
+ throw ValidationError("Invalid email")
116
+ }
117
+
118
+ const password = await cli.prompt("What is your password?", {
119
+ type: "hide",
120
+ })
121
+
122
+ const data = await api.login(email, password)
123
+
124
+ if (data) {
125
+ Console.debug("Login successfull")
126
+ // cli.log(data)
127
+ await this.start({ token: data.token, payload: data })
128
+ return data
129
+ }
130
+ },
131
+ loginWeb: async function (email, password) {
132
+ if (!v.isEmail(email)) {
133
+ throw ValidationError("Invalid email")
134
+ }
135
+
136
+ const data = await api.login(email, password)
137
+ if (data) {
138
+ this.start({ token: data.token, payload: data })
139
+
140
+ return data
141
+ }
142
+ },
143
+ sync: async function () {
144
+ const payload = await this.getPayload()
145
+ if (payload) {
146
+ this.token = payload.token
147
+ }
148
+ },
149
+ start: async function ({ token, payload = null }: IStartProps) {
150
+ if (!token) {
151
+ throw new Error("A token and email is needed to start a session")
152
+ }
153
+
154
+ this.token = token
155
+
156
+ if (payload && (await this.setPayload(payload))) {
157
+ Console.success(`Successfully logged in as ${payload.email}`)
158
+ }
159
+ },
160
+ destroy: async function () {
161
+ if (!this.sessionStarted) {
162
+ await this.initialize()
163
+ }
164
+
165
+ await storage.clear()
166
+ this.token = null
167
+ Console.success("You have logged out")
168
+ },
169
+ breakToken: async function () {
170
+ const payload = await this.getPayload()
171
+ if (payload) {
172
+ this.token = "asdasdasdasd"
173
+ await storage.setItem("bc-payload", {
174
+ ...payload,
175
+ token: "asdasdsad",
176
+ })
177
+ Console.success("Token broken successfully")
178
+ }
179
+ },
180
+ }
181
+
182
+ export default Session