solid-server 5.8.7 → 5.8.8-5fdbfa12

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 (686) hide show
  1. package/CHANGELOG.md +0 -0
  2. package/CONTRIBUTING.md +0 -0
  3. package/CONTRIBUTORS.md +0 -0
  4. package/Dockerfile +0 -0
  5. package/LICENSE.md +0 -0
  6. package/README.md +0 -0
  7. package/bin/config.json +0 -0
  8. package/bin/lib/cli-utils.mjs +54 -0
  9. package/bin/lib/cli.mjs +44 -0
  10. package/bin/lib/{init.js → init.mjs} +93 -94
  11. package/bin/lib/{invalidUsernames.js → invalidUsernames.mjs} +136 -148
  12. package/bin/lib/{migrateLegacyResources.js → migrateLegacyResources.mjs} +64 -69
  13. package/bin/lib/{options.js → options.mjs} +379 -405
  14. package/bin/lib/{start.js → start.mjs} +124 -148
  15. package/bin/lib/{updateIndex.js → updateIndex.mjs} +55 -56
  16. package/bin/solid +2 -2
  17. package/bin/solid-test +0 -0
  18. package/common/css/bootstrap.min.css +6 -0
  19. package/common/css/solid.css +0 -0
  20. package/common/fonts/glyphicons-halflings-regular.eot +0 -0
  21. package/common/fonts/glyphicons-halflings-regular.svg +0 -0
  22. package/common/fonts/glyphicons-halflings-regular.ttf +0 -0
  23. package/common/fonts/glyphicons-halflings-regular.woff +0 -0
  24. package/common/fonts/glyphicons-halflings-regular.woff2 +0 -0
  25. package/common/img/solid-emblem.svg +0 -0
  26. package/common/js/auth-buttons.js +0 -0
  27. package/common/js/auth-buttons.mjs +57 -0
  28. package/common/js/index-buttons.js +0 -0
  29. package/common/js/index-buttons.mjs +38 -0
  30. package/common/js/solid.js +0 -0
  31. package/common/js/solid.mjs +456 -0
  32. package/common/well-known/security.txt +0 -0
  33. package/config/defaults.js +0 -0
  34. package/config/defaults.mjs +22 -0
  35. package/config/templates/emails/delete-account.js +49 -0
  36. package/config/templates/emails/delete-account.mjs +31 -0
  37. package/config/templates/emails/invalid-username.js +30 -0
  38. package/config/templates/emails/invalid-username.mjs +27 -0
  39. package/config/templates/emails/reset-password.js +49 -0
  40. package/config/templates/emails/reset-password.mjs +31 -0
  41. package/config/templates/emails/welcome.js +39 -0
  42. package/config/templates/emails/welcome.mjs +23 -0
  43. package/config/templates/new-account/favicon.ico +0 -0
  44. package/config/templates/new-account/favicon.ico.acl +26 -0
  45. package/config/templates/new-account/profile/card$.ttl +26 -0
  46. package/config/templates/new-account/robots.txt +3 -0
  47. package/config/templates/new-account/robots.txt.acl +26 -0
  48. package/config/templates/new-account/settings/prefs.ttl +15 -0
  49. package/config/templates/new-account/settings/privateTypeIndex.ttl +4 -0
  50. package/config/templates/new-account/settings/publicTypeIndex.ttl +4 -0
  51. package/{default-templates/new-account/.meta.acl → config/templates/new-account/settings/publicTypeIndex.ttl.acl} +4 -4
  52. package/config/templates/new-account/settings/serverSide.ttl.acl +13 -0
  53. package/config/templates/new-account/settings/serverSide.ttl.inactive +12 -0
  54. package/config/templates/server/favicon.ico +0 -0
  55. package/{.well-known/.acl → config/templates/server/favicon.ico.acl} +2 -2
  56. package/config/templates/server/index.html +54 -0
  57. package/config/templates/server/robots.txt +3 -0
  58. package/{default-templates/server/.well-known/.acl → config/templates/server/robots.txt.acl} +2 -2
  59. package/config/usernames-blacklist.json +0 -0
  60. package/config/views/account/account-deleted.hbs +17 -0
  61. package/config/views/account/delete-confirm.hbs +51 -0
  62. package/config/views/account/delete-link-sent.hbs +17 -0
  63. package/config/views/account/delete.hbs +51 -0
  64. package/config/views/account/invalid-username.hbs +22 -0
  65. package/config/views/account/register-disabled.hbs +6 -0
  66. package/config/views/account/register-form.hbs +133 -0
  67. package/config/views/account/register.hbs +24 -0
  68. package/config/views/auth/auth-hidden-fields.hbs +8 -0
  69. package/config/views/auth/change-password.hbs +58 -0
  70. package/config/views/auth/goodbye.hbs +23 -0
  71. package/config/views/auth/login-required.hbs +34 -0
  72. package/config/views/auth/login-tls.hbs +11 -0
  73. package/config/views/auth/login-username-password.hbs +28 -0
  74. package/config/views/auth/login.hbs +55 -0
  75. package/config/views/auth/no-permission.hbs +29 -0
  76. package/config/views/auth/password-changed.hbs +27 -0
  77. package/config/views/auth/reset-link-sent.hbs +21 -0
  78. package/config/views/auth/reset-password.hbs +52 -0
  79. package/config/views/auth/sharing.hbs +49 -0
  80. package/config/views/shared/create-account.hbs +8 -0
  81. package/config/views/shared/error.hbs +5 -0
  82. package/config.json-default +0 -0
  83. package/coverage/tmp/coverage-2275-1766876301000-0.json +1 -0
  84. package/coverage/tmp/coverage-2276-1766876279735-0.json +1 -0
  85. package/default-templates/emails/delete-account.js +0 -0
  86. package/default-templates/emails/delete-account.mjs +31 -0
  87. package/default-templates/emails/invalid-username.js +0 -0
  88. package/default-templates/emails/invalid-username.mjs +27 -0
  89. package/default-templates/emails/reset-password.js +0 -0
  90. package/default-templates/emails/reset-password.mjs +31 -0
  91. package/default-templates/emails/welcome.js +0 -0
  92. package/default-templates/emails/welcome.mjs +23 -0
  93. package/default-templates/new-account/favicon.ico +0 -0
  94. package/default-templates/new-account/favicon.ico.acl +0 -0
  95. package/default-templates/new-account/profile/card$.ttl +0 -0
  96. package/default-templates/new-account/robots.txt +0 -0
  97. package/default-templates/new-account/robots.txt.acl +0 -0
  98. package/default-templates/new-account/settings/prefs.ttl +0 -0
  99. package/default-templates/new-account/settings/privateTypeIndex.ttl +0 -0
  100. package/default-templates/new-account/settings/publicTypeIndex.ttl +0 -0
  101. package/default-templates/new-account/settings/publicTypeIndex.ttl.acl +0 -0
  102. package/default-templates/new-account/settings/serverSide.ttl.acl +0 -0
  103. package/default-templates/new-account/settings/serverSide.ttl.inactive +0 -0
  104. package/default-templates/server/favicon.ico +0 -0
  105. package/default-templates/server/favicon.ico.acl +0 -0
  106. package/default-templates/server/index.html +0 -0
  107. package/default-templates/server/robots.txt +0 -0
  108. package/default-templates/server/robots.txt.acl +0 -0
  109. package/default-views/account/account-deleted.hbs +0 -0
  110. package/default-views/account/delete-confirm.hbs +0 -0
  111. package/default-views/account/delete-link-sent.hbs +0 -0
  112. package/default-views/account/delete.hbs +0 -0
  113. package/default-views/account/invalid-username.hbs +0 -0
  114. package/default-views/account/register-disabled.hbs +0 -0
  115. package/default-views/account/register-form.hbs +0 -0
  116. package/default-views/account/register.hbs +0 -0
  117. package/default-views/auth/auth-hidden-fields.hbs +0 -0
  118. package/default-views/auth/change-password.hbs +0 -0
  119. package/default-views/auth/goodbye.hbs +0 -0
  120. package/default-views/auth/login-required.hbs +0 -0
  121. package/default-views/auth/login-tls.hbs +0 -0
  122. package/default-views/auth/login-username-password.hbs +0 -0
  123. package/default-views/auth/login.hbs +0 -0
  124. package/default-views/auth/no-permission.hbs +0 -0
  125. package/default-views/auth/password-changed.hbs +0 -0
  126. package/default-views/auth/reset-link-sent.hbs +0 -0
  127. package/default-views/auth/reset-password.hbs +0 -0
  128. package/default-views/auth/sharing.hbs +0 -0
  129. package/default-views/shared/create-account.hbs +0 -0
  130. package/default-views/shared/error.hbs +0 -0
  131. package/docker-compose.yml +0 -0
  132. package/docker-image/CONTRIBUTING.md +33 -0
  133. package/docker-image/Makefile +32 -0
  134. package/docker-image/README.md +65 -0
  135. package/docker-image/examples/docker-compose.all-in-one.yml +76 -0
  136. package/docker-image/examples/docker-compose.nginx.yml +51 -0
  137. package/docker-image/examples/docker-compose.simple.yml +34 -0
  138. package/docker-image/src/Dockerfile +34 -0
  139. package/docker-image/src/checks.sh +56 -0
  140. package/docker-image/src/create-temporary-cert.sh +14 -0
  141. package/docker-image/src/entrypoint.sh +8 -0
  142. package/{common/img/.gitkeep → docker-image/test/__init__.py} +0 -0
  143. package/docker-image/test/conftest.py +15 -0
  144. package/docker-image/test/test_image_foundations.py +51 -0
  145. package/docker-image/test/test_non_accessible_key_cert.py +36 -0
  146. package/docker-image/test/test_precondition_checks.py +41 -0
  147. package/docker-image/test/test_solid_default_config.py +66 -0
  148. package/docker-image/test/test_volumes.py +55 -0
  149. package/docker-image/test/wait_for_container.py +8 -0
  150. package/docs/how-to-delete-your-account.md +0 -0
  151. package/docs/login-and-grant-access-to-application.md +0 -0
  152. package/eslint.config.mjs +102 -0
  153. package/examples/custom-error-handling.js +0 -0
  154. package/examples/custom-error-handling.mjs +29 -0
  155. package/examples/ldp-with-webid.js +0 -0
  156. package/examples/ldp-with-webid.mjs +12 -0
  157. package/examples/simple-express-app.js +0 -0
  158. package/examples/simple-express-app.mjs +20 -0
  159. package/examples/simple-ldp-server.js +0 -0
  160. package/examples/simple-ldp-server.mjs +8 -0
  161. package/favicon.ico +0 -0
  162. package/favicon.ico.acl +0 -0
  163. package/index.cjs +4 -0
  164. package/index.html +0 -0
  165. package/index.mjs +23 -0
  166. package/lib/{acl-checker.js → acl-checker.mjs} +13 -17
  167. package/lib/api/accounts/{user-accounts.js → user-accounts.mjs} +17 -16
  168. package/lib/api/authn/{force-user.js → force-user.mjs} +5 -4
  169. package/lib/api/authn/index.mjs +8 -0
  170. package/lib/api/authn/{webid-oidc.js → webid-oidc.mjs} +27 -20
  171. package/lib/api/authn/{webid-tls.js → webid-tls.mjs} +12 -11
  172. package/lib/api/index.mjs +7 -0
  173. package/lib/{capability-discovery.js → capability-discovery.mjs} +3 -6
  174. package/lib/common/{fs-utils.js → fs-utils.mjs} +35 -43
  175. package/lib/common/template-utils.mjs +29 -0
  176. package/lib/common/{user-utils.js → user-utils.mjs} +24 -28
  177. package/lib/{create-app.js → create-app.mjs} +372 -361
  178. package/lib/{create-server.js → create-server.mjs} +34 -13
  179. package/lib/debug.mjs +37 -0
  180. package/lib/handlers/{allow.js → allow.mjs} +79 -83
  181. package/lib/handlers/{auth-proxy.js → auth-proxy.mjs} +8 -8
  182. package/lib/handlers/{copy.js → copy.mjs} +35 -39
  183. package/lib/handlers/{cors-proxy.js → cors-proxy.mjs} +11 -16
  184. package/lib/handlers/{delete.js → delete.mjs} +20 -22
  185. package/lib/handlers/{error-pages.js → error-pages.mjs} +144 -212
  186. package/lib/handlers/{get.js → get.mjs} +258 -252
  187. package/lib/handlers/{index.js → index.mjs} +7 -10
  188. package/lib/handlers/{notify.js → notify.mjs} +8 -10
  189. package/lib/handlers/{options.js → options.mjs} +3 -7
  190. package/lib/handlers/patch/{n3-patch-parser.js → n3-patch-parser.mjs} +57 -59
  191. package/lib/handlers/patch/{sparql-update-parser.js → sparql-update-parser.mjs} +14 -16
  192. package/lib/handlers/{patch.js → patch.mjs} +241 -235
  193. package/lib/handlers/{post.js → post.mjs} +101 -99
  194. package/lib/handlers/{put.js → put.mjs} +101 -105
  195. package/lib/handlers/{restrict-to-top-domain.js → restrict-to-top-domain.mjs} +2 -2
  196. package/lib/{header.js → header.mjs} +138 -143
  197. package/lib/{http-error.js → http-error.mjs} +35 -34
  198. package/lib/{ldp-container.js → ldp-container.mjs} +10 -12
  199. package/lib/ldp-copy.mjs +82 -0
  200. package/lib/ldp-middleware.mjs +38 -0
  201. package/lib/{ldp.js → ldp.mjs} +286 -78
  202. package/lib/{lock.js → lock.mjs} +10 -10
  203. package/lib/{metadata.js → metadata.mjs} +11 -11
  204. package/lib/models/account-manager.mjs +297 -0
  205. package/lib/models/account-template.mjs +70 -0
  206. package/lib/models/authenticator.mjs +161 -0
  207. package/lib/models/oidc-manager.mjs +22 -0
  208. package/lib/models/solid-host.mjs +63 -0
  209. package/lib/models/user-account.mjs +50 -0
  210. package/lib/models/webid-tls-certificate.mjs +97 -0
  211. package/lib/{payment-pointer-discovery.js → payment-pointer-discovery.mjs} +5 -8
  212. package/lib/{rdf-notification-template.js → rdf-notification-template.mjs} +3 -5
  213. package/lib/requests/add-cert-request.mjs +70 -0
  214. package/lib/requests/auth-request.mjs +151 -0
  215. package/lib/requests/{create-account-request.js → create-account-request.mjs} +249 -452
  216. package/lib/requests/delete-account-confirm-request.mjs +85 -0
  217. package/lib/requests/{delete-account-request.js → delete-account-request.mjs} +73 -134
  218. package/lib/requests/login-request.mjs +89 -0
  219. package/lib/requests/{password-change-request.js → password-change-request.mjs} +132 -201
  220. package/lib/requests/{password-reset-email-request.js → password-reset-email-request.mjs} +123 -202
  221. package/lib/requests/password-reset-request.mjs +47 -0
  222. package/lib/requests/register-request.mjs +48 -0
  223. package/lib/requests/{sharing-request.js → sharing-request.mjs} +174 -261
  224. package/lib/{resource-mapper.js → resource-mapper.mjs} +8 -9
  225. package/lib/{server-config.js → server-config.mjs} +15 -20
  226. package/lib/services/{blacklist-service.js → blacklist-service.mjs} +36 -33
  227. package/lib/services/email-service.mjs +76 -0
  228. package/lib/services/{token-service.js → token-service.mjs} +36 -44
  229. package/lib/{utils.js → utils.mjs} +307 -254
  230. package/lib/webid/{index.js → index.mjs} +9 -13
  231. package/lib/webid/lib/{get.js → get.mjs} +30 -35
  232. package/lib/webid/lib/{parse.js → parse.mjs} +10 -12
  233. package/lib/webid/lib/verify.mjs +77 -0
  234. package/lib/webid/tls/generate.mjs +53 -0
  235. package/lib/webid/tls/index.mjs +6 -0
  236. package/package.json +75 -67
  237. package/renovate.json +0 -0
  238. package/robots.txt +0 -0
  239. package/robots.txt.acl +0 -0
  240. package/solid-server-5.8.8.tgz +0 -0
  241. package/static/account-recovery.html +0 -0
  242. package/static/popup-redirect.html +0 -0
  243. package/static/signup.html +0 -0
  244. package/static/signup.html.acl +0 -0
  245. package/test/index.mjs +167 -0
  246. package/test/integration/account-creation-tls-test.mjs +127 -0
  247. package/test/integration/account-manager-test.mjs +150 -0
  248. package/test/integration/account-template-test.mjs +135 -0
  249. package/test/integration/acl-oidc-test.mjs +1047 -0
  250. package/test/integration/acl-tls-test.mjs +964 -0
  251. package/test/integration/auth-proxy-test.mjs +144 -0
  252. package/test/integration/authentication-oidc-test.mjs +816 -0
  253. package/test/integration/authentication-oidc-with-strict-origins-turned-off-test.mjs +643 -0
  254. package/test/integration/capability-discovery-test.mjs +115 -0
  255. package/test/integration/cors-proxy-test.mjs +145 -0
  256. package/test/integration/errors-oidc-test.mjs +109 -0
  257. package/test/integration/errors-test.mjs +49 -0
  258. package/test/integration/formats-test.mjs +136 -0
  259. package/test/integration/header-test.mjs +101 -0
  260. package/test/integration/http-copy-test.mjs +109 -0
  261. package/test/integration/http-test.mjs +1197 -0
  262. package/test/integration/ldp-test.mjs +528 -0
  263. package/test/integration/oidc-manager-test.mjs +41 -0
  264. package/test/integration/params-test.mjs +192 -0
  265. package/test/integration/patch-sparql-update-test.mjs +195 -0
  266. package/test/integration/patch-test.mjs +590 -0
  267. package/test/integration/payment-pointer-test.mjs +155 -0
  268. package/test/integration/prep-test.mjs +314 -0
  269. package/test/integration/quota-test.mjs +50 -0
  270. package/test/integration/special-root-acl-handling-test.mjs +68 -0
  271. package/test/integration/validate-tts-test.mjs +57 -0
  272. package/test/integration/www-account-creation-oidc-test.mjs +310 -0
  273. package/test/keys/cert.pem +21 -0
  274. package/test/keys/client-cert.pem +19 -0
  275. package/test/keys/client-key.pem +27 -0
  276. package/test/keys/key.pem +27 -0
  277. package/test/keys/user1-cert.pem +23 -0
  278. package/test/keys/user1-key.pem +28 -0
  279. package/test/keys/user2-cert.pem +23 -0
  280. package/test/keys/user2-key.pem +27 -0
  281. package/test/mocha.opts +2 -0
  282. package/test/resources/Makefile +146 -0
  283. package/test/resources/accounts/alice.localhost/profile/card +0 -0
  284. package/test/resources/accounts/db/oidc/op/clients/_key_abbf27de893abf7d05279547c22d9366.json +1 -0
  285. package/test/resources/accounts/db/oidc/op/provider.json +763 -0
  286. package/test/resources/accounts/db/oidc/rp/clients/_key_https%3A%2F%2Flocalhost%3A3457.json +1 -0
  287. package/test/resources/accounts/localhost/samplePublicContainer/nicola.jpg +0 -0
  288. package/test/resources/accounts/tim.localhost/hello.html +9 -0
  289. package/test/resources/accounts/tim.localhost/profile/card +0 -0
  290. package/test/resources/accounts-acl/config/templates/emails/welcome-test.js +39 -0
  291. package/test/resources/accounts-acl/config/templates/new-account/favicon.ico +0 -0
  292. package/test/resources/accounts-acl/config/templates/new-account/favicon.ico.acl +26 -0
  293. package/test/resources/accounts-acl/config/templates/new-account/index.html +28 -0
  294. package/test/resources/accounts-acl/config/templates/new-account/index.html.acl +22 -0
  295. package/test/resources/accounts-acl/config/templates/new-account/profile/card +27 -0
  296. package/{default-templates/new-account/inbox/.acl → test/resources/accounts-acl/config/templates/new-account/profile/card.acl} +5 -6
  297. package/test/resources/accounts-acl/config/templates/new-account/settings/prefs.ttl +9 -0
  298. package/test/resources/accounts-acl/config/templates/new-account/settings/privateTypeIndex.ttl +4 -0
  299. package/test/resources/accounts-acl/config/templates/new-account/settings/publicTypeIndex.ttl +4 -0
  300. package/test/resources/accounts-acl/config/templates/new-account/settings/publicTypeIndex.ttl.acl +25 -0
  301. package/test/resources/accounts-acl/config/templates/new-account/settings/serverSide.ttl +14 -0
  302. package/test/resources/accounts-acl/config/templates/server/index.html +35 -0
  303. package/{.acl → test/resources/accounts-acl/config/templates/server/index.html.acl} +4 -3
  304. package/test/resources/accounts-acl/config/views/account/register.hbs +58 -0
  305. package/test/resources/accounts-acl/config/views/auth/consent.hbs +49 -0
  306. package/test/resources/accounts-acl/config/views/auth/goodbye.hbs +20 -0
  307. package/test/resources/accounts-acl/config/views/auth/login-required.hbs +0 -0
  308. package/test/resources/accounts-acl/config/views/auth/login.hbs +51 -0
  309. package/test/resources/accounts-acl/config/views/auth/no-permission.hbs +0 -0
  310. package/test/resources/accounts-acl/db/oidc/op/clients/_key_77bb3b35edb1f3f7b887c25d1211a491.json +1 -0
  311. package/test/resources/accounts-acl/db/oidc/op/provider.json +763 -0
  312. package/test/resources/accounts-acl/db/oidc/rp/clients/_key_https%3A%2F%2Flocalhost%3A7777.json +1 -0
  313. package/test/resources/accounts-acl/localhost/favicon.ico +0 -0
  314. package/test/resources/accounts-acl/localhost/index.html +35 -0
  315. package/{default-templates/server/.acl → test/resources/accounts-acl/localhost/index.html.acl} +4 -3
  316. package/test/resources/accounts-acl/nicola.localhost/index.html +1 -0
  317. package/test/resources/accounts-acl/nicola.localhost/index.html.acl +10 -0
  318. package/test/resources/accounts-acl/quota/settings/serverSide.ttl +11 -0
  319. package/test/resources/accounts-acl/tim.localhost/append-acl/abc.ttl +1 -0
  320. package/test/resources/accounts-acl/tim.localhost/append-acl/abc.ttl.acl +8 -0
  321. package/test/resources/accounts-acl/tim.localhost/append-acl/abc2.ttl +1 -0
  322. package/test/resources/accounts-acl/tim.localhost/append-acl/abc2.ttl.acl +8 -0
  323. package/test/resources/accounts-acl/tim.localhost/fake-account/hello.html +9 -0
  324. package/test/resources/accounts-acl/tim.localhost/group/test-folder/group-listing-error.ttl +1 -0
  325. package/test/resources/accounts-acl/tim.localhost/group/test-folder/group-listing.ttl +14 -0
  326. package/test/resources/accounts-acl/tim.localhost/group/test-folder/some-other-file.txt +1 -0
  327. package/test/resources/accounts-acl/tim.localhost/multi-server/protected.txt +1 -0
  328. package/test/resources/accounts-acl/tim.localhost/multi-server/protected.txt.acl +8 -0
  329. package/test/resources/accounts-acl/tim.localhost/no-acl/test-file.html +1 -0
  330. package/test/resources/accounts-acl/tim.localhost/read-acl/deeper-tree/acls-only-on-top/example.ttl +1 -0
  331. package/test/resources/accounts-acl/tim.localhost/write-acl/test-file$.txt +1 -0
  332. package/test/resources/accounts-scenario/alice/db/oidc/op/clients/_key_931f2a0c999a8f0695573844341dde0e.json +1 -0
  333. package/test/resources/accounts-scenario/alice/db/oidc/op/provider.json +761 -0
  334. package/test/resources/accounts-scenario/alice/db/oidc/rp/clients/_key_https%3A%2F%2Flocalhost%3A7000.json +1 -0
  335. package/test/resources/accounts-scenario/alice/private-for-alice.txt +1 -0
  336. package/test/resources/accounts-scenario/alice/private-for-alice.txt.acl +12 -0
  337. package/test/resources/accounts-scenario/alice/profile/card$.ttl +10 -0
  338. package/test/resources/accounts-scenario/bob/db/oidc/op/clients/_key_8bdd350afbe0452a42fe6b3b3705d25f.json +1 -0
  339. package/test/resources/accounts-scenario/bob/db/oidc/op/provider.json +761 -0
  340. package/test/resources/accounts-scenario/bob/db/oidc/rp/clients/_key_https%3A%2F%2Flocalhost%3A7001.json +1 -0
  341. package/test/resources/accounts-scenario/bob/profile/card$.ttl +5 -0
  342. package/test/resources/accounts-scenario/bob/shared-with-alice.txt +1 -0
  343. package/test/resources/accounts-scenario/bob/shared-with-alice.txt.acl +15 -0
  344. package/test/resources/accounts-scenario/charlie/db/oidc/op/clients/_key_e4ed74eed3926d2f8d4d1d9661be7aea.json +1 -0
  345. package/test/resources/accounts-scenario/charlie/db/oidc/op/provider.json +759 -0
  346. package/test/resources/accounts-scenario/charlie/db/oidc/rp/clients/_key_https%3A%2F%2Flocalhost%3A5002.json +1 -0
  347. package/test/resources/accounts-scenario/charlie/profile/card$.ttl +5 -0
  348. package/test/resources/accounts-strict-origin-off/alice/db/oidc/op/clients/_key_9d6b49e3a595c4942e1105545518362d.json +1 -0
  349. package/test/resources/accounts-strict-origin-off/alice/db/oidc/op/provider.json +763 -0
  350. package/test/resources/accounts-strict-origin-off/alice/db/oidc/rp/clients/_key_https%3A%2F%2Flocalhost%3A7010.json +1 -0
  351. package/test/resources/accounts-strict-origin-off/alice/private-for-alice.txt +1 -0
  352. package/test/resources/accounts-strict-origin-off/alice/private-for-alice.txt.acl +12 -0
  353. package/test/resources/accounts-strict-origin-off/alice/profile/card$.ttl +10 -0
  354. package/test/resources/accounts-strict-origin-off/bob/db/oidc/op/clients/_key_5f68117de7511ed2b2290d81c83a2d98.json +1 -0
  355. package/test/resources/accounts-strict-origin-off/bob/db/oidc/op/provider.json +763 -0
  356. package/test/resources/accounts-strict-origin-off/bob/db/oidc/rp/clients/_key_https%3A%2F%2Flocalhost%3A7011.json +1 -0
  357. package/test/resources/accounts-strict-origin-off/bob/shared-with-alice.txt +1 -0
  358. package/test/resources/accounts-strict-origin-off/bob/shared-with-alice.txt.acl +15 -0
  359. package/test/resources/acl-tls/config/templates/emails/delete-account.js +49 -0
  360. package/test/resources/acl-tls/config/templates/emails/invalid-username.js +30 -0
  361. package/test/resources/acl-tls/config/templates/emails/reset-password.js +49 -0
  362. package/test/resources/acl-tls/config/templates/emails/welcome.js +39 -0
  363. package/test/resources/acl-tls/config/templates/new-account/favicon.ico +0 -0
  364. package/test/resources/acl-tls/config/templates/new-account/favicon.ico.acl +26 -0
  365. package/test/resources/acl-tls/config/templates/new-account/profile/card$.ttl +26 -0
  366. package/test/resources/acl-tls/config/templates/new-account/robots.txt +3 -0
  367. package/test/resources/acl-tls/config/templates/new-account/robots.txt.acl +26 -0
  368. package/test/resources/acl-tls/config/templates/new-account/settings/prefs.ttl +15 -0
  369. package/test/resources/acl-tls/config/templates/new-account/settings/privateTypeIndex.ttl +4 -0
  370. package/test/resources/acl-tls/config/templates/new-account/settings/publicTypeIndex.ttl +4 -0
  371. package/test/resources/acl-tls/config/templates/new-account/settings/publicTypeIndex.ttl.acl +25 -0
  372. package/test/resources/acl-tls/config/templates/new-account/settings/serverSide.ttl.acl +13 -0
  373. package/test/resources/acl-tls/config/templates/new-account/settings/serverSide.ttl.inactive +12 -0
  374. package/test/resources/acl-tls/config/templates/server/favicon.ico +0 -0
  375. package/test/resources/acl-tls/config/templates/server/favicon.ico.acl +15 -0
  376. package/test/resources/acl-tls/config/templates/server/index.html +55 -0
  377. package/test/resources/acl-tls/config/templates/server/robots.txt +3 -0
  378. package/test/resources/acl-tls/config/templates/server/robots.txt.acl +15 -0
  379. package/test/resources/acl-tls/config/views/account/account-deleted.hbs +17 -0
  380. package/test/resources/acl-tls/config/views/account/delete-confirm.hbs +51 -0
  381. package/test/resources/acl-tls/config/views/account/delete-link-sent.hbs +17 -0
  382. package/test/resources/acl-tls/config/views/account/delete.hbs +51 -0
  383. package/test/resources/acl-tls/config/views/account/invalid-username.hbs +22 -0
  384. package/test/resources/acl-tls/config/views/account/register-disabled.hbs +6 -0
  385. package/test/resources/acl-tls/config/views/account/register-form.hbs +147 -0
  386. package/test/resources/acl-tls/config/views/account/register.hbs +24 -0
  387. package/test/resources/acl-tls/config/views/auth/auth-hidden-fields.hbs +8 -0
  388. package/test/resources/acl-tls/config/views/auth/change-password.hbs +58 -0
  389. package/test/resources/acl-tls/config/views/auth/goodbye.hbs +23 -0
  390. package/test/resources/acl-tls/config/views/auth/login-required.hbs +34 -0
  391. package/test/resources/acl-tls/config/views/auth/login-tls.hbs +11 -0
  392. package/test/resources/acl-tls/config/views/auth/login-username-password.hbs +28 -0
  393. package/test/resources/acl-tls/config/views/auth/login.hbs +55 -0
  394. package/test/resources/acl-tls/config/views/auth/no-permission.hbs +29 -0
  395. package/test/resources/acl-tls/config/views/auth/password-changed.hbs +27 -0
  396. package/test/resources/acl-tls/config/views/auth/reset-link-sent.hbs +21 -0
  397. package/test/resources/acl-tls/config/views/auth/reset-password.hbs +52 -0
  398. package/test/resources/acl-tls/config/views/auth/sharing.hbs +49 -0
  399. package/test/resources/acl-tls/config/views/shared/create-account.hbs +8 -0
  400. package/test/resources/acl-tls/config/views/shared/error.hbs +5 -0
  401. package/test/resources/acl-tls/localhost/favicon.ico +0 -0
  402. package/test/resources/acl-tls/localhost/favicon.ico.acl +15 -0
  403. package/test/resources/acl-tls/localhost/index.html +48 -0
  404. package/test/resources/acl-tls/localhost/robots.txt +3 -0
  405. package/test/resources/acl-tls/localhost/robots.txt.acl +15 -0
  406. package/test/resources/acl-tls/tim.localhost/append-acl/abc.ttl +1 -0
  407. package/test/resources/acl-tls/tim.localhost/append-acl/abc.ttl.acl +8 -0
  408. package/test/resources/acl-tls/tim.localhost/append-acl/abc2.ttl +1 -0
  409. package/test/resources/acl-tls/tim.localhost/append-acl/abc2.ttl.acl +8 -0
  410. package/test/resources/acl-tls/tim.localhost/fake-account/hello.html +9 -0
  411. package/test/resources/acl-tls/tim.localhost/no-acl/test-file.html +1 -0
  412. package/test/resources/acl-tls/tim.localhost/profile/card$.ttl +17 -0
  413. package/test/resources/acl-tls/write-acl/test-file$.ttl +1 -0
  414. package/test/resources/auth-proxy/index.html +0 -0
  415. package/test/resources/auth-proxy/index.html.acl +0 -0
  416. package/test/resources/config/templates/emails/delete-account.js +49 -0
  417. package/test/resources/config/templates/emails/delete-account.mjs +31 -0
  418. package/test/resources/config/templates/emails/invalid-username.js +30 -0
  419. package/test/resources/config/templates/emails/invalid-username.mjs +27 -0
  420. package/test/resources/config/templates/emails/reset-password.js +49 -0
  421. package/test/resources/config/templates/emails/reset-password.mjs +31 -0
  422. package/test/resources/config/templates/emails/welcome.js +39 -0
  423. package/test/resources/config/templates/emails/welcome.mjs +23 -0
  424. package/test/resources/config/templates/new-account/favicon.ico +0 -0
  425. package/test/resources/config/templates/new-account/favicon.ico.acl +26 -0
  426. package/test/resources/config/templates/new-account/profile/card$.ttl +26 -0
  427. package/test/resources/config/templates/new-account/robots.txt +3 -0
  428. package/test/resources/config/templates/new-account/robots.txt.acl +26 -0
  429. package/test/resources/config/templates/new-account/settings/prefs.ttl +15 -0
  430. package/test/resources/config/templates/new-account/settings/privateTypeIndex.ttl +4 -0
  431. package/test/resources/config/templates/new-account/settings/publicTypeIndex.ttl +4 -0
  432. package/test/resources/config/templates/new-account/settings/publicTypeIndex.ttl.acl +25 -0
  433. package/test/resources/config/templates/new-account/settings/serverSide.ttl.acl +13 -0
  434. package/test/resources/config/templates/new-account/settings/serverSide.ttl.inactive +12 -0
  435. package/test/resources/config/templates/server/favicon.ico +0 -0
  436. package/test/resources/config/templates/server/favicon.ico.acl +15 -0
  437. package/test/resources/config/templates/server/index.html +54 -0
  438. package/test/resources/config/templates/server/robots.txt +3 -0
  439. package/test/resources/config/templates/server/robots.txt.acl +15 -0
  440. package/test/resources/config/views/account/account-deleted.hbs +17 -0
  441. package/test/resources/config/views/account/delete-confirm.hbs +51 -0
  442. package/test/resources/config/views/account/delete-link-sent.hbs +17 -0
  443. package/test/resources/config/views/account/delete.hbs +51 -0
  444. package/test/resources/config/views/account/invalid-username.hbs +22 -0
  445. package/test/resources/config/views/account/register-disabled.hbs +6 -0
  446. package/test/resources/config/views/account/register-form.hbs +133 -0
  447. package/test/resources/config/views/account/register.hbs +24 -0
  448. package/test/resources/config/views/auth/auth-hidden-fields.hbs +8 -0
  449. package/test/resources/config/views/auth/change-password.hbs +58 -0
  450. package/test/resources/config/views/auth/goodbye.hbs +23 -0
  451. package/test/resources/config/views/auth/login-required.hbs +34 -0
  452. package/test/resources/config/views/auth/login-tls.hbs +11 -0
  453. package/test/resources/config/views/auth/login-username-password.hbs +28 -0
  454. package/test/resources/config/views/auth/login.hbs +55 -0
  455. package/test/resources/config/views/auth/no-permission.hbs +29 -0
  456. package/test/resources/config/views/auth/password-changed.hbs +27 -0
  457. package/test/resources/config/views/auth/reset-link-sent.hbs +21 -0
  458. package/test/resources/config/views/auth/reset-password.hbs +52 -0
  459. package/test/resources/config/views/auth/sharing.hbs +49 -0
  460. package/test/resources/config/views/shared/create-account.hbs +8 -0
  461. package/test/resources/config/views/shared/error.hbs +5 -0
  462. package/test/resources/empty.spatch +0 -0
  463. package/test/resources/errorPages/401.html +5 -0
  464. package/test/resources/errorPages/403.html +5 -0
  465. package/test/resources/errorPages/404.html +5 -0
  466. package/test/resources/errorPages/405.html +5 -0
  467. package/test/resources/errorPages/415.html +5 -0
  468. package/test/resources/errorPages/500.html +5 -0
  469. package/test/resources/example_spkac.cnf +1 -0
  470. package/test/resources/external-servers/example.com/jwks.json +81 -0
  471. package/test/resources/external-servers/example.com/openid-configuration.json +53 -0
  472. package/test/resources/favicon.ico +0 -0
  473. package/test/resources/favicon.ico.acl +15 -0
  474. package/test/resources/headers/index.html +0 -0
  475. package/test/resources/headers/public-ra +0 -0
  476. package/test/resources/headers/public-ra.acl +7 -0
  477. package/test/resources/headers/user-rw-public-r +0 -0
  478. package/test/resources/headers/user-rw-public-r.acl +12 -0
  479. package/test/resources/headers/user-rwac-public-0 +0 -0
  480. package/test/resources/headers/user-rwac-public-0.acl +7 -0
  481. package/test/resources/hello.html +3 -0
  482. package/test/resources/invalid1.ttl +13 -0
  483. package/test/resources/invalid2.ttl +9 -0
  484. package/test/resources/ldpatch-example-final.ttl +23 -0
  485. package/test/resources/ldpatch-example-initial.ttl +22 -0
  486. package/test/resources/ldpatch-example-patch-1.spatch +8 -0
  487. package/test/resources/ldpatch-example-patch-2.spatch +12 -0
  488. package/test/resources/ldpatch-example-patch-3.spatch +14 -0
  489. package/test/resources/ldpatch-example-patch.ldpatch +25 -0
  490. package/test/resources/ldpatch-example-patch.spatch +24 -0
  491. package/test/resources/lennon.jsonld +7 -0
  492. package/test/resources/lfs-0.sparql +9 -0
  493. package/test/resources/lfs-1-final.json +10 -0
  494. package/test/resources/lfs-1.sparql +11 -0
  495. package/test/resources/messaging-scenario/user1.databox.me/profile/card +21 -0
  496. package/test/resources/nicola.jpg +0 -0
  497. package/test/resources/patch/append-only.ttl +2 -0
  498. package/test/resources/patch/append-only.ttl.acl +6 -0
  499. package/test/resources/patch/favicon.ico +0 -0
  500. package/test/resources/patch/favicon.ico.acl +15 -0
  501. package/test/resources/patch/index.html +0 -0
  502. package/test/resources/patch/read-append.ttl +2 -0
  503. package/test/resources/patch/read-append.ttl.acl +6 -0
  504. package/test/resources/patch/read-only.ttl +2 -0
  505. package/test/resources/patch/read-only.ttl.acl +6 -0
  506. package/test/resources/patch/read-write.ttl +2 -0
  507. package/test/resources/patch/read-write.ttl.acl +6 -0
  508. package/test/resources/patch/robots.txt +3 -0
  509. package/test/resources/patch/robots.txt.acl +15 -0
  510. package/test/resources/patch/write-only.ttl +2 -0
  511. package/test/resources/patch/write-only.ttl.acl +6 -0
  512. package/test/resources/patch-1-initial.ttl +3 -0
  513. package/test/resources/patch-2-final.ttl +2 -0
  514. package/test/resources/patch-2-initial.ttl +3 -0
  515. package/test/resources/patch-2.spatch +2 -0
  516. package/test/resources/patch-2n.spatch +2 -0
  517. package/test/resources/patch-3-final.ttl +28 -0
  518. package/test/resources/patch-4-final.ttl +29 -0
  519. package/test/resources/patch-5-final.ttl +1 -0
  520. package/test/resources/patch-5-initial.ttl +3 -0
  521. package/test/resources/patch-5.spatch +2 -0
  522. package/test/resources/put-input-2.html +13 -0
  523. package/test/resources/put-input.txt +6 -0
  524. package/test/resources/robots.txt +3 -0
  525. package/test/resources/robots.txt.acl +15 -0
  526. package/test/resources/sampleContainer/blank +0 -0
  527. package/test/resources/sampleContainer/cert.pkcs +0 -0
  528. package/test/resources/sampleContainer/example.ttl.old +1 -0
  529. package/test/resources/sampleContainer/example1.ttl +12 -0
  530. package/test/resources/sampleContainer/example2.ttl +3 -0
  531. package/test/resources/sampleContainer/example3.ttl +7 -0
  532. package/test/resources/sampleContainer/example4$.ttl +7 -0
  533. package/test/resources/sampleContainer/filename with spaces.txt +0 -0
  534. package/test/resources/sampleContainer/index.html +9 -0
  535. package/test/resources/sampleContainer/post2.ttl +6 -0
  536. package/test/resources/sampleContainer/put1.ttl +13 -0
  537. package/test/resources/sampleContainer/solid.png +0 -0
  538. package/test/resources/sampleContainer/user1.pfx +0 -0
  539. package/test/resources/sampleContainer/user2.pfx +0 -0
  540. package/test/resources/sampleContainer2/example1.ttl +10 -0
  541. package/test/resources/sampleContainer2/example2.ttl +7 -0
  542. package/test/resources/timbl.jpg +0 -0
  543. package/test/scenarios.md +23 -0
  544. package/test/surface/docker/cookie/Dockerfile +6 -0
  545. package/test/surface/docker/cookie/app/index.js +29 -0
  546. package/test/surface/docker/cookie/app/package-lock.json +13 -0
  547. package/test/surface/docker/cookie/app/package.json +14 -0
  548. package/test/surface/docker/server/Dockerfile +19 -0
  549. package/test/surface/docker/server/config/defaults.js +10 -0
  550. package/test/surface/docker/server/config/templates/emails/delete-account.js +49 -0
  551. package/test/surface/docker/server/config/templates/emails/invalid-username.js +30 -0
  552. package/test/surface/docker/server/config/templates/emails/reset-password.js +49 -0
  553. package/test/surface/docker/server/config/templates/emails/welcome.js +39 -0
  554. package/test/surface/docker/server/config/templates/new-account/favicon.ico +0 -0
  555. package/test/surface/docker/server/config/templates/new-account/favicon.ico.acl +26 -0
  556. package/test/surface/docker/server/config/templates/new-account/profile/card$.ttl +26 -0
  557. package/test/surface/docker/server/config/templates/new-account/robots.txt +3 -0
  558. package/test/surface/docker/server/config/templates/new-account/robots.txt.acl +26 -0
  559. package/test/surface/docker/server/config/templates/new-account/settings/prefs.ttl +15 -0
  560. package/test/surface/docker/server/config/templates/new-account/settings/privateTypeIndex.ttl +4 -0
  561. package/test/surface/docker/server/config/templates/new-account/settings/publicTypeIndex.ttl +4 -0
  562. package/test/surface/docker/server/config/templates/new-account/settings/publicTypeIndex.ttl.acl +25 -0
  563. package/test/surface/docker/server/config/templates/new-account/settings/serverSide.ttl.acl +13 -0
  564. package/test/surface/docker/server/config/templates/new-account/settings/serverSide.ttl.inactive +12 -0
  565. package/test/surface/docker/server/config/templates/server/favicon.ico +0 -0
  566. package/test/surface/docker/server/config/templates/server/favicon.ico.acl +15 -0
  567. package/test/surface/docker/server/config/templates/server/index.html +55 -0
  568. package/test/surface/docker/server/config/templates/server/robots.txt +3 -0
  569. package/test/surface/docker/server/config/templates/server/robots.txt.acl +15 -0
  570. package/test/surface/docker/server/config/usernames-blacklist.json +4 -0
  571. package/test/surface/docker/server/config/views/account/account-deleted.hbs +17 -0
  572. package/test/surface/docker/server/config/views/account/delete-confirm.hbs +51 -0
  573. package/test/surface/docker/server/config/views/account/delete-link-sent.hbs +17 -0
  574. package/test/surface/docker/server/config/views/account/delete.hbs +51 -0
  575. package/test/surface/docker/server/config/views/account/invalid-username.hbs +22 -0
  576. package/test/surface/docker/server/config/views/account/register-disabled.hbs +6 -0
  577. package/test/surface/docker/server/config/views/account/register-form.hbs +147 -0
  578. package/test/surface/docker/server/config/views/account/register.hbs +24 -0
  579. package/test/surface/docker/server/config/views/auth/auth-hidden-fields.hbs +8 -0
  580. package/test/surface/docker/server/config/views/auth/change-password.hbs +58 -0
  581. package/test/surface/docker/server/config/views/auth/goodbye.hbs +23 -0
  582. package/test/surface/docker/server/config/views/auth/login-required.hbs +34 -0
  583. package/test/surface/docker/server/config/views/auth/login-tls.hbs +11 -0
  584. package/test/surface/docker/server/config/views/auth/login-username-password.hbs +28 -0
  585. package/test/surface/docker/server/config/views/auth/login.hbs +55 -0
  586. package/test/surface/docker/server/config/views/auth/no-permission.hbs +29 -0
  587. package/test/surface/docker/server/config/views/auth/password-changed.hbs +27 -0
  588. package/test/surface/docker/server/config/views/auth/reset-link-sent.hbs +21 -0
  589. package/test/surface/docker/server/config/views/auth/reset-password.hbs +52 -0
  590. package/test/surface/docker/server/config/views/auth/sharing.hbs +49 -0
  591. package/test/surface/docker/server/config/views/shared/create-account.hbs +8 -0
  592. package/test/surface/docker/server/config/views/shared/error.hbs +5 -0
  593. package/test/surface/docker/server/config.json +22 -0
  594. package/test/surface/docker/server/data/favicon.ico +0 -0
  595. package/test/surface/docker/server/data/favicon.ico.acl +26 -0
  596. package/test/surface/docker/server/data/index.html +48 -0
  597. package/test/surface/docker/server/data/profile/card$.ttl +31 -0
  598. package/test/surface/docker/server/data/robots.txt +3 -0
  599. package/test/surface/docker/server/data/robots.txt.acl +26 -0
  600. package/test/surface/docker/server/data/settings/prefs.ttl +15 -0
  601. package/test/surface/docker/server/data/settings/privateTypeIndex.ttl +4 -0
  602. package/test/surface/docker/server/data/settings/publicTypeIndex.ttl +4 -0
  603. package/test/surface/docker/server/data/settings/publicTypeIndex.ttl.acl +25 -0
  604. package/test/surface/docker/server/data/settings/serverSide.ttl +0 -0
  605. package/test/surface/docker/server/data/settings/serverSide.ttl.acl +13 -0
  606. package/test/surface/docker/server/data/settings/serverSide.ttl.inactive +12 -0
  607. package/test/surface/docker/server/env.list +4 -0
  608. package/test/surface/docker/solid-crud/Dockerfile +4 -0
  609. package/test/surface/docker/web-access-control/Dockerfile +1 -0
  610. package/test/surface/docker/webid-provider/Dockerfile +1 -0
  611. package/test/surface/run-solid-test-suite.sh +75 -0
  612. package/test/surface/server-env.list +5 -0
  613. package/test/surface/solid-crud-tests-env.list +5 -0
  614. package/test/surface/thirdparty-config.json +23 -0
  615. package/test/surface/thirdparty-env.list +6 -0
  616. package/test/surface/web-access-control-tests-env.list +6 -0
  617. package/test/surface/webid-provider-tests-env.list +4 -0
  618. package/test/test-helpers.mjs +63 -0
  619. package/test/unit/account-manager-test.mjs +610 -0
  620. package/test/unit/account-template-test.mjs +58 -0
  621. package/test/unit/acl-checker-test.mjs +51 -0
  622. package/test/unit/add-cert-request-test.mjs +119 -0
  623. package/test/unit/auth-handlers-test.mjs +108 -0
  624. package/test/unit/auth-proxy-test.mjs +224 -0
  625. package/test/unit/auth-request-test.mjs +96 -0
  626. package/test/unit/authenticator-test.mjs +34 -0
  627. package/test/unit/blacklist-service-test.mjs +49 -0
  628. package/test/unit/create-account-request-test.mjs +306 -0
  629. package/test/unit/delete-account-confirm-request-test.mjs +234 -0
  630. package/test/unit/delete-account-request-test.mjs +180 -0
  631. package/test/unit/email-service-test.mjs +165 -0
  632. package/test/unit/email-welcome-test.mjs +80 -0
  633. package/test/unit/error-pages-test.mjs +100 -0
  634. package/test/unit/esm-imports.test.mjs +148 -0
  635. package/test/unit/force-user-test.mjs +73 -0
  636. package/test/unit/getAvailableUrl-test.mjs +30 -0
  637. package/test/unit/getTrustedOrigins-test.mjs +20 -0
  638. package/test/unit/login-request-test.mjs +246 -0
  639. package/test/unit/oidc-manager-test.mjs +49 -0
  640. package/test/unit/password-authenticator-test.mjs +125 -0
  641. package/test/unit/password-change-request-test.mjs +259 -0
  642. package/test/unit/password-reset-email-request-test.mjs +234 -0
  643. package/test/unit/resource-mapper-test.mjs +673 -0
  644. package/test/unit/solid-host-test.mjs +118 -0
  645. package/test/unit/tls-authenticator-test.mjs +174 -0
  646. package/test/unit/token-service-test.mjs +82 -0
  647. package/test/unit/user-account-test.mjs +37 -0
  648. package/test/unit/user-accounts-api-test.mjs +59 -0
  649. package/test/unit/user-utils-test.mjs +64 -0
  650. package/test/unit/utils-test.mjs +112 -0
  651. package/test/utils/index.mjs +166 -0
  652. package/test/utils.mjs +204 -0
  653. package/test/validate-turtle.mjs +42 -0
  654. package/.github/workflows/ci.yml +0 -113
  655. package/.nvmrc +0 -1
  656. package/.snyk +0 -35
  657. package/bin/lib/cli-utils.js +0 -85
  658. package/bin/lib/cli.js +0 -39
  659. package/bin/solid.js +0 -3
  660. package/default-templates/new-account/.acl +0 -26
  661. package/default-templates/new-account/.meta +0 -5
  662. package/default-templates/new-account/.well-known/.acl +0 -19
  663. package/default-templates/new-account/private/.acl +0 -10
  664. package/default-templates/new-account/profile/.acl +0 -19
  665. package/default-templates/new-account/public/.acl +0 -19
  666. package/default-templates/new-account/settings/.acl +0 -20
  667. package/index.js +0 -3
  668. package/lib/api/authn/index.js +0 -5
  669. package/lib/api/index.js +0 -6
  670. package/lib/common/template-utils.js +0 -50
  671. package/lib/debug.js +0 -18
  672. package/lib/ldp-copy.js +0 -73
  673. package/lib/ldp-middleware.js +0 -40
  674. package/lib/models/account-manager.js +0 -604
  675. package/lib/models/account-template.js +0 -156
  676. package/lib/models/authenticator.js +0 -337
  677. package/lib/models/oidc-manager.js +0 -53
  678. package/lib/models/solid-host.js +0 -131
  679. package/lib/models/user-account.js +0 -113
  680. package/lib/models/webid-tls-certificate.js +0 -184
  681. package/lib/requests/add-cert-request.js +0 -138
  682. package/lib/requests/auth-request.js +0 -234
  683. package/lib/requests/delete-account-confirm-request.js +0 -170
  684. package/lib/requests/login-request.js +0 -205
  685. package/lib/services/email-service.js +0 -162
  686. package/lib/webid/tls/index.js +0 -185
@@ -1,13 +1,11 @@
1
- module.exports = createServer
2
-
3
- const express = require('express')
4
- const fs = require('fs')
5
- const https = require('https')
6
- const http = require('http')
7
- const SolidWs = require('solid-ws')
8
- const debug = require('./debug')
9
- const createApp = require('./create-app')
10
- const globalTunnel = require('global-tunnel-ng')
1
+ import express from 'express'
2
+ import fs from 'fs'
3
+ import https from 'https'
4
+ import http from 'http'
5
+ import SolidWs from 'solid-ws'
6
+ import globalTunnel from 'global-tunnel-ng'
7
+ import debug from './debug.mjs'
8
+ import createApp from './create-app.mjs'
11
9
 
12
10
  function createServer (argv, app) {
13
11
  argv = argv || {}
@@ -22,7 +20,6 @@ function createServer (argv, app) {
22
20
  }
23
21
  app.use(mount, ldpApp)
24
22
  debug.settings('Base URL (--mount): ' + mount)
25
-
26
23
  if (argv.idp) {
27
24
  console.warn('The idp configuration option has been renamed to multiuser.')
28
25
  argv.multiuser = argv.idp
@@ -68,8 +65,8 @@ function createServer (argv, app) {
68
65
  }
69
66
 
70
67
  const credentials = Object.assign({
71
- key: key,
72
- cert: cert
68
+ key,
69
+ cert
73
70
  }, argv)
74
71
 
75
72
  if (ldp.webid && ldp.auth === 'tls') {
@@ -103,5 +100,29 @@ function createServer (argv, app) {
103
100
  ldpApp.locals.ldp.live = solidWs.publish.bind(solidWs)
104
101
  }
105
102
 
103
+ // Wrap server.listen() to ensure async initialization completes after server starts
104
+ const originalListen = server.listen.bind(server)
105
+ server.listen = function (...args) {
106
+ // Start listening first
107
+ originalListen(...args)
108
+
109
+ // Then run async initialization (if needed)
110
+ if (ldpApp.locals.initFunction) {
111
+ const initFunction = ldpApp.locals.initFunction
112
+ delete ldpApp.locals.initFunction
113
+
114
+ // Run initialization after server is listening
115
+ initFunction()
116
+ .catch(err => {
117
+ console.error('Initialization error:', err)
118
+ server.emit('error', err)
119
+ })
120
+ }
121
+
122
+ return server
123
+ }
124
+
106
125
  return server
107
126
  }
127
+
128
+ export default createServer
package/lib/debug.mjs ADDED
@@ -0,0 +1,37 @@
1
+ import debug from 'debug'
2
+
3
+ export const handlers = debug('solid:handlers')
4
+ export const errors = debug('solid:errors')
5
+ export const ACL = debug('solid:ACL')
6
+ export const cache = debug('solid:cache')
7
+ export const parse = debug('solid:parse')
8
+ export const metadata = debug('solid:metadata')
9
+ export const authentication = debug('solid:authentication')
10
+ export const settings = debug('solid:settings')
11
+ export const server = debug('solid:server')
12
+ export const subscription = debug('solid:subscription')
13
+ export const container = debug('solid:container')
14
+ export const accounts = debug('solid:accounts')
15
+ export const email = debug('solid:email')
16
+ export const ldp = debug('solid:ldp')
17
+ export const fs = debug('solid:fs')
18
+ export const prep = debug('solid:prep')
19
+
20
+ export default {
21
+ handlers,
22
+ errors,
23
+ ACL,
24
+ cache,
25
+ parse,
26
+ metadata,
27
+ authentication,
28
+ settings,
29
+ server,
30
+ subscription,
31
+ container,
32
+ accounts,
33
+ email,
34
+ ldp,
35
+ fs,
36
+ prep
37
+ }
@@ -1,83 +1,79 @@
1
- module.exports = allow
2
-
3
- // const path = require('path')
4
- const ACL = require('../acl-checker')
5
- // const debug = require('../debug.js').ACL
6
- // const error = require('../http-error')
7
-
8
- function allow (mode) {
9
- return async function allowHandler (req, res, next) {
10
- const ldp = req.app.locals.ldp || {}
11
- if (!ldp.webid) {
12
- return next()
13
- }
14
-
15
- // Set up URL to filesystem mapping
16
- const rootUrl = ldp.resourceMapper.resolveUrl(req.hostname)
17
-
18
- // Determine the actual path of the request
19
- // (This is used as an ugly hack to check the ACL status of other resources.)
20
- let resourcePath = res && res.locals && res.locals.path
21
- ? res.locals.path
22
- : req.path
23
-
24
- // Check whether the resource exists
25
- let stat
26
- try {
27
- const ret = await ldp.exists(req.hostname, resourcePath)
28
- stat = ret.stream
29
- } catch (err) {
30
- stat = null
31
- }
32
-
33
- // Ensure directories always end in a slash
34
- if (!resourcePath.endsWith('/') && stat && stat.isDirectory()) {
35
- resourcePath += '/'
36
- }
37
-
38
- const trustedOrigins = [ldp.resourceMapper.resolveUrl(req.hostname)].concat(ldp.trustedOrigins)
39
- if (ldp.multiuser) {
40
- trustedOrigins.push(ldp.serverUri)
41
- }
42
- // Obtain and store the ACL of the requested resource
43
- const resourceUrl = rootUrl + resourcePath
44
- // Ensure the user has the required permission
45
- const userId = req.session.userId
46
- try {
47
- req.acl = ACL.createFromLDPAndRequest(resourceUrl, ldp, req)
48
-
49
- // if (resourceUrl.endsWith('.acl')) mode = 'Control'
50
- const isAllowed = await req.acl.can(userId, mode, req.method, stat)
51
- if (isAllowed) {
52
- return next()
53
- }
54
- } catch (error) { next(error) }
55
- if (mode === 'Read' && (resourcePath === '' || resourcePath === '/')) {
56
- // This is a hack to make NSS check the ACL for representation that is served for root (if any)
57
- // See https://github.com/solid/node-solid-server/issues/1063 for more info
58
- const representationUrl = `${rootUrl}/index.html`
59
- let representationPath
60
- try {
61
- representationPath = await ldp.resourceMapper.mapUrlToFile({ url: representationUrl })
62
- } catch (err) {
63
- }
64
-
65
- // We ONLY want to do this when the HTML representation exists
66
- if (representationPath) {
67
- req.acl = ACL.createFromLDPAndRequest(representationUrl, ldp, req)
68
- const representationIsAllowed = await req.acl.can(userId, mode)
69
- if (representationIsAllowed) {
70
- return next()
71
- }
72
- }
73
- }
74
-
75
- // check if user is owner. Check isOwner from /.meta
76
- try {
77
- if (resourceUrl.endsWith('.acl') && (await ldp.isOwner(userId, req.hostname))) return next()
78
- } catch (err) {}
79
- const error = req.authError || await req.acl.getError(userId, mode)
80
- // debug(`${mode} access denied to ${userId || '(none)'}: ${error.status} - ${error.message}`)
81
- next(error)
82
- }
83
- }
1
+ import ACL from '../acl-checker.mjs'
2
+ // import debug from '../debug.mjs'
3
+
4
+ export default function allow (mode) {
5
+ return async function allowHandler (req, res, next) {
6
+ const ldp = req.app.locals.ldp || {}
7
+ if (!ldp.webid) {
8
+ return next()
9
+ }
10
+
11
+ // Set up URL to filesystem mapping
12
+ const rootUrl = ldp.resourceMapper.resolveUrl(req.hostname)
13
+
14
+ // Determine the actual path of the request
15
+ // (This is used as an ugly hack to check the ACL status of other resources.)
16
+ let resourcePath = res && res.locals && res.locals.path
17
+ ? res.locals.path
18
+ : req.path
19
+
20
+ // Check whether the resource exists
21
+ let stat
22
+ try {
23
+ const ret = await ldp.exists(req.hostname, resourcePath)
24
+ stat = ret.stream
25
+ } catch (err) {
26
+ stat = null
27
+ }
28
+
29
+ // Ensure directories always end in a slash
30
+ if (!resourcePath.endsWith('/') && stat && stat.isDirectory()) {
31
+ resourcePath += '/'
32
+ }
33
+
34
+ const trustedOrigins = [ldp.resourceMapper.resolveUrl(req.hostname)].concat(ldp.trustedOrigins)
35
+ if (ldp.multiuser) {
36
+ trustedOrigins.push(ldp.serverUri)
37
+ }
38
+ // Obtain and store the ACL of the requested resource
39
+ const resourceUrl = rootUrl + resourcePath
40
+ // Ensure the user has the required permission
41
+ const userId = req.session.userId
42
+ try {
43
+ req.acl = ACL.createFromLDPAndRequest(resourceUrl, ldp, req)
44
+
45
+ // if (resourceUrl.endsWith('.acl')) mode = 'Control'
46
+ const isAllowed = await req.acl.can(userId, mode, req.method, stat)
47
+ if (isAllowed) {
48
+ return next()
49
+ }
50
+ } catch (error) { next(error) }
51
+ if (mode === 'Read' && (resourcePath === '' || resourcePath === '/')) {
52
+ // This is a hack to make NSS check the ACL for representation that is served for root (if any)
53
+ // See https://github.com/solid/node-solid-server/issues/1063 for more info
54
+ const representationUrl = `${rootUrl}/index.html`
55
+ let representationPath
56
+ try {
57
+ representationPath = await ldp.resourceMapper.mapUrlToFile({ url: representationUrl })
58
+ } catch (err) {
59
+ }
60
+
61
+ // We ONLY want to do this when the HTML representation exists
62
+ if (representationPath) {
63
+ req.acl = ACL.createFromLDPAndRequest(representationUrl, ldp, req)
64
+ const representationIsAllowed = await req.acl.can(userId, mode)
65
+ if (representationIsAllowed) {
66
+ return next()
67
+ }
68
+ }
69
+ }
70
+
71
+ // check if user is owner. Check isOwner from /.meta
72
+ try {
73
+ if (resourceUrl.endsWith('.acl') && (await ldp.isOwner(userId, req.hostname))) return next()
74
+ } catch (err) {}
75
+ const error = req.authError || await req.acl.getError(userId, mode)
76
+ // debug.handlers(`ALLOW -- ${mode} access denied to ${userId || '(none)'}: ${error.status} - ${error.message}`)
77
+ next(error)
78
+ }
79
+ }
@@ -1,13 +1,11 @@
1
1
  // An authentication proxy is a reverse proxy
2
2
  // that sends a logged-in Solid user's details to a backend
3
- module.exports = addAuthProxyHandlers
4
3
 
5
- const { createProxyMiddleware } = require('http-proxy-middleware')
6
- const debug = require('../debug')
7
- const allow = require('./allow')
4
+ import { createProxyMiddleware } from 'http-proxy-middleware'
5
+ import debug from '../debug.mjs'
6
+ import allow from './allow.mjs'
8
7
 
9
8
  const PROXY_SETTINGS = {
10
- logLevel: 'silent',
11
9
  changeOrigin: true
12
10
  }
13
11
  const REQUIRED_PERMISSIONS = {
@@ -17,7 +15,7 @@ const REQUIRED_PERMISSIONS = {
17
15
  }
18
16
 
19
17
  // Registers Auth Proxy handlers for each target
20
- function addAuthProxyHandlers (app, targets) {
18
+ export default function addAuthProxyHandlers (app, targets) {
21
19
  for (const sourcePath in targets) {
22
20
  addAuthProxyHandler(app, sourcePath, targets[sourcePath])
23
21
  }
@@ -32,8 +30,10 @@ function addAuthProxyHandler (app, sourcePath, target) {
32
30
  const sourcePathLength = sourcePath.length
33
31
  const settings = Object.assign({
34
32
  target,
35
- onProxyReq: addAuthHeaders,
36
- onProxyReqWs: addAuthHeaders,
33
+ on: {
34
+ proxyReq: addAuthHeaders,
35
+ proxyReqWs: addAuthHeaders
36
+ },
37
37
  pathRewrite: path => path.substr(sourcePathLength)
38
38
  }, PROXY_SETTINGS)
39
39
 
@@ -1,39 +1,35 @@
1
- /* eslint-disable node/no-deprecated-api */
2
-
3
- module.exports = handler
4
-
5
- const debug = require('../debug')
6
- const error = require('../http-error')
7
- const ldpCopy = require('../ldp-copy')
8
- const url = require('url')
9
-
10
- /**
11
- * Handles HTTP COPY requests to import a given resource (specified in the
12
- * `Source:` header) to a destination (specified in request path).
13
- * For the moment, you can copy from public resources only (no auth delegation
14
- * is implemented), and is mainly intended for use with
15
- * "Save an external resource to Solid" type apps.
16
- * @method handler
17
- */
18
- async function handler (req, res, next) {
19
- const copyFrom = req.header('Source')
20
- if (!copyFrom) {
21
- return next(error(400, 'Source header required'))
22
- }
23
- const fromExternal = !!url.parse(copyFrom).hostname
24
- const ldp = req.app.locals.ldp
25
- const serverRoot = ldp.resourceMapper.resolveUrl(req.hostname)
26
- const copyFromUrl = fromExternal ? copyFrom : serverRoot + copyFrom
27
- const copyToUrl = res.locals.path || req.path
28
- try {
29
- await ldpCopy(ldp.resourceMapper, copyToUrl, copyFromUrl)
30
- } catch (err) {
31
- const statusCode = err.statusCode || 500
32
- const errorMessage = err.statusMessage || err.message
33
- debug.handlers('Error with COPY request:' + errorMessage)
34
- return next(error(statusCode, errorMessage))
35
- }
36
- res.set('Location', copyToUrl)
37
- res.sendStatus(201)
38
- next()
39
- }
1
+ import debug from '../debug.mjs'
2
+ import HTTPError from '../http-error.mjs'
3
+ import ldpCopy from '../ldp-copy.mjs'
4
+ import { parse } from 'url'
5
+
6
+ /**
7
+ * Handles HTTP COPY requests to import a given resource (specified in the
8
+ * `Source:` header) to a destination (specified in request path).
9
+ * For the moment, you can copy from public resources only (no auth delegation
10
+ * is implemented), and is mainly intended for use with
11
+ * "Save an external resource to Solid" type apps.
12
+ * @method handler
13
+ */
14
+ export default async function handler (req, res, next) {
15
+ const copyFrom = req.header('Source')
16
+ if (!copyFrom) {
17
+ return next(HTTPError(400, 'Source header required'))
18
+ }
19
+ const fromExternal = !!parse(copyFrom).hostname
20
+ const ldp = req.app.locals.ldp
21
+ const serverRoot = ldp.resourceMapper.resolveUrl(req.hostname)
22
+ const copyFromUrl = fromExternal ? copyFrom : serverRoot + copyFrom
23
+ const copyToUrl = res.locals.path || req.path
24
+ try {
25
+ await ldpCopy(ldp.resourceMapper, copyToUrl, copyFromUrl)
26
+ } catch (err) {
27
+ const statusCode = err.statusCode || 500
28
+ const errorMessage = err.statusMessage || err.message
29
+ debug.handlers('Error with COPY request:' + errorMessage)
30
+ return next(HTTPError(statusCode, errorMessage))
31
+ }
32
+ res.set('Location', copyToUrl)
33
+ res.sendStatus(201)
34
+ next()
35
+ }
@@ -1,15 +1,11 @@
1
- /* eslint-disable node/no-deprecated-api */
2
-
3
- module.exports = addCorsProxyHandler
4
-
5
- const { createProxyMiddleware } = require('http-proxy-middleware')
6
- const cors = require('cors')
7
- const debug = require('../debug')
8
- const url = require('url')
9
- const dns = require('dns')
10
- const isIp = require('is-ip')
11
- const ipRange = require('ip-range-check')
12
- const validUrl = require('valid-url')
1
+ import { createProxyMiddleware } from 'http-proxy-middleware'
2
+ import cors from 'cors'
3
+ import debug from '../debug.mjs'
4
+ import url from 'url'
5
+ import dns from 'dns'
6
+ import { isIP } from 'is-ip'
7
+ import ipRange from 'ip-range-check'
8
+ import validUrl from 'valid-url'
13
9
 
14
10
  const CORS_SETTINGS = {
15
11
  methods: 'GET',
@@ -18,8 +14,7 @@ const CORS_SETTINGS = {
18
14
  origin: true
19
15
  }
20
16
  const PROXY_SETTINGS = {
21
- target: 'dynamic',
22
- logLevel: 'silent',
17
+ target: 'http://placeholder',
23
18
  changeOrigin: true,
24
19
  followRedirects: true,
25
20
  proxyTimeout: 10000,
@@ -58,7 +53,7 @@ const RESERVED_IP_RANGES = [
58
53
  ]
59
54
 
60
55
  // Adds a CORS proxy handler to the application on the given path
61
- function addCorsProxyHandler (app, path) {
56
+ export default function addCorsProxyHandler (app, path) {
62
57
  const corsHandler = cors(CORS_SETTINGS)
63
58
  const proxyHandler = createProxyMiddleware(PROXY_SETTINGS)
64
59
 
@@ -77,7 +72,7 @@ function extractProxyConfig (req, res, next) {
77
72
 
78
73
  // Parse the URL and retrieve its host's IP address
79
74
  const { protocol, host, hostname, path } = url.parse(uri)
80
- if (isIp(hostname)) {
75
+ if (isIP(hostname)) {
81
76
  addProxyConfig(null, hostname)
82
77
  } else {
83
78
  dns.lookup(hostname, addProxyConfig)
@@ -1,23 +1,21 @@
1
- module.exports = handler
2
-
3
- const debug = require('../debug').handlers
4
-
5
- async function handler (req, res, next) {
6
- debug('DELETE -- Request on' + req.originalUrl)
7
-
8
- const ldp = req.app.locals.ldp
9
- try {
10
- await ldp.delete(req)
11
- debug('DELETE -- Ok.')
12
- res.sendStatus(200)
13
- next()
14
- } catch (err) {
15
- debug('DELETE -- Failed to delete: ' + err)
16
-
17
- // method DELETE not allowed
18
- if (err.status === 405) {
19
- res.set('allow', 'OPTIONS, HEAD, GET, PATCH, POST, PUT')
20
- }
21
- next(err)
22
- }
1
+ import { handlers as debug } from '../debug.mjs'
2
+
3
+ export default async function handler (req, res, next) {
4
+ debug('DELETE -- Request on' + req.originalUrl)
5
+
6
+ const ldp = req.app.locals.ldp
7
+ try {
8
+ await ldp.delete(req)
9
+ debug('DELETE -- Ok.')
10
+ res.sendStatus(200)
11
+ next()
12
+ } catch (err) {
13
+ debug('DELETE -- Failed to delete: ' + err)
14
+
15
+ // method DELETE not allowed
16
+ if (err.status === 405) {
17
+ res.set('allow', 'OPTIONS, HEAD, GET, PATCH, POST, PUT')
18
+ }
19
+ next(err)
20
+ }
23
21
  }